:root{--paper:oklch(97.2% .006 80);--paper-2:oklch(95.5% .006 80);--ink:oklch(18% .012 60);--ink-2:oklch(32% .01 60);--muted:oklch(55% .008 60);--rule:oklch(85% .006 60);--rule-soft:oklch(91% .005 60);--font-display:"Instrument Serif", "Cormorant Garamond", "Times New Roman", serif;--font-mono:"JetBrains Mono", ui-monospace, Menlo, Consolas, monospace;--pad-x:clamp(28px, 5vw, 96px);--pad-y:clamp(24px, 3.5vw, 56px)}*{box-sizing:border-box}html,body{margin:0;padding:0}html{background:var(--paper)}body{font-family:var(--font-mono);color:var(--ink);background:var(--paper);-webkit-font-smoothing:antialiased;text-rendering:optimizelegibility;letter-spacing:.01em;min-height:100vh;font-size:13px;line-height:1.5}body:before{content:"";pointer-events:none;mix-blend-mode:multiply;opacity:var(--grain-opacity,.5);z-index:1;background-image:radial-gradient(circle at 1px 1px,oklch(40% .01 60/.06) 1px,#0000 0);background-size:3px 3px;transition:opacity .3s;position:fixed;inset:0}body.no-grain:before{opacity:0}a{color:inherit;text-decoration:none}html,body{overflow-x:clip}.app{min-height:100vh;padding:var(--pad-y) var(--pad-x);z-index:2;grid-template-rows:auto 1fr auto;grid-template-columns:minmax(0,1fr);gap:clamp(40px,6vh,80px);display:grid;position:relative}.app>main,.marquee{min-width:0}.topbar{font-family:var(--font-mono);letter-spacing:.08em;text-transform:uppercase;color:var(--ink-2);grid-template-columns:1fr auto 1fr;align-items:start;gap:24px;font-size:11px;display:grid}.topbar .corner-l{align-items:baseline;gap:18px;display:flex}.topbar .corner-c{text-align:center}.topbar .corner-r{flex-wrap:wrap;justify-content:flex-end;align-items:baseline;gap:18px;display:flex}.topbar .nameplate{font-family:var(--font-display);text-transform:none;letter-spacing:-.01em;color:var(--ink);font-size:clamp(22px,2vw,30px);font-style:italic;line-height:1}.topbar .dot{vertical-align:middle;background:oklch(70% .15 145);border-radius:50%;width:6px;height:6px;margin-right:6px;animation:2.4s ease-in-out infinite pulse;display:inline-block}@keyframes pulse{0%,to{opacity:.55}50%{opacity:1}}.topbar .nav{align-items:center;gap:22px;display:flex}.topbar .nav a{color:var(--ink-2);padding:4px 0;transition:color .2s;position:relative}.topbar .nav a:hover,.topbar .nav a.active{color:var(--ink)}.topbar .nav a.active:after{content:"";background:var(--ink);height:1px;position:absolute;bottom:-2px;left:0;right:0}.hero{grid-template-columns:1fr;align-content:center;gap:clamp(28px,4vh,48px);padding-block:clamp(20px,5vh,60px);display:grid}.hero .meta-row{font-family:var(--font-mono);letter-spacing:.1em;text-transform:uppercase;color:var(--muted);grid-template-columns:1fr auto 1fr;gap:24px;font-size:10.5px;display:grid}.hero .meta-row .role{text-align:center;color:var(--ink-2)}.hero .meta-row .right{text-align:right}.display-row{grid-template-columns:1fr auto;align-items:end;gap:clamp(20px,3vw,48px);display:grid}.hero-img{flex-direction:column;align-items:flex-end;gap:8px;width:clamp(180px,22vw,280px);margin:0;padding-bottom:clamp(8px,1.5vw,16px);display:flex}.hero-img img{aspect-ratio:4/5;object-fit:cover;filter:grayscale()contrast(1.05);border:1px solid var(--rule);background:var(--paper-2);width:100%;display:block}.hero-img figcaption{font-family:var(--font-mono);letter-spacing:.08em;color:var(--muted);text-transform:lowercase;font-size:10px}@media (width<=900px){.display-row{grid-template-columns:1fr}.hero-img{align-items:flex-start;width:60%}}.display{font-family:var(--font-display);letter-spacing:-.055em;color:var(--ink);text-wrap:balance;margin:0 0 0 -.04em;font-size:clamp(96px,22vw,360px);font-weight:400;line-height:.82;position:relative}.display .it{font-style:italic}.display .amp{color:var(--muted);padding:0 .05em;font-style:italic}.display .stop{color:var(--ink);margin-left:-.04em;font-style:normal;display:inline-block}.display-meta{font-family:var(--font-mono);letter-spacing:.1em;text-transform:uppercase;color:var(--muted);border-top:1px solid var(--rule);grid-template-columns:1fr 1fr;gap:24px;margin-top:16px;padding-top:14px;font-size:11px;display:grid}.display-meta .dm-r{text-align:right;color:var(--ink-2)}.display-meta em{color:var(--ink);font-style:italic;font-family:var(--font-display);text-transform:lowercase;letter-spacing:0;font-size:14px}.hero .deck{grid-template-columns:1.2fr 1fr 1fr;align-items:end;gap:clamp(24px,4vw,64px);padding-top:clamp(20px,4vh,40px);display:grid}.hero .deck .lede{font-family:var(--font-display);letter-spacing:0;color:var(--ink-2);text-wrap:pretty;max-width:38ch;font-size:clamp(20px,1.6vw,26px);line-height:1.3}.hero .deck .lede em{color:var(--ink);font-style:italic}.hero .deck .col{letter-spacing:.08em;text-transform:uppercase;color:var(--ink-2);border-top:1px solid var(--rule);gap:6px;padding-top:12px;font-size:11px;display:grid}.hero .deck .col .lab{color:var(--muted);font-size:10px}.hero .deck .col .val{color:var(--ink)}.hero .deck .col ul{gap:4px;margin:0;padding:0;list-style:none;display:grid}.plates-section{gap:24px;padding-block:clamp(40px,6vh,80px);display:grid}.plates-head{font-family:var(--font-mono);letter-spacing:.1em;text-transform:uppercase;color:var(--muted);border-top:1px solid var(--rule);justify-content:space-between;align-items:baseline;padding-top:12px;font-size:11px;display:flex}.plates-strip{margin-inline:calc(-1 * var(--pad-x));padding-block:8px;padding-inline:var(--pad-x);scrollbar-width:thin;scrollbar-color:var(--rule) transparent;scroll-snap-type:x proximity;grid-auto-columns:clamp(220px,22vw,320px);grid-auto-flow:column;gap:clamp(16px,2vw,28px);display:grid;overflow-x:auto}.plates-strip::-webkit-scrollbar{height:6px}.plates-strip::-webkit-scrollbar-thumb{background:var(--rule);border-radius:3px}.plate{scroll-snap-align:start;transform:rotate(var(--rot,0deg));gap:14px;transition:transform .4s cubic-bezier(.2,.7,.2,1);display:grid}.plate:hover{transform:rotate(0)translateY(-4px)}.plate-frame{aspect-ratio:4/5;background:var(--paper-2);border:1px solid var(--rule);color:var(--ink-2);position:relative;overflow:hidden}.plate-frame svg{width:100%;height:100%;display:block}.plate-mark{font-family:var(--font-mono);letter-spacing:.1em;color:var(--ink);background:var(--paper);border:1px solid var(--rule);padding:3px 7px;font-size:11px;position:absolute;top:14px;left:14px}.plate-cap{font-family:var(--font-mono);letter-spacing:.05em;color:var(--muted);background:var(--paper);border:1px solid var(--rule);padding:3px 7px;font-size:10px;position:absolute;bottom:14px;left:14px}.plate-meta{font-family:var(--font-mono);letter-spacing:.08em;text-transform:uppercase;color:var(--muted);justify-content:space-between;align-items:baseline;gap:12px;font-size:10.5px;display:flex}.plate-name{color:var(--ink);font-family:var(--font-display);text-transform:none;letter-spacing:0;font-size:18px;font-style:italic}.divider{text-align:center;border-top:1px solid var(--rule);border-bottom:1px solid var(--rule);gap:18px;padding-block:clamp(60px,10vh,140px);display:grid}.divider-q{font-family:var(--font-display);letter-spacing:-.02em;color:var(--ink);text-wrap:balance;margin:0;max-width:22ch;margin-inline:auto;font-size:clamp(36px,5.5vw,88px);font-style:italic;line-height:1.05}.divider-q em{color:var(--muted);font-style:italic}.divider-q .quote-l,.divider-q .quote-r{color:var(--muted);padding:0 .05em;font-style:normal}.divider-attr{font-family:var(--font-mono);letter-spacing:.1em;text-transform:uppercase;color:var(--muted);font-size:11px}.section{gap:clamp(24px,4vh,40px);padding-block:clamp(40px,8vh,96px);display:grid}.section-head{grid-template-columns:auto 1fr auto;align-items:baseline;gap:24px;padding-top:12px;display:grid;position:relative}.section-head:before{content:"";background:var(--ink);transform-origin:0;width:100%;height:1px;transform:scaleX(var(--head-rule,1));position:absolute;top:0;left:0}@media (prefers-reduced-motion:reduce){.section-head:before{transform:none}}.section-head .num{font-family:var(--font-mono);letter-spacing:.1em;text-transform:uppercase;color:var(--muted);font-size:11px}.section-head .ttl{font-family:var(--font-display);letter-spacing:-.02em;font-size:clamp(28px,3.2vw,48px);font-style:italic;line-height:1}.section-head .meta{font-family:var(--font-mono);letter-spacing:.1em;text-transform:uppercase;color:var(--muted);text-align:right;font-size:11px}.projects{gap:0;display:grid}.project{border-bottom:1px solid var(--rule);cursor:pointer;grid-template-columns:60px 1.4fr 1fr 1fr 90px 56px 24px;align-items:center;gap:clamp(16px,2vw,32px);padding:clamp(20px,2.5vh,28px) 0;transition:padding .4s,background .4s;display:grid;position:relative}.project:hover{padding-left:12px;padding-right:12px}.project:hover .arrow{opacity:1;transform:translate(4px)}.project:hover .pname .it{font-style:italic}.project:hover .pthumb img{filter:grayscale(.4)contrast(1.05);transform:scale(1.04)}.project .pthumb{background:var(--paper-2);border:1px solid var(--rule);flex-shrink:0;align-self:center;width:56px;height:70px;display:block;position:relative;overflow:hidden}.project .pthumb img{object-fit:cover;filter:grayscale()contrast(1.05);width:100%;height:100%;transition:filter .4s,transform .5s;display:block;position:absolute;inset:0}.project .pidx{font-family:var(--font-mono);color:var(--muted);letter-spacing:.05em;font-size:11px}.project .pname{font-family:var(--font-display);letter-spacing:-.02em;color:var(--ink);font-size:clamp(28px,3.6vw,56px);line-height:1}.project .pdesc{font-family:var(--font-mono);color:var(--ink-2);letter-spacing:.01em;max-width:36ch;font-size:12px;line-height:1.5}.project .ptags{font-family:var(--font-mono);letter-spacing:.08em;text-transform:uppercase;color:var(--muted);flex-wrap:wrap;gap:12px;font-size:10.5px;display:flex}.project .pyear{font-family:var(--font-mono);letter-spacing:.08em;color:var(--ink-2);text-transform:uppercase;text-align:right;font-size:11px}.project .pstatus{font-family:var(--font-mono);letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin-top:4px;font-size:9.5px;display:block}.project .pstatus.live:before{content:"● ";color:oklch(70% .15 145)}.project .pstatus.beta:before{content:"◐ ";color:oklch(72% .13 75)}.project .pstatus.wip:before{content:"◌ ";color:var(--muted)}.project .arrow{font-family:var(--font-display);color:var(--ink-2);opacity:.4;text-align:right;font-size:28px;transition:transform .3s,opacity .3s}.about-grid{grid-template-columns:1.4fr 1fr;align-items:start;gap:clamp(40px,6vw,96px);display:grid}.about-grid .essay{font-family:var(--font-display);letter-spacing:-.005em;color:var(--ink);text-wrap:pretty;max-width:28ch;font-size:clamp(22px,2vw,32px);line-height:1.35}.about-grid .essay em{color:var(--em-ink,var(--muted));font-style:italic;transition:color .6s}@media (prefers-reduced-motion:reduce){.about-grid .essay em{color:var(--ink);transition:none}}.about-grid .essay span.muted{color:var(--muted)}.about-grid .columns{font-family:var(--font-mono);letter-spacing:.05em;text-transform:uppercase;grid-template-columns:1fr 1fr;gap:32px 24px;font-size:11px;display:grid}.about-grid .columns .blk{border-top:1px solid var(--rule);gap:6px;padding-top:10px;display:grid}.about-grid .columns .blk .lab{color:var(--muted);font-size:10px}.about-grid .columns .blk .val{color:var(--ink)}.about-grid .columns .blk ul{gap:4px;margin:0;padding:0;list-style:none;display:grid}.posts{display:grid}.post{border-bottom:1px solid var(--rule-soft);cursor:pointer;grid-template-columns:80px 1fr auto 60px;align-items:baseline;gap:24px;padding:16px 0;transition:padding .3s;display:grid}.post:hover{padding-left:8px}.post .pdate{font-family:var(--font-mono);color:var(--muted);letter-spacing:.05em;font-size:11px}.post .ptitle{font-family:var(--font-display);letter-spacing:-.005em;color:var(--ink);font-size:clamp(20px,1.7vw,26px);line-height:1.2}.post:hover .ptitle{font-style:italic}.post .pcat{font-family:var(--font-mono);letter-spacing:.12em;text-transform:uppercase;color:var(--muted);font-size:10px}.post .pread{font-family:var(--font-mono);color:var(--ink-2);text-align:right;font-size:10.5px}.footer{border-top:1px solid var(--ink);font-family:var(--font-mono);letter-spacing:.08em;text-transform:uppercase;color:var(--ink-2);grid-template-columns:1fr auto 1fr;align-items:end;gap:24px;padding-top:clamp(40px,6vh,80px);font-size:11px;display:grid}.footer .center{text-align:center;color:var(--muted)}.footer .right{text-align:right;justify-content:flex-end;gap:16px;display:flex}.footer .word{font-family:var(--font-display);letter-spacing:-.04em;color:var(--ink);text-transform:none;margin:0;font-size:clamp(48px,8vw,120px);font-style:italic;line-height:.9}.hint{font-family:var(--font-mono);letter-spacing:.1em;text-transform:uppercase;color:var(--muted);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid var(--rule);z-index:50;background:oklch(97% .005 80/.85);border-radius:999px;align-items:center;gap:10px;padding:7px 14px;font-size:10.5px;transition:opacity .3s,transform .3s;display:flex;position:fixed;bottom:18px;left:50%;transform:translate(-50%)}.hint.hidden{opacity:0;pointer-events:none;transform:translate(-50%)translateY(8px)}.hint kbd{font-family:var(--font-mono);background:var(--paper-2);border:1px solid var(--rule);color:var(--ink);letter-spacing:0;border-bottom-width:2px;border-radius:4px;padding:1px 6px;font-size:11px}.hint .blink{background:var(--ink);vertical-align:-2px;width:6px;height:12px;animation:1.1s steps(2,end) infinite blink;display:inline-block}@keyframes blink{50%{opacity:0}}@media (width<=900px){.hero .deck{grid-template-columns:1fr}.project{grid-template-columns:30px 1fr 24px}.project .pdesc,.project .ptags,.project .pyear,.project .pthumb{display:none}.about-grid{grid-template-columns:1fr}.post{grid-template-columns:60px 1fr 40px}.post .pcat{display:none}.topbar{grid-template-columns:1fr 1fr}.topbar .corner-c{display:none}}.view-more{font-family:var(--font-mono);letter-spacing:.1em;text-transform:uppercase;color:var(--ink-2);border:1px solid var(--rule);cursor:pointer;background:0 0;align-self:center;margin-top:8px;padding:10px 18px;font-size:11px;transition:background .2s,color .2s,border-color .2s}.view-more:hover{background:var(--ink);color:var(--paper);border-color:var(--ink)}.scroll-progress{background:var(--ink);transform-origin:0;width:100%;height:1px;transform:scaleX(var(--scroll-progress,0));z-index:60;pointer-events:none;transition:transform 50ms linear;position:fixed;top:0;left:0}@media (prefers-reduced-motion:reduce){.scroll-progress{transition:none}}.marquee{border-top:1px solid var(--rule);border-bottom:1px solid var(--rule);margin-block:clamp(40px,6vh,80px);margin-inline:calc(-1 * var(--pad-x));-webkit-user-select:none;user-select:none;padding:clamp(20px,3vh,36px) 0;position:relative;overflow:hidden}.marquee-track{white-space:nowrap;font-family:var(--font-display);letter-spacing:-.02em;color:var(--ink);will-change:transform;gap:48px;font-size:clamp(48px,8vw,120px);font-style:italic;line-height:1;display:inline-flex}.marquee-track .sep{color:var(--muted);padding:0 .1em}@media (prefers-reduced-motion:reduce){.marquee-track{animation:none}}.term-overlay{z-index:100;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:oklch(10% .01 60/.55);place-items:center;padding:clamp(20px,5vh,60px);animation:.18s fadein;display:grid;position:fixed;inset:0}@keyframes fadein{0%{opacity:0}to{opacity:1}}.term{color:oklch(93% .01 80);width:min(880px,100%);height:min(560px,80vh);font-family:var(--font-mono);background:oklch(13% .012 60);border:1px solid oklch(25% .012 60);border-radius:8px;grid-template-rows:auto 1fr;font-size:13px;line-height:1.55;animation:.22s cubic-bezier(.2,.7,.2,1) termin;display:grid;overflow:hidden;box-shadow:0 30px 80px -20px oklch(0% 0 0/.6)}@keyframes termin{0%{opacity:0;transform:translateY(8px)scale(.99)}to{opacity:1;transform:none}}.term .tbar{letter-spacing:.05em;color:oklch(60% .01 60);background:oklch(16% .012 60);border-bottom:1px solid oklch(22% .012 60);align-items:center;gap:10px;padding:10px 14px;font-size:11px;display:flex}.term .tbar .lights{gap:6px;display:flex}.term .tbar .lights i{border-radius:50%;width:11px;height:11px;display:inline-block}.term .tbar .lights i.r{background:oklch(65% .18 25)}.term .tbar .lights i.y{background:oklch(78% .15 80)}.term .tbar .lights i.g{background:oklch(70% .16 145)}.term .tbar .ttl{text-align:center;flex:1;margin-left:8px}.term .tbar .esc{color:oklch(55% .01 60)}.term .tbar .esc kbd{font-family:var(--font-mono);color:oklch(85% .01 60);background:oklch(20% .012 60);border:1px solid oklch(30% .012 60);border-radius:3px;padding:1px 5px;font-size:10px}.term .tbody{scrollbar-width:thin;scrollbar-color:oklch(30% .012 60) transparent;padding:16px 18px 22px;overflow-y:auto}.term .tbody::-webkit-scrollbar{width:8px}.term .tbody::-webkit-scrollbar-thumb{background:oklch(30% .012 60);border-radius:4px}.term .line{white-space:pre-wrap;word-break:break-word}.term .prompt{color:oklch(70% .16 145)}.term .prompt .at{color:oklch(75% .13 250)}.term .prompt .path{color:oklch(78% .13 75)}.term .cmd{color:oklch(95% .01 80)}.term .out{color:oklch(82% .01 80)}.term .out.dim{color:oklch(60% .01 60)}.term .out .key{color:oklch(75% .13 250)}.term .out .val{color:oklch(93% .01 80)}.term .out .lnk{color:oklch(75% .13 75);text-decoration:underline}.term .err{color:oklch(70% .16 25)}.term .ok{color:oklch(70% .16 145)}.term .input-row{align-items:center;gap:8px;display:flex}.term .input-row .caret{vertical-align:-2px;background:oklch(93% .01 80);width:8px;height:14px;animation:1.1s steps(2,end) infinite blink;display:inline-block}.term .input-row input{color:oklch(95% .01 80);font:inherit;caret-color:#0000;background:0 0;border:none;outline:none;flex:1;padding:0}
