@keyframes astroFadeInOut{0%{opacity:1}to{opacity:0}}@keyframes astroFadeIn{0%{opacity:0;mix-blend-mode:plus-lighter}to{opacity:1;mix-blend-mode:plus-lighter}}@keyframes astroFadeOut{0%{opacity:1;mix-blend-mode:plus-lighter}to{opacity:0;mix-blend-mode:plus-lighter}}@keyframes astroSlideFromRight{0%{transform:translate(100%)}}@keyframes astroSlideFromLeft{0%{transform:translate(-100%)}}@keyframes astroSlideToRight{to{transform:translate(100%)}}@keyframes astroSlideToLeft{to{transform:translate(-100%)}}@media(prefers-reduced-motion){::view-transition-group(*),::view-transition-old(*),::view-transition-new(*){animation:none!important}[data-astro-transition-scope]{animation:none!important}}.astro-route-announcer{position:absolute;left:0;top:0;clip:rect(0 0 0 0);clip-path:inset(50%);overflow:hidden;white-space:nowrap;width:1px;height:1px}:root{color-scheme:dark;--bg: #0a0d18;--bg-deep: #06080f;--surface: #121728;--surface-2: #1a2139;--surface-3: #232c48;--hairline: rgba(235, 230, 218, .08);--hairline-2: rgba(235, 230, 218, .16);--hairline-3: rgba(235, 230, 218, .28);--text: #ece7db;--text-mute: #969cb1;--text-dim: #626880;--header-text: #0ebe6d;--accent: var(--header-text);--accent-soft: rgba(14, 190, 109, .12);--accent-line: rgba(14, 190, 109, .4);--work: #4dd0c5;--school: #c997f5;--hobby: #f5b95c;--life: #94c89a;--nda: #ff8a8a;--lost: #8a8fa3;--ongoing: #f5b95c;--serif: "Fraunces", "Iowan Old Style", Georgia, serif;--sans: "Geist", system-ui, -apple-system, sans-serif;--mono: "Geist Mono", "JetBrains Mono", ui-monospace, monospace;--fs-eyebrow: 11px;--fs-caption: 12.5px;--fs-sm: 14px;--fs-base: 16.5px;--fs-md: 18px;--fs-lead: clamp(19px, 1.5vw, 23px);--fs-h3: clamp(24px, 2.6vw, 34px);--fs-h2: clamp(38px, 5.2vw, 64px);--fs-display: clamp(58px, 10.5vw, 150px);--sp-1: 4px;--sp-2: 8px;--sp-3: 12px;--sp-4: 16px;--sp-5: 24px;--sp-6: 32px;--sp-7: 48px;--sp-8: 64px;--sp-9: 96px;--sp-10: 128px;--section-y: clamp(80px, 11vw, 160px);--r-xs: 4px;--r-sm: 8px;--r-md: 12px;--r-lg: 18px;--r-pill: 100px;--dur-1: .15s;--dur-2: .25s;--dur-3: .4s;--dur-4: .8s;--ease: cubic-bezier(.4, 0, .2, 1);--ease-out: cubic-bezier(.16, 1, .3, 1);--ease-in-out: cubic-bezier(.65, 0, .35, 1);--shadow-card: 0 1px 0 rgba(235, 230, 218, .04) inset, 0 2px 6px rgba(0, 0, 0, .28), 0 14px 44px rgba(0, 0, 0, .34);--shadow-lg: 0 1px 0 rgba(235, 230, 218, .05) inset, 0 24px 70px rgba(0, 0, 0, .55);--maxw: 1280px;--maxw-text: 760px;--gutter: clamp(22px, 4.5vw, 64px)}*{box-sizing:border-box}html{scroll-behavior:smooth;scroll-padding-top:88px;-webkit-text-size-adjust:100%}body{margin:0;font-family:var(--sans);font-size:var(--fs-base);line-height:1.7;color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-feature-settings:"ss01","cv11";font-variation-settings:"wght" 400;background-image:radial-gradient(1100px 720px at 88% -6%,rgba(14,190,109,.05),transparent 60%),linear-gradient(180deg,var(--bg-deep) 0%,var(--bg) 24%);background-repeat:no-repeat;background-attachment:scroll}a{color:inherit;text-decoration:none;border-bottom:1px solid var(--hairline-2);transition:border-color var(--dur-1) var(--ease),color var(--dur-1) var(--ease)}a:hover{border-color:var(--text)}:focus-visible{outline:2px solid var(--accent);outline-offset:3px;border-radius:3px}::selection{background:#ece7dbeb;color:var(--bg-deep)}.wrap{max-width:var(--maxw);margin-inline:auto;padding-inline:var(--gutter)}.eyebrow{font-family:var(--mono);font-size:var(--fs-eyebrow);letter-spacing:.22em;text-transform:uppercase;color:var(--text-dim)}.site-nav{position:sticky;top:0;z-index:50;display:flex;align-items:center;gap:18px;padding:16px var(--gutter);backdrop-filter:blur(16px) saturate(140%);-webkit-backdrop-filter:blur(16px) saturate(140%);background:#0a0d188c;border-bottom:1px solid transparent;transition:background var(--dur-2) var(--ease),border-color var(--dur-2) var(--ease),box-shadow var(--dur-2) var(--ease)}.site-nav.is-scrolled{background:#080b14d1;border-bottom-color:var(--hairline);box-shadow:0 10px 30px #00000047}.brand{display:flex;align-items:center;gap:12px;border:none;font-family:var(--mono);font-size:13px;letter-spacing:.04em}.brand-mark{display:inline-grid;place-items:center;width:30px;height:30px;border:1px solid var(--hairline-2);border-radius:var(--r-xs);font-family:var(--serif);font-weight:500;font-style:italic;font-size:14px;transition:border-color var(--dur-1) var(--ease),color var(--dur-1) var(--ease)}.brand-name{color:var(--text-mute);transition:color var(--dur-1) var(--ease)}.brand:hover .brand-mark{border-color:var(--accent);color:var(--accent)}.brand:hover .brand-name{color:var(--text)}.nav-links{display:flex;gap:28px;list-style:none;margin:0 0 0 auto;padding:0;font-family:var(--mono);font-size:13px}.nav-links a{border:none;color:var(--text-mute);position:relative}.nav-links a:after{content:"";position:absolute;left:0;right:0;bottom:-6px;height:1px;background:var(--text);transform:scaleX(0);transform-origin:left;transition:transform .25s}.nav-links a:hover{color:var(--text)}.nav-links a:hover:after{transform:scaleX(1)}.lang-switch{display:inline-flex;align-items:center;gap:5px;padding:3px 8px 3px 6px;border:1px solid var(--hairline-2);border-radius:100px;font-family:var(--mono);font-size:11px;letter-spacing:.04em;text-transform:uppercase;background:#13182980;transition:border-color .2s;flex-shrink:0}.lang-switch:hover{border-color:var(--text)}.lang-globe{width:14px;height:14px;flex-shrink:0;color:var(--text-mute)}.lang-pair{display:inline-flex;align-items:baseline;gap:2px}.lang-current{color:var(--text-dim);opacity:.5}.lang-sep{color:var(--text-dim);opacity:.4}.lang-target{color:var(--text-mute);transition:color .2s}.lang-switch:hover .lang-target{color:var(--text)}.nav-toggle{display:none;width:32px;height:32px;padding:0;background:transparent;border:1px solid var(--hairline-2);border-radius:6px;color:var(--text-mute);cursor:pointer;flex-shrink:0;align-items:center;justify-content:center;flex-direction:column;gap:4px;transition:color .2s,border-color .2s}.nav-toggle:hover{color:var(--text);border-color:var(--text)}.nav-toggle-bar{display:block;width:16px;height:1.5px;background:currentColor;transition:transform .25s,opacity .2s;transform-origin:center}@media(max-width:640px){.brand-name{display:none}.lang-switch{padding:3px 7px 3px 5px;font-size:10px;gap:4px}.lang-globe{width:13px;height:13px}.site-nav{flex-wrap:wrap;row-gap:0;padding:12px var(--gutter)}.nav-toggle{display:inline-flex;margin-left:auto}.nav-links{order:99;flex-basis:100%;margin:0;flex-direction:column;align-items:flex-start;gap:14px;font-size:14px;max-height:0;opacity:0;overflow:hidden;pointer-events:none;padding-top:0;padding-bottom:0;border-top:1px solid transparent;transition:max-height .28s ease,opacity .2s ease,margin-top .28s ease,padding .28s ease,border-color .2s}.site-nav.is-open .nav-links{max-height:320px;opacity:1;pointer-events:auto;margin-top:12px;padding-top:14px;padding-bottom:4px;border-top-color:var(--hairline)}.nav-toggle[aria-expanded=true] .nav-toggle-bar:nth-child(1){transform:translateY(5.5px) rotate(45deg)}.nav-toggle[aria-expanded=true] .nav-toggle-bar:nth-child(2){opacity:0}.nav-toggle[aria-expanded=true] .nav-toggle-bar:nth-child(3){transform:translateY(-5.5px) rotate(-45deg)}}.hero{position:relative;max-width:var(--maxw);margin:0 auto;padding:clamp(40px,6vw,84px) var(--gutter) clamp(56px,8vw,108px);overflow:hidden}.hero-bg{position:absolute;inset:0;pointer-events:none;color:var(--hairline-2);mask-image:linear-gradient(180deg,black 0%,black 60%,transparent 100%);-webkit-mask-image:linear-gradient(180deg,black 0%,black 60%,transparent 100%)}.hero-traces{position:absolute;inset:0;width:100%;height:100%;color:var(--accent);opacity:.6}.hero-traces .trace-group path{stroke-linecap:square}.hero-traces .trace-pads circle{opacity:.55}.hero-inner{position:relative;display:grid;grid-template-columns:minmax(0,1fr) minmax(300px,380px);align-items:start;gap:clamp(36px,5vw,84px)}@media(max-width:980px){.hero-inner{grid-template-columns:1fr;align-items:start}.hero-right{display:none}}.hero-left{min-width:0}.hero-tag{display:inline-flex;align-items:center;gap:10px;margin:0 0 var(--sp-6);padding:6px 12px 6px 10px;border:1px solid var(--hairline-2);border-radius:100px;font-family:var(--mono);font-size:var(--fs-eyebrow);letter-spacing:.14em;text-transform:uppercase;color:var(--text-mute);background:#13182980}.tag-dot{width:7px;height:7px;flex-shrink:0;border-radius:50%;background:var(--accent);box-shadow:0 0 0 2px #0ebe6d2e,0 0 14px var(--accent);animation:pulse 2.4s var(--ease-in-out) infinite}@keyframes pulse{0%,to{transform:scale(1);opacity:1}50%{transform:scale(.7);opacity:.55}}.hero-title{font-family:var(--serif);font-weight:350;font-size:clamp(54px,10vw,124px);line-height:.94;letter-spacing:-.035em;margin:0 0 var(--sp-6);font-variation-settings:"opsz" 144,"SOFT" 0;text-wrap:balance}.hero-title .line{display:block}.hero-title .italic{font-style:italic;font-weight:300;color:var(--accent);margin-left:.08em;font-variation-settings:"opsz" 144,"SOFT" 100}.hero-sub{font-family:var(--serif);font-weight:400;font-size:clamp(19px,1.85vw,23px);line-height:1.45;color:var(--text);max-width:52ch;margin:0 0 var(--sp-7);font-variation-settings:"opsz" 36}.hero-build{font-family:var(--serif);font-weight:350;font-size:clamp(21px,2.2vw,28px);line-height:1.4;color:var(--text);margin:0 0 var(--sp-8);font-variation-settings:"opsz" 36;display:flex;flex-wrap:wrap;align-items:baseline;gap:.4em;min-height:1.4em}.hero-build .build-lead{color:var(--text)}.hero-build .build-type{display:inline-flex;align-items:baseline;color:var(--accent);font-style:italic;font-variation-settings:"opsz" 36,"SOFT" 60;min-width:1ch}.typewriter-text{white-space:pre}.typewriter-caret{display:inline-block;width:2px;height:1em;margin-left:4px;background:var(--accent);transform:translateY(.12em);animation:typewriter-blink 1s steps(2,start) infinite}@keyframes typewriter-blink{to{background:transparent}}@media(prefers-reduced-motion:reduce){.typewriter-caret{animation:none}}.status-block{margin:0;border-top:1px solid var(--hairline);padding-top:var(--sp-5);display:flex;flex-direction:column;gap:var(--sp-3);max-width:640px}.status-row{display:grid;grid-template-columns:76px 1fr;align-items:baseline;gap:18px;font-family:var(--mono);font-size:12.5px}.status-row dt{color:var(--text-dim);font-size:10px;letter-spacing:.18em;text-transform:uppercase}.status-row dd{margin:0;color:var(--text);letter-spacing:.01em}.hero-right{position:relative;min-width:0}.lossgraph{margin:0;border:1px solid var(--hairline-2);border-radius:var(--r-md);background:linear-gradient(180deg,#1a21398c,#0a0d1880);box-shadow:var(--shadow-card);padding:16px 18px 14px;font-family:var(--mono);backdrop-filter:blur(8px) saturate(120%);-webkit-backdrop-filter:blur(8px) saturate(120%)}.lg-head{display:flex;align-items:center;justify-content:space-between;gap:10px;padding-bottom:12px;margin-bottom:12px;border-bottom:1px solid var(--hairline)}.lg-title{color:var(--text);font-size:var(--fs-eyebrow);letter-spacing:.18em;text-transform:uppercase}.lg-state{display:inline-flex;align-items:center;gap:7px;color:var(--accent);font-size:10px;letter-spacing:.16em;text-transform:uppercase}.lg-dot{width:6px;height:6px;border-radius:50%;background:var(--accent);box-shadow:0 0 8px var(--accent);animation:pulse 2.6s var(--ease-in-out) infinite}.lg-plot-wrap{position:relative}.lg-plot{display:block;width:100%;height:auto}.lg-grid line{stroke:var(--text);opacity:.07;vector-effect:non-scaling-stroke}.lg-line{stroke:var(--accent);stroke-width:2;stroke-linecap:round;stroke-linejoin:round;vector-effect:non-scaling-stroke;filter:drop-shadow(0 0 5px rgba(14,190,109,.5));stroke-dasharray:1;stroke-dashoffset:1;animation:lg-draw 2.2s var(--ease-out) .3s forwards}@keyframes lg-draw{to{stroke-dashoffset:0}}.lg-area{opacity:0;animation:lg-fade 1.1s ease-out 1.7s forwards}@keyframes lg-fade{to{opacity:1}}.lg-cursor{fill:var(--accent);opacity:0;animation:lg-fade .4s ease-out 2.3s forwards}.lg-cursor-ring{fill:none;stroke:var(--accent);stroke-width:1.5;vector-effect:non-scaling-stroke;transform-box:fill-box;transform-origin:center;opacity:0;animation:lg-ping 2.6s ease-out 2.6s infinite}@keyframes lg-ping{0%{opacity:.6;transform:scale(.7)}70%,to{opacity:0;transform:scale(2.4)}}.lg-readouts{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:4px 10px;margin:14px 0 0;padding:12px 0 0;border-top:1px solid var(--hairline)}.lg-readouts dt{font-size:9px;letter-spacing:.14em;text-transform:uppercase;color:var(--text-dim);margin-bottom:3px}.lg-readouts dd{margin:0;font-size:13.5px;color:var(--text);letter-spacing:.02em;font-variant-numeric:tabular-nums}.lg-readouts dd[data-tick=loss]{color:var(--accent)}.lg-foot{margin-top:12px;padding-top:9px;border-top:1px dashed var(--hairline);display:flex;flex-wrap:wrap;gap:7px;font-size:9.5px;color:var(--text-dim);letter-spacing:.08em}.lg-foot-sep{opacity:.5}.scroll-cue{position:relative;display:inline-flex;align-items:center;gap:12px;margin-top:clamp(40px,6vw,64px);padding:8px 4px;border:none;font-family:var(--mono);font-size:var(--fs-eyebrow);letter-spacing:.2em;text-transform:uppercase;color:var(--text-mute);width:max-content}.scroll-cue:hover{color:var(--text)}.scroll-cue .cue-arrow{display:inline-block;animation:cue-bob 2.2s var(--ease-in-out) infinite}@keyframes cue-bob{0%,to{transform:translateY(0);opacity:.7}50%{transform:translateY(4px);opacity:1}}.js .reveal{opacity:0;transform:translateY(18px);transition:opacity var(--dur-4) var(--ease-out),transform var(--dur-4) var(--ease-out);transition-delay:var(--reveal-delay, 0ms);will-change:opacity,transform}.js .reveal.is-visible{opacity:1;transform:none}@media(prefers-reduced-motion:reduce){.js .reveal{opacity:1;transform:none;transition:none}}.highlights{max-width:var(--maxw);margin:0 auto;padding:clamp(40px,6vw,72px) var(--gutter) var(--section-y)}.hl-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--sp-5);align-items:stretch}@media(max-width:900px){.hl-grid{grid-template-columns:1fr}}.hl-card{position:relative;display:flex;flex-direction:column;padding:var(--sp-6) var(--sp-6) var(--sp-5);background:linear-gradient(180deg,#1a213980,#0a0d1852);border:1px solid var(--hairline);border-radius:var(--r-md);box-shadow:var(--shadow-card);overflow:hidden;transition:border-color var(--dur-2) var(--ease),transform var(--dur-2) var(--ease),box-shadow var(--dur-2) var(--ease)}.hl-card:before{content:"";position:absolute;inset:0;pointer-events:none;background:radial-gradient(82% 60% at 100% 0%,var(--hl-accent, var(--accent)),transparent 70%);opacity:.06;transition:opacity var(--dur-2) var(--ease)}.hl-card:hover{transform:translateY(-3px);border-color:color-mix(in srgb,var(--hl-accent, var(--accent)) 45%,var(--hairline-2));box-shadow:var(--shadow-lg)}.hl-card:hover:before{opacity:.14}.hl-card>*{position:relative}.hl-1{--hl-accent: var(--accent)}.hl-2{--hl-accent: var(--hobby)}.hl-3{--hl-accent: var(--work)}.hl-head{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:10px;margin-bottom:var(--sp-5)}.hl-kicker{display:inline-flex;align-items:center;gap:8px;font-family:var(--mono);font-size:10.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--hl-accent, var(--text-mute))}.hl-kicker-dot{width:6px;height:6px;border-radius:50%;background:var(--hl-accent, var(--accent));box-shadow:0 0 8px var(--hl-accent, var(--accent));animation:pulse 2.6s var(--ease-in-out) infinite}.hl-meta{font-family:var(--mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--text-dim)}.hl-title{font-family:var(--serif);font-weight:380;font-style:italic;font-size:var(--fs-h3);line-height:1.05;margin:0 0 var(--sp-4);letter-spacing:-.02em;color:var(--text);font-variation-settings:"opsz" 60,"SOFT" 60}.hl-blurb{font-family:var(--serif);font-size:var(--fs-base);line-height:1.6;color:var(--text-mute);margin:0 0 var(--sp-5);font-variation-settings:"opsz" 24}.hl-blurb em{font-style:italic;color:var(--text)}.hl-tags{list-style:none;margin:0 0 var(--sp-5);padding:0;display:flex;flex-wrap:wrap;gap:6px}.hl-tags li{font-family:var(--mono);font-size:10px;letter-spacing:.06em;padding:4px 10px;border:1px solid var(--hairline-2);border-radius:var(--r-pill);color:var(--text-mute);background:#0a0d1866}.hl-foot{margin-top:auto;padding-top:var(--sp-4);border-top:1px solid var(--hairline)}.cta{display:inline-flex;align-items:center;gap:7px;font-family:var(--mono);font-size:12px;letter-spacing:.04em;color:var(--hl-accent, var(--accent));border:none;padding:2px 0;border-bottom:1px solid color-mix(in srgb,var(--hl-accent, var(--accent)) 38%,transparent);transition:border-color var(--dur-1) var(--ease),color var(--dur-1) var(--ease)}.cta:hover{color:var(--text);border-bottom-color:var(--text)}.hl-locked{display:inline-flex;align-items:center;gap:8px;font-family:var(--mono);font-size:11.5px;letter-spacing:.05em;color:var(--text-dim)}.hl-locked svg{width:13px;height:13px;opacity:.85}.stack{max-width:var(--maxw);margin:0 auto;padding:clamp(40px,6vw,72px) var(--gutter) clamp(28px,4vw,44px)}.stk-group.is-also{margin-top:clamp(30px,4vw,44px)}.stk-collapse>summary{cursor:pointer;list-style:none;user-select:none;margin:0;padding:13px 18px;border:1px solid var(--hairline-2);border-radius:var(--r-md);background:#1a21396b;color:var(--text);transition:color var(--dur-1) var(--ease),border-color var(--dur-1) var(--ease),background var(--dur-1) var(--ease)}.stk-collapse>summary::-webkit-details-marker{display:none}.stk-collapse>summary:hover{border-color:color-mix(in srgb,var(--accent) 45%,transparent);background:#1a21399e}.stk-collapse[open]>summary{margin-bottom:18px}.stk-toggle{display:inline-flex;align-items:center;gap:7px;margin-left:auto;font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:none;color:var(--accent)}.stk-toggle:after{content:"";width:7px;height:7px;flex-shrink:0;border-right:1.7px solid currentColor;border-bottom:1.7px solid currentColor;transform:rotate(45deg) translate(-1px,-1px);transition:transform var(--dur-1) var(--ease)}.stk-collapse[open] .stk-toggle:after{transform:rotate(225deg) translate(-1px,-1px)}.stk-less,.stk-collapse[open] .stk-more{display:none}.stk-collapse[open] .stk-less{display:inline}.stk-group-title{display:flex;align-items:center;gap:10px;margin:0 0 16px;font-family:var(--mono);font-size:12px;font-weight:500;letter-spacing:.18em;text-transform:uppercase;color:var(--text-mute)}.stk-group-title:before{content:"";width:7px;height:7px;border-radius:50%;flex-shrink:0}.stk-group.is-expert .stk-group-title:before{background:var(--accent);box-shadow:0 0 10px var(--accent)}.stk-group.is-also .stk-group-title:before{background:var(--text-dim)}.stack-grid{list-style:none;margin:0;padding:0;display:grid;grid-template-columns:repeat(auto-fill,minmax(96px,1fr));gap:clamp(10px,1.4vw,16px)}.stk-tile{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:11px;min-height:96px;padding:18px 10px;border:1px solid var(--hairline);border-radius:var(--r-md);background:#1a213952;color:var(--brand, var(--accent));transition:color var(--dur-1) var(--ease),border-color var(--dur-1) var(--ease),background var(--dur-1) var(--ease),transform var(--dur-1) var(--ease)}.stk-tile:hover{color:var(--brand, var(--accent));border-color:color-mix(in srgb,var(--brand, var(--accent)) 55%,transparent);background:#1a213999;transform:translateY(-3px)}.stk-mark{display:flex;align-items:center;justify-content:center;height:34px}.stk-mark svg{width:34px;height:34px;display:block}.stk-token{font-family:var(--mono);font-weight:600;font-size:23px;line-height:1;letter-spacing:-.01em;text-align:center}.stk-token.is-long{font-size:13.5px;line-height:1.2;letter-spacing:.01em}.stk-text:hover{color:var(--accent);border-color:color-mix(in srgb,var(--accent) 55%,transparent)}.stk-label{font-family:var(--mono);font-size:11px;letter-spacing:.04em;color:var(--text-dim);text-align:center;transition:color var(--dur-1) var(--ease)}.stk-tile:hover .stk-label{color:var(--text-mute)}.stack-grid.is-expert{grid-template-columns:repeat(auto-fill,minmax(108px,1fr))}.stack-grid.is-expert .stk-tile{min-height:110px}.stack-grid.is-expert .stk-mark{height:40px}.stack-grid.is-expert .stk-mark svg{width:40px;height:40px}.stack-grid.is-expert .stk-token{font-size:26px}.stack-grid.is-expert .stk-token.is-long{font-size:15px}.explore-head{margin-bottom:clamp(28px,4vw,44px)}.explore-head .eyebrow{display:block;margin-bottom:14px}.explore-title{font-family:var(--serif);font-weight:380;font-style:italic;font-size:clamp(30px,4vw,46px);line-height:1;margin:0 0 10px;letter-spacing:-.02em;font-variation-settings:"opsz" 72,"SOFT" 50}.explore-sub{font-family:var(--mono);font-size:12.5px;color:var(--text-mute);margin:0;letter-spacing:.04em}.explore{max-width:var(--maxw);margin:0 auto;padding:clamp(40px,6vw,72px) var(--gutter) var(--section-y)}.ex-cats{display:flex;flex-direction:column;gap:clamp(40px,6vw,72px)}.ex-cat{--ex-accent: var(--accent);--hl-accent: var(--accent);--mp-accent: var(--accent)}.ex-game{--ex-accent: var(--school);--hl-accent: var(--school);--mp-accent: var(--school)}.ex-hardware{--ex-accent: var(--work);--hl-accent: var(--work);--mp-accent: var(--work)}.ex-cat-title{display:flex;align-items:center;gap:12px;font-family:var(--mono);font-size:13px;letter-spacing:.2em;text-transform:uppercase;color:var(--text);margin:0 0 var(--sp-5);padding-bottom:14px;border-bottom:1px solid var(--hairline)}.ex-cat-dot{width:9px;height:9px;border-radius:2px;background:var(--ex-accent);box-shadow:0 0 10px var(--ex-accent);flex-shrink:0}.ex-featured{display:grid;grid-template-columns:1fr 1fr;gap:var(--sp-4);margin-bottom:var(--sp-4)}@media(max-width:720px){.ex-featured{grid-template-columns:1fr}}.ex-card{display:flex;flex-direction:column;padding:var(--sp-5);border:1px solid var(--hairline);border-left:2px solid var(--ex-accent);border-radius:var(--r-sm);background:linear-gradient(180deg,#1a213980,#0a0d184d);transition:border-color var(--dur-2) var(--ease),transform var(--dur-2) var(--ease)}.ex-card:hover{transform:translateY(-2px);border-color:color-mix(in srgb,var(--ex-accent) 45%,var(--hairline-2));border-left-color:var(--ex-accent)}.ex-card-title{font-family:var(--serif);font-style:italic;font-weight:400;font-size:20px;margin:0 0 8px;color:var(--text);font-variation-settings:"opsz" 40}.ex-card-desc{font-family:var(--serif);font-size:15px;line-height:1.5;color:var(--text-mute);margin:0 0 var(--sp-4);font-variation-settings:"opsz" 20}.ex-card .cta{margin-top:auto;align-self:flex-start}.ex-more{border:1px solid var(--hairline);border-radius:var(--r-sm);background:#ffffff04;overflow:hidden}.ex-more summary{display:flex;align-items:center;gap:12px;padding:13px 18px;cursor:pointer;list-style:none;transition:background var(--dur-1) var(--ease)}.ex-more summary::-webkit-details-marker{display:none}.ex-more summary::marker{content:""}.ex-more summary:hover{background:#ffffff08}.mp-summary-label{font-family:var(--mono);font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--text-mute)}.mp-count{font-family:var(--mono);font-size:11px;color:var(--text-dim);letter-spacing:.04em}.mp-chev{margin-left:auto;width:8px;height:8px;border-right:1.5px solid var(--text-mute);border-bottom:1.5px solid var(--text-mute);transform:rotate(45deg);transition:transform var(--dur-2) var(--ease)}.ex-more[open] .mp-chev{transform:rotate(-135deg)}.mp-list{list-style:none;margin:0;padding:6px 18px 16px;display:grid;grid-template-columns:repeat(auto-fill,minmax(190px,1fr));gap:2px 18px;border-top:1px solid var(--hairline)}.mp-list a{display:block;padding:8px 0;border:none;font-family:var(--mono);font-size:13px;color:var(--text-mute);transition:color var(--dur-1) var(--ease),padding-left var(--dur-1) var(--ease)}.mp-list a:hover{color:var(--mp-accent);padding-left:6px}@media(max-width:560px){.ex-card{padding:var(--sp-4)}.mp-list{grid-template-columns:1fr}}.offcuts{max-width:var(--maxw);margin:0 auto;padding:clamp(36px,5vw,64px) var(--gutter)}.offcuts-inner{max-width:var(--maxw-text);margin-left:auto;margin-right:auto;padding:clamp(28px,4vw,44px) clamp(24px,4vw,40px);border:1px solid var(--hairline);border-left:2px solid var(--hobby);background:linear-gradient(180deg,#1a213966,#0a0d182e);border-radius:var(--r-md)}.offcuts-lede{font-family:var(--serif);font-size:clamp(18px,1.9vw,23px);line-height:1.55;color:var(--text);margin:0 0 18px;font-variation-settings:"opsz" 48}.offcuts-lede em{font-style:italic;color:var(--hobby)}.offcuts-body{font-size:15.5px;line-height:1.75;color:var(--text-mute);margin:0 0 24px;max-width:64ch}.offcuts-tags{list-style:none;margin:0;padding:18px 0 0;display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:6px 24px;border-top:1px solid var(--hairline)}.offcuts-tags li{font-family:var(--mono);font-size:12px;letter-spacing:.04em;color:var(--text-mute);display:flex;align-items:baseline;gap:10px}.offcuts-tags .oc-dash{color:var(--hobby);font-weight:500}.section-head{display:flex;flex-wrap:wrap;align-items:baseline;gap:18px;margin-bottom:clamp(40px,6vw,72px);padding-bottom:var(--sp-5);border-bottom:1px solid var(--hairline)}.section-num{font-family:var(--mono);font-size:12px;letter-spacing:.2em;color:var(--accent)}.section-title{font-family:var(--serif);font-weight:380;font-style:italic;font-size:var(--fs-h2);line-height:.98;margin:0;letter-spacing:-.02em;font-variation-settings:"opsz" 90,"SOFT" 50}.section-sub{font-family:var(--mono);font-size:12px;color:var(--text-mute);margin:0 0 0 auto;letter-spacing:.05em}.notes{max-width:var(--maxw);margin:0 auto;padding:var(--section-y) var(--gutter)}.notes-grid{display:grid;grid-template-columns:minmax(0,1.4fr) minmax(0,1fr);gap:clamp(40px,6vw,80px);align-items:start}@media(max-width:920px){.notes-grid{grid-template-columns:1fr}}.portrait-inline{float:right;margin:4px 0 14px 28px;max-width:200px;width:38%;min-width:140px;display:flex;flex-direction:column;gap:10px}.portrait-inline picture{display:block}.portrait-inline img{display:block;width:100%;height:auto;aspect-ratio:1 / 1;object-fit:cover;background:var(--surface);border:1px solid var(--hairline-2);border-radius:var(--r-sm);filter:grayscale(.18) contrast(1.02)}.portrait-inline figcaption{font-family:var(--mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--text-dim)}@media(max-width:560px){.portrait-inline{float:none;margin:0 0 24px;width:160px}}.notes-text p{font-size:var(--fs-base);line-height:1.78;margin:0 0 22px;color:var(--text-mute);max-width:64ch}.notes-text p.lede{font-family:var(--serif);font-size:clamp(20px,1.9vw,25px);line-height:1.5;color:var(--text);font-variation-settings:"opsz" 40}.notes-text strong{color:var(--text);font-weight:500;border-bottom:1px solid var(--accent-line);padding-bottom:1px}.notes-text a{color:var(--text);border-bottom-color:var(--accent-line)}.notes-text a:hover{color:var(--accent);border-bottom-color:var(--accent)}.notes-side{display:flex;flex-direction:column;gap:var(--sp-7);position:relative}.notes-side:before{content:"";position:absolute;left:calc(-1*clamp(20px,3vw,40px));top:0;bottom:0;width:1px;background:var(--hairline)}@media(max-width:920px){.notes-side:before{display:none}}.stack-diagram{margin:0;display:flex;flex-direction:column}.stack-node{display:flex;align-items:center;gap:14px;padding:13px 16px;background:linear-gradient(180deg,#1a213980,#0a0d1847);border:1px solid var(--hairline);border-left:2px solid var(--stack-accent, var(--accent));border-radius:var(--r-sm);transition:border-color var(--dur-2) var(--ease),transform var(--dur-2) var(--ease)}.stack-node:hover{transform:translate(2px);border-color:color-mix(in srgb,var(--stack-accent, var(--accent)) 40%,var(--hairline-2))}.stack-idx{font-family:var(--mono);font-size:11px;letter-spacing:.08em;color:var(--stack-accent, var(--accent));font-variant-numeric:tabular-nums;flex-shrink:0}.stack-body{display:flex;flex-direction:column;gap:3px;min-width:0}.stack-name{font-family:var(--serif);font-style:italic;font-size:18px;color:var(--text);font-variation-settings:"opsz" 36}.stack-tag{font-family:var(--mono);font-style:normal;font-size:10.5px;letter-spacing:.06em;color:var(--text-dim);margin-left:8px}.stack-items{font-family:var(--mono);font-size:11px;letter-spacing:.02em;color:var(--text-mute)}.stack-flow{position:relative;display:flex;align-items:center;min-height:26px;padding-left:26px}.stack-flow:before{content:"";position:absolute;left:17px;top:0;bottom:0;width:1px;background:var(--hairline-2)}.stack-flow-label{font-family:var(--mono);font-size:9.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--text-dim)}.stack-flow-label:before{content:"↓";margin-right:7px;opacity:.7}.stack-hardware{--stack-accent: var(--work)}.stack-data{--stack-accent: var(--hobby)}.stack-models{--stack-accent: var(--accent)}.stack-product{--stack-accent: var(--school)}.facts{margin:0;display:grid;grid-template-columns:1fr 1fr;gap:20px 20px}.facts>div{border-top:1px solid var(--hairline);padding-top:12px}.facts dt{font-family:var(--mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--text-dim);margin-bottom:7px}.facts dd{margin:0;font-family:var(--serif);font-size:22px;line-height:1.15;color:var(--text);font-variation-settings:"opsz" 36}.timeline-section{max-width:var(--maxw);margin:0 auto;padding:var(--section-y) var(--gutter)}.timeline-controls{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:16px;margin-bottom:32px}.filters{display:flex;flex-wrap:wrap;gap:8px}.filter-chip{display:inline-flex;align-items:center;gap:8px;padding:8px 15px;background:#ffffff05;border:1px solid var(--hairline-2);border-radius:var(--r-pill);color:var(--text-mute);font-family:var(--mono);font-size:12px;letter-spacing:.04em;cursor:pointer;transition:color var(--dur-1) var(--ease),border-color var(--dur-1) var(--ease),background var(--dur-1) var(--ease)}.filter-chip:hover{color:var(--text);border-color:var(--hairline-3);background:#ffffff0b}.filter-chip.is-active{background:var(--text);color:var(--bg-deep);border-color:var(--text)}.chip-swatch{width:8px;height:8px;border-radius:2px;background:var(--text-mute)}.chip-swatch.all{background:linear-gradient(135deg,var(--work) 0%,var(--school) 50%,var(--hobby) 100%)}.chip-swatch.work{background:var(--work)}.chip-swatch.school{background:var(--school)}.chip-swatch.hobby{background:var(--hobby)}.chip-swatch.type{background:transparent;border:1px solid var(--text-mute)}.chip-swatch.project{background:var(--text);border:1px solid var(--bg)}.filter-sep{display:inline-block;width:1px;height:18px;background:var(--hairline);margin:0 4px;align-self:center}.timeline-hint{font-family:var(--mono);font-size:11px;letter-spacing:.06em;color:var(--text-dim);margin:0}.timeline-loading{display:flex;align-items:center;justify-content:center;gap:12px;padding:80px 20px;color:var(--text-mute);font-family:var(--mono);font-size:13px}.timeline-loading.hidden{display:none}.timeline-loading span{width:6px;height:6px;border-radius:50%;background:var(--text-mute);animation:blink 1.2s ease-in-out infinite}.timeline-loading span:nth-child(2){animation-delay:.2s}.timeline-loading span:nth-child(3){animation-delay:.4s}@keyframes blink{0%,80%,to{opacity:.2}40%{opacity:1}}.swimlane{position:relative;border-top:1px solid var(--hairline);border-bottom:1px solid var(--hairline);margin:0 calc(var(--gutter) * -.5);padding:0 calc(var(--gutter) * .5)}.swimlane.hidden{display:none}.swimlane-scroll{overflow-x:auto;overflow-y:visible;scrollbar-width:thin;scrollbar-color:var(--text-dim) transparent;padding-bottom:12px}.swimlane-scroll::-webkit-scrollbar{height:8px}.swimlane-scroll::-webkit-scrollbar-thumb{background:var(--text-dim);border-radius:100px}.swimlane-inner{position:relative;min-width:100%}.year-axis{display:grid;position:relative;height:36px;border-bottom:1px solid var(--hairline)}.year-tick{display:flex;align-items:center;padding-left:8px;font-family:var(--mono);font-size:11px;letter-spacing:.1em;color:var(--text-mute);border-left:1px solid var(--hairline)}.year-tick:first-child{border-left:none}.year-tick.current{color:var(--hobby)}.lane{position:relative;display:block;min-height:360px}.lane.unified{padding-top:8px}.year-guides{position:absolute;inset:0;display:grid;pointer-events:none}.year-guide{border-left:1px solid var(--hairline)}.year-guide:first-child{border-left:none}.entry{position:absolute;z-index:1;cursor:pointer;font-family:var(--mono);font-size:calc(10px + var(--importance, .4) * 3px);letter-spacing:.02em;border:none;background:transparent;padding:0;text-align:left;color:var(--text);opacity:calc(.55 + var(--importance, .4) * .45);transition:transform .2s,opacity .2s,filter .2s;z-index:calc(1 + var(--importance, .4) * 10)}.entry:focus-visible{outline:2px solid var(--text);outline-offset:3px;border-radius:4px}.entry.point{display:flex;align-items:center;gap:8px;height:calc(22px + var(--importance, .4) * 14px)}.entry.point .marker{width:calc(6px + var(--importance, .4) * 12px);height:calc(6px + var(--importance, .4) * 12px);border-radius:50%;flex-shrink:0;box-shadow:0 0 0 3px var(--bg),0 0 0 4px var(--cat-color);background:var(--bg);position:relative;z-index:2}.entry.point.is-clickable .marker{background:var(--cat-color)}.entry.point:not(.is-clickable){cursor:default}.entry.range:not(.is-clickable){cursor:default}.entry.range:not(.is-clickable) .bar{background:transparent;border:1px dashed var(--cat-color);color:var(--cat-color)}.entry.point .label{white-space:nowrap;padding:2px 8px;background:var(--surface);border:1px solid var(--hairline-2);border-radius:3px;max-width:220px;overflow:hidden;text-overflow:ellipsis;transition:opacity .2s,background .2s,color .2s,border-color .2s;position:relative;z-index:0}.entry.point.label-hidden .label{opacity:0;pointer-events:none}.entry.point.label-hidden:hover .label,.entry.point.label-hidden:focus-visible .label{opacity:1}.entry.range{height:calc(20px + var(--importance, .4) * 18px);display:flex;align-items:stretch}.entry.range .bar{position:relative;flex:1;background:linear-gradient(90deg,var(--cat-color),color-mix(in srgb,var(--cat-color) 60%,transparent));border-radius:3px;padding:6px 10px;color:var(--bg);font-weight:500;overflow:hidden;white-space:nowrap;text-overflow:ellipsis;display:flex;align-items:center;gap:8px}.entry.range.is-clickable .bar{background:linear-gradient(90deg,var(--cat-color),color-mix(in srgb,var(--cat-color) 60%,transparent))}.entry.range .ongoing-arrow{position:absolute;right:-4px;top:50%;transform:translateY(-50%);width:0;height:0;border-top:6px solid transparent;border-bottom:6px solid transparent;border-left:8px solid var(--cat-color)}.entry:hover{transform:translateY(-1px);z-index:99}.entry:hover .label,.entry:hover .bar{background:var(--text);color:var(--bg);border-color:var(--text);max-width:400px;opacity:1}.entry .status-dot{width:5px;height:5px;border-radius:50%;flex-shrink:0}.entry .status-dot.nda{background:var(--nda)}.entry .status-dot.lost{background:var(--lost)}.entry .status-dot.ongoing{background:var(--ongoing)}.entry.is-faded{opacity:.12;filter:saturate(.3);pointer-events:none}.tooltip{position:fixed;z-index:100;width:320px;padding:18px 20px;background:var(--surface);border:1px solid var(--hairline-2);border-radius:6px;box-shadow:var(--shadow-card);font-family:var(--sans);font-size:13px;line-height:1.5;color:var(--text);pointer-events:none;opacity:0;transform:translateY(4px);transition:opacity .15s,transform .15s}.tooltip.is-visible{opacity:1;transform:translateY(0)}.tooltip .tt-cat{display:inline-flex;align-items:center;gap:6px;font-family:var(--mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--text-mute);margin-bottom:8px}.tooltip .tt-cat-swatch{width:8px;height:8px;border-radius:2px}.tooltip .tt-title{font-family:var(--serif);font-style:italic;font-size:18px;line-height:1.25;margin:0 0 6px;color:var(--text);font-variation-settings:"opsz" 36}.tooltip .tt-date{font-family:var(--mono);font-size:11px;color:var(--text-dim);margin-bottom:12px}.tooltip .tt-desc{margin:0 0 12px;color:var(--text)}.tooltip .tt-status{display:inline-block;font-family:var(--mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;padding:3px 8px;border-radius:2px;margin-right:6px}.tooltip .tt-status.nda{background:#ff8a8a1f;color:var(--nda)}.tooltip .tt-status.lost{background:#8a8fa31f;color:var(--lost)}.tooltip .tt-status.ongoing{background:#f5b95c1f;color:var(--ongoing)}.tooltip .tt-tags{display:flex;flex-wrap:wrap;gap:4px;margin-top:10px}.tooltip .tt-tag{font-family:var(--mono);font-size:10px;padding:2px 6px;border:1px solid var(--hairline-2);border-radius:2px;color:var(--text-mute)}.tooltip .tt-cta{margin-top:12px;font-family:var(--mono);font-size:11px;color:var(--text-mute);border-top:1px solid var(--hairline);padding-top:10px}.sheet-backdrop{position:fixed;inset:0;background:#06081099;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);opacity:0;pointer-events:none;transition:opacity .2s;z-index:110}.sheet-backdrop.is-visible{opacity:1;pointer-events:auto}.tooltip.is-sheet{position:fixed;inset:auto 0 0;width:auto;max-width:560px;margin:0 auto;max-height:80vh;overflow-y:auto;padding:24px 22px calc(22px + env(safe-area-inset-bottom,0px));border-radius:16px 16px 0 0;pointer-events:auto;transform:translateY(100%);transition:transform .25s ease,opacity .2s;z-index:120}.tooltip.is-sheet.is-visible{transform:translateY(0);opacity:1}.tooltip.is-sheet:before{content:"";position:absolute;top:9px;left:50%;transform:translate(-50%);width:38px;height:4px;border-radius:100px;background:var(--hairline-2)}.tooltip.is-sheet .tt-title{font-size:22px}.tooltip.is-sheet a.tt-cta{display:block;margin-top:18px;padding:13px 16px;border:1px solid var(--hairline-2);border-radius:8px;background:var(--surface-2);color:var(--text);text-align:center;text-decoration:none;letter-spacing:.02em}.tooltip.is-sheet a.tt-cta:active{background:var(--surface)}.tt-status-note{display:block;margin-top:8px;font-size:11px;color:var(--text-mute)}.seo-fallback{display:none;margin:8px 0 0}.no-js .seo-fallback{display:block}.no-js #timeline{display:none}.seo-fallback h2{font-family:var(--serif);font-style:italic;font-size:clamp(22px,4vw,30px);font-variation-settings:"opsz" 40;margin:0 0 20px}.seo-fallback ol{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:14px}.seo-fallback li{line-height:1.55;color:var(--text-mute);border-bottom:1px solid var(--hairline);padding-bottom:14px}.seo-fallback li:last-child{border-bottom:none}.seo-fallback li a,.seo-fallback li strong{color:var(--text);font-weight:600}.seo-fallback time{font-family:var(--mono);font-size:12px;color:var(--text-dim)}.seo-fallback small{display:block;margin-top:4px;font-size:12px;color:var(--text-dim)}.bench{max-width:var(--maxw);margin:0 auto;padding:var(--section-y) var(--gutter)}.signal-chain{list-style:none;margin:0;padding:0;display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:16px;counter-reset:stage;position:relative}@media(max-width:1080px){.signal-chain{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:560px){.signal-chain{grid-template-columns:1fr}}.stage{position:relative;padding:var(--sp-5);background:linear-gradient(180deg,#1a213973,#0a0d1847);border:1px solid var(--hairline);border-radius:var(--r-md);transition:border-color var(--dur-2) var(--ease),transform var(--dur-2) var(--ease),box-shadow var(--dur-2) var(--ease)}.stage:hover{border-color:var(--hairline-2);transform:translateY(-3px);box-shadow:var(--shadow-card)}.stage+.stage:before{content:"→";position:absolute;left:-14px;top:32px;font-family:var(--mono);font-size:14px;color:var(--text-dim);pointer-events:none}@media(max-width:1080px){.stage+.stage:before{display:none}}.stage-head{margin-bottom:16px;padding-bottom:12px;border-bottom:1px dashed var(--hairline)}.stage-num{display:inline-block;font-family:var(--mono);font-size:10px;letter-spacing:.2em;color:var(--text-dim);margin-bottom:8px}.stage-name{margin:0 0 6px;font-family:var(--serif);font-style:italic;font-weight:400;font-size:26px;line-height:1;color:var(--text);font-variation-settings:"opsz" 48,"SOFT" 60}.stage-blurb{margin:0;font-family:var(--mono);font-size:11px;letter-spacing:.04em;color:var(--text-mute);line-height:1.5}.stage-list{margin:0;padding:0;list-style:none;display:flex;flex-direction:column;gap:7px}.stage-list li{font-family:var(--mono);font-size:12.5px;color:var(--text-mute);position:relative;padding-left:14px;line-height:1.5}.stage-list li:before{content:"·";position:absolute;left:2px;top:-2px;color:var(--text-dim);font-size:18px;line-height:1}.stage-list li strong{color:var(--text);font-weight:500}.bench-foot{margin:32px 0 0;padding-top:20px;border-top:1px solid var(--hairline);display:flex;flex-wrap:wrap;align-items:center;gap:10px;font-family:var(--mono);font-size:11px}.foot-label{color:var(--text-dim);letter-spacing:.14em;text-transform:uppercase;margin-right:6px}.foot-tag{padding:4px 10px;border:1px solid var(--hairline-2);border-radius:100px;color:var(--text);letter-spacing:.04em}.contact{max-width:var(--maxw);margin:0 auto;padding:var(--section-y) var(--gutter)}.contact-body{max-width:var(--maxw-text)}.contact-lede{font-family:var(--serif);font-size:clamp(22px,2.6vw,32px);line-height:1.45;margin:0 0 var(--sp-7);color:var(--text);font-variation-settings:"opsz" 72;max-width:52ch}.contact-links{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:4px;border-top:1px solid var(--hairline)}.contact-links li{display:grid;grid-template-columns:60px 1fr;align-items:baseline;gap:16px;padding:15px 0;border-bottom:1px solid var(--hairline);font-family:var(--mono);font-size:14px;transition:padding-left var(--dur-1) var(--ease),border-color var(--dur-1) var(--ease)}.contact-links li:hover{padding-left:8px;border-bottom-color:var(--hairline-2)}.contact-links .ck{color:var(--text-dim);font-size:10px;letter-spacing:.18em;text-transform:uppercase}.contact-links a{color:var(--text);border-bottom-color:transparent;transition:color var(--dur-1) var(--ease),border-color var(--dur-1) var(--ease)}.contact-links a:hover{color:var(--accent);border-bottom-color:var(--accent)}.contact-links a[target=_blank]:after{content:"↗";margin-left:8px;color:var(--text-dim);transition:color var(--dur-1) var(--ease)}.contact-links a[target=_blank]:hover:after{color:var(--accent)}.site-footer{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:12px;max-width:var(--maxw);margin:0 auto;padding:var(--sp-8) var(--gutter);border-top:1px solid var(--hairline);font-family:var(--mono);font-size:11px;letter-spacing:.06em;color:var(--text-dim)}.project-page{max-width:820px;margin:0 auto;padding:clamp(40px,6vw,80px) var(--gutter) 80px}.project-back{display:inline-flex;align-items:center;gap:8px;font-family:var(--mono);font-size:12px;letter-spacing:.04em;color:var(--text-mute);border:none;margin-bottom:48px}.project-back:hover{color:var(--text)}.project-back:before{content:"←"}.project-meta-row{display:flex;flex-wrap:wrap;align-items:center;gap:12px;margin-bottom:24px;font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--text-mute)}.project-meta-row .cat-tag{display:inline-flex;align-items:center;gap:6px}.project-meta-row .cat-swatch{width:8px;height:8px;border-radius:2px}.project-meta-row .cat-swatch.work{background:var(--work)}.project-meta-row .cat-swatch.school{background:var(--school)}.project-meta-row .cat-swatch.hobby{background:var(--hobby)}.project-meta-row .sep{width:4px;height:4px;border-radius:50%;background:var(--text-dim)}.project-meta-row .status-tag{padding:3px 8px;border-radius:2px}.project-meta-row .status-tag.nda{background:#ff8a8a1f;color:var(--nda)}.project-meta-row .status-tag.lost{background:#8a8fa31f;color:var(--lost)}.project-meta-row .status-tag.ongoing{background:#f5b95c1f;color:var(--ongoing)}.project-title{font-family:var(--serif);font-weight:350;font-size:clamp(40px,6vw,64px);line-height:1.05;letter-spacing:-.025em;margin:0 0 16px;font-variation-settings:"opsz" 100,"SOFT" 30}.project-title em{font-style:italic;color:var(--accent);font-variation-settings:"opsz" 100,"SOFT" 100}.project-lede{font-family:var(--serif);font-size:clamp(18px,2vw,22px);line-height:1.55;color:var(--text);margin:0 0 56px;padding-bottom:32px;border-bottom:1px solid var(--hairline);font-variation-settings:"opsz" 36}.project-section{margin:0 0 48px}.project-section h2{font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--text-mute);margin:0 0 16px}.project-section h3{font-family:var(--serif);font-style:italic;font-weight:400;font-size:24px;margin:24px 0 12px;font-variation-settings:"opsz" 48}.project-section p{font-size:16px;line-height:1.75;margin:0 0 18px;color:var(--text)}.project-section em{font-style:italic;color:var(--text)}.project-section strong{color:var(--text)}.project-section ul{padding-left:22px;margin:0 0 18px}.project-section li{font-size:16px;line-height:1.7;margin-bottom:6px}.project-section li::marker{color:var(--text-dim)}.project-section blockquote{margin:24px 0;padding:18px 22px;border-left:2px solid var(--accent);background:var(--surface);font-family:var(--serif);font-style:italic;font-size:17px;color:var(--text);font-variation-settings:"opsz" 36}.project-section code{font-family:var(--mono);font-size:.86em;padding:.12em .42em;background:var(--surface-2);border:1px solid var(--hairline);border-radius:var(--r-sm);color:var(--text)}.project-section pre{margin:18px 0;padding:16px 18px;background:var(--surface);border:1px solid var(--hairline);border-radius:var(--r-md);overflow-x:auto}.project-section pre code{padding:0;background:none;border:0;font-size:13.5px;white-space:pre}.table-wrap{overflow-x:auto;margin:18px 0}.project-section table{border-collapse:collapse;width:100%;font-family:var(--mono);font-size:13px}.project-section th{text-align:left;font-weight:500;font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--text-mute);border-bottom:1px solid var(--hairline-2);padding:8px 12px;white-space:nowrap}.project-section td{padding:7px 12px;border-bottom:1px solid var(--hairline);color:var(--text);font-variant-numeric:tabular-nums}.project-section tbody tr:last-child td{border-bottom:0}.project-links{display:flex;flex-direction:column;gap:10px;margin-top:24px}.project-links a{display:inline-flex;align-items:center;justify-content:space-between;padding:14px 18px;background:var(--surface);border:1px solid var(--hairline);border-radius:4px;font-family:var(--mono);font-size:13px;color:var(--text);transition:border-color .2s,background .2s,transform .2s}.project-links a:hover{border-color:var(--hairline-2);background:var(--surface-2);transform:translate(2px)}.project-links a:after{content:"↗";color:var(--text-mute)}.video-embed{position:relative;display:block;width:100%;margin:18px 0 8px;background:var(--surface);border:1px solid var(--hairline);border-radius:6px;overflow:hidden}.video-embed.aspect-16-9{aspect-ratio:16 / 9}.video-embed.aspect-9-16{aspect-ratio:9 / 16;max-width:380px}.video-embed iframe{position:absolute;inset:0;width:100%;height:100%;border:0}.video-caption{font-family:var(--mono);font-size:11px;letter-spacing:.08em;color:var(--text-mute);margin:4px 0 22px}.video-stack{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:18px;margin:18px 0}.video-stack .video-embed{margin:0}.project-figure{margin:22px 0 8px;background:var(--surface);border:1px solid var(--hairline);border-radius:6px;overflow:hidden}.project-figure img{display:block;width:100%;height:auto;background:#fff}.project-figure figcaption{font-family:var(--mono);font-size:11px;letter-spacing:.08em;color:var(--text-mute);padding:10px 14px;border-top:1px solid var(--hairline)}.project-figure.narrow{max-width:480px}.project-figure.wide{max-width:100%}.figure-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:16px;margin:22px 0}.figure-row .project-figure{margin:0}.project-disclosure{padding:18px 22px;background:#ff8a8a0d;border-left:2px solid var(--nda);margin:24px 0;font-size:14px;color:var(--text-mute);border-radius:0 4px 4px 0}.project-disclosure strong{color:var(--nda)}@media(max-width:900px){.hero-inner{gap:36px}.hero{padding-top:clamp(40px,8vw,80px);padding-bottom:clamp(48px,8vw,96px)}}@media(max-width:760px){:root{--gutter: 18px}.site-nav{padding:12px 16px}.brand{font-size:12px}.brand-mark{width:26px;height:26px;font-size:12px}.nav-links{gap:14px;font-size:11.5px}.hero{padding:56px 18px 80px}.hero-tag{margin-bottom:32px;font-size:10px;letter-spacing:.14em}.hero-title{font-size:clamp(56px,16vw,92px);margin-bottom:28px}.hero-sub{font-size:18px;line-height:1.45;margin-bottom:32px}.hero-build{font-size:20px;line-height:1.4;margin-bottom:88px;display:block;min-height:2.8em}.hero-build .build-type{display:inline}.hero-build .typewriter-text{white-space:normal}.status-block{padding-top:18px;gap:8px}.status-row{grid-template-columns:56px 1fr;gap:14px;font-size:12px}.status-row dt{font-size:9.5px;letter-spacing:.14em}.scroll-cue{display:none}.section-head{gap:12px;margin-bottom:36px;padding-bottom:18px}.section-head .section-sub{margin:0;flex-basis:100%;font-size:11px}.section-title{font-size:38px}.highlights{padding:32px 18px 64px}.hl-card{padding:24px 22px 20px}.hl-blurb{font-size:15.5px}.hl-tags li{font-size:9.5px;padding:3px 8px}.timeline-section{padding:56px 18px 64px}.timeline-controls{flex-direction:column;align-items:stretch;gap:12px;margin-bottom:20px;min-width:0}.filters{flex-wrap:nowrap;overflow-x:auto;overflow-y:hidden;padding-bottom:6px;margin:0 -18px;padding-left:18px;padding-right:18px;scrollbar-width:none;-webkit-overflow-scrolling:touch;min-width:0;max-width:100vw}.filters::-webkit-scrollbar{display:none}.filter-chip{flex-shrink:0;padding:7px 12px;font-size:11.5px}.filter-sep{display:none}.timeline-hint{font-size:10.5px;line-height:1.5}.vyear-label{font-size:9.5px}.offcuts{padding:16px 18px 36px}.offcuts-inner{padding:22px 18px}.offcuts-lede{font-size:17px}.offcuts-body{font-size:14px;line-height:1.65}.offcuts-tags{grid-template-columns:1fr;gap:4px}.notes{padding:48px 18px}.notes-grid{gap:32px}.portrait-inline{float:none;margin:0 auto 20px;width:150px;align-items:center}.portrait-inline figcaption{text-align:center}.notes-text p{font-size:15.5px;line-height:1.7}.notes-text p.lede{font-size:19px}.stack-name{font-size:17px}.facts{grid-template-columns:1fr 1fr;gap:16px}.facts dd{font-size:19px}.bench{padding:56px 18px 64px}.signal-chain{gap:12px}.stage{padding:18px 18px 20px}.stage-name{font-size:22px}.stage-list li{font-size:12px}.bench-foot{margin-top:24px;padding-top:16px;gap:8px}.foot-tag{padding:3px 8px}.contact{padding:56px 18px 72px}.contact-lede{font-size:19px;line-height:1.4;margin-bottom:24px}.contact-links li{grid-template-columns:44px 1fr;gap:12px;padding:12px 0;font-size:13px;overflow-wrap:anywhere}.contact-links a{word-break:break-all}.site-footer{flex-direction:column;gap:8px;padding:28px 18px 36px;font-size:10.5px}}@media(max-width:380px){.hero-title{font-size:clamp(48px,16vw,68px)}.hero-sub{font-size:16.5px}.hero-build{font-size:18px}.section-title{font-size:32px}.nav-links{gap:10px;font-size:11px}.hl-title{font-size:26px}.stage-name{font-size:20px}}.frame-anim{margin:18px 0 8px}.frame-anim-stage{position:relative;background:#ebe6da;border:1px solid var(--hairline);border-radius:6px;overflow:hidden;aspect-ratio:4 / 5;max-width:460px;margin:0 auto}.frame-anim-img{position:absolute;inset:0;width:100%;height:100%;object-fit:contain;opacity:0;transition:opacity .35s ease;user-select:none;-webkit-user-drag:none}.frame-anim.is-ready .frame-anim-img{opacity:1}.frame-anim-loader{position:absolute;inset:0;display:grid;place-items:center;font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:#5d6378;pointer-events:none}.frame-anim.is-ready .frame-anim-loader{display:none}.frame-anim-controls{display:flex;align-items:center;gap:14px;max-width:460px;margin:14px auto 0;font-family:var(--mono);font-size:11px;letter-spacing:.08em;color:var(--text-mute)}.frame-anim-toggle{width:30px;height:30px;border-radius:50%;border:1px solid var(--hairline-2);background:var(--surface);color:var(--text);display:grid;place-items:center;cursor:pointer;flex-shrink:0;transition:border-color .2s,background .2s,color .2s;padding:0}.frame-anim-toggle:hover{border-color:var(--text);background:var(--surface-2);color:var(--hobby)}.frame-anim-toggle .icon{display:block;position:relative;width:10px;height:10px}.frame-anim-toggle[data-state=playing] .icon:before,.frame-anim-toggle[data-state=playing] .icon:after{content:"";position:absolute;top:0;bottom:0;width:3px;background:currentColor;border-radius:1px}.frame-anim-toggle[data-state=playing] .icon:before{left:1px}.frame-anim-toggle[data-state=playing] .icon:after{right:1px}.frame-anim-toggle[data-state=paused] .icon:before{content:"";position:absolute;left:1px;top:50%;transform:translateY(-50%);width:0;height:0;border-left:9px solid currentColor;border-top:5px solid transparent;border-bottom:5px solid transparent}.frame-anim-scrub{flex:1;appearance:none;-webkit-appearance:none;background:transparent;height:18px;cursor:pointer}.frame-anim-scrub::-webkit-slider-runnable-track{height:2px;background:var(--hairline-2);border-radius:2px}.frame-anim-scrub::-moz-range-track{height:2px;background:var(--hairline-2);border-radius:2px}.frame-anim-scrub::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:12px;height:12px;border-radius:50%;background:var(--hobby);border:0;margin-top:-5px;cursor:pointer}.frame-anim-scrub::-moz-range-thumb{width:12px;height:12px;border-radius:50%;background:var(--hobby);border:0;cursor:pointer}.frame-anim-scrub:focus{outline:none}.frame-anim-count{flex-shrink:0;font-variant-numeric:tabular-nums;min-width:56px;text-align:right}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}
