:root{--bg: #14181c;--bg-alt: #1c2127;--fg: #e8e6df;--fg-dim: rgba(232,230,223,.78);--fg-soft: rgba(232,230,223,.48);--line: rgba(232,230,223,.1);--line-strong: rgba(232,230,223,.22);--accent: #7af07a;--accent-2: #a8f5a8;--accent-soft: rgba(122,240,122,.14);--accent-wash: rgba(122,240,122,.05);--display: "VT323", "Geist Mono", ui-monospace, monospace;--serif: "Geist", system-ui, -apple-system, sans-serif;--sans: "Geist", system-ui, -apple-system, BlinkMacSystemFont, sans-serif;--mono: "Geist Mono", ui-monospace, SFMono-Regular, Menlo, monospace;--r-1: 6px;--r-2: 10px;--r-3: 14px;--container: 1180px;--measure: 68ch;--d-x: 32px;--d-y: 28px;--d-section: 96px;--base-size: 17px}[data-density=compact]{--d-x: 22px;--d-y: 18px;--d-section: 64px;--base-size: 15.5px}[data-density=comfy]{--d-x: 40px;--d-y: 36px;--d-section: 128px;--base-size: 18px}[data-fontpair=modern]{--display: "Geist", system-ui, sans-serif;--serif: "Geist", system-ui, sans-serif;--sans: "Geist", system-ui, sans-serif}[data-fontpair=mono]{--display: "Geist Mono", ui-monospace, monospace;--serif: "Geist Mono", ui-monospace, monospace;--sans: "Geist", system-ui, sans-serif}[data-fontpair=classic]{--display: "VT323", "Geist Mono", monospace;--serif: "Geist", system-ui, sans-serif;--sans: "Geist", system-ui, sans-serif}*{box-sizing:border-box}html,body{margin:0;padding:0}html{overflow-x:clip}body{overflow-x:clip;background:var(--bg);background-image:radial-gradient(1200px 600px at 0% 0%,var(--accent-wash),transparent 60%),radial-gradient(900px 500px at 100% 20%,var(--accent-wash),transparent 60%);color:var(--fg);font-family:var(--sans);font-size:var(--base-size);line-height:1.55;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;transition:background .25s ease,color .25s ease}a{color:inherit;text-decoration:none}a:hover{color:var(--accent)}button{font-family:inherit}::selection{background:var(--accent-soft);color:var(--fg)}.shell{min-height:100vh;display:flex;flex-direction:column}.shell-main{flex:1;max-width:var(--container);width:100%;margin:0 auto;padding:0 28px}.topnav{position:sticky;top:0;z-index:50;background:color-mix(in srgb,var(--bg) 86%,transparent);backdrop-filter:blur(14px) saturate(160%);-webkit-backdrop-filter:blur(14px) saturate(160%);border-bottom:1px solid var(--line)}.topnav-inner{max-width:var(--container);margin:0 auto;padding:14px 28px;display:flex;align-items:center;justify-content:space-between;gap:24px}.brand{display:flex;align-items:center;gap:10px;cursor:pointer;font-family:var(--display);font-weight:600;font-size:18px;letter-spacing:-.01em}.brand-avatar{width:36px;height:36px;border-radius:50%;background:var(--bg-alt);border:1.5px solid var(--accent);display:grid;place-items:center;overflow:hidden;flex-shrink:0}.brand-avatar img{width:100%;height:100%;object-fit:cover;display:block}.brand-mark{width:26px;height:26px;border-radius:50%;background:var(--accent);color:#fff;display:grid;place-items:center;font-size:11px;font-weight:700;font-family:var(--sans);letter-spacing:.02em}.brand-name{line-height:1}.brand-sub{display:block;font-size:14px;font-weight:500;color:var(--fg);letter-spacing:0;font-family:var(--sans);line-height:1.1}.nav-links{display:flex;align-items:center;gap:4px}.nav-links a{padding:6px 12px;border-radius:999px;font-size:14px;color:var(--fg-dim);font-weight:500;transition:color .15s,background .15s}.nav-links a:hover{color:var(--accent);background:var(--accent-wash)}.nav-links a.is-active{color:var(--accent);background:var(--accent-soft)}.nav-tools{display:flex;align-items:center;gap:6px}.theme-toggle,.nav-tools>button{width:34px;height:34px;border-radius:999px;border:0;background:transparent;color:var(--fg-dim);cursor:pointer;display:grid;place-items:center;transition:background .15s,color .15s}.theme-toggle:hover,.nav-tools>button:hover{background:var(--bg-alt);color:var(--fg)}.lang-switcher{display:flex;align-items:center;gap:2px;border:1px solid var(--line);border-radius:999px;padding:0 8px;height:28px}.lang-btn{width:auto;height:auto;border-radius:0;border:0;background:transparent;color:var(--fg-soft);cursor:pointer;font-size:11px;font-weight:600;letter-spacing:.06em;padding:0 3px;line-height:1;transition:color .15s}.lang-btn:hover{color:var(--fg);background:transparent}.lang-btn.is-active{color:var(--accent)}.lang-sep{color:var(--line-strong);font-size:11px;-webkit-user-select:none;user-select:none}.nav-hamburger{display:none;flex-direction:column;justify-content:center;gap:5px;width:34px;height:34px;background:transparent;border:0;cursor:pointer;padding:6px;border-radius:8px;flex-shrink:0}.nav-hamburger span{display:block;height:2px;border-radius:2px;background:var(--fg-dim);transition:background .15s}.nav-hamburger:hover span{background:var(--fg)}.nav-mobile-menu{display:flex;flex-direction:column;border-top:1px solid var(--line);padding:12px 20px 16px;gap:2px}.nav-mobile-menu a{padding:10px 12px;border-radius:8px;font-size:15px;font-weight:500;color:var(--fg-dim);transition:background .15s,color .15s}.nav-mobile-menu a:hover{background:var(--accent-wash);color:var(--accent)}.nav-mobile-menu a.is-active{color:var(--accent);background:var(--accent-soft)}.nav-mobile-tools{display:flex;align-items:center;gap:6px;padding:10px 12px 0;margin-top:6px;border-top:1px solid var(--line)}.gh-stars-badge{display:inline-flex;align-items:center;gap:6px;height:28px;padding:0 10px 0 8px;border-radius:999px;background:transparent;color:var(--fg-dim);border:1px solid transparent;font-size:12px;font-weight:500;font-variant-numeric:tabular-nums;line-height:1;text-decoration:none;transition:background .15s,color .15s,border-color .15s}.gh-stars-badge:hover{background:var(--bg-alt);color:var(--fg)}.gh-stars-badge svg{display:block;color:currentColor}.gh-meta{display:inline-flex;align-items:center;gap:3px;color:var(--fg-soft);opacity:.55;font-size:11px;font-variant-numeric:tabular-nums;transition:opacity .15s}.gh-stars-badge:hover .gh-meta{opacity:.9}.gh-stars-badge .gh-stars-icon{display:inline-flex;align-items:center}.gh-stars-num{letter-spacing:.01em;line-height:1}.page{padding:60px 0 var(--d-section);position:relative;overflow:clip}.deco{position:absolute;pointer-events:none;color:var(--accent);opacity:.08}.deco-pen{width:380px;top:-30px;right:-40px}.page-head{max-width:var(--measure);margin-bottom:48px}.page-title{font-family:var(--display);font-weight:500;font-size:clamp(40px,5vw,64px);line-height:1.05;letter-spacing:-.02em;margin:12px 0 16px}.page-lede{font-size:19px;color:var(--fg-dim);line-height:1.55;max-width:60ch}.section{margin-top:var(--d-section)}.section-head{display:flex;justify-content:space-between;align-items:end;gap:24px;margin-bottom:32px;padding-bottom:16px;border-bottom:1px solid var(--line);position:relative}.section-head:after{content:"";position:absolute;left:0;bottom:-1px;width:64px;height:2px;background:var(--accent)}.section-title{font-family:var(--display);font-weight:500;font-size:32px;margin:8px 0 0;letter-spacing:-.015em}.section-head-right{font-size:14px;color:var(--fg-dim)}.hero-eyebrow{font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--accent);font-weight:600}.hero{padding:124px 0 calc(24px + var(--d-section));position:relative;isolation:isolate}.hero>:not(.hero-rain-wrap){position:relative;z-index:1}.page.home{overflow:visible;padding:0}.now-section{position:relative;margin-top:0;padding:var(--d-section) 0;background:var(--bg-alt)}.now-section:before{content:"";position:absolute;top:0;right:50%;bottom:0;left:50%;width:100vw;height:100%;transform:translate(-50%);background:var(--bg-alt);border-top:1px solid var(--line);z-index:-1}.now-section>*{position:relative;z-index:1}.hero-stacked .hero-name{font-family:var(--display);font-weight:400;font-size:clamp(72px,9vw,128px);line-height:.92;letter-spacing:0;margin:12px 0 8px;text-transform:uppercase}.hero-stacked .hero-role{font-size:18px;color:var(--accent);margin:0 0 28px;font-family:var(--mono);letter-spacing:.04em}.hero-stacked .hero-bio{max-width:60ch;font-size:19px;line-height:1.55;color:var(--fg)}.hero-split{display:grid;grid-template-columns:1.4fr 1fr;gap:64px;align-items:center}.hero-split .hero-name.display{font-family:var(--display);font-weight:400;font-size:clamp(64px,8vw,112px);line-height:.94;letter-spacing:0;margin:12px 0 20px;text-transform:uppercase;white-space:nowrap}.hero-type{display:inline-block;overflow:hidden;vertical-align:bottom;white-space:nowrap;max-width:0;animation:hero-type 1.4s steps(15,end) .35s forwards}.hero-caret{display:inline-block;width:.5ch;height:.78em;margin-left:.06em;background:var(--accent);vertical-align:-.04em;box-shadow:0 0 12px color-mix(in srgb,var(--accent) 65%,transparent);animation:hero-caret-blink .9s steps(1) infinite;animation-delay:1.9s}@keyframes hero-type{to{max-width:15ch}}@keyframes hero-caret-blink{50%{background:transparent;box-shadow:none}}@media(prefers-reduced-motion:reduce){.hero-type{animation:none;max-width:none}.hero-caret{animation:hero-caret-blink .9s steps(1) infinite;animation-delay:0s}}.hero-split .hero-bio{font-size:18px;color:var(--fg-dim);margin-bottom:28px}.tech-stack{display:flex;align-items:flex-start;gap:16px;margin:0 0 32px;padding-top:4px}.tech-stack-label{font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--fg-soft);padding-top:8px;flex-shrink:0}.tech-stack-list{list-style:none;margin:0;padding:0;display:flex;flex-wrap:wrap;gap:8px}.tech-chip{display:inline-flex;align-items:center;gap:8px;padding:5px 10px 5px 9px;border:1px solid var(--line);border-radius:var(--r-1);background:var(--accent-wash);font-family:var(--mono);font-size:12.5px;color:var(--fg-dim);transition:border-color .18s ease,color .18s ease,background .18s ease;cursor:default}.tech-chip:hover{border-color:var(--line-strong);color:var(--fg);background:var(--accent-soft)}.tech-chip-icon{display:block;width:18px;height:18px;opacity:.95;filter:brightness(0) saturate(100%) invert(86%) sepia(38%) saturate(749%) hue-rotate(45deg) brightness(102%) contrast(95%)}.hero-manifesto{padding:96px 0 40px;max-width:28ch}.manifesto-line{font-family:var(--display);font-weight:400;font-size:clamp(48px,6.5vw,84px);line-height:1;letter-spacing:0;margin:0;text-wrap:balance;text-transform:uppercase}.manifesto-line.dim{color:var(--fg-soft)}.manifesto-line strong{font-weight:600;color:var(--accent)}.hero-actions{display:flex;gap:12px;margin-top:28px;flex-wrap:wrap}.now-card{background:var(--accent-soft);border:1px solid var(--line-strong);border-radius:var(--r-3);padding:24px;position:relative;overflow:hidden}.now-card:before{content:"";position:absolute;top:-40px;right:-40px;width:120px;height:120px;border-radius:50%;background:var(--accent);opacity:.1}.now-card-hd{display:flex;align-items:center;gap:8px;font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--accent);font-weight:700;margin-bottom:14px;position:relative}.now-pulse{width:8px;height:8px;border-radius:50%;background:var(--accent);box-shadow:0 0 0 0 var(--accent);animation:pulse 2.4s ease-out infinite}@keyframes pulse{0%{box-shadow:0 0 0 0 var(--accent-soft)}70%{box-shadow:0 0 0 10px transparent}to{box-shadow:0 0 0 0 transparent}}.now-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px}.now-list li{font-size:14px;line-height:1.5;color:var(--fg);padding-left:14px;position:relative}.now-list li:before{content:"";position:absolute;left:0;top:9px;width:5px;height:5px;border-radius:50%;background:var(--accent)}.now-list.large li{font-size:17px;color:var(--fg)}.now-list a{color:var(--accent);font-weight:600;text-decoration:underline;text-decoration-thickness:1px;text-underline-offset:2px}.now-list a:hover{color:var(--accent-strong, var(--accent));text-decoration-thickness:2px}.now-more{display:inline-block;margin-top:16px;font-size:13px;color:var(--accent);font-weight:500}.btn{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:0;cursor:pointer;font-size:14.5px;font-weight:500;padding:12px 22px;border-radius:999px;transition:transform .12s,background .15s,color .15s;font-family:inherit}.btn:active{transform:translateY(1px)}.btn-primary{background:var(--accent);color:var(--bg);font-weight:600}.btn-primary:hover{background:var(--accent-2);color:var(--bg)}.btn-ghost{background:transparent;color:var(--accent);border:1px solid var(--line-strong)}.btn-ghost:hover{background:var(--accent-soft);border-color:var(--accent)}.tag-pill{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:1px solid var(--line);background:var(--bg);color:var(--fg-dim);cursor:pointer;font-size:12px;font-weight:500;padding:4px 10px 4px 8px;border-radius:999px;display:inline-flex;align-items:center;gap:6px;font-family:inherit;transition:background .15s,border-color .15s,color .15s}.tag-pill:hover{color:var(--accent);border-color:var(--accent)}.tag-pill.is-active{background:var(--accent);color:#fff;border-color:var(--accent)}.tag-pill.is-active .tag-dot{background:#fff}.tag-dot{width:6px;height:6px;border-radius:50%;background:var(--tag-color, var(--fg-soft))}.tag-pill.all{padding:4px 12px}.featured-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}.feat-card{background:var(--bg);border:1px solid var(--line);border-radius:var(--r-3);padding:28px 24px;cursor:pointer;transition:transform .2s cubic-bezier(.3,.7,.4,1),border-color .2s,background .2s,box-shadow .2s;display:flex;flex-direction:column;gap:14px;position:relative;overflow:hidden}.feat-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--accent);transform-origin:left;transform:scaleX(0);transition:transform .25s cubic-bezier(.3,.7,.4,1)}.feat-card:hover{transform:translateY(-3px);border-color:var(--accent);box-shadow:0 12px 28px -16px var(--accent-soft)}.feat-card:hover:before{transform:scaleX(1)}.feat-meta{font-size:12px;color:var(--accent);font-weight:600;display:flex;gap:8px;align-items:center}.feat-meta .dot{color:var(--fg-soft)}.feat-title{font-family:var(--display);font-weight:500;font-size:22px;line-height:1.2;letter-spacing:-.015em;margin:0;text-wrap:balance}.feat-excerpt{font-size:14.5px;color:var(--fg-dim);margin:0;line-height:1.55}.feat-tags{display:flex;gap:6px;flex-wrap:wrap;margin-top:auto}.article-list{display:flex;flex-direction:column}.article-row{display:grid;grid-template-columns:160px 1fr 28px;gap:32px;padding:var(--d-y) 16px;border-top:1px solid var(--line);cursor:pointer;align-items:start;transition:background .15s}[data-js] .article-row{animation:row-in .5s ease both}.article-row:first-child{border-top:none}.article-row:last-child{border-bottom:1px solid var(--line)}.variant-stacked .article-row{margin:0 -16px}.article-row:hover{background:var(--accent-wash)}.article-row:hover .article-row-title{color:var(--accent)}.article-row:hover .article-row-arrow{transform:translate(4px);color:var(--accent)}@keyframes row-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.article-row-meta{font-size:13px;color:var(--fg-soft);display:flex;flex-direction:column;gap:2px;font-variant-numeric:tabular-nums;padding-top:4px}.article-row-meta .dot{display:none}.article-row-meta time{color:var(--accent);font-weight:600}.article-row-meta .stat{display:inline-flex;align-items:center;gap:5px;line-height:1}.article-row-meta .stat svg{opacity:.85}.article-row-title{font-family:var(--display);font-weight:500;font-size:24px;line-height:1.25;letter-spacing:-.015em;margin:0 0 8px;text-wrap:balance;transition:color .15s}.article-row-excerpt{color:var(--fg-dim);margin:0 0 12px;font-size:15px;line-height:1.55;max-width:60ch}.article-row-tags{display:flex;gap:6px;flex-wrap:wrap}.article-row-arrow{font-size:18px;color:var(--accent);transition:transform .2s,color .2s;padding-top:4px}.variant-grid .article-list{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}.filters{margin:32px 0 24px;display:flex;flex-direction:column;gap:16px}.search-row{display:flex;align-items:center;gap:10px;background:var(--bg);border:1px solid var(--line);border-radius:var(--r-2);padding:0 14px;height:44px;transition:border-color .15s,box-shadow .15s}.search-row:focus-within{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.search-row svg{color:var(--accent);flex-shrink:0}.search-row input{flex:1;border:0;background:transparent;color:var(--fg);font-family:inherit;font-size:15px;outline:none}.search-row input::placeholder{color:var(--fg-soft)}.search-clear{border:0;background:transparent;color:var(--fg-soft);cursor:pointer;font-size:13px;padding:4px 8px;border-radius:6px}.search-clear:hover{background:var(--line);color:var(--fg)}.tag-row{display:flex;gap:8px;flex-wrap:wrap}.newsletter-card{background:var(--accent);color:#fff;border:1px solid var(--accent);border-radius:var(--r-3);padding:40px;display:grid;grid-template-columns:1fr auto;gap:40px;align-items:center;position:relative;overflow:hidden}.newsletter-card:before{content:"";position:absolute;bottom:-80px;right:-80px;width:240px;height:240px;border-radius:50%;background:#ffffff14}.newsletter-card *{position:relative}.newsletter-card .newsletter-eyebrow{color:#ffffffc7}.newsletter-card .newsletter-title{color:#fff}.newsletter-card .newsletter-sub{color:#ffffffdb}.newsletter-eyebrow{font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--accent);font-weight:600;margin-bottom:8px}.newsletter-title{font-family:var(--display);font-weight:500;font-size:28px;letter-spacing:-.015em;margin:0 0 8px}.newsletter-sub{color:var(--fg-dim);margin:0;font-size:15px;max-width:50ch}.newsletter-form{display:flex;gap:8px}.newsletter-form input{border:1px solid rgba(255,255,255,.4);background:#ffffff1f;border-radius:999px;padding:12px 18px;min-width:240px;font-family:inherit;font-size:14.5px;color:#fff;outline:none}.newsletter-form input::placeholder{color:#fff9}.newsletter-form input:focus{border-color:#fff;background:#fff3}.newsletter-card .btn-primary{background:#fff;color:var(--accent)}.newsletter-card .btn-primary:hover{background:var(--fg);color:#fff}.reading-progress{position:fixed;top:0;left:0;right:0;height:2px;background:var(--accent);transform-origin:0 0;transform:scaleX(0);z-index:100;transition:transform .1s}.back-link{display:inline-flex;align-items:center;gap:6px;background:transparent;border:0;color:var(--fg-dim);font-family:inherit;font-size:13.5px;cursor:pointer;padding:8px 0;margin-bottom:24px}.back-link:hover{color:var(--fg)}.article-head{max-width:760px;margin-bottom:56px}.article-tags{display:flex;gap:6px;margin-bottom:18px}.article-title{font-family:var(--display);font-weight:500;font-size:clamp(36px,4.5vw,56px);line-height:1.08;letter-spacing:-.025em;margin:0 0 20px;text-wrap:balance}.article-excerpt{font-family:var(--sans);font-size:21px;line-height:1.55;color:var(--fg);font-style:normal;margin:0 0 32px;max-width:62ch;padding-left:20px;border-left:2px solid var(--accent)}.article-meta{display:flex;align-items:center;justify-content:space-between;padding-top:24px;border-top:1px solid var(--line)}.byline{display:flex;align-items:center;gap:12px}.avatar{width:40px;height:40px;border-radius:50%;background:var(--accent);color:#fff;display:grid;place-items:center;font-size:13px;font-weight:600;letter-spacing:.02em}.avatar.small{width:32px;height:32px;font-size:11px}.byline-name{font-weight:600;font-size:14.5px}.byline-sub{font-size:12.5px;color:var(--fg-soft);display:flex;gap:6px}.article-actions{display:flex;gap:4px}.icon-btn{width:38px;height:38px;border-radius:999px;border:1px solid var(--line);background:transparent;color:var(--fg-dim);cursor:pointer;display:grid;place-items:center;transition:all .15s}.icon-btn:hover{color:var(--fg);border-color:var(--line-strong)}.icon-btn.is-on{color:var(--accent);border-color:var(--accent)}.article-layout{display:grid;grid-template-columns:200px 1fr;gap:64px;align-items:start}.toc{position:sticky;top:92px;font-size:13px;border-left:1px solid var(--line);padding-left:16px}.toc-label{font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--fg-soft);font-weight:600;margin-bottom:12px}.toc ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:6px}.toc li a{color:var(--fg-soft);display:block;padding:4px 0;line-height:1.4;transition:color .15s}.toc li a:hover{color:var(--fg)}.toc{border-left:2px solid var(--line)}.toc li.is-active{position:relative}.toc li.is-active:before{content:"";position:absolute;left:-18px;top:0;bottom:0;width:2px;background:var(--accent)}.toc li.is-active a{color:var(--accent);font-weight:600}.toc-3{padding-left:12px;font-size:12.5px}.article-body{font-family:var(--serif);font-size:19px;line-height:1.65;max-width:64ch;color:var(--fg)}.article-body p{margin:0 0 1.4em;text-align:justify;hyphens:auto;-webkit-hyphens:auto}.article-body li{text-align:justify;hyphens:auto;-webkit-hyphens:auto}.article-body h2{font-family:var(--display);font-weight:500;font-size:30px;line-height:1.2;letter-spacing:-.015em;margin:2em 0 .6em;scroll-margin-top:100px}.article-body h3{font-family:var(--display);font-weight:500;font-size:22px;margin:1.6em 0 .5em;scroll-margin-top:100px}.article-body ul{font-size:17px;line-height:1.6;padding-left:22px;margin:0 0 1.4em}.article-body ul li{margin-bottom:8px}.article-body strong{font-weight:600;color:var(--accent)}.article-body :not(pre)>code{font-family:var(--mono);font-size:.86em;background:var(--accent-soft);color:var(--accent-2);padding:2px 6px;border-radius:4px;border:1px solid color-mix(in srgb,var(--accent) 22%,transparent)}.article-body h2{color:var(--fg);position:relative}.article-body h2:before{content:"";display:inline-block;width:24px;height:2px;background:var(--accent);vertical-align:middle;margin-right:12px;transform:translateY(-4px)}.code-block{margin:1.4em 0;border-radius:var(--r-2);overflow:hidden;border:1px solid var(--line);background:var(--bg-alt);font-family:var(--mono);font-size:14px}.code-head{display:flex;justify-content:space-between;align-items:center;padding:8px 14px;border-bottom:1px solid var(--line);background:color-mix(in srgb,var(--bg-alt) 60%,var(--bg))}.code-lang{font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--fg-soft);font-weight:600}.code-copy{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:0;background:transparent;color:var(--fg-dim);font-family:inherit;font-size:11.5px;cursor:pointer;padding:4px 8px;border-radius:6px}.code-copy:hover{background:var(--line);color:var(--fg)}.code-block pre{margin:0;padding:16px 18px;overflow-x:auto;line-height:1.6}.code-block code{font-family:var(--mono)}.tk-kw{color:#b8553f}.tk-str{color:#1f8a5b}.tk-cmt{color:var(--fg-soft);font-style:italic}[data-theme=dark] .tk-kw{color:var(--accent-2)}[data-theme=dark] .tk-str{color:var(--accent)}.article-body pre{margin:1.4em 0;padding:16px 18px;overflow-x:auto;border-radius:var(--r-2);border:1px solid var(--line);background:var(--bg-alt);font-family:var(--mono);font-size:14px;line-height:1.6}.article-body pre code{font-family:var(--mono);font-size:inherit;background:none;border:0;padding:0;color:var(--fg)}.article-body a{color:var(--accent);text-decoration:underline;text-underline-offset:2px;text-decoration-thickness:1px}.article-body a:hover{color:var(--accent-2)}.article-body table{width:100%;border-collapse:collapse;margin:1.6em 0;font-family:var(--sans);font-size:15px}.article-body th,.article-body td{text-align:left;padding:9px 14px;border-bottom:1px solid var(--line)}.article-body th{font-weight:600;color:var(--fg-dim);font-size:12.5px;letter-spacing:.04em;text-transform:uppercase}.article-body tbody tr:last-child td{border-bottom:0}.article-body blockquote{margin:1.4em 0;padding:4px 0 4px 18px;border-left:3px solid var(--accent);color:var(--fg-dim);font-style:italic}.article-body figure{margin:2em 0}.article-body img{display:block;max-width:100%;height:auto;border-radius:var(--r-2);border:1px solid var(--line)}.article-body figcaption{margin-top:10px;font-family:var(--sans);font-size:13.5px;color:var(--fg-soft);text-align:center;line-height:1.5}.comments{margin:48px 0}.comments h3{font-family:var(--sans);font-size:14px;font-weight:600;letter-spacing:.02em;color:var(--fg-dim);margin:0 0 20px;text-transform:uppercase;letter-spacing:.08em}.comment-form{display:grid;grid-template-columns:auto 1fr auto;gap:12px;margin-bottom:32px;align-items:start}.comment-form textarea{border:1px solid var(--line);border-radius:var(--r-2);background:var(--bg-alt);padding:12px 14px;font-family:var(--sans);font-size:14.5px;color:var(--fg);min-height:76px;resize:vertical;outline:none}.comment-form textarea:focus{border-color:var(--line-strong)}.comment-form button{align-self:end}.comment-form button:disabled{opacity:.4;cursor:not-allowed}.comment-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:24px}.comment-list li{display:grid;grid-template-columns:auto 1fr;gap:12px}.comment-head{display:flex;gap:8px;align-items:baseline;margin-bottom:4px;font-size:13px}.comment-head .dim{color:var(--fg-soft)}.comment-list p{margin:0;font-family:var(--sans);font-size:14.5px;line-height:1.55;color:var(--fg-dim)}.related{margin-top:64px}.about-grid{display:grid;grid-template-columns:280px 1fr;gap:64px;align-items:start}.about-portrait{position:sticky;top:92px}.portrait-frame{width:100%;aspect-ratio:4/5;border-radius:var(--r-3);background:var(--bg-alt);border:1px solid var(--line);overflow:hidden;margin-bottom:24px}.portrait-img{width:100%;height:100%;object-fit:cover;display:block}.portrait-placeholder{width:100%;height:100%;background:repeating-linear-gradient(45deg,transparent 0,transparent 14px,var(--line) 14px,var(--line) 15px);display:grid;place-items:center;color:var(--fg-soft);font-family:var(--mono);font-size:12px;letter-spacing:.06em}.about-facts{margin:0;display:flex;flex-direction:column;gap:14px;font-size:13.5px}.about-facts>div{display:grid;grid-template-columns:80px 1fr;gap:12px}.about-facts dt{color:var(--fg-soft);margin:0}.about-facts dd{margin:0;color:var(--fg)}.about-facts a{color:var(--fg);border-bottom:1px solid var(--line-strong)}.about-facts a:hover{color:var(--accent);border-color:var(--accent)}.about-prose{font-family:var(--serif);font-size:18px;line-height:1.65;max-width:60ch}.about-prose .lede-prose{font-size:22px;color:var(--fg);margin-top:0}.about-prose p{margin:0 0 1.3em;color:var(--fg-dim)}.about-prose h3{font-family:var(--display);font-size:22px;font-weight:500;margin:2em 0 .5em;color:var(--fg)}.about-prose strong{color:var(--fg);font-weight:600}.about-actions{margin-top:32px;display:flex;gap:12px}.projects-list{display:flex;flex-direction:column}.project-row{display:grid;grid-template-columns:200px 1fr;gap:32px;padding:32px 0;border-top:1px solid var(--line);align-items:start}.project-row:last-child{border-bottom:1px solid var(--line)}.project-row.is-minor{padding:14px 0;opacity:.55}.project-row.is-minor .project-name{font-size:15px;font-weight:500}.project-row.is-minor .project-body p{font-size:13px;max-width:50ch;margin-bottom:8px}.project-row.is-minor .project-meta{font-size:11px}.project-row.is-minor .project-year{font-size:12px}.project-row.is-minor .stack-chip{font-size:10px;padding:2px 6px}.project-row.is-minor:hover{opacity:.9}.projects-divider{margin:56px 0 16px;display:flex;align-items:center;gap:14px}.projects-divider-label{font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--fg-soft)}.projects-list-minor{opacity:1}.project-meta{font-size:13px;color:var(--fg-soft);display:flex;flex-direction:column;gap:4px;padding-top:6px}.project-year{color:var(--accent);font-weight:600;font-variant-numeric:tabular-nums}.project-name{font-family:var(--display);font-weight:500;font-size:26px;letter-spacing:-.015em;margin:0 0 12px;display:inline-flex;align-items:center;gap:8px}.project-link{font-size:16px;color:var(--fg-soft);transition:transform .15s}.project-row:hover .project-link{transform:translate(2px,-2px);color:var(--accent)}.project-wip{display:inline-block;font-family:var(--mono);font-size:10px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;padding:2px 7px;border-radius:999px;background:var(--accent-soft);color:var(--accent);border:1px solid var(--line-strong);vertical-align:middle;margin-left:4px}.project-body p{color:var(--fg-dim);margin:0 0 14px;max-width:78ch;line-height:1.55}.project-highlights-wrap{margin:0 0 18px;max-width:78ch}.project-highlights-eyebrow{font-size:10.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--accent);font-weight:700;margin-bottom:10px}.project-highlights{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:6px}.project-highlight{background:var(--accent-wash);border:1px solid var(--line);border-left:2px solid var(--accent);border-radius:var(--r-1);padding:8px 8px 4px 12px}.project-highlight-title{font-family:var(--display);font-weight:500;font-size:14.5px;letter-spacing:-.01em;color:var(--fg);margin-bottom:2px}.project-highlight-text{margin:0;font-size:13px;line-height:1.45;color:var(--fg-dim)}.project-stack{display:flex;gap:6px;flex-wrap:wrap}.stack-chip{font-size:11.5px;padding:3px 9px;border-radius:999px;background:var(--accent-soft);border:1px solid var(--line-strong);color:var(--accent);font-family:var(--mono);font-weight:500}.now-uses{display:grid;grid-template-columns:1fr 1fr;gap:64px}.uses-list{margin:0;display:flex;flex-direction:column;gap:18px}.uses-list>div{display:grid;grid-template-columns:130px 1fr;gap:16px;padding-bottom:18px;border-bottom:1px solid var(--line)}.uses-list dt{color:var(--fg-soft);margin:0;font-size:13.5px;font-weight:500}.uses-list dd{margin:0;color:var(--fg-dim);font-size:14.5px;line-height:1.5}.footer{border-top:2px solid var(--accent);margin-top:96px;background:var(--bg-alt)}.footer-inner{max-width:var(--container);margin:0 auto;padding:48px 28px 32px;display:grid;grid-template-columns:2fr 1fr 1fr;gap:40px}.footer-inner>div{padding:32px 0}.footer h4{font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--accent);font-weight:700;margin:0 0 14px}.footer ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:8px;font-size:14px}.footer ul a{color:var(--fg-dim)}.footer ul a:hover{color:var(--accent)}.footer-brand p{margin:12px 0 0;color:var(--fg-dim);font-size:14px;max-width:40ch}.footer-bottom{max-width:var(--container);margin:0 auto;padding:20px 28px;border-top:1px solid var(--line);display:flex;justify-content:space-between;font-size:12.5px;color:var(--fg-soft)}.empty-state{text-align:center;padding:64px 0;color:var(--fg-dim)}.empty-state p{margin-bottom:16px}.dot{color:var(--accent)}.link-arrow{color:var(--accent);font-weight:600}.link-arrow:hover{text-decoration:underline}@media(max-width:920px){.hero-split{grid-template-columns:1fr;gap:32px}.featured-grid{grid-template-columns:1fr}.article-row{grid-template-columns:1fr;gap:8px}.article-row-arrow{display:none}.article-layout{grid-template-columns:1fr}.toc{display:none}.about-grid{grid-template-columns:1fr}.about-portrait{position:static;max-width:280px}.project-row{grid-template-columns:1fr;gap:12px}.now-uses{grid-template-columns:1fr;gap:40px}.footer-inner{grid-template-columns:1fr 1fr}.newsletter-card{grid-template-columns:1fr;gap:24px;padding:28px}.newsletter-form{flex-direction:column}.newsletter-form input{min-width:0;width:100%}.nav-links,.nav-tools{display:none}.nav-hamburger{display:flex}.shell-main{padding:0 20px}.topnav-inner{padding:14px 20px}.footer-inner{padding:0 20px}}@media(max-width:480px){.shell-main{padding:0 20px}.topnav-inner{padding:12px 20px}}.hero-split{grid-template-columns:1fr}.hero-split-right{display:none}.content-with-sidebar{display:grid;grid-template-columns:220px 1fr;gap:56px;align-items:start}.content-with-sidebar.is-guides{grid-template-columns:320px 1fr}.content-sidebar{position:sticky;top:92px}.sidebar-link{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:0;background:transparent;cursor:pointer;font-family:inherit;color:var(--fg-dim);display:flex;flex-direction:column;gap:4px;width:100%;padding:8px 14px;text-align:left;border-left:2px solid transparent;margin:0 0 12px -16px;transition:color .15s,border-color .15s}.sidebar-link:hover{color:var(--fg)}.sidebar-link:hover .sidebar-hint{color:var(--fg-dim)}.sidebar-link.is-active{color:var(--accent);border-left-color:var(--accent)}.sidebar-link-row{font-family:var(--display);font-weight:500;font-size:22px;letter-spacing:-.015em;display:flex;align-items:baseline;justify-content:space-between;gap:10px}.sidebar-count{font-family:var(--mono);font-size:11px;font-weight:500;color:var(--fg-soft);letter-spacing:.05em}.sidebar-link.is-active .sidebar-count{color:var(--accent)}.sidebar-hint{font-size:12.5px;color:var(--fg-soft);line-height:1.45;margin:0}.sidebar-chips{list-style:none;padding:0;margin:0 0 24px;display:grid;grid-template-columns:repeat(auto-fill,68px);gap:6px;justify-content:start}.sidebar-chips li{display:contents}.sidebar-chip{-webkit-appearance:none;-moz-appearance:none;appearance:none;cursor:pointer;width:100%;aspect-ratio:1 / 1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;border:1px solid var(--line);background:transparent;color:var(--fg-dim);font-family:inherit;font-size:9.5px;font-weight:500;line-height:1.15;padding:6px 4px;border-radius:var(--r-1);text-align:center;text-wrap:balance;transition:background .15s,border-color .15s,color .15s}.sidebar-chip-label{display:block}.sidebar-chip:hover{color:var(--fg);border-color:var(--line-strong);background:var(--accent-wash)}.sidebar-chip.is-active{background:var(--accent-soft);border-color:var(--accent);color:var(--accent)}.guides-list{display:flex;flex-direction:column;gap:28px}.guide-card{border:1px solid var(--line);border-left:3px solid var(--accent);border-radius:var(--r-3);padding:24px 28px;background:color-mix(in srgb,var(--bg-alt) 60%,transparent)}.guide-card-head{display:flex;align-items:baseline;justify-content:space-between;gap:16px;margin-bottom:8px}.guide-card-title{font-family:var(--display);font-weight:500;font-size:26px;letter-spacing:-.015em;color:var(--fg);margin:0}.guide-card-count{font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--accent);font-weight:600}.guide-card-blurb{margin:0 0 18px;color:var(--fg-dim);font-size:15px;line-height:1.55;max-width:60ch}.guide-steps{list-style:none;padding:0;margin:0}.guide-step{display:grid;grid-template-columns:auto 1fr auto;gap:16px;align-items:center;padding:12px;border-top:1px solid var(--line);color:var(--fg);cursor:pointer;transition:background .15s,color .15s}.guide-step:hover{background:var(--accent-wash);color:var(--accent)}.guide-step-num{font-family:var(--mono);font-size:12px;font-weight:600;color:var(--accent);letter-spacing:.06em}.guide-step-body{display:flex;flex-direction:column;gap:2px}.guide-step-title{font-family:var(--display);font-weight:500;font-size:16px;letter-spacing:-.01em;line-height:1.3}.guide-step-meta{font-size:12px;color:var(--fg-soft);display:flex;gap:6px}.guide-step-arrow{color:var(--accent);font-size:16px;transition:transform .15s}.guide-step:hover .guide-step-arrow{transform:translate(3px)}.guide-step-badge{display:inline-block;vertical-align:middle;margin-left:8px;padding:1px 7px;font-family:var(--mono);font-size:9.5px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--accent);background:var(--accent-soft);border:1px solid var(--accent);border-radius:999px;line-height:1.4}.guide-step.is-guide-step .guide-step-num{color:var(--accent)}@media(max-width:920px){.content-with-sidebar{grid-template-columns:1fr;gap:24px}.content-sidebar{position:static;display:flex;flex-wrap:wrap;gap:6px}.sidebar-link{width:auto;padding:6px 14px;margin-left:0}.sidebar-hint{display:none}}.longform-card{display:block;text-decoration:none;color:inherit;border:1px solid var(--line);border-left:3px solid var(--accent);border-radius:var(--r-3);padding:28px 32px;background:color-mix(in srgb,var(--bg-alt) 60%,transparent);transition:border-color .15s,transform .15s,background .15s}.longform-card+.longform-card{margin-top:20px}.longform-card:hover{border-color:var(--accent);transform:translateY(-2px);background:color-mix(in srgb,var(--accent-wash) 50%,var(--bg-alt))}.longform-card-eyebrow{font-family:var(--mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--accent);font-weight:600;display:flex;align-items:center;gap:8px;margin-bottom:12px}.longform-card-eyebrow .dot{color:var(--fg-soft)}.longform-card-title{font-family:var(--display);font-weight:500;font-size:clamp(26px,3vw,32px);line-height:1.15;letter-spacing:-.02em;margin:0 0 12px;color:var(--fg);text-wrap:balance}.longform-card-subtitle{font-family:var(--serif);font-size:17px;line-height:1.5;font-style:italic;color:var(--fg-dim);margin:0 0 14px;max-width:60ch}.longform-card-blurb{margin:0 0 22px;color:var(--fg-dim);font-size:14.5px;line-height:1.6;max-width:64ch}.longform-card-foot{display:flex;align-items:center;justify-content:space-between;gap:16px;padding-top:16px;border-top:1px solid var(--line)}.longform-card-tags{display:flex;gap:6px;flex-wrap:wrap}.longform-card-cta{font-family:var(--mono);font-size:12.5px;font-weight:600;letter-spacing:.04em;color:var(--accent)}.guide-page{max-width:1140px}.guide-hero{max-width:820px;margin-bottom:56px}.guide-hero-eyebrow{font-family:var(--mono);font-size:12px;letter-spacing:.08em;text-transform:uppercase;color:var(--accent);font-weight:600;display:flex;align-items:center;gap:8px;margin-bottom:18px}.guide-hero-eyebrow .dot{color:var(--fg-soft)}.guide-hero-title{font-family:var(--display);font-weight:500;font-size:clamp(40px,5vw,60px);line-height:1.05;letter-spacing:-.025em;margin:0 0 20px;text-wrap:balance}.guide-hero-subtitle{font-family:var(--serif);font-size:22px;line-height:1.5;color:var(--fg);font-style:italic;margin:0 0 32px;max-width:62ch;padding-left:20px;border-left:3px solid var(--accent)}.guide-hero-meta{display:flex;align-items:center;justify-content:space-between;gap:16px;padding-top:24px;border-top:1px solid var(--line)}.guide-hero-tags{display:flex;gap:6px;flex-wrap:wrap}.guide-layout{display:grid;grid-template-columns:240px 1fr;gap:64px;align-items:start}.guide-toc{position:sticky;top:92px;font-size:13.5px;border-left:2px solid var(--line);padding-left:18px}.guide-toc-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:4px}.guide-toc-item a{display:grid;grid-template-columns:auto 1fr;gap:10px;padding:6px 0;color:var(--fg-soft);align-items:baseline;line-height:1.35;transition:color .15s}.guide-toc-item a:hover{color:var(--fg)}.guide-toc-num{font-family:var(--mono);font-size:10.5px;font-weight:600;letter-spacing:.06em;color:var(--fg-soft)}.guide-toc-text{color:inherit}.guide-toc-item.is-active{position:relative}.guide-toc-item.is-active:before{content:"";position:absolute;left:-20px;top:4px;bottom:4px;width:2px;background:var(--accent)}.guide-toc-item.is-active a,.guide-toc-item.is-active .guide-toc-num{color:var(--accent);font-weight:600}.guide-body{font-family:var(--serif);font-size:19px;line-height:1.7;max-width:68ch;color:var(--fg)}.guide-body p{margin:0 0 1.4em}.guide-body strong{font-weight:600;color:var(--accent)}.guide-intro{margin-bottom:56px;padding-bottom:32px;border-bottom:1px solid var(--line)}.guide-intro p{font-size:20px;line-height:1.7}.guide-body h2{font-family:var(--display);font-weight:500;font-size:34px;line-height:1.15;letter-spacing:-.02em;margin:64px 0 28px;scroll-margin-top:100px;color:var(--fg);text-wrap:balance;padding-bottom:12px;border-bottom:1px solid var(--line)}.guide-body h2:first-of-type{margin-top:0}.guide-body h2[data-label]:before{content:attr(data-label);display:block;font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--accent);font-weight:600;margin-bottom:8px}.guide-body h3{font-family:var(--display);font-weight:500;font-size:22px;line-height:1.3;margin:1.8em 0 .5em;color:var(--fg);scroll-margin-top:100px}.guide-body ul,.guide-body ol.guide-ol{font-size:17px;line-height:1.65;padding-left:24px;margin:0 0 1.5em}.guide-body ul li,.guide-body ol.guide-ol li{margin-bottom:10px}.guide-body ol{counter-reset:guideol;list-style:none;padding-left:0}.guide-body ol li{counter-increment:guideol;padding-left:36px;position:relative}.guide-body ol li:before{content:counter(guideol,decimal-leading-zero);position:absolute;left:0;top:0;font-family:var(--mono);font-size:12px;font-weight:700;color:var(--accent);letter-spacing:.04em;padding-top:4px}.callout{font-family:var(--sans);font-size:15px;line-height:1.6;margin:1.8em 0;border-radius:var(--r-2);border:1px solid var(--line);background:var(--bg-alt);color:var(--fg);position:relative;padding:16px 20px 16px 56px}.callout:before{content:"";position:absolute;left:18px;top:18px;width:22px;height:22px;border-radius:50%;display:grid;place-items:center;font-family:var(--mono);font-size:12px;font-weight:700;color:#fff}.callout-note{border-left:3px solid #2a6fdb}.callout-note:before{content:"i";background:#2a6fdb;font-style:italic}.callout-tip{border-left:3px solid var(--accent)}.callout-tip:before{content:"+";background:var(--accent)}.callout-warn{border-left:3px solid #c43d6e}.callout-warn:before{content:"!";background:#c43d6e}.guide-quote{margin:1.8em 0;padding:4px 0 4px 20px;border-left:3px solid var(--accent);font-style:italic;color:var(--fg-dim)}.guide-quote cite{display:block;margin-top:8px;font-style:normal;font-size:13.5px;color:var(--fg-soft)}.guide-related{margin-top:80px;padding-top:40px;border-top:1px solid var(--line)}@media(max-width:920px){.guide-layout{grid-template-columns:1fr;gap:32px}.guide-toc{position:static;border-left:0;padding-left:0;border-top:1px solid var(--line);padding-top:16px}.guide-toc-item.is-active:before{display:none}.guide-body h2{font-size:28px}}
