:root{color-scheme:light;--page: oklch(.975 .009 83);--ink: oklch(.235 .018 67);--muted: oklch(.44 .019 67);--rule: oklch(.82 .018 78);--panel: oklch(.93 .018 80);--accent: oklch(.53 .13 38);--blue: oklch(.48 .09 220);--green: oklch(.48 .08 145);--focus: oklch(.62 .14 38);--max: 1180px;--measure: 72ch;font-family:Aptos,Segoe UI,system-ui,-apple-system,sans-serif}*{box-sizing:border-box}html{background:var(--page);color:var(--ink);text-rendering:optimizeLegibility}body{margin:0;min-width:320px;background:linear-gradient(90deg,color-mix(in oklch,var(--rule),transparent 66%) 1px,transparent 1px) 0 0 / clamp(4rem,8vw,8rem) 100%,var(--page);color:var(--ink);font-size:17px;line-height:1.65}body::selection{background:color-mix(in oklch,var(--accent),transparent 72%)}a{color:inherit;text-decoration-color:color-mix(in oklch,var(--accent),transparent 30%);text-decoration-thickness:.08em;text-underline-offset:.18em}a:hover{color:var(--accent)}a:focus-visible,button:focus-visible{outline:3px solid color-mix(in oklch,var(--focus),transparent 25%);outline-offset:4px}img,svg{max-width:100%}.shell{width:min(var(--max),calc(100% - clamp(2rem,5vw,6rem)));margin-inline:auto}.site-header{position:sticky;top:0;z-index:10;border-bottom:1px solid var(--rule);background:color-mix(in oklch,var(--page),transparent 8%)}.nav{display:flex;align-items:center;justify-content:space-between;gap:1.5rem;min-height:4.4rem}.brand{font-weight:780;font-size:1rem;text-decoration:none}.nav-links{display:flex;align-items:center;gap:clamp(.85rem,2vw,1.6rem);font-size:.92rem}.nav-links a{text-decoration:none;color:var(--muted)}.nav-links a[aria-current=page],.nav-links a:hover{color:var(--ink)}main{min-height:72vh;overflow-x:clip}.hero{display:grid;grid-template-columns:minmax(0,1.05fr) minmax(18rem,.7fr);gap:clamp(2.5rem,8vw,7rem);align-items:end;min-height:min(760px,calc(100vh - 4.4rem));padding-block:clamp(4.5rem,10vw,8rem) clamp(3rem,8vw,6rem)}.hero>*,.section-head>*,.writing-row>*,.split>*{min-width:0}.eyebrow{margin:0 0 1rem;color:var(--accent);font-size:.78rem;font-weight:760;text-transform:uppercase;letter-spacing:.06em}h1,h2,h3{margin:0;line-height:1.05}h1{max-width:11ch;font-size:clamp(3.7rem,11vw,9.4rem);font-weight:820;text-wrap:balance}.hero-copy{max-width:44rem;margin:clamp(1.4rem,3vw,2rem) 0 0;color:var(--muted);font-size:clamp(1.16rem,2vw,1.55rem);line-height:1.45;overflow-wrap:anywhere}.hero-note{border:1px solid var(--rule);background:color-mix(in oklch,var(--panel),transparent 18%);padding:clamp(1.2rem,2.4vw,1.8rem)}.hero-note p{margin:0}.hero-note strong{color:var(--ink)}.section{padding-block:clamp(3rem,8vw,6.5rem);border-top:1px solid var(--rule)}.section-head{display:grid;grid-template-columns:minmax(10rem,.38fr) minmax(0,1fr);gap:clamp(1.5rem,5vw,5rem);margin-bottom:clamp(1.8rem,4vw,3.5rem)}.section-kicker{margin:0;color:var(--accent);font-size:.78rem;font-weight:760;text-transform:uppercase;letter-spacing:.06em}.section-title{max-width:14ch;font-size:clamp(2.1rem,5vw,4.6rem);font-weight:800;text-wrap:balance}.lede{max-width:var(--measure);color:var(--muted);font-size:clamp(1.08rem,1.6vw,1.28rem);overflow-wrap:anywhere}.writing-list{display:grid;border-top:1px solid var(--rule)}.writing-row{display:grid;grid-template-columns:minmax(8rem,.24fr) minmax(0,1fr);gap:clamp(1.4rem,4vw,4rem);padding:clamp(1.35rem,3vw,2.2rem) 0;border-bottom:1px solid var(--rule);text-decoration:none}.writing-row:hover .row-title{color:var(--accent)}.row-meta{color:var(--muted);font-size:.9rem}.row-title{margin-bottom:.55rem;font-size:clamp(1.45rem,3vw,2.45rem);font-weight:780;overflow-wrap:anywhere;text-wrap:balance;transition:color .18s cubic-bezier(.16,1,.3,1)}.row-description{max-width:68ch;margin:0;color:var(--muted);overflow-wrap:anywhere}.tags{display:flex;flex-wrap:wrap;gap:.45rem;margin-top:1rem}.tag{border:1px solid color-mix(in oklch,var(--blue),transparent 55%);color:color-mix(in oklch,var(--blue),var(--ink) 24%);padding:.18rem .5rem;font-size:.78rem;line-height:1.3}.split{display:grid;grid-template-columns:minmax(0,.86fr) minmax(17rem,.45fr);gap:clamp(2rem,6vw,5rem);align-items:start}.plain-list{display:grid;gap:1rem;margin:0;padding:0;list-style:none}.plain-list li{border-top:1px solid var(--rule);padding-top:1rem}.project{border:1px solid var(--rule);padding:clamp(1.1rem,2.5vw,1.55rem);background:color-mix(in oklch,var(--panel),transparent 34%)}.project+.project{margin-top:1rem}.project h3{font-size:1.2rem}.project p{margin:.55rem 0 0;color:var(--muted)}.diagram{display:block;width:100%;border:1px solid var(--rule);background:color-mix(in oklch,var(--panel),transparent 18%)}.page-header{padding-block:clamp(4rem,10vw,8rem) clamp(2.5rem,6vw,4.5rem)}.page-header h1{max-width:12ch;font-size:clamp(3.2rem,9vw,7rem)}.article{width:min(var(--measure),calc(100% - 2rem));margin-inline:auto;padding-block:clamp(3rem,7vw,5.5rem)}.article-header{border-bottom:1px solid var(--rule);padding-bottom:clamp(2rem,5vw,3.5rem);margin-bottom:clamp(2rem,5vw,3.8rem)}.article-header h1{max-width:15ch;font-size:clamp(2.35rem,5.6vw,4.8rem);overflow-wrap:anywhere}.article-meta{margin:0 0 1rem;color:var(--accent);font-size:.86rem;font-weight:720}.article-description{max-width:58ch;color:var(--muted);font-size:1.18rem}.article-body{font-size:1.08rem}.article-body h2{margin-top:2.8rem;font-size:clamp(1.7rem,3vw,2.35rem)}.article-body p,.article-body li{max-width:var(--measure)}.article-body p{margin:1.1rem 0}.article-body ul,.article-body ol{padding-left:1.35rem}.article-body blockquote{margin:2rem 0;border:1px solid var(--rule);padding:1rem 1.25rem;color:var(--muted);background:color-mix(in oklch,var(--panel),transparent 28%)}.article-bridge{margin-top:clamp(3rem,7vw,5rem);border-top:1px solid var(--rule);padding-top:1.5rem;color:var(--muted)}.site-footer{border-top:1px solid var(--rule);padding-block:2rem;color:var(--muted);font-size:.92rem}.footer-inner{display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap}@media(max-width:1080px){.hero,.section-head,.split{grid-template-columns:1fr}.hero{min-height:auto;align-items:start}.hero-note{max-width:44rem}}@media(max-width:820px){body{font-size:16px}.nav{align-items:flex-start;flex-direction:column;justify-content:center;padding-block:.9rem}.nav-links{width:100%;flex-wrap:wrap;overflow-x:visible;row-gap:.25rem}.writing-row,.split{grid-template-columns:1fr}h1{font-size:clamp(3.7rem,19vw,6.2rem)}}@media(prefers-reduced-motion:no-preference){.reveal{animation:rise .52s cubic-bezier(.16,1,.3,1) both}@keyframes rise{0%{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}}
