:root{--bg: #16161e;--bg-1: #1a1b26;--bg-2: #1f2335;--panel: #1c1d29;--border: #2a2e42;--border-hi: #3b4261;--fg: #c0caf5;--fg-dim: #9aa5ce;--fg-mute: #565f89;--blue: #7aa2f7;--cyan: #7dcfff;--purple: #bb9af7;--green: #9ece6a;--teal: #2ac3de;--red: #f7768e;--orange: #ff9e64;--yellow: #e0af68;--accent: var(--cyan);--accent-2: var(--purple);--mono: "JetBrains Mono", ui-monospace, "SF Mono", Menlo, monospace;--display: "Space Grotesk", var(--mono);--maxw: 1100px;--ease: cubic-bezier(.22, 1, .36, 1)}*,*:before,*:after{box-sizing:border-box}html{scrollbar-width:thin;scrollbar-color:var(--border-hi) transparent}html,body{margin:0;padding:0}body{background:var(--bg);color:var(--fg);font-family:var(--mono);font-size:16px;line-height:1.65;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;overflow-x:hidden}body.cursor-hidden{cursor:none}::selection{background:#7aa2f74d;color:#fff}a{color:var(--accent);text-decoration:none;transition:color .2s var(--ease)}a:hover{color:var(--purple)}:focus-visible{outline:2px solid var(--accent);outline-offset:3px;border-radius:2px}:focus:not(:focus-visible){outline:none}#hero-canvas{position:fixed;top:0;right:0;bottom:0;left:0;width:100vw;height:100vh;height:100dvh;z-index:0;pointer-events:none}.bg-grid{position:fixed;top:-2px;right:-2px;bottom:-2px;left:-2px;z-index:1;pointer-events:none;background-image:linear-gradient(rgba(122,162,247,.05) 1px,transparent 1px),linear-gradient(90deg,rgba(122,162,247,.05) 1px,transparent 1px);background-size:44px 44px;mask-image:radial-gradient(ellipse 80% 60% at 50% 0%,#000 0%,transparent 75%);-webkit-mask-image:radial-gradient(ellipse 80% 60% at 50% 0%,#000 0%,transparent 75%)}.scanlines{position:fixed;top:0;right:0;bottom:0;left:0;z-index:2;pointer-events:none;background:repeating-linear-gradient(to bottom,#0000,#0000 2px,#00000029,#0000 4px);opacity:.35;mix-blend-mode:multiply}.noise{position:fixed;top:0;right:0;bottom:0;left:0;z-index:2;pointer-events:none;opacity:.035;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}.cursor-dot{position:fixed;top:0;left:0;z-index:9999;width:26px;height:26px;margin:-13px 0 0 -13px;border:1px solid var(--accent);border-radius:50%;pointer-events:none;transition:width .18s var(--ease),height .18s var(--ease),background .18s var(--ease),border-color .18s var(--ease),opacity .2s var(--ease);mix-blend-mode:difference}.cursor-dot.hover{width:46px;height:46px;margin:-23px 0 0 -23px;background:#7dcfff1f;border-color:var(--purple)}@media(max-width:768px){.cursor-dot{display:none}}@media(prefers-reduced-motion:reduce){.scanlines,.noise{display:none}}#app{position:relative;z-index:3}.wrap{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 28px}section{padding:clamp(64px,12vh,140px) 0;position:relative}.section-label{font-size:.78rem;letter-spacing:.22em;text-transform:uppercase;color:var(--fg-mute);margin-bottom:28px;display:flex;align-items:center;gap:12px}.section-label:before{content:"";width:28px;height:1px;background:var(--accent)}.section-label .idx{color:var(--accent);font-weight:700}h2.heading{font-family:var(--display);font-size:clamp(1.9rem,4.5vw,3rem);line-height:1.05;letter-spacing:-.02em;margin:0 0 8px;font-weight:700;white-space:pre-line}.nav{position:fixed;top:0;left:0;right:0;z-index:50;display:flex;align-items:center;justify-content:space-between;padding:16px clamp(20px,4vw,40px);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:linear-gradient(to bottom,rgba(22,22,30,.85),transparent);transition:transform .3s var(--ease)}.nav .brand{font-weight:800;letter-spacing:-.02em;color:var(--fg)}.nav .brand .dot{color:var(--accent)}.nav .links{display:flex;gap:clamp(10px,2vw,26px);font-size:.85rem}.nav .links a{color:var(--fg-dim);position:relative}.nav .links a:before{content:"0" counter(navc) " ";color:var(--accent);font-size:.72em;opacity:.7}.nav .links{counter-reset:navc}.nav .links a{counter-increment:navc}.nav .links a:hover{color:var(--accent)}.nav-toggle{display:none;background:transparent;border:1px solid var(--border-hi);color:var(--fg);font-family:var(--mono);font-size:1.05rem;line-height:1;padding:7px 11px;border-radius:4px;cursor:pointer;transition:color .2s var(--ease),border-color .2s var(--ease)}.nav-toggle:hover{color:var(--accent);border-color:var(--accent)}@media(max-width:720px){.nav-toggle{display:block}.nav .links{position:absolute;top:calc(100% + 6px);left:clamp(12px,4vw,40px);right:clamp(12px,4vw,40px);flex-direction:column;gap:2px;padding:8px;background:#1a1b26f7;border:1px solid var(--border);border-radius:10px;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);box-shadow:0 18px 44px -18px #000000b3;opacity:0;transform:translateY(-8px);pointer-events:none;transition:opacity .2s var(--ease),transform .2s var(--ease)}.nav.open .links{opacity:1;transform:none;pointer-events:auto}.nav .links a{padding:12px 14px;border-radius:6px;font-size:.95rem}.nav .links a:hover{background:#7dcfff14}}.hero{min-height:100vh;min-height:100dvh;display:flex;flex-direction:column;justify-content:center;padding-top:80px}.hero .boot{font-size:.82rem;color:var(--green);margin-bottom:26px;min-height:1.2em;white-space:pre-wrap}.hero .boot .blink{color:var(--green);animation:blink 1s steps(2) infinite}@keyframes blink{50%{opacity:0}}.hero h1{font-family:var(--display);font-weight:700;font-size:clamp(2.6rem,11vw,7.5rem);line-height:.92;letter-spacing:-.04em;margin:0;color:var(--fg)}.hero h1 .accent{background:linear-gradient(120deg,var(--cyan),var(--purple) 60%,var(--blue));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}.hero .role-line{font-family:var(--mono);font-size:clamp(1rem,2.4vw,1.5rem);color:var(--fg-dim);margin:22px 0 0;height:1.6em}.hero .role-line .cursor{color:var(--accent);animation:blink 1s steps(2) infinite}.hero .blurb{max-width:56ch;color:var(--fg-dim);margin:28px 0 0;font-size:clamp(.95rem,1.4vw,1.05rem)}.hero .cta{display:flex;flex-wrap:wrap;gap:14px;margin-top:40px}.btn{font-family:var(--mono);font-size:.9rem;font-weight:500;color:var(--fg);border:1px solid var(--border-hi);background:#1f233580;padding:12px 22px;border-radius:4px;display:inline-flex;align-items:center;gap:10px;transition:all .22s var(--ease);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.btn:hover{border-color:var(--accent);color:var(--accent);transform:translateY(-2px);box-shadow:0 8px 30px -12px #7dcfff80}.btn.primary{border-color:var(--accent);background:#7dcfff14}.btn .prompt{color:var(--green)}.scroll-hint{position:absolute;bottom:28px;left:50%;transform:translate(-50%);font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;color:var(--fg-mute);display:flex;flex-direction:column;align-items:center;gap:8px}.scroll-hint .line{width:1px;height:36px;background:linear-gradient(var(--accent),transparent);animation:drop 1.8s var(--ease) infinite}@keyframes drop{0%{transform:scaleY(0);transform-origin:top}40%{transform:scaleY(1);transform-origin:top}60%{transform:scaleY(1);transform-origin:bottom}to{transform:scaleY(0);transform-origin:bottom}}.stats-section{padding:0}.impact{margin-top:40px}.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;border:1px solid var(--border);background:var(--border);border-radius:10px;overflow:hidden}.stat{background:linear-gradient(160deg,var(--bg-2),var(--panel));padding:28px 22px;text-align:center}.stat .num{font-family:var(--display);font-size:clamp(1.8rem,4vw,2.8rem);font-weight:700;letter-spacing:-.02em;line-height:1;background:linear-gradient(120deg,var(--cyan),var(--purple));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}.stat .stat-label{margin-top:10px;font-size:.78rem;color:var(--fg-mute);letter-spacing:.04em}@media(max-width:720px){.stats{grid-template-columns:repeat(2,1fr)}}.about-grid{display:grid;grid-template-columns:1.4fr 1fr;gap:48px;align-items:start}@media(max-width:820px){.about-grid{grid-template-columns:1fr;gap:28px}}.about-body p{color:var(--fg-dim);margin:0 0 16px}.about-body strong{color:var(--fg);font-weight:500}.id-card{border:1px solid var(--border);border-radius:8px;background:linear-gradient(160deg,var(--bg-2),var(--panel));overflow:hidden}.id-card .titlebar{display:flex;align-items:center;gap:8px;padding:10px 14px;border-bottom:1px solid var(--border);font-size:.74rem;color:var(--fg-mute)}.id-card .dots{display:flex;gap:6px}.id-card .dots i{width:11px;height:11px;border-radius:50%;display:block}.id-card .dots i:nth-child(1){background:var(--red)}.id-card .dots i:nth-child(2){background:var(--yellow)}.id-card .dots i:nth-child(3){background:var(--green)}.id-card .body{padding:18px;font-size:.86rem}.id-card .row{display:flex;gap:10px;padding:5px 0}.id-card .k{color:var(--fg-mute);min-width:84px}.id-card .v{color:var(--fg)}.id-card .v .str{color:var(--green)}.id-card .v .num{color:var(--orange)}.timeline{display:flex;flex-direction:column;gap:0}.job{display:grid;grid-template-columns:160px 1fr;gap:28px;padding:26px 0;border-top:1px solid var(--border);position:relative}.job:last-child{border-bottom:1px solid var(--border)}@media(max-width:720px){.job{grid-template-columns:1fr;gap:8px}}.job .when{font-size:.8rem;color:var(--fg-mute);padding-top:4px}.job .when .badge{display:inline-block;margin-top:8px;font-size:.68rem;letter-spacing:.12em;text-transform:uppercase;color:var(--green);border:1px solid rgba(158,206,106,.4);background:#9ece6a14;padding:2px 8px;border-radius:999px}.job h3{font-family:var(--display);font-size:1.3rem;margin:0;color:var(--fg);letter-spacing:-.01em}.job .co{color:var(--accent);font-weight:500}.job .summary{color:var(--fg-dim);font-style:italic;margin:8px 0 12px;font-size:.92rem}.job ul{margin:12px 0 0;padding:0;list-style:none}.job li{position:relative;padding-left:22px;margin-bottom:10px;color:var(--fg-dim);font-size:.92rem}.job li:before{content:"▹";position:absolute;left:0;color:var(--accent)}.tags{display:flex;flex-wrap:wrap;gap:7px;margin-top:14px}.tag{font-size:.72rem;color:var(--cyan);border:1px solid var(--border-hi);background:#7dcfff0d;padding:3px 10px;border-radius:4px}.proj-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}@media(max-width:760px){.proj-grid{grid-template-columns:1fr}}.card{position:relative;border:1px solid var(--border);border-radius:10px;background:linear-gradient(165deg,#1f233599,#1c1d2999);padding:24px;overflow:hidden;transition:transform .3s var(--ease),border-color .3s var(--ease),box-shadow .3s var(--ease);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.card:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;border-radius:10px;padding:1px;background:radial-gradient(400px circle at var(--mx, 50%) var(--my, 0%),rgba(125,207,255,.5),transparent 40%);-webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);-webkit-mask-composite:xor;mask-composite:exclude;opacity:0;transition:opacity .3s var(--ease)}.card:hover{transform:translateY(-4px);border-color:var(--border-hi)}.card:hover:after{opacity:1}.card .top{display:flex;flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:8px 12px;margin-bottom:10px}.card h3{font-family:var(--display);font-size:1.15rem;margin:0;letter-spacing:-.01em}.card .highlight{font-size:.72rem;color:var(--orange);border:1px solid rgba(255,158,100,.35);background:#ff9e6412;padding:3px 9px;border-radius:999px;white-space:nowrap}.card .meta{font-size:.76rem;color:var(--fg-mute);margin-bottom:12px}.card .meta .org{color:var(--accent)}.card .blurb{color:var(--fg-dim);font-size:.9rem;margin:0 0 14px}.card ul{margin:0;padding:0;list-style:none}.card li{position:relative;padding-left:18px;margin-bottom:8px;color:var(--fg-dim);font-size:.85rem}.card li:before{content:"›";position:absolute;left:0;color:var(--accent)}.card-links{display:flex;flex-wrap:wrap;gap:16px;margin-top:16px}.card-links a{font-size:.78rem;color:var(--accent);border-bottom:1px solid transparent;padding-bottom:1px}.card-links a:hover{border-color:currentColor}.stack-block{margin-bottom:26px}.stack-block .label{font-size:.78rem;letter-spacing:.16em;text-transform:uppercase;color:var(--fg-mute);margin-bottom:14px}.chips{display:flex;flex-wrap:wrap;gap:10px}.chip{font-size:.85rem;color:var(--fg);border:1px solid var(--border);background:var(--panel);padding:7px 14px;border-radius:6px;transition:all .2s var(--ease);cursor:default}.chip:hover{border-color:var(--accent);color:var(--accent);transform:translateY(-2px)}.edu{margin-top:40px;border-left:2px solid var(--accent);padding-left:20px}.edu h3{margin:0;font-family:var(--display);font-size:1.1rem}.edu .deg{color:var(--fg-dim);font-size:.9rem}.edu .meta{color:var(--fg-mute);font-size:.8rem;margin-top:4px}.contact{text-align:center}.contact h2{font-family:var(--display);font-size:clamp(2rem,7vw,4.5rem);letter-spacing:-.03em;margin:0 0 18px}.contact h2 .accent{background:linear-gradient(120deg,var(--cyan),var(--purple));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}.contact p{color:var(--fg-dim);max-width:48ch;margin:0 auto 32px}.contact .row{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}footer{border-top:1px solid var(--border);padding:28px 0 100px;text-align:center;color:var(--fg-mute);font-size:.78rem}footer .mono{color:var(--fg-dim)}.statusbar{position:fixed;bottom:0;left:0;right:0;z-index:60;display:flex;align-items:center;font-size:.74rem;background:var(--bg-2);border-top:1px solid var(--border);color:var(--fg-dim);height:26px;font-family:var(--mono)}.statusbar .seg{padding:0 12px;height:100%;display:flex;align-items:center;gap:6px}.statusbar .mode{background:var(--accent);color:#11121a;font-weight:700;letter-spacing:.1em}.statusbar .file{color:var(--fg)}.statusbar .spacer{flex:1}.statusbar .git{color:var(--green)}.statusbar .pos{color:var(--fg-mute)}@media(max-width:640px){.statusbar .hide-sm{display:none}}.engage-wrap{margin-top:40px;display:flex;flex-direction:column;align-items:center;gap:10px}.engage-btn{font-family:var(--mono);font-size:.86rem;color:var(--red);background:#f7768e0f;border:1px solid rgba(247,118,142,.4);padding:11px 22px;border-radius:4px;cursor:pointer;transition:all .22s var(--ease)}.engage-btn:hover{color:#fff;background:#f7768e33;border-color:var(--red);box-shadow:0 8px 30px -12px #f7768e99;transform:translateY(-2px)}.engage-note{font-size:.74rem;color:var(--fg-mute)}.egg-prompt{position:fixed;left:50%;bottom:54px;transform:translate(-50%,160%);z-index:70;display:flex;align-items:center;gap:12px;padding:11px 13px 11px 18px;background:#1c1d29eb;border:1px solid rgba(247,118,142,.5);border-radius:999px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 12px 40px -16px #f7768e99;font-size:.85rem;opacity:0;transition:transform .4s var(--ease),opacity .4s var(--ease);max-width:calc(100vw - 24px)}.egg-prompt.show{transform:translate(-50%);opacity:1}.egg-prompt[hidden]{display:none}.egg-prompt .egg-icon{color:var(--red);animation:ann-blink .9s steps(2) infinite}.egg-prompt .egg-text{color:var(--fg-dim)}.egg-prompt .egg-go{font-family:var(--mono);font-size:.82rem;color:#fff;background:#f7768e2e;border:1px solid var(--red);padding:6px 14px;border-radius:999px;cursor:pointer;transition:all .2s var(--ease)}.egg-prompt .egg-go:hover{background:#f7768e57}.egg-prompt .egg-x{font-family:var(--mono);font-size:.82rem;color:var(--fg-mute);background:transparent;border:none;cursor:pointer;padding:4px 8px}.egg-prompt .egg-x:hover{color:var(--fg)}.egg-msg{display:flex;align-items:center;gap:10px}.egg-actions{display:flex;align-items:center;gap:8px}@media(prefers-reduced-motion:reduce){.egg-prompt .egg-icon{animation:none}}@media(max-width:480px){.egg-prompt{left:12px;right:12px;flex-direction:column;gap:12px;padding:14px 16px;border-radius:14px;text-align:center;transform:translateY(180%)}.egg-prompt.show{transform:translateY(0)}.egg-msg{justify-content:center}.egg-text{white-space:nowrap}}.game-hud{position:fixed;top:64px;left:50%;transform:translate(-50%);z-index:70;display:flex;align-items:center;gap:18px;padding:10px 18px;background:#1c1d29d9;border:1px solid var(--border-hi);border-radius:8px;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);font-size:.8rem;max-width:calc(100vw - 28px);flex-wrap:wrap;justify-content:center}.game-hud[hidden]{display:none}.game-hud .g-title{color:var(--red);font-weight:700;letter-spacing:.12em}.game-hud .g-score{color:var(--cyan);font-weight:700}.game-hud .g-hint{color:var(--fg-mute)}.game-hud .g-exit{font-family:var(--mono);font-size:.76rem;color:var(--fg-dim);background:transparent;border:1px solid var(--border-hi);border-radius:4px;padding:5px 12px;cursor:pointer;transition:all .2s var(--ease)}.game-hud .g-exit:hover{color:var(--red);border-color:var(--red)}@media(max-width:640px){.game-hud .g-hint{display:none}}.game-hud .g-lives{color:var(--red);letter-spacing:2px}.game-hud .g-boss{display:flex;align-items:center;gap:7px}.game-hud .g-boss[hidden]{display:none}.game-hud .g-boss-label{color:var(--orange);font-weight:700;letter-spacing:.1em}.game-hud .g-boss-bar{width:90px;height:8px;border:1px solid var(--border-hi);border-radius:999px;overflow:hidden;background:#00000059}.game-hud .g-boss-bar i{display:block;height:100%;width:100%;background:linear-gradient(90deg,var(--orange),var(--red));transition:width .12s linear}.game-announce.win .ann-main{text-shadow:0 0 42px rgba(158,206,106,.7)}.game-announce.win .ann-sub{color:var(--green)}.game-announce.win.show:before{background:radial-gradient(circle at 50% 58%,rgba(158,206,106,.28),transparent 60%)}.game-announce.win.show .ann-main:before{color:var(--teal)}.game-announce.win.show .ann-main:after{color:var(--green)}.game-over{position:fixed;top:0;right:0;bottom:0;left:0;z-index:85;display:none;align-items:center;justify-content:center;background:#0b0c129e;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);opacity:0;transition:opacity .25s var(--ease)}.game-over.show{display:flex;opacity:1}.game-over[hidden]{display:none}.go-card{text-align:center;border:1px solid rgba(247,118,142,.5);background:var(--bg-2);border-radius:12px;padding:34px 44px;box-shadow:0 24px 70px -22px #f7768e8c}.go-title{font-family:var(--display);font-size:clamp(2rem,7vw,3.4rem);font-weight:700;letter-spacing:-.02em;color:var(--red);line-height:1}.go-score{color:var(--fg-dim);margin-top:8px;font-size:1rem}.go-actions{display:flex;gap:12px;justify-content:center;margin-top:24px}.go-retry,.go-quit{font-family:var(--mono);font-size:.86rem;padding:10px 20px;border-radius:6px;cursor:pointer;transition:all .2s var(--ease)}.go-retry{color:#fff;background:#f7768e2e;border:1px solid var(--red)}.go-retry:hover{background:#f7768e57;transform:translateY(-2px)}.go-quit{color:var(--fg-dim);background:transparent;border:1px solid var(--border-hi)}.go-quit:hover{color:var(--fg);border-color:var(--fg-mute)}@media(pointer:coarse){.egg-prompt .egg-go,.egg-prompt .egg-x{min-height:40px}.go-retry,.go-quit{min-height:44px}}.game-announce{position:fixed;top:0;right:0;bottom:0;left:0;z-index:80;display:none;align-items:center;justify-content:center;text-align:center;pointer-events:none}.game-announce.show{display:flex}.game-announce.show:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;background:radial-gradient(circle at 50% 58%,rgba(247,118,142,.28),transparent 60%);animation:ann-flash .6s var(--ease) forwards}.ann-inner{display:flex;flex-direction:column;align-items:center;gap:10px;padding:0 16px}.ann-sub{font-family:var(--mono);font-size:clamp(.8rem,2.5vw,1.1rem);letter-spacing:.35em;text-transform:uppercase;color:var(--red);animation:ann-blink .28s steps(2) 6}.ann-main{position:relative;font-family:var(--display);font-weight:700;text-transform:uppercase;font-size:clamp(2rem,9vw,6rem);letter-spacing:-.02em;line-height:.95;color:#fff;text-shadow:0 0 38px rgba(247,118,142,.6);animation:ann-slam 2.2s var(--ease) forwards}.game-announce.show .ann-main:before,.game-announce.show .ann-main:after{content:attr(data-text);position:absolute;top:0;right:0;bottom:0;left:0}.game-announce.show .ann-main:before{color:var(--cyan);animation:ann-glitch .5s steps(2) 3}.game-announce.show .ann-main:after{color:var(--red);animation:ann-glitch .5s steps(2) 3 reverse}@keyframes ann-slam{0%{opacity:0;transform:scale(1.5);filter:blur(14px)}12%{opacity:1;transform:scale(1);filter:blur(0)}72%{opacity:1;transform:scale(1)}to{opacity:0;transform:scale(.92);filter:blur(5px)}}@keyframes ann-flash{0%{opacity:0}22%{opacity:1}to{opacity:0}}@keyframes ann-blink{50%{opacity:.25}}@keyframes ann-glitch{0%{clip-path:inset(0 0 70% 0);transform:translate(-5px)}50%{clip-path:inset(50% 0 0 0);transform:translate(5px)}to{clip-path:inset(20% 0 40% 0);transform:translate(-2px)}}@media(prefers-reduced-motion:reduce){.ann-main,.ann-sub,.game-announce.show:before,.game-announce.show .ann-main:before,.game-announce.show .ann-main:after{animation:none}.ann-main{opacity:1}}body.playing #app{opacity:.12;transition:opacity .4s var(--ease);pointer-events:none}body.playing{cursor:none}.reveal{opacity:0;transform:translateY(26px);transition:opacity .7s var(--ease),transform .7s var(--ease)}.reveal.in{opacity:1;transform:none}@media(prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}}.blog-head{padding-top:120px}.back-link{font-size:.82rem;color:var(--fg-dim);display:inline-flex;gap:8px;margin-bottom:24px}.post-list{display:flex;flex-direction:column;gap:4px;margin-top:24px}.post-item{display:grid;grid-template-columns:120px 1fr auto;gap:20px;align-items:baseline;padding:20px 14px;border-radius:8px;border:1px solid transparent;transition:all .22s var(--ease)}.post-item:hover{border-color:var(--border);background:#1f233566}.post-item .date{font-size:.78rem;color:var(--fg-mute)}.post-item h3{margin:0;font-family:var(--display);font-size:1.15rem;color:var(--fg)}.post-item p{margin:6px 0 0;font-size:.88rem;color:var(--fg-dim)}.post-item .read{font-size:.76rem;color:var(--accent);white-space:nowrap}.blog-all{margin-top:26px}@media(max-width:640px){.post-item{grid-template-columns:1fr;gap:4px}.post-item .read{display:none}}.post{max-width:720px;margin:0 auto;padding-top:120px}.post .post-meta{color:var(--fg-mute);font-size:.82rem;margin-bottom:8px}.post h1{font-family:var(--display);font-size:clamp(1.8rem,5vw,2.8rem);letter-spacing:-.02em;line-height:1.1;margin:0 0 28px}.post-body{color:var(--fg-dim)}.post-body h2{font-family:var(--display);color:var(--fg);margin-top:40px;font-size:1.5rem}.post-body h3{font-family:var(--display);color:var(--fg);margin-top:28px;font-size:1.2rem}.post-body p{margin:0 0 18px}.post-body a{text-decoration:underline;text-underline-offset:3px}.post-body code{font-family:var(--mono);background:var(--bg-2);border:1px solid var(--border);padding:1px 6px;border-radius:4px;font-size:.86em;color:var(--cyan)}.post-body pre{background:var(--bg-2);border:1px solid var(--border);border-radius:8px;padding:18px;overflow-x:auto;margin:0 0 22px}.post-body pre code{background:none;border:none;padding:0;color:var(--fg)}.post-body blockquote{border-left:3px solid var(--accent);margin:0 0 20px;padding-left:18px;color:var(--fg-mute);font-style:italic}.post-body ul,.post-body ol{color:var(--fg-dim);padding-left:22px}.post-body li{margin-bottom:8px}.post-body hr{border:none;border-top:1px solid var(--border);margin:36px 0}.post-body img{max-width:100%;border-radius:8px}.glitch{position:relative;display:inline-block}.glitch:before,.glitch:after{content:attr(data-text);position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;opacity:0}.glitch:hover:before{opacity:.9;color:var(--red);animation:glitch-x .5s steps(2) infinite}.glitch:hover:after{opacity:.9;color:var(--cyan);animation:glitch-y .5s steps(2) infinite reverse}@keyframes glitch-x{0%{transform:translate(0);clip-path:inset(0 0 60% 0)}50%{transform:translate(-3px,1px);clip-path:inset(40% 0 0 0)}to{transform:translate(2px,-1px);clip-path:inset(0 0 30% 0)}}@keyframes glitch-y{0%{transform:translate(0);clip-path:inset(50% 0 0 0)}50%{transform:translate(3px,-1px);clip-path:inset(0 0 50% 0)}to{transform:translate(-2px,1px);clip-path:inset(20% 0 20% 0)}}@media(prefers-reduced-motion:reduce){.glitch:hover:before,.glitch:hover:after{animation:none;opacity:0}}html.lenis,html.lenis body{height:auto}.lenis:not(.lenis-autoToggle).lenis-stopped{overflow:clip}.lenis [data-lenis-prevent],.lenis [data-lenis-prevent-wheel],.lenis [data-lenis-prevent-touch],.lenis [data-lenis-prevent-vertical],.lenis [data-lenis-prevent-horizontal]{overscroll-behavior:contain}.lenis.lenis-smooth iframe{pointer-events:none}.lenis.lenis-autoToggle{transition-property:overflow;transition-duration:1ms;transition-behavior:allow-discrete}
