:root{--ink: #080806;--ink-2: #0e0e0b;--panel: #131310;--panel-2: #1a1a15;--line: #26261f;--line-2: #353029;--bone: #f3efe3;--mute: #9b968a;--faint: #66635a;--yellow: #ffd400;--yellow-2: #ffe24a;--yellow-deep: #d9a800;--yellow-glow: rgba(255, 212, 0, .16);--maxw: 1240px;--e1: cubic-bezier(.16, 1, .3, 1);--e2: cubic-bezier(.65, 0, .35, 1)}*{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}body{background:var(--ink);color:var(--bone);font-family:Familjen Grotesk,system-ui,sans-serif;font-size:16px;line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden}a{color:inherit;text-decoration:none}ul{list-style:none}::selection{background:var(--yellow);color:#000}h1,h2,h3,h4{font-family:Bricolage Grotesque,system-ui,sans-serif;font-weight:800;line-height:.98;letter-spacing:-.03em}.mono{font-family:Space Mono,monospace}.wrap{max-width:var(--maxw);margin:0 auto;padding:0 clamp(20px,5vw,64px)}.grain{position:fixed;top:0;right:0;bottom:0;left:0;z-index:9000;pointer-events:none;opacity:.04;mix-blend-mode:overlay;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='140' height='140'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='3'/%3E%3C/filter%3E%3Crect width='140' height='140' filter='url(%23n)'/%3E%3C/svg%3E")}.bg-aura{position:fixed;top:0;right:0;bottom:0;left:0;z-index:-1;pointer-events:none;background:radial-gradient(60vw 50vw at 82% -8%,var(--yellow-glow),transparent 60%),radial-gradient(45vw 45vw at 0% 105%,rgba(255,212,0,.07),transparent 60%)}.grid-lines{position:fixed;top:0;right:0;bottom:0;left:0;z-index:-1;pointer-events:none;background-image:linear-gradient(var(--line) 1px,transparent 1px),linear-gradient(90deg,var(--line) 1px,transparent 1px);background-size:100% 64px,64px 100%;opacity:.25;-webkit-mask-image:radial-gradient(circle at 50% 30%,#000 0%,transparent 75%);mask-image:radial-gradient(circle at 50% 30%,#000 0%,transparent 75%)}.scroll-prog{position:fixed;top:0;left:0;right:0;height:3px;z-index:9500;pointer-events:none;background:#ffd40014}.scroll-prog>div{height:100%;width:100%;transform-origin:left;transform:scaleX(0);background:linear-gradient(90deg,var(--yellow-deep),var(--yellow),var(--yellow-2));box-shadow:0 0 14px var(--yellow-glow)}[data-magnetic]{transition:transform .45s var(--e1);will-change:transform}.cur-dot,.cur-ring{position:fixed;top:0;left:0;z-index:9999;pointer-events:none;border-radius:50%;transform:translate(-50%,-50%);mix-blend-mode:difference}.cur-dot{width:7px;height:7px;background:var(--yellow)}.cur-ring{width:38px;height:38px;border:1px solid var(--yellow);transition:width .25s var(--e1),height .25s var(--e1),opacity .25s}.cur-ring.lg{width:72px;height:72px}@media (hover: none),(pointer: coarse){.cur-dot,.cur-ring{display:none}}section{position:relative;padding:clamp(80px,13vh,160px) 0}.tag{font-family:Space Mono,monospace;font-size:12px;letter-spacing:.22em;text-transform:uppercase;color:var(--yellow);display:inline-flex;align-items:center;gap:14px}.tag:before{content:"";width:34px;height:2px;background:var(--yellow)}.h-mega{font-size:clamp(44px,9vw,132px);text-transform:uppercase}.h-sec{font-size:clamp(34px,6vw,78px);text-transform:uppercase;margin:26px 0 18px}.lead{color:var(--mute);max-width:560px;font-size:clamp(15px,1.4vw,18px)}.reveal{opacity:0;transform:translateY(40px);transition:opacity .9s var(--e1),transform .9s var(--e1)}.reveal.in{opacity:1;transform:none}.reveal[data-d="1"]{transition-delay:.08s}.reveal[data-d="2"]{transition-delay:.16s}.reveal[data-d="3"]{transition-delay:.24s}.reveal[data-d="4"]{transition-delay:.32s}.hero-name.split .line-mask>span{transform:none}.hero-name.split .ch{display:inline-block;transform:translateY(115%) rotate(8deg);opacity:0;animation:char-in 1s var(--e1) forwards}.hero-name.split .ln2 .ch{will-change:transform}@keyframes char-in{0%{transform:translateY(115%) rotate(8deg);opacity:0}60%{opacity:1}to{transform:translateY(0) rotate(0);opacity:1}}.line-mask{display:block;overflow:hidden}.line-mask>span{display:block;transform:translateY(110%) rotate(4deg);transition:transform 1s var(--e1)}.in .line-mask>span{transform:none}.in .line-mask:nth-child(2)>span{transition-delay:.09s}.in .line-mask:nth-child(3)>span{transition-delay:.18s}.nav{position:fixed;top:0;left:0;right:0;z-index:200;transition:background .4s var(--e1),border-color .4s,padding .4s;border-bottom:1px solid transparent}.nav.solid{background:#080806b8;-webkit-backdrop-filter:blur(16px) saturate(140%);backdrop-filter:blur(16px) saturate(140%);border-bottom-color:var(--line)}.nav-in{display:flex;align-items:center;justify-content:space-between;height:80px;transition:height .4s}.nav.solid .nav-in{height:64px}.brand{font-family:Bricolage Grotesque;font-weight:800;font-size:19px;letter-spacing:-.04em}.brand i{color:var(--yellow);font-style:normal}.nav-links{display:flex;gap:4px;align-items:center}.nav-links a{font-family:Space Mono,monospace;font-size:12.5px;letter-spacing:.06em;color:var(--mute);padding:10px 16px;border-radius:2px;position:relative;transition:color .25s}.nav-links a:after{content:"";position:absolute;left:16px;right:16px;bottom:7px;height:1.5px;background:var(--yellow);transform:scaleX(0);transform-origin:left;transition:transform .4s var(--e1)}.nav-links a:hover{color:var(--bone)}.nav-links a:hover:after{transform:scaleX(1)}.nav-cta{background:var(--yellow);color:#000!important;font-weight:700;padding:11px 20px!important;border-radius:2px}.nav-cta:after{display:none}.nav-cta:hover{background:var(--yellow-2)}.burger{display:none;background:none;border:1px solid var(--line-2);color:var(--bone);padding:9px 14px;font-family:Space Mono;font-size:12px;cursor:pointer}.hero{min-height:100vh;display:flex;flex-direction:column;justify-content:center;padding-top:120px;padding-bottom:60px}.hero-top{display:flex;justify-content:space-between;align-items:flex-end;flex-wrap:wrap;gap:24px;margin-bottom:clamp(20px,4vw,46px)}.hero-status{display:inline-flex;align-items:center;gap:11px;font-family:Space Mono,monospace;font-size:12.5px;color:var(--mute);border:1px solid var(--line-2);padding:9px 16px;border-radius:2px}.pulse{width:8px;height:8px;border-radius:50%;background:var(--yellow);position:relative}.pulse:after{content:"";position:absolute;top:-5px;right:-5px;bottom:-5px;left:-5px;border-radius:50%;border:1px solid var(--yellow);animation:ping 2s var(--e2) infinite}@keyframes ping{0%{transform:scale(.6);opacity:1}to{transform:scale(1.8);opacity:0}}.hero-id{font-family:Space Mono;font-size:12px;color:var(--faint);letter-spacing:.18em;text-align:right}.hero-name{font-size:clamp(58px,15.5vw,250px);text-transform:uppercase;letter-spacing:-.045em}.hero-name .ln2{color:var(--yellow);position:relative}.hero-name .ln2:after{content:"";position:absolute;right:0;bottom:.16em;width:.42em;height:.42em;background:var(--yellow);border-radius:50%}.hero-bottom{display:grid;grid-template-columns:1.15fr 1fr;gap:clamp(28px,5vw,72px);align-items:end;margin-top:clamp(28px,5vw,58px);border-top:1px solid var(--line);padding-top:34px}.hero-role{font-family:Bricolage Grotesque;font-weight:700;font-size:clamp(20px,2.6vw,34px);line-height:1.1}.hero-role b{color:var(--yellow)}.hero-blurb{color:var(--mute);font-size:15.5px}.hero-cta-row{display:flex;gap:14px;flex-wrap:wrap;margin-top:24px}.btn{display:inline-flex;align-items:center;gap:10px;font-family:Space Mono,monospace;font-size:13px;letter-spacing:.04em;padding:15px 26px;border-radius:2px;cursor:pointer;border:1px solid var(--line-2);background:transparent;color:var(--bone);position:relative;overflow:hidden;transition:color .4s var(--e1),border-color .4s}.btn span{position:relative;z-index:1;display:inline-flex;align-items:center;gap:10px}.btn:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:var(--yellow);transform:translateY(101%);transition:transform .5s var(--e1)}.btn:hover{color:#000;border-color:var(--yellow)}.btn:hover:before{transform:translateY(0)}.btn-solid{background:var(--yellow);color:#000;border-color:var(--yellow);font-weight:700}.btn-solid:before{background:#000}.btn-solid:hover{color:var(--yellow)}.scroll-cue{margin-top:clamp(40px,7vw,90px);display:flex;align-items:center;gap:14px;font-family:Space Mono;font-size:11.5px;letter-spacing:.2em;color:var(--faint)}.scroll-cue .bar{width:54px;height:1px;background:var(--line-2);position:relative;overflow:hidden}.scroll-cue .bar:after{content:"";position:absolute;left:0;top:0;height:100%;width:40%;background:var(--yellow);animation:slide 2.4s var(--e2) infinite}@keyframes slide{0%{left:-40%}to{left:100%}}.marquee{border-block:1px solid var(--line);background:var(--yellow);color:#000;padding:18px 0;overflow:hidden;display:flex;transform:rotate(-1.2deg) scale(1.04)}.marquee-track{display:flex;gap:48px;white-space:nowrap;animation:scroll-x 26s linear infinite}.marquee:hover .marquee-track{animation-play-state:paused}.marquee-track span{font-family:Bricolage Grotesque;font-weight:800;font-size:clamp(22px,3.4vw,46px);text-transform:uppercase;letter-spacing:-.02em;display:flex;align-items:center;gap:48px}.marquee-track span:after{content:"/";color:#00000059}@keyframes scroll-x{to{transform:translate(-50%)}}.about-grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:clamp(36px,6vw,90px);align-items:start}.about-side{position:sticky;top:110px}.about-cards{display:grid;gap:18px}.acard{border:1px solid var(--line);border-radius:3px;padding:30px 32px;background:linear-gradient(180deg,var(--panel),var(--ink-2));position:relative;overflow:hidden;transition:border-color .5s var(--e1),transform .5s var(--e1)}.acard:before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--yellow);transform:scaleY(0);transform-origin:top;transition:transform .6s var(--e1)}.acard:hover{border-color:var(--line-2);transform:translate(6px)}.acard:hover:before{transform:scaleY(1)}.acard .n{font-family:Space Mono;font-size:13px;color:var(--yellow);display:block;margin-bottom:16px}.acard p{color:var(--bone);font-size:clamp(16px,1.7vw,20px);line-height:1.5}.stats{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:3px;margin-top:36px;overflow:hidden}.stat{background:var(--ink-2);padding:26px 22px;text-align:left}.stat .v{font-family:Bricolage Grotesque;font-weight:800;font-size:clamp(34px,5vw,58px);color:var(--yellow);line-height:1}.stat .l{font-family:Space Mono;font-size:11px;letter-spacing:.12em;color:var(--mute);text-transform:uppercase;margin-top:10px}.skills-head{display:flex;justify-content:space-between;align-items:flex-end;flex-wrap:wrap;gap:24px;margin-bottom:54px}.skills-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:3px;overflow:hidden}.scell{background:var(--ink-2);padding:clamp(26px,3vw,40px);position:relative;transition:background .5s var(--e1)}.scell:after{content:attr(data-i);position:absolute;top:22px;right:26px;font-family:Space Mono;font-size:12px;color:var(--faint)}.scell:hover{background:var(--panel-2)}.scell h3{font-family:Space Mono;font-weight:700;font-size:12.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--mute);margin-bottom:22px}.chips{display:flex;flex-wrap:wrap;gap:10px}.chip{font-family:Familjen Grotesk;font-size:14.5px;padding:8px 15px;border:1px solid var(--line-2);border-radius:2px;color:var(--bone);transition:background .3s var(--e1),color .3s,border-color .3s,transform .3s;cursor:default}.chip:hover{background:var(--yellow);color:#000;border-color:var(--yellow);transform:translateY(-3px)}.proj-list{display:flex;flex-direction:column}.proj{position:relative;display:grid;grid-template-columns:64px 1fr auto;gap:clamp(20px,4vw,56px);align-items:start;padding:clamp(38px,5vw,64px) 0;border-top:1px solid var(--line);transition:padding-left .6s var(--e1)}.proj:last-child{border-bottom:1px solid var(--line)}.proj:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(60% 100% at 0% 50%,var(--yellow-glow),transparent 70%);opacity:0;transition:opacity .6s var(--e1);pointer-events:none}.proj:hover{padding-left:18px}.proj:hover:before{opacity:1}.proj-no{font-family:Space Mono;font-size:14px;color:var(--yellow);padding-top:8px}.proj-main{min-width:0}.proj-name{font-size:clamp(30px,5vw,68px);text-transform:uppercase;display:inline-block;position:relative}.proj-name:after{content:"";position:absolute;left:0;bottom:-2px;height:4px;width:100%;background:var(--yellow);transform:scaleX(0);transform-origin:left;transition:transform .55s var(--e1)}.proj:hover .proj-name:after{transform:scaleX(1)}.proj-type{font-family:Space Mono;font-size:13px;color:var(--yellow);margin:18px 0 14px;letter-spacing:.08em}.proj-desc{color:var(--mute);max-width:640px;font-size:16px;margin-bottom:26px}.proj-hi{display:grid;gap:13px;margin-bottom:28px;max-width:680px}.proj-hi li{display:flex;gap:14px;color:var(--bone);font-size:15px}.proj-hi li i{color:var(--yellow);font-family:Space Mono;font-style:normal;flex:none}.proj-stack{display:flex;flex-wrap:wrap;gap:9px}.stk{font-family:Space Mono;font-size:11.5px;padding:7px 13px;border:1px solid var(--line-2);color:var(--mute);border-radius:2px;transition:color .3s,border-color .3s}.proj:hover .stk{color:var(--bone);border-color:var(--line-2)}.proj-side{text-align:right;padding-top:8px;min-width:140px}.proj-year{font-family:Bricolage Grotesque;font-weight:800;font-size:clamp(20px,2.4vw,30px);color:var(--bone)}.proj-repo{display:inline-flex;align-items:center;gap:8px;font-family:Space Mono;font-size:12px;color:var(--faint);margin-top:14px}.proj-repo.link:hover{color:var(--yellow)}.proj-soon{border:1px dashed var(--line-2);border-radius:3px;padding:clamp(30px,4vw,46px);margin-top:34px;text-align:center}.proj-soon p{color:var(--faint);font-family:Space Mono;font-size:13px;letter-spacing:.1em}.edu-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:1px;background:var(--line);border:1px solid var(--line);border-radius:3px;overflow:hidden}.edu-col{background:var(--ink-2);padding:clamp(30px,4vw,48px)}.edu-col h3.kicker{font-family:Space Mono;font-size:12px;letter-spacing:.2em;text-transform:uppercase;color:var(--yellow);margin-bottom:30px}.edu-item{padding-bottom:26px;margin-bottom:26px;border-bottom:1px solid var(--line)}.edu-item:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}.edu-item .t{font-family:Bricolage Grotesque;font-weight:700;font-size:clamp(18px,2vw,23px)}.edu-item .w{color:var(--yellow);font-size:14px;margin:7px 0 5px}.edu-item .d{font-family:Space Mono;font-size:12px;color:var(--faint);margin-bottom:13px}.edu-item p{color:var(--mute);font-size:14.5px}.os-list{display:grid;gap:14px;margin-top:24px}.os-list li{display:flex;gap:13px;color:var(--mute);font-size:14.5px}.os-list li:before{content:"›";color:var(--yellow);font-family:Space Mono;flex:none}.contact{background:var(--yellow);color:#000;padding:clamp(80px,14vh,170px) 0;position:relative;overflow:hidden}.contact:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;opacity:.5;background-image:radial-gradient(rgba(0,0,0,.08) 1px,transparent 1px);background-size:22px 22px}.contact .wrap{position:relative}.contact .tag{color:#000}.contact .tag:before{background:#000}.contact h2{font-size:clamp(46px,11vw,170px);text-transform:uppercase;letter-spacing:-.04em;margin:24px 0 0;color:#000}.contact-sub{font-size:clamp(16px,2vw,22px);color:#000000b3;max-width:520px;margin:28px 0 44px}.contact-links{display:flex;flex-wrap:wrap;gap:14px}.cbtn{display:inline-flex;align-items:center;gap:11px;font-family:Space Mono;font-size:14px;font-weight:700;padding:16px 26px;border:2px solid #000;border-radius:2px;background:transparent;color:#000;cursor:pointer;transition:background .35s var(--e1),color .35s,transform .35s}.cbtn:hover{background:#000;color:var(--yellow);transform:translate(-3px,-3px);box-shadow:6px 6px #00000059}.cbtn.fill{background:#000;color:var(--yellow)}.cbtn.fill:hover{background:#0a0a0a}.foot{background:var(--ink);border-top:1px solid var(--line);padding:34px 0;display:flex;justify-content:space-between;flex-wrap:wrap;gap:14px;font-family:Space Mono;font-size:12px;color:var(--faint);letter-spacing:.04em}.foot a:hover{color:var(--yellow)}.side-idx{position:fixed;right:34px;top:50%;transform:translateY(-50%);z-index:150;display:flex;flex-direction:column;gap:14px}.side-idx button{background:none;border:none;cursor:pointer;padding:6px 0;font-family:Space Mono;font-size:10px;letter-spacing:.1em;color:var(--faint);display:flex;align-items:center;gap:10px;transition:color .3s}.side-idx .ln{width:22px;height:1.5px;background:var(--line-2);transition:width .4s var(--e1),background .4s}.side-idx button.active{color:var(--yellow)}.side-idx button.active .ln{width:40px;background:var(--yellow)}.side-idx button:hover{color:var(--bone)}@media (max-width: 1180px){.side-idx{display:none}}@media (max-width: 920px){.nav-links{position:fixed;inset:64px 0 auto 0;flex-direction:column;background:var(--ink-2);border-bottom:1px solid var(--line);padding:16px;gap:4px;display:none}.nav-links.open{display:flex}.nav-links a{padding:14px 16px}.burger{display:inline-flex}.hero-bottom,.about-grid,.skills-grid,.edu-grid{grid-template-columns:1fr}.about-side{position:static}.stats{grid-template-columns:1fr}.proj{grid-template-columns:1fr;gap:8px}.proj-side{text-align:left}.cur-dot,.cur-ring{display:none}}@media (prefers-reduced-motion: reduce){html{scroll-behavior:auto}*,*:before,*:after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important}.reveal{opacity:1;transform:none}.line-mask>span{transform:none}}
