:root{--bg: #04060a;--bg-2: #070b12;--ink: #e8f0ff;--ink-dim: #8aa0c0;--ink-faint: #46566f;--cyan: #2af5ff;--violet: #b06bff;--magenta: #ff3ec9;--line: rgba(110, 150, 220, .14);--glow-cyan: 0 0 24px rgba(42, 245, 255, .45);--glow-violet: 0 0 28px rgba(176, 107, 255, .4);--font-sans: "Space Grotesk", "Inter", system-ui, -apple-system, sans-serif;--font-mono: "JetBrains Mono", "SFMono-Regular", ui-monospace, monospace;--maxw: 1200px;--ease: cubic-bezier(.16, 1, .3, 1)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-text-size-adjust:100%}body{background:var(--bg);color:var(--ink);font-family:var(--font-sans);font-weight:400;line-height:1.5;overflow-x:hidden;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;cursor:none}@media (hover: none){body{cursor:auto}}body:before{content:"";position:fixed;inset:0;z-index:-2;background:radial-gradient(70% 50% at 50% 0%,rgba(45,60,130,.18),transparent 70%),radial-gradient(60% 60% at 85% 30%,rgba(176,107,255,.1),transparent 70%),radial-gradient(50% 50% at 10% 70%,rgba(42,245,255,.08),transparent 70%),var(--bg)}a{color:inherit;text-decoration:none}em{font-style:normal;color:var(--cyan)}strong{font-weight:600;color:var(--ink)}::selection{background:#2af5ff40;color:#fff}.boot{position:fixed;inset:0;z-index:1000;display:grid;place-items:center;background:var(--bg);transition:opacity .8s var(--ease),visibility .8s}.boot.is-done{opacity:0;visibility:hidden;pointer-events:none}.boot__inner{width:min(360px,70vw);font-family:var(--font-mono)}.boot__label{font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-dim);margin-bottom:.9rem}.boot__bar{height:2px;width:100%;background:var(--line);overflow:hidden}.boot__bar span{display:block;height:100%;width:0%;background:linear-gradient(90deg,var(--cyan),var(--violet));box-shadow:var(--glow-cyan);transition:width .2s linear}.boot__pct{margin-top:.8rem;font-size:3.4rem;font-weight:300;letter-spacing:-.04em;color:var(--ink)}.cursor{position:fixed;top:0;left:0;z-index:900;pointer-events:none;mix-blend-mode:screen;will-change:transform}.cursor__dot{position:absolute;width:6px;height:6px;margin:-3px;border-radius:50%;background:var(--cyan);box-shadow:var(--glow-cyan)}.cursor__ring{position:absolute;width:34px;height:34px;margin:-17px;border:1px solid rgba(42,245,255,.6);border-radius:50%;transition:width .25s var(--ease),height .25s var(--ease),margin .25s var(--ease),border-color .25s,opacity .25s}.cursor.is-hover .cursor__ring{width:64px;height:64px;margin:-32px;border-color:var(--violet)}.cursor.is-down .cursor__ring{width:22px;height:22px;margin:-11px}@media (hover: none){.cursor{display:none}}.gl{position:fixed;inset:0;z-index:-1;width:100%;height:100%;display:block;opacity:0;transition:opacity 1.2s var(--ease)}.gl.is-ready{opacity:1}.fx-overlay{position:fixed;inset:0;z-index:0;pointer-events:none;opacity:.5;background-image:repeating-linear-gradient(0deg,rgba(0,0,0,.16) 0px,rgba(0,0,0,.16) 1px,transparent 2px,transparent 3px);mix-blend-mode:multiply}.hud{position:fixed;bottom:1rem;left:1rem;z-index:80;font-family:var(--font-mono);font-size:.66rem;letter-spacing:.1em;color:var(--ink-faint);text-transform:uppercase;opacity:0;transition:opacity .6s;pointer-events:none}.hud.is-visible{opacity:1}.hud__sep{opacity:.4;margin:0 .3em}#hud-fps{color:var(--cyan)}.nav{position:fixed;top:0;left:0;right:0;z-index:100;display:flex;align-items:center;justify-content:space-between;padding:1.5rem clamp(1.2rem,4vw,3rem);mix-blend-mode:difference}.nav__brand-mark{font-family:var(--font-mono);font-weight:700;font-size:1.1rem;letter-spacing:.05em;color:#fff}.nav__links{display:flex;gap:clamp(1rem,3vw,2.4rem);font-family:var(--font-mono);font-size:.8rem;letter-spacing:.04em;color:#fff}.nav__links a{position:relative;padding:.2em 0}.nav__links a:after{content:"";position:absolute;left:0;bottom:-2px;width:100%;height:1px;background:currentColor;transform:scaleX(0);transform-origin:left;transition:transform .4s var(--ease)}.nav__links a:hover:after{transform:scaleX(1)}.nav__cmd{display:flex;gap:3px;background:none;border:none;cursor:none}.nav__cmd kbd{font-family:var(--font-mono);font-size:.7rem;color:#fff;border:1px solid rgba(255,255,255,.4);border-radius:5px;padding:.15em .45em;line-height:1}@media (max-width: 720px){.nav__links{display:none}}.nav__links a.is-active{color:var(--cyan);text-shadow:0 0 14px rgba(42,245,255,.45)}.scroll-rail{position:fixed;top:50%;right:clamp(.9rem,2vw,1.8rem);transform:translateY(-50%);height:42vh;width:2px;z-index:60;background:#ffffff14;border-radius:2px}.scroll-rail__fill{position:absolute;inset:0;transform-origin:top center;transform:scaleY(0);background:linear-gradient(180deg,var(--cyan),var(--violet));box-shadow:0 0 10px #2af5ff80;border-radius:2px;will-change:transform}.scroll-rail__dot{position:absolute;right:-4px;width:10px;height:10px;margin-top:-5px;padding:0;border:0;border-radius:50%;background:#fff3;cursor:none;transition:background .3s var(--ease),box-shadow .3s var(--ease),transform .3s var(--ease)}.scroll-rail__dot:after{content:attr(data-label);position:absolute;right:20px;top:50%;transform:translateY(-50%);font-family:var(--font-mono);font-size:.6rem;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-dim);opacity:0;pointer-events:none;white-space:nowrap;transition:opacity .3s var(--ease)}.scroll-rail__dot:hover{transform:scale(1.4)}.scroll-rail__dot:hover:after{opacity:1}.scroll-rail__dot.is-active{background:var(--cyan);box-shadow:0 0 12px #2af5ffe6;transform:scale(1.35)}@media (max-width: 900px),(hover: none){.scroll-rail{display:none}}main{position:relative;z-index:1}.section{position:relative;max-width:var(--maxw);margin:0 auto;padding:clamp(6rem,14vh,11rem) clamp(1.2rem,4vw,3rem)}.section__index{font-family:var(--font-mono);font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;color:var(--cyan);margin-bottom:2.5rem;opacity:.85}.section__index:before{content:"";display:inline-block;width:28px;height:1px;background:var(--cyan);vertical-align:middle;margin-right:.8em;box-shadow:var(--glow-cyan)}@media (max-width: 680px){.section{padding:clamp(3rem,8vh,4.5rem) clamp(1.2rem,5vw,2rem)}.section__index{margin-bottom:1.6rem}}.hero{position:relative;min-height:100svh;display:flex;flex-direction:column;align-items:center;justify-content:space-between;text-align:center;max-width:var(--maxw);margin:0 auto;padding:clamp(7rem,17vh,11rem) clamp(1.2rem,4vw,3rem) clamp(2.4rem,7vh,4rem)}.hero__top,.hero__bottom{width:100%;max-width:640px}.hero__eyebrow{font-family:var(--font-mono);font-size:clamp(.68rem,1.6vw,.85rem);letter-spacing:.26em;text-transform:uppercase;color:var(--ink-dim)}.hero__name{font-size:clamp(2.6rem,9vw,6.4rem);font-weight:600;line-height:.98;letter-spacing:-.035em;background:linear-gradient(100deg,#fff 10%,var(--cyan) 55%,var(--violet) 95%);-webkit-background-clip:text;background-clip:text;color:transparent;filter:drop-shadow(0 0 34px rgba(42,245,255,.28))}.webgl-active .hero__name{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.hero__sub{margin:0 auto;font-size:clamp(1rem,2.3vw,1.28rem);max-width:42ch;color:var(--ink-dim)}.hero__cta{display:flex;flex-wrap:wrap;justify-content:center;gap:1rem;margin-top:2.2rem}.hero__hint{display:flex;align-items:center;justify-content:center;gap:.7rem;margin-top:2.6rem;font-family:var(--font-mono);font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-faint)}.hero__hint-arrow{animation:bob 2s var(--ease) infinite}@keyframes bob{0%,to{transform:translateY(0)}50%{transform:translateY(5px)}}.btn{position:relative;display:inline-flex;align-items:center;gap:.5em;font-family:var(--font-mono);font-size:.82rem;letter-spacing:.06em;text-transform:uppercase;padding:.95em 1.6em;border-radius:999px;border:1px solid var(--line);overflow:hidden;transition:color .3s,border-color .3s,transform .3s var(--ease)}.btn:before{content:"";position:absolute;inset:0;background:linear-gradient(100deg,var(--cyan),var(--violet));opacity:0;transition:opacity .35s;z-index:-1}.btn--primary{border-color:transparent;color:#04060a}.btn--primary:before{opacity:1}.btn--primary:hover{box-shadow:var(--glow-cyan)}.btn--ghost:hover{border-color:var(--cyan);color:var(--cyan)}.about__grid{display:grid;grid-template-columns:1.1fr 1fr;gap:clamp(2rem,6vw,5rem);align-items:start}.about__lead{position:relative;padding-left:1.4rem;font-size:clamp(1.7rem,4.2vw,3rem);font-weight:500;line-height:1.12;letter-spacing:-.02em}.about__lead:before{content:"";position:absolute;left:0;top:.2em;bottom:.2em;width:3px;border-radius:3px;background:linear-gradient(180deg,var(--cyan),var(--violet));box-shadow:var(--glow-cyan)}.about__body p{color:var(--ink-dim);font-size:clamp(.98rem,1.7vw,1.12rem);margin-bottom:1.2rem}.about__stats{list-style:none;display:flex;gap:1rem;margin-top:2.4rem}.about__stats li{flex:1;position:relative;display:flex;flex-direction:column;padding:1rem 1.1rem 1.05rem;border:1px solid var(--line);border-radius:14px;background:#ffffff04;overflow:hidden;transition:border-color .35s,box-shadow .35s,transform .35s var(--ease)}.about__stats li:before{content:"";position:absolute;left:0;top:0;width:100%;height:2px;background:linear-gradient(90deg,var(--cyan),var(--violet));opacity:.55}.about__stats li:hover{border-color:color-mix(in srgb,var(--cyan) 45%,var(--line));box-shadow:0 16px 42px -24px #2af5ffb3;transform:translateY(-3px)}.about__stats span{font-family:var(--font-mono);font-size:clamp(1.7rem,4.4vw,2.6rem);font-weight:500;background:linear-gradient(180deg,#fff,var(--cyan));-webkit-background-clip:text;background-clip:text;color:transparent}.about__stats small{font-size:.68rem;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-faint);margin-top:.3rem}@media (max-width: 800px){.about__grid{grid-template-columns:1fr}}.work__filters{display:flex;flex-wrap:wrap;gap:.6rem;margin-bottom:2rem}.filter-chip{font-family:var(--font-mono);font-size:.72rem;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-dim);background:none;border:1px solid var(--line);border-radius:999px;padding:.5em .95em;cursor:none;transition:color .3s,border-color .3s,background .3s,transform .3s var(--ease)}.filter-chip:hover{color:var(--cyan);border-color:var(--cyan);transform:translateY(-2px)}.filter-chip.is-active{color:#04060a;background:linear-gradient(100deg,var(--cyan),var(--violet));border-color:transparent}.filter-chip__n{opacity:.55;font-size:.9em}.work__list{display:grid;grid-template-columns:repeat(2,1fr);gap:clamp(.9rem,2vw,1.3rem);perspective:1200px}@media (max-width: 820px){.work__list{grid-template-columns:1fr}}.work-card.is-hidden{display:none}.work-card{--accent: var(--cyan);--accent2: var(--violet);--mx: 50%;--my: 0%;position:relative;display:flex;flex-direction:column;gap:.8rem;min-height:220px;padding:clamp(1.3rem,2.6vw,1.9rem);border:1px solid var(--line);border-radius:18px;background:radial-gradient(130% 100% at 100% 0%,color-mix(in srgb,var(--accent) 9%,transparent),transparent 58%),#ffffff04;overflow:hidden;isolation:isolate;cursor:none;text-decoration:none;color:inherit;transform-style:preserve-3d;will-change:transform;transition:border-color .4s var(--ease),box-shadow .4s var(--ease)}.work-card:after{content:"";position:absolute;inset:0;background:radial-gradient(340px circle at var(--mx) var(--my),color-mix(in srgb,var(--accent) 20%,transparent),transparent 46%);opacity:0;transition:opacity .4s var(--ease);pointer-events:none;z-index:0}.work-card:hover{border-color:color-mix(in srgb,var(--accent) 55%,var(--line));box-shadow:0 22px 55px -26px color-mix(in srgb,var(--accent) 65%,transparent)}.work-card:hover:after{opacity:1}.work-card__ghost{position:absolute;right:-.06em;bottom:-.3em;font-size:clamp(6rem,15vw,10.5rem);font-weight:700;line-height:1;letter-spacing:-.05em;color:color-mix(in srgb,var(--accent) 11%,transparent);z-index:0;pointer-events:none;transition:color .4s var(--ease)}.work-card:hover .work-card__ghost{color:color-mix(in srgb,var(--accent) 19%,transparent)}.work-card>*:not(.work-card__ghost):not(.work-card__ripple){position:relative;z-index:1}.work-card__head{display:flex;align-items:center;justify-content:space-between;gap:1rem}.work-card__no{font-family:var(--font-mono);font-size:.78rem;letter-spacing:.12em;color:var(--accent)}.work-card__cat{font-family:var(--font-mono);font-size:.6rem;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-faint);border:1px solid var(--line);border-radius:999px;padding:.35em .7em}.work-card__title{display:flex;align-items:center;gap:.5rem;font-size:clamp(1.35rem,2.6vw,1.9rem);font-weight:550;letter-spacing:-.02em;line-height:1.05}.work-card__title .arrow{color:var(--accent);opacity:0;transform:translate(-6px,4px);transition:.4s var(--ease)}.work-card:hover .work-card__title .arrow{opacity:1;transform:translate(0)}.work-card__desc{color:var(--ink-dim);font-size:.95rem;line-height:1.5}.work-card__tags{display:flex;flex-wrap:wrap;gap:.45rem;margin-top:auto;padding-top:.3rem}.tag{font-family:var(--font-mono);font-size:.68rem;letter-spacing:.05em;color:var(--ink-dim);border:1px solid var(--line);border-radius:999px;padding:.3em .7em;white-space:nowrap}.work-card[data-accent=violet]{--accent: #b06bff;--accent2: #7a5cff}.work-card[data-accent=cyan]{--accent: #2af5ff;--accent2: #38b6ff}.work-card[data-accent=lime]{--accent: #6effb4;--accent2: #2af5c0}.work-card[data-accent=blue]{--accent: #5c9dff;--accent2: #7a5cff}.work-card[data-accent=amber]{--accent: #ffcf6b;--accent2: #ff9b6b}.work-card__ripple{position:absolute;width:14px;height:14px;margin:-7px 0 0 -7px;border-radius:50%;background:radial-gradient(circle,color-mix(in srgb,var(--accent) 55%,transparent),transparent 70%);transform:scale(0);opacity:.6;pointer-events:none;z-index:0;animation:work-ripple .62s var(--ease) forwards}@keyframes work-ripple{to{transform:scale(26);opacity:0}}@media (hover: none){.work-card{cursor:pointer;border-color:color-mix(in srgb,var(--accent) 22%,var(--line))}.work-card:active{transform:scale(.985)}}.stack__lead{font-size:clamp(1.7rem,4.2vw,3rem);font-weight:500;letter-spacing:-.02em;margin-bottom:3rem}.stack__cloud{display:flex;flex-direction:column;gap:2rem}.stack__group{--accent: var(--cyan)}.stack__group[data-accent=violet]{--accent: #b06bff}.stack__group[data-accent=cyan]{--accent: #2af5ff}.stack__group[data-accent=lime]{--accent: #6effb4}.stack__group[data-accent=blue]{--accent: #5c9dff}.stack__group-label{display:block;font-family:var(--font-mono);font-size:.68rem;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-faint);margin-bottom:.9rem}.stack__group-label:before{content:"";display:inline-block;width:18px;height:1px;background:var(--accent);vertical-align:middle;margin-right:.6em;box-shadow:0 0 8px var(--accent)}.stack__chips{display:flex;flex-wrap:wrap;gap:.7rem}.chip{font-family:var(--font-mono);font-size:clamp(.8rem,1.8vw,1rem);letter-spacing:.02em;color:var(--ink);border:1px solid var(--line);border-radius:999px;padding:.6em 1.1em;transition:transform .3s var(--ease),border-color .3s,color .3s,box-shadow .3s;cursor:none;will-change:transform}.chip:hover{color:var(--accent);border-color:var(--accent);box-shadow:0 0 18px -2px color-mix(in srgb,var(--accent) 60%,transparent);transform:translateY(-4px)}.contact{position:relative;text-align:center;padding-bottom:4rem}.contact:before{content:"";position:absolute;left:50%;top:34%;width:min(680px,92%);aspect-ratio:1;transform:translate(-50%,-50%);background:radial-gradient(circle,rgba(42,245,255,.1),rgba(176,107,255,.06) 40%,transparent 64%);filter:blur(12px);pointer-events:none;z-index:0}.contact>*{position:relative;z-index:1}.contact__lead{font-size:clamp(2rem,7vw,4.6rem);font-weight:600;letter-spacing:-.03em;line-height:1.02;margin-bottom:2.4rem}.contact__email{display:inline-block;font-family:var(--font-mono);font-size:clamp(1rem,3.4vw,1.7rem);color:var(--cyan);border-bottom:1px solid rgba(42,245,255,.4);padding-bottom:.2em;transition:text-shadow .3s}.contact__email:hover{text-shadow:var(--glow-cyan)}.contact__links{display:flex;justify-content:center;gap:1.4rem;margin-top:2.4rem;flex-wrap:wrap}.contact__links a{display:inline-flex;align-items:center;gap:.5em;font-family:var(--font-mono);font-size:.8rem;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-dim);border:1px solid var(--line);border-radius:999px;padding:.7em 1.3em;transition:color .3s,border-color .3s,background .3s,box-shadow .3s}.contact__links a:after{content:"↗";font-size:.9em;opacity:.6}.contact__links a:hover{color:#04060a;border-color:transparent;background:linear-gradient(100deg,var(--cyan),var(--violet));box-shadow:var(--glow-cyan)}.footer{display:flex;justify-content:space-between;flex-wrap:wrap;gap:1rem;margin-top:5rem;padding-top:1.6rem;border-top:1px solid var(--line);font-family:var(--font-mono);font-size:.72rem;color:var(--ink-faint)}.footer code,.footer kbd{color:var(--cyan)}.js [data-reveal]{opacity:0;transform:translateY(28px)}.split-char{display:inline-block;will-change:transform,opacity}.term{position:fixed;bottom:1.2rem;right:1.2rem;z-index:850;width:min(540px,calc(100vw - 2.4rem));height:min(380px,60vh);display:flex;flex-direction:column;background:#060a12eb;backdrop-filter:blur(14px);border:1px solid var(--line);border-radius:12px;box-shadow:0 30px 80px #0009,0 0 60px #2af5ff12;opacity:0;transform:translateY(20px) scale(.98);pointer-events:none;transition:opacity .35s var(--ease),transform .35s var(--ease);font-family:var(--font-mono)}.term.is-open{opacity:1;transform:translateY(0) scale(1);pointer-events:auto}.term__bar{display:flex;align-items:center;gap:.5rem;padding:.7rem .9rem;border-bottom:1px solid var(--line)}.term__dot{width:11px;height:11px;border-radius:50%;background:var(--ink-faint)}.term__dot:nth-child(1){background:#ff5f57}.term__dot:nth-child(2){background:#febc2e}.term__dot:nth-child(3){background:#28c840}.term__title{margin-left:.5rem;font-size:.72rem;color:var(--ink-dim)}.term__close{margin-left:auto;background:none;border:none;color:var(--ink-dim);font-size:1.2rem;cursor:none;line-height:1}.term__output{flex:1;overflow-y:auto;padding:.9rem;font-size:.82rem;line-height:1.6;color:var(--ink-dim)}.term__output .ok{color:var(--cyan)}.term__output .accent{color:var(--violet)}.term__output .err{color:var(--magenta)}.term__output a{color:var(--cyan);border-bottom:1px solid rgba(42,245,255,.4)}.term__input-line{display:flex;align-items:center;gap:.6rem;padding:.7rem .9rem;border-top:1px solid var(--line)}.term__prompt{color:var(--cyan);font-size:.82rem}.term__input{flex:1;background:none;border:none;outline:none;color:var(--ink);font-family:var(--font-mono);font-size:.82rem;caret-color:var(--cyan)}.palette{position:fixed;inset:0;z-index:950;display:grid;place-items:start center;padding-top:18vh;background:#02040899;backdrop-filter:blur(6px);opacity:0;visibility:hidden;transition:opacity .25s,visibility .25s}.palette.is-open{opacity:1;visibility:visible}.palette__panel{width:min(560px,90vw);background:#080c14f5;border:1px solid var(--line);border-radius:14px;box-shadow:0 40px 100px #000000b3;overflow:hidden;transform:translateY(-16px);transition:transform .3s var(--ease)}.palette.is-open .palette__panel{transform:translateY(0)}.palette__input{width:100%;background:none;border:none;outline:none;padding:1.2rem 1.3rem;color:var(--ink);font-family:var(--font-sans);font-size:1.05rem;border-bottom:1px solid var(--line)}.palette__list{list-style:none;max-height:320px;overflow-y:auto}.palette__item{display:flex;align-items:center;gap:.9rem;padding:.85rem 1.3rem;font-size:.95rem;color:var(--ink-dim);cursor:none}.palette__item .ico{font-family:var(--font-mono);color:var(--cyan);width:1.4em;text-align:center}.palette__item .hint{margin-left:auto;font-family:var(--font-mono);font-size:.72rem;color:var(--ink-faint)}.palette__item.is-active,.palette__item:hover{background:#2af5ff14;color:var(--ink)}@media (prefers-reduced-motion: reduce){*{animation-duration:.001ms!important;transition-duration:.05ms!important}.js [data-reveal]{opacity:1;transform:none}.hero__hint-arrow{animation:none}}.reduced-motion .gl{display:none}.reduced-motion body:before{background:radial-gradient(60% 50% at 50% 0%,rgba(45,60,130,.25),transparent 70%),var(--bg)}
