@import "https://fonts.googleapis.com/css2?family=JetBrains+Mono:wght@300;400;500;700;800&display=swap";
:root{--mono:"JetBrains Mono", ui-monospace, monospace;--bg:#0a0f0c;--fg:#eceae2;--fg-dim:#8b8a80;--fg-faint:#57564f;--line:#eceae21c;--line-strong:#eceae238;--accent:#57b97e;--bg-rise:#eceae20a;--maxw:1080px;--row-pad:24px}*,:before,:after{box-sizing:border-box}html{scroll-behavior:smooth}body{background:var(--bg);color:var(--fg);font-family:var(--mono);letter-spacing:-.01em;-webkit-font-smoothing:antialiased;text-rendering:optimizelegibility;margin:0;font-size:16px;font-weight:400;line-height:1.5}::selection{background:var(--accent);color:#0d0d0c}a{color:inherit;text-decoration:none}img{max-width:100%;display:block}.wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px}.narrow{max-width:760px}header.bar{z-index:40;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:color-mix(in oklab, var(--bg) 82%, transparent);border-bottom:1px solid var(--line);position:sticky;top:0}.bar .wrap{justify-content:space-between;align-items:center;height:54px;display:flex}.bar .brand{letter-spacing:.16em;text-transform:uppercase;font-size:12.5px;font-weight:700}.bar nav{align-items:center;gap:22px;display:flex}.bar nav a{color:var(--fg-dim);letter-spacing:.04em;font-size:12.5px;transition:color .15s}.bar nav a:hover,.bar nav a[aria-current=page]{color:var(--fg)}.bar nav a.mail{color:var(--accent)}.bar nav a.mail:after{content:" ↗"}@media (max-width:620px){.bar nav a.hide-sm{display:none}}.eyebrow{letter-spacing:.16em;text-transform:uppercase;color:var(--fg-faint);flex-wrap:wrap;align-items:center;gap:14px;margin-bottom:28px;font-size:12px;display:flex}.eyebrow .rule{background:var(--line);flex:1;min-width:30px;height:1px}.eyebrow b{color:var(--accent);font-weight:500}.sec-head{align-items:baseline;gap:16px;margin-bottom:26px;display:flex}.sec-head .idx{color:var(--accent);letter-spacing:.1em;font-size:12px;font-weight:500}.sec-head h2{letter-spacing:.2em;text-transform:uppercase;color:var(--fg-dim);margin:0;font-size:12px;font-weight:500}.sec-head .count{color:var(--fg-faint);letter-spacing:.08em;margin-left:auto;font-size:12px}.sec-head .rule{background:var(--line);flex:1;align-self:center;height:1px}footer.foot{border-top:1px solid var(--line);padding:clamp(36px,6vh,64px) 0 48px}.foot-big{letter-spacing:-.04em;font-size:clamp(28px,5vw,56px);font-weight:700;line-height:1}.foot-big a{border-bottom:2px solid var(--line);padding-bottom:4px;transition:border-color .15s,color .15s}.foot-big a:hover{border-color:var(--accent);color:var(--accent)}.foot-row{color:var(--fg-faint);letter-spacing:.04em;flex-wrap:wrap;align-items:center;gap:14px 30px;margin-top:30px;font-size:12.5px;display:flex}.foot-row a{color:var(--fg-dim);border-bottom:1px solid #0000;padding-bottom:2px;transition:color .15s,border-color .15s}.foot-row a:hover{color:var(--fg);border-color:var(--line-strong)}.foot-row .sp{flex:1}section.hero{padding:clamp(56px,12vh,128px) 0 clamp(48px,9vh,96px)}.name{letter-spacing:-.045em;flex-direction:column;gap:.02em;margin:0 0 0 -.04em;font-size:clamp(64px,15.5vw,188px);font-weight:800;line-height:.9;display:flex}.nline{width:max-content;max-width:100%;display:block;position:relative}.nline .ghost{color:#0000;-webkit-text-stroke:1.4px color-mix(in oklab, var(--accent) 50%, transparent);z-index:0;pointer-events:none;-webkit-user-select:none;user-select:none;position:absolute;top:0;left:0;transform:translate(.05em,.06em)}.nline .ch{z-index:1;display:inline-block;position:relative}[data-animate=on] .nline .ch{animation:.62s cubic-bezier(.2,.72,.18,1) both chIn;animation-delay:calc(var(--i,0) * 45ms + .12s)}@keyframes chIn{0%{opacity:0;transform:translateY(.42em)}to{opacity:1;transform:none}}@media (prefers-reduced-motion:reduce){[data-animate=on] .nline .ch{animation:none}}.lede{max-width:52ch;color:var(--fg);letter-spacing:-.005em;margin:38px 0 0;font-size:clamp(15px,1.5vw,18px);font-weight:300;line-height:1.62}.lede .ph{color:var(--accent);font-weight:400}.hero-foot{flex-wrap:wrap;align-items:center;gap:10px 26px;margin-top:30px;display:flex}.maillink{border-bottom:1px solid var(--line-strong);padding-bottom:3px;font-size:15px;font-weight:500;transition:border-color .15s,color .15s}.maillink:hover{border-color:var(--accent);color:var(--accent)}.scrollcue{color:var(--fg-faint);letter-spacing:.06em;font-size:12px}section.block{padding:clamp(46px,8vh,86px) 0}ul.index{border-top:1px solid var(--line);margin:0;padding:0;list-style:none}.proj{border-bottom:1px solid var(--line)}.proj-row{width:100%;color:inherit;font:inherit;cursor:pointer;padding:var(--row-pad) 12px;text-align:left;background:0 0;border:0;grid-template-columns:3.4rem minmax(0,1fr) 12.5rem 3.6rem 1.4rem;align-items:center;gap:18px;transition:background .16s;display:grid}.proj-row:hover,.proj-row:focus-visible{background:var(--bg-rise);outline:none}.proj-row:focus-visible{box-shadow:inset 2px 0 0 var(--accent)}.proj-num{color:var(--fg-faint);font-variant-numeric:tabular-nums;font-size:13px;font-weight:500;transition:color .16s}.proj-row:hover .proj-num,.proj.open .proj-num{color:var(--accent)}.proj-name{letter-spacing:-.02em;color:var(--fg);font-size:clamp(18px,2.1vw,23px);font-weight:500}.proj-stack{color:var(--fg-dim);letter-spacing:.01em;white-space:nowrap;text-overflow:ellipsis;font-size:12px;overflow:hidden}.proj-year{color:var(--fg-faint);font-variant-numeric:tabular-nums;text-align:right;font-size:13px}.proj-ind{justify-self:end;width:13px;height:13px;position:relative}.proj-ind:before,.proj-ind:after{content:"";background:var(--fg-dim);transition:transform .28s,background .16s;position:absolute}.proj-ind:before{width:13px;height:1.5px;top:6px;left:0}.proj-ind:after{width:1.5px;height:13px;top:0;left:6px}.proj-row:hover .proj-ind:before,.proj-row:hover .proj-ind:after{background:var(--accent)}.proj.open .proj-ind:after{transform:scaleY(0)}.proj.open .proj-ind:before{background:var(--accent)}.proj-reveal{grid-template-rows:0fr;transition:grid-template-rows .4s cubic-bezier(.4,0,.1,1);display:grid}.proj.open .proj-reveal{grid-template-rows:1fr}.proj-reveal-inner{min-height:0;overflow:hidden}.proj-body{max-width:64ch;padding:2px 12px 26px calc(3.4rem + 18px)}.proj-desc{color:var(--fg-dim);margin:0;font-size:14.5px;font-weight:300;line-height:1.62}.proj-meta-sm{color:var(--fg-faint);letter-spacing:.02em;margin:0 0 12px;font-size:12px;display:none}.proj-links{flex-wrap:wrap;gap:10px 20px;margin-top:16px;display:flex}.proj-links a{color:var(--accent);border-bottom:1px solid #0000;padding-bottom:2px;font-size:13px;transition:border-color .15s}.proj-links a:after{content:" ↗";color:var(--fg-faint)}.proj-links a:hover{border-color:color-mix(in oklab, var(--accent) 45%, transparent)}.proj-links .none{color:var(--fg-faint);font-size:12.5px}.proj-links .none:after{content:""}@media (max-width:680px){.proj-row{grid-template-columns:2.6rem minmax(0,1fr) 1.4rem;gap:12px}.col-stack,.col-year{display:none}.proj-body{padding-left:calc(2.6rem + 12px)}.proj-meta-sm{display:block}}.about-grid{grid-template-columns:minmax(0,1fr);gap:8px;max-width:60ch;display:grid}.about-lead{letter-spacing:-.015em;color:var(--fg);margin:0;font-size:clamp(18px,2.3vw,26px);font-weight:300;line-height:1.42}.about-sub{color:var(--fg-dim);max-width:54ch;margin:18px 0 0;font-size:14px;font-weight:300;line-height:1.65}.about-kv{grid-template-columns:auto 1fr;align-items:baseline;gap:9px 22px;margin-top:30px;font-size:13px;display:grid}.about-kv dt{color:var(--fg-faint);letter-spacing:.1em;text-transform:uppercase;font-size:11px}.about-kv dd{color:var(--fg-dim);margin:0}main.idx{padding:clamp(40px,8vh,92px) 0 clamp(48px,9vh,96px)}.idx-head{flex-wrap:wrap;justify-content:space-between;align-items:flex-end;gap:20px;margin-bottom:30px;display:flex}.idx-head h1{letter-spacing:-.045em;margin:0;font-size:clamp(40px,7vw,84px);font-weight:800;line-height:.9}.idx-head h1 .ph{color:var(--accent)}.idx-head .sub{letter-spacing:.14em;text-transform:uppercase;color:var(--fg-faint);text-align:right;font-size:12px;line-height:1.7}.search{border:1px solid var(--line);background:var(--bg-rise);border-radius:5px;align-items:center;gap:12px;margin-bottom:2px;padding:13px 18px;transition:border-color .16s;display:flex}.search:focus-within{border-color:color-mix(in oklab, var(--accent) 50%, transparent)}.search .pr{color:var(--accent);font-weight:600}.search input{color:var(--fg);font:inherit;letter-spacing:.01em;background:0 0;border:0;outline:0;flex:1;font-size:14px}.search input::placeholder{color:var(--fg-faint)}.search .ct{color:var(--fg-faint);letter-spacing:.08em;white-space:nowrap;font-size:12px}.console{border:1px solid var(--line);border-radius:6px;grid-template-columns:minmax(0,380px) minmax(0,1fr);gap:0;min-height:520px;margin-top:18px;display:grid;overflow:hidden}.clist{border-right:1px solid var(--line);overflow:auto}.crow{text-align:left;border:0;border-bottom:1px solid var(--line);width:100%;color:inherit;font:inherit;cursor:pointer;background:0 0;padding:20px 22px;transition:background .14s;display:block;position:relative}.crow:last-child{border-bottom:0}.crow:before{content:"";background:0 0;width:2px;transition:background .16s;position:absolute;top:0;bottom:0;left:0}.crow:hover,.crow.sel{background:var(--bg-rise)}.crow.sel:before{background:var(--accent)}.crow .rtop{align-items:center;gap:12px;margin-bottom:9px;display:flex}.crow .rn{color:var(--fg-faint);font-variant-numeric:tabular-nums;font-size:12px;font-weight:500;transition:color .16s}.crow.sel .rn,.crow:hover .rn{color:var(--accent)}.crow .badge{letter-spacing:.14em;text-transform:uppercase;border:1px solid var(--line-strong);border-radius:99px;margin-left:auto;padding:3px 9px;font-size:10px}.crow .badge.live{color:var(--accent);border-color:color-mix(in oklab, var(--accent) 45%, transparent)}.crow .badge.draft{color:var(--fg-faint)}.crow .rt{letter-spacing:-.02em;color:var(--fg);font-size:16px;font-weight:500;line-height:1.32}.crow .rmeta{letter-spacing:.04em;color:var(--fg-dim);margin-top:8px;font-size:11.5px}.crow .rmeta .dot{color:var(--fg-faint);margin:0 8px}.reader{flex-direction:column;min-width:0;padding:clamp(26px,3.4vw,44px);display:flex}.reader .eyebrow{margin-bottom:22px}.reader .rtitle{letter-spacing:-.035em;color:var(--fg);margin:0;font-size:clamp(26px,3.4vw,40px);font-weight:800;line-height:1.02}.reader .rdek{color:var(--fg-dim);max-width:46ch;margin:18px 0 0;font-size:15px;font-weight:300;line-height:1.62}.reader .rspec{flex-wrap:wrap;gap:10px;margin:24px 0 0;display:flex}.reader .rspec span{letter-spacing:.06em;color:var(--fg-dim);border:1px solid var(--line);background:var(--bg-rise);border-radius:4px;padding:7px 11px;font-size:11px}.reader .rspec span b{color:var(--fg-faint);text-transform:uppercase;letter-spacing:.1em;margin-right:7px;font-weight:400}.reader .vizmount{flex:1;justify-content:center;align-items:center;min-height:200px;margin:28px 0 0;display:flex}.reader .ractions{flex-wrap:wrap;align-items:center;gap:18px;margin-top:28px;display:flex}.open-btn{letter-spacing:.02em;color:#08130c;background:var(--accent);cursor:pointer;border:0;border-radius:5px;align-items:center;gap:10px;padding:12px 20px;font-size:13px;font-weight:600;text-decoration:none;transition:transform .14s,filter .14s;display:inline-flex}.open-btn:hover{filter:brightness(1.08);transform:translateY(-1px)}.open-btn .k{opacity:.6;background:#ffffff2e;border:1px solid #08130c66;border-radius:3px;padding:1px 5px;font-size:10px}.soon{letter-spacing:.1em;text-transform:uppercase;color:var(--fg-faint);border:1px dashed var(--line-strong);border-radius:5px;padding:11px 18px;font-size:12px}.rsrc{color:var(--fg-dim);border-bottom:1px solid #0000;font-size:12.5px;transition:color .15s,border-color .15s}.rsrc:hover{color:var(--accent);border-color:color-mix(in oklab, var(--accent) 40%, transparent)}.rsrc:after{content:" ↗";color:var(--fg-faint)}.vwrap{flex-direction:column;align-items:center;display:flex}.grid28{aspect-ratio:1;grid-template-columns:repeat(28,1fr);gap:1px;width:min(78%,300px);display:grid}.grid28 i{background:#eceae20a;border-radius:1px;transition:background .5s}.vizcap{letter-spacing:.12em;text-transform:uppercase;color:var(--fg-faint);text-align:center;margin-top:16px;font-size:11px}.vizcap b{color:var(--accent)}.grid2048{aspect-ratio:1;grid-template-columns:repeat(4,1fr);gap:8px;width:min(78%,264px);display:grid}.grid2048 i{color:#08130c;font-variant-numeric:tabular-nums;background:#eceae20d;border-radius:5px;justify-content:center;align-items:center;font-size:clamp(13px,2.6vw,19px);font-weight:600;transition:background .32s,color .32s;display:flex}.hint{letter-spacing:.06em;color:var(--fg-faint);flex-wrap:wrap;gap:18px;margin-top:18px;font-size:11.5px;display:flex}.hint kbd{font-family:var(--mono);border:1px solid var(--line-strong);color:var(--fg-dim);border-radius:3px;padding:1px 7px;font-size:11px}@media (max-width:860px){.console{grid-template-columns:1fr}.clist{border-right:0;border-bottom:1px solid var(--line)}.reader .vizmount{min-height:240px}}.post-hero{padding:clamp(44px,9vh,96px) 0 clamp(28px,5vh,52px)}.post-title{letter-spacing:-.04em;max-width:18ch;margin:0;font-size:clamp(40px,6.4vw,78px);font-weight:800;line-height:.96}.post-title .ph{color:var(--accent)}.post-dek{max-width:60ch;color:var(--fg-dim);margin:26px 0 0;font-size:clamp(16px,1.7vw,20px);font-weight:300;line-height:1.6}.byline{letter-spacing:.06em;text-transform:uppercase;color:var(--fg-faint);flex-wrap:wrap;gap:8px 22px;margin-top:30px;font-size:12px;display:flex}.byline b{color:var(--fg-dim);font-weight:500}.spec{border-top:1px solid var(--line);border-bottom:1px solid var(--line);grid-template-columns:repeat(4,1fr);margin:8px 0 0;display:grid}.spec .cell{border-right:1px solid var(--line);padding:22px 24px}.spec .cell:first-child{padding-left:0}.spec .cell:last-child{border-right:0}.spec dt{letter-spacing:.14em;text-transform:uppercase;color:var(--fg-faint);margin:0 0 10px;font-size:11px}.spec dd{color:var(--fg);letter-spacing:-.01em;margin:0;font-size:clamp(16px,1.7vw,20px);font-weight:500}.spec dd .u{color:var(--fg-faint);font-size:.7em;font-weight:400}.spec dd.accent{color:var(--accent)}@media (max-width:720px){.spec{grid-template-columns:repeat(2,1fr)}.spec .cell{padding:18px 20px}.spec .cell:nth-child(odd){padding-left:0}.spec .cell:nth-child(2n){border-right:0}}.prose{max-width:680px}.prose>section{border-top:1px solid var(--line);padding:clamp(34px,6vh,64px) 0}.prose p{color:#cfcdc4;letter-spacing:-.003em;text-wrap:pretty;margin:0 0 18px;font-size:16.5px;font-weight:300;line-height:1.72}.prose p:last-child{margin-bottom:0}.prose strong{color:var(--fg);font-weight:600}.prose a.inl{color:var(--accent);border-bottom:1px solid color-mix(in oklab, var(--accent) 35%, transparent);transition:border-color .15s}.prose a.inl:hover{border-color:var(--accent)}.prose ul.aims{background:var(--line);border:1px solid var(--line);gap:1px;margin:6px 0 0;padding:0;list-style:none;display:grid}.prose ul.aims li{background:var(--bg);color:#cfcdc4;grid-template-columns:2.2rem 1fr;align-items:start;gap:14px;padding:16px 20px;font-size:14.5px;font-weight:300;line-height:1.55;display:grid}.prose ul.aims li .n{color:var(--accent);font-variant-numeric:tabular-nums;font-weight:500}code.k{font-family:var(--mono);background:var(--bg-rise);border:1px solid var(--line);color:var(--fg);border-radius:3px;padding:1px 7px;font-size:.86em;font-weight:400}.note{border-top:1px solid var(--line-strong);color:var(--fg-dim);margin:26px 0 0;padding:22px 0 0;font-size:14px;font-weight:300;line-height:1.65}.note b{color:var(--accent);letter-spacing:.14em;text-transform:uppercase;margin-bottom:9px;font-size:11px;font-weight:500;display:block}.statband{border-top:1px solid var(--line);border-bottom:1px solid var(--line);flex-wrap:wrap;align-items:baseline;gap:28px;margin:0;padding:clamp(40px,8vh,80px) 0;display:flex}.statband .big{letter-spacing:-.05em;color:var(--accent);font-size:clamp(80px,16vw,200px);font-weight:800;line-height:.82}.statband .lbl{letter-spacing:.14em;text-transform:uppercase;color:var(--fg-faint);max-width:24ch;font-size:13px;line-height:1.7}.statband .lbl b{color:var(--fg-dim);margin-bottom:4px;font-weight:500;display:block}figure{margin:8px 0 0}figure figcaption{color:var(--fg-faint);letter-spacing:.02em;margin-top:12px;font-size:12px}figure figcaption .accent{color:var(--accent)}.plate{border:1px solid var(--line);background:#f4f2ea;border-radius:6px;padding:clamp(14px,2.4vw,26px);overflow:hidden}.plate img{border-radius:2px;width:100%;display:block}.viz-inline{border:1px solid var(--line);background:var(--bg-rise);border-radius:5px;flex-wrap:wrap;align-items:center;gap:clamp(20px,4vw,52px);margin-top:26px;padding:clamp(22px,3vw,38px);display:flex}.viz-inline .grid28{width:clamp(196px,40vw,308px)}.viz-copy{flex:1;min-width:220px}.viz-copy .tag{letter-spacing:.16em;text-transform:uppercase;color:var(--accent);margin:0 0 12px;font-size:11px}.viz-copy p{color:var(--fg-dim);margin:0;font-size:14px;font-weight:300;line-height:1.65}.viz-copy .ch{color:var(--fg-faint);letter-spacing:.06em;margin-top:16px;font-size:12px}.viz-copy .ch b{color:var(--fg);font-weight:600}.repo{border:1px solid var(--line-strong);border-radius:5px;flex-wrap:wrap;align-items:center;gap:18px;margin:0;padding:22px 24px;transition:border-color .16s,background .16s;display:flex}.repo:hover{border-color:color-mix(in oklab, var(--accent) 45%, transparent);background:var(--bg-rise)}.repo .lead{letter-spacing:.16em;text-transform:uppercase;color:var(--fg-faint);font-size:11px}.repo .path{letter-spacing:-.01em;color:var(--fg);font-size:clamp(18px,2.4vw,24px);font-weight:600}.repo .path .slash{color:var(--fg-faint)}.repo .go{color:var(--accent);margin-left:auto;font-size:13px}.repo .go:after{content:" ↗"}.postnav{border-top:1px solid var(--line);flex-wrap:wrap;justify-content:space-between;gap:18px;padding:34px 0;font-size:13px;display:flex}.postnav a{color:var(--fg-dim);border-bottom:1px solid #0000;padding-bottom:2px;transition:color .15s,border-color .15s}.postnav a:hover{color:var(--fg);border-color:var(--line-strong)}@media (prefers-reduced-motion:no-preference){.fade{animation:.7s cubic-bezier(.2,.72,.18,1) both fade}@keyframes fade{0%{transform:translateY(14px)}to{transform:none}}}
