:root{--ink:#e9dfca;--muted:#bcae95;--green:#65d45b;--green-bright:#34f46e;--cyan:#75cfff;--screen:#061411;--page-bg:#07100f;--stage-ratio:1.49902}*{box-sizing:border-box}html,body{background:var(--page-bg);min-height:100%;color:var(--ink);margin:0;font-family:Courier New,ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace}body{overflow:hidden}a{color:inherit}.studio-shell{background:var(--page-bg);place-items:center;min-height:100svh;display:grid;overflow:hidden}.scene-stage{background:var(--page-bg);--stage-scale:0;--stage-x:0px;--stage-y:0px;width:100vw;height:100svh;position:relative;overflow:hidden}.scene-backdrop{object-fit:cover;filter:blur(20px)brightness(.5)saturate(.78);pointer-events:none;-webkit-user-select:none;user-select:none;width:100%;height:100%;position:absolute;inset:0;transform:scale(1.04)}.scene-image{z-index:1;image-rendering:auto;-webkit-user-select:none;user-select:none;pointer-events:none;width:1535px;height:1024px;transform:translate(var(--stage-x), var(--stage-y)) scale(var(--stage-scale));transform-origin:0 0;display:block;position:absolute;inset:0 auto auto 0;box-shadow:0 0 2.5rem #00000061}.stage-coordinate-plane{z-index:3;pointer-events:auto;width:1535px;height:1024px;transform:translate(var(--stage-x), var(--stage-y)) scale(var(--stage-scale));transform-origin:0 0;position:absolute;inset:0}.desktop-terminal{width:560px;min-height:445px;color:var(--ink);letter-spacing:0;text-shadow:0 2px #000000a6,0 0 10px #65d45b1c;font-size:23px;font-weight:700;line-height:1.18;position:absolute;top:195px;left:580px}.terminal-prompt p{margin:0}.terminal-identity{color:var(--ink);white-space:nowrap;align-items:baseline;gap:10px;display:flex}.terminal-identity span{color:var(--green-bright)}.terminal-identity b{color:var(--ink);font-weight:inherit}.terminal-identity em{color:var(--cyan);font-style:normal}.terminal-identity i{font-family:Apple Color Emoji,Segoe UI Emoji,Noto Color Emoji,sans-serif;font-size:.86em;font-style:normal}.terminal-command{color:var(--ink);white-space:nowrap;margin-top:8px}.desktop-projects{gap:26px;margin:38px 0 50px;display:grid}.desktop-project{color:var(--ink);pointer-events:auto;grid-template-columns:44px 250px 1fr;align-items:start;gap:0;text-decoration:none;display:grid}.desktop-project:hover,.desktop-project:focus-visible{color:var(--green-bright);outline:none}.desktop-project:focus-visible{box-shadow:0 0 0 3px #34f46eb3}.desktop-project-icon{font-family:Apple Color Emoji,Segoe UI Emoji,Noto Color Emoji,sans-serif;font-size:24px;line-height:1}.desktop-project-name{color:var(--green);white-space:nowrap}.desktop-project-description{color:var(--ink);font-size:.88em;line-height:1.22}.terminal-cursor{background:var(--ink);width:14px;height:26px;margin-left:4px;animation:1.05s steps(2,start) infinite terminal-blink;display:inline-block;translate:0 5px;box-shadow:0 0 .7rem #e9dfca33}@keyframes terminal-blink{50%{opacity:0}}.sr-only{clip:rect(0, 0, 0, 0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.logo-hotspot{z-index:4;color:#f4edddf2;text-shadow:0 2px #0000008c;place-items:center;text-decoration:none;transition:color .16s,transform .16s,filter .16s;display:grid;position:absolute}.logo-hotspot:hover,.logo-hotspot:focus-visible{color:var(--green-bright);filter:drop-shadow(0 0 .65rem #34f46e73);outline:none;transform:translateY(-2%)}.logo-hotspot{aspect-ratio:1;width:55px;font-size:32px;top:53.7%}.github-hotspot{left:1.9%}.linkedin-hotspot{left:6.6%}.x-hotspot{left:11.35%}.app-placeholder{min-height:100svh;color:var(--ink);background:radial-gradient(circle at top,#65d45b2e,#0000 26rem),#050808;place-items:center;padding:2rem;display:grid}.app-placeholder section{background:#05100cdb;border:2px solid #65d45b6b;width:min(100%,42rem);padding:clamp(1.25rem,5vw,3rem);box-shadow:0 1.5rem 3rem #00000059}.app-placeholder h1{color:var(--green);margin:0 0 1rem;font-size:clamp(2rem,8vw,4rem);line-height:1}.app-placeholder p{font-size:1.1rem;line-height:1.6}.app-placeholder a{color:var(--green-bright)}.project-frame-page{background:#050808;width:100vw;height:100svh;position:relative;overflow:hidden}.project-frame{background:#050808;border:0;width:100%;height:100%;display:block}.project-frame-home{z-index:10;color:var(--ink);background:#040808c7;border:1px solid #e9dfca6b;padding:.42rem .65rem;font-size:.82rem;line-height:1;text-decoration:none;position:fixed;top:.85rem;left:.85rem;box-shadow:0 .35rem 1rem #00000052}.project-frame-home:hover,.project-frame-home:focus-visible{color:var(--green-bright);outline-offset:.2rem;outline:2px solid #34f46e9e}.mobile-stage{display:none}.mobile-scene{aspect-ratio:.613367;filter:drop-shadow(0 1.2rem 2.4rem #00000094);width:min(100vw,61.3367svh);position:relative;overflow:hidden;container-type:size}.mobile-scene-image{object-fit:cover;object-position:center top;-webkit-user-select:none;user-select:none;pointer-events:none;width:100%;height:100%;display:block;position:absolute;inset:0}.mobile-scene-projects .mobile-scene-image{object-position:center top}.mobile-overlay{position:absolute;inset:0}.mobile-load-time{color:var(--ink);letter-spacing:0;text-shadow:0 .15rem #00000094;white-space:nowrap;font-size:min(3.55cqh,1.72rem);font-weight:700;line-height:1;position:absolute;top:11.05%;left:50%;translate:-50%}.mobile-socials{gap:min(2cqh,1.05rem);display:flex;position:absolute;top:54.05%;left:15.7%}.mobile-social-link{aspect-ratio:1;color:#f4edddf5;background:#0408088f;border:min(.32cqh,.18rem) solid #e9dfcab8;place-items:center;width:min(7.15cqh,3.72rem);font-size:min(3.35cqh,1.74rem);text-decoration:none;transition:color .15s,border-color .15s,background .15s,filter .15s,transform .15s;display:grid;box-shadow:inset 0 0 0 min(.18cqh,.1rem) #000000a6,0 .24rem #0000006b}.mobile-social-link:hover,.mobile-social-link:focus-visible,.mobile-projects-button:hover,.mobile-projects-button:focus-visible,.mobile-back-arrow:hover,.mobile-back-arrow:focus-visible,.mobile-back-button:hover,.mobile-back-button:focus-visible{color:var(--green-bright);outline:none}.mobile-projects-button,.mobile-back-button,.mobile-back-arrow{color:var(--green);font:inherit;letter-spacing:0;cursor:pointer;text-shadow:0 .12rem #00000094;background:#030d0ba3;border:min(.18cqh,.1rem) solid #65d45b4d;place-items:center;font-weight:700;transition:color .15s,border-color .15s,background .15s,filter .15s,transform .15s;display:inline-grid;box-shadow:inset 0 0 0 min(.16cqh,.09rem) #0000008c,0 .22rem #00000057}.mobile-social-link:hover,.mobile-social-link:focus-visible,.mobile-projects-button:hover,.mobile-projects-button:focus-visible,.mobile-back-arrow:hover,.mobile-back-arrow:focus-visible,.mobile-back-button:hover,.mobile-back-button:focus-visible{filter:drop-shadow(0 0 min(1.2cqh,.65rem) #34f46e47);background:#0a1f14d1;border-color:#34f46eb8;transform:translateY(max(-.28cqh,-.16rem))}.mobile-projects-button{width:min(17.4cqh,8.35rem);min-height:min(4.9cqh,2.52rem);padding:0 min(1cqh,.52rem);font-size:min(2.7cqh,1.38rem);line-height:1;position:absolute;top:65.25%;right:30.2%}.mobile-back-arrow{width:min(5.5cqh,2.85rem);height:min(4.9cqh,2.54rem);font-size:min(3.9cqh,2rem);line-height:1;position:absolute;top:14.2%;left:15.9%}.mobile-projects-panel{gap:min(1.25cqh,.65rem);width:67.8%;display:grid;position:absolute;top:14.25%;left:16.1%}.mobile-workspace{min-height:min(5cqh,2.6rem);color:var(--cyan);text-shadow:0 .12rem #00000094;white-space:nowrap;justify-self:center;margin-bottom:min(1.2cqh,.62rem);padding-top:min(.4cqh,.22rem);font-size:min(3.35cqh,1.72rem);line-height:1}.mobile-project{min-height:min(11.1cqh,5.78rem);color:var(--ink);border-bottom:min(.18cqh,.1rem) solid #e9dfca21;border-radius:min(.8cqh,.42rem);grid-template-columns:min(6.2cqh,3.25rem) 1fr;align-items:start;gap:min(1.45cqh,.76rem);padding:min(1.35cqh,.7rem) min(1.3cqh,.68rem);text-decoration:none;transition:background .15s,box-shadow .15s,transform .15s;display:grid;position:relative}.mobile-project:before{content:"";background:var(--green-bright);opacity:0;width:min(.42cqh,.22rem);height:0;transition:height .15s,opacity .15s;position:absolute;top:50%;left:min(.2cqh,.1rem);translate:0 -50%;box-shadow:0 0 min(1cqh,.52rem) #34f46e9e}.mobile-project:hover,.mobile-project:focus-visible{background:linear-gradient(90deg,#34f46e2b,#34f46e0e 70%,#0000);outline:none;transform:translate(min(.38cqh,.2rem));box-shadow:inset 0 0 0 min(.16cqh,.09rem) #34f46e47,0 0 min(1.4cqh,.72rem) #34f46e14}.mobile-project:hover:before,.mobile-project:focus-visible:before{opacity:1;height:calc(100% - min(2.2cqh,1.15rem))}.mobile-project:focus-visible{box-shadow:inset 0 0 0 min(.2cqh,.1rem) #34f46e8a,0 0 min(1.6cqh,.84rem) #34f46e26}.mobile-project-icon{font-family:Apple Color Emoji,Segoe UI Emoji,Noto Color Emoji,sans-serif;font-size:min(3.45cqh,1.78rem);line-height:1}.mobile-project strong{color:var(--green);font-size:min(3.05cqh,1.58rem);font-weight:700;line-height:1.05;display:block}.mobile-project small{color:var(--ink);margin-top:min(.5cqh,.26rem);font-size:min(2.18cqh,1.13rem);line-height:1.2;display:block}.mobile-back-button{min-width:min(13cqh,6.75rem);min-height:min(4.7cqh,2.44rem);padding:0 min(1.4cqh,.74rem);font-size:min(2.9cqh,1.5rem);line-height:1;position:absolute;top:71.7%;right:18.6%}.phone-shell{background:linear-gradient(90deg,#ffe4a014,#0000 24% 76%,#00000038),#201b16;border:.55rem solid #463929;border-width:1.2rem .55rem .85rem;border-radius:2.3rem 2.3rem 1.2rem 1.2rem;width:min(88vw,22rem);height:min(94svh,42rem);margin:auto;padding:4.25rem 1.15rem 1.1rem;position:relative;box-shadow:inset 0 0 0 .18rem #00000073,0 1.5rem 3rem #0009}.phone-speaker{background:#070908;border-radius:999px;width:5rem;height:.42rem;position:absolute;top:1.4rem;left:50%;translate:-50%;box-shadow:inset 0 .1rem .1rem #ffffff14,0 .1rem #7e644499}.phone-screen{background:linear-gradient(#ffffff06 1px, transparent 1px), radial-gradient(circle at 50% 42%, #2058392e, transparent 52%), var(--screen);background-size:100% 4px,auto,auto;border:.35rem solid #111611;border-radius:1.35rem 1.35rem .6rem .6rem;height:69%;position:relative;overflow:hidden;box-shadow:inset 0 0 2.2rem #000000ad,inset 0 0 0 .12rem #5dd26a14}.phone-status{z-index:2;height:2.45rem;color:var(--ink);border-bottom:.12rem solid #627f4b38;grid-template-columns:1fr auto 1fr;align-items:end;padding:.6rem .9rem .38rem;font-size:1.25rem;line-height:1;display:grid;position:relative}.signal-bars{align-items:end;gap:.16rem;display:inline-flex}.signal-bars i{background:var(--ink);width:.18rem;display:block}.signal-bars i:first-child{height:.28rem}.signal-bars i:nth-child(2){height:.48rem}.signal-bars i:nth-child(3){height:.68rem}.signal-bars i:nth-child(4){height:.88rem}.battery{border:.15rem solid var(--ink);width:2.1rem;height:1rem;box-shadow:.3rem 0 0 -.18rem var(--ink);justify-self:end;padding:.18rem}.battery i{background:var(--green);width:72%;height:100%;display:block;box-shadow:0 0 .45rem #65d45b7a}.phone-content{padding:1.15rem 1.05rem 3.2rem;position:relative}.phone-home{min-height:calc(100% - 2.45rem)}.phone-portrait{aspect-ratio:3/4;object-fit:cover;width:32%;max-width:7.5rem;image-rendering:pixelated;border:.12rem solid #e9dfca52;position:absolute;top:1.15rem;right:.9rem;box-shadow:0 0 0 .18rem #00000085}.phone-eyebrow,.phone-home h1,.phone-tagline{z-index:1;text-shadow:0 .16rem #00000094;margin:0;position:relative}.phone-eyebrow{font-size:clamp(1.65rem,8.6vw,2.35rem);font-weight:900;line-height:1}.phone-home h1{color:var(--green);font-size:clamp(2.4rem,12vw,3.55rem);line-height:.95}.phone-tagline{max-width:11rem;margin-top:.95rem;font-size:clamp(.95rem,4.5vw,1.2rem);font-weight:700}.phone-bio{gap:.85rem;margin-top:1.3rem;font-size:clamp(.92rem,4.3vw,1.12rem);line-height:1.28;display:grid}.phone-bio p{grid-template-columns:2.15rem 1fr;align-items:start;gap:.65rem;margin:0;display:grid}.phone-bio svg,.phone-bio p>span:first-child{width:1.75rem;height:1.75rem;font-size:1.65rem}.phone-socials{gap:.8rem;margin-top:1.25rem;display:flex}.phone-socials a{aspect-ratio:1;width:2.75rem;color:var(--ink);background:#0408089e;border:.16rem solid #e9dfca8a;place-items:center;font-size:1.5rem;text-decoration:none;display:grid}.phone-socials a:focus-visible,.phone-socials a:hover{color:var(--green-bright);outline:none}.soft-key{z-index:3;color:var(--green);font:inherit;cursor:pointer;text-shadow:0 0 .6rem #65d45b42;background:0 0;border:0;font-size:clamp(.95rem,4.4vw,1.25rem);line-height:1;position:absolute;top:calc(69% + 5.15rem);bottom:auto;right:1.2rem}.soft-key:focus-visible{outline:.12rem solid var(--green-bright);outline-offset:.3rem}.phone-titlebar{height:3rem;color:var(--cyan);border-bottom:.12rem solid #627f4b38;grid-template-columns:2.4rem 1fr 2.4rem;align-items:center;font-size:clamp(1.2rem,6vw,1.65rem);display:grid}.phone-titlebar button{width:100%;height:100%;color:var(--ink);font:inherit;cursor:pointer;background:0 0;border:0;place-items:center;display:grid}.phone-titlebar span{justify-self:center}.phone-project-list{scrollbar-width:none;grid-auto-rows:minmax(3.85rem,auto);align-content:start;height:calc(100% - 5.45rem);display:grid;overflow:auto}.phone-project-list::-webkit-scrollbar{display:none}.phone-project{min-height:3.85rem;color:var(--ink);border-bottom:.12rem solid #e9dfca1a;grid-template-columns:2.45rem 1fr;align-items:center;gap:.55rem;padding:.35rem .65rem .42rem;text-decoration:none;display:grid}.phone-project:focus-visible,.phone-project:hover{background:#4c9b5214;outline:none}.project-icon{font-size:1.55rem}.phone-project strong{color:var(--green);font-size:clamp(.95rem,4.5vw,1.16rem);font-weight:700;line-height:1.05;display:block}.phone-project small{color:var(--ink);margin-top:.2rem;font-size:clamp(.72rem,3.45vw,.88rem);line-height:1.1;display:block}.phone-controls{grid-template-columns:repeat(3,1fr);gap:.45rem .7rem;margin-top:.85rem;display:grid}.phone-controls span{color:#c9b997;background:linear-gradient(#2c2a24,#171713);border:.18rem solid #0e1210;border-radius:.45rem;place-items:center;min-height:2.45rem;font-size:1.1rem;display:grid;box-shadow:inset 0 .12rem #ffffff0f,0 .18rem #0a0b09}.phone-controls .nav-key{grid-row:span 2;min-height:5.35rem}.nav-key i{border:.2rem solid #a88b60;border-color:#a88b60 #0000;width:2.3rem;height:1.15rem}.phone-controls .call-key:before,.phone-controls .end-key:before{content:"";background:#a1a332;border-radius:1rem 1rem .2rem .2rem;width:1.85rem;height:.7rem;display:block}.phone-controls .end-key:before{background:#bb432f}@media (max-width:760px){body{overflow:hidden}.studio-shell{background:radial-gradient(circle at 50% 20%,#28534838,#0000 20rem),#07100f;place-items:center;min-height:100svh;padding:0;overflow:hidden}.scene-stage{display:none}.mobile-stage{place-items:center;width:100%;min-height:100svh;display:grid;overflow:hidden}.app-placeholder section{width:min(100%,24rem)}}@media (max-width:380px),(max-height:760px){.phone-shell{border-width:1rem .45rem .45rem;width:min(92vw,20rem);height:min(96svh,39rem);padding:3.55rem .85rem .85rem}.phone-screen{height:70%}.phone-content{padding:1rem .9rem 3rem}.phone-portrait{width:30%}.phone-bio{gap:.75rem;margin-top:1.1rem}.phone-socials{margin-top:1.1rem}.phone-socials a{width:2.75rem}.phone-project{min-height:4.4rem}.phone-controls{gap:.35rem .45rem}.phone-controls span{min-height:2rem;font-size:.95rem}.phone-controls .nav-key{min-height:4.35rem}}
