:root{color-scheme:dark;--bg: #0e1218;--bg-2: #161a22;--ink: #dee3ea;--ink-2: #a3acb6;--ink-3: #6e7783;--rule: #232830;--rule-2: #1b2028;--accent: #8ab2d4;--accent-2: #a4c4e0;--term-green: #5cff85;--code-bg: #161a22;--sans: "IBM Plex Sans", ui-sans-serif, system-ui, sans-serif;--mono: "IBM Plex Mono", ui-monospace, Menlo, Consolas, monospace;--measure: 38rem;--sidebar-w: 240px;--gutter: 2rem}*{box-sizing:border-box}html,body{margin:0;padding:0;background:var(--bg);color:var(--ink);font-family:var(--sans);font-size:17px;line-height:1.7;font-feature-settings:"kern","liga","calt";-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;min-height:100vh}::selection{background:var(--accent);color:var(--bg)}a{color:var(--accent);text-decoration:none;border-bottom:1px solid color-mix(in srgb,var(--accent) 35%,transparent);transition:border-color .15s ease,color .15s ease}a:hover,a:focus{color:var(--accent-2);border-bottom-color:var(--accent-2);outline:none}.topbar{border-bottom:1px solid var(--rule);background:var(--bg)}.topbar-inner{max-width:1080px;margin:0 auto;padding:14px var(--gutter);display:flex;align-items:center;justify-content:space-between;font-family:var(--mono);font-size:12.5px;color:var(--ink-3);letter-spacing:-.005em}.topbar .path{color:var(--ink-2)}.topbar .path .dim{color:var(--ink-3)}.topbar .path .cur{color:var(--ink)}.topbar .meta{display:flex;gap:1.5rem;color:var(--ink-3)}.topbar .meta .live{color:var(--ink-2)}.layout{max-width:1080px;margin:0 auto;padding:56px var(--gutter) 48px;display:grid;grid-template-columns:var(--sidebar-w) 1fr;gap:4rem;align-items:start}.sidebar{position:sticky;top:56px;display:flex;flex-direction:column;gap:24px}.brand{display:flex;flex-direction:column;gap:6px;text-decoration:none;border:0;color:var(--ink)}.brand:hover{color:var(--ink)}.brand-name{font-family:var(--sans);font-weight:600;font-size:18px;letter-spacing:-.01em}.brand-role{font-family:var(--mono);font-size:11.5px;color:var(--ink-3);letter-spacing:.02em}.callsign{position:relative;border:1px solid var(--rule);background:var(--bg-2);padding:20px 16px 14px;font-family:var(--mono);font-size:11.5px;line-height:1.7;color:var(--ink-2);border-radius:0}.callsign:before{content:"john@~";position:absolute;top:-7px;left:12px;background:var(--bg);padding:0 6px;font-family:var(--mono);font-size:10px;letter-spacing:.08em;color:var(--ink-2);animation:callsign-type .4s steps(6,end) .15s both}.callsign .row{display:grid;grid-template-columns:56px 1fr;gap:8px;clip-path:inset(0 100% 0 0);animation:callsign-row-type .45s steps(28,end) both;color:var(--term-green)}.callsign .row:nth-child(1){animation-delay:.7s}.callsign .row:nth-child(2){animation-delay:.95s}.callsign .row:nth-child(3){animation-delay:1.2s}.callsign .row:nth-child(4){animation-delay:1.45s}.callsign .row:nth-child(5){animation-delay:1.7s}.callsign .row:nth-child(6){animation-delay:1.95s}.callsign .k:after{content:":"}@keyframes callsign-type{0%{clip-path:inset(0 100% 0 0)}to{clip-path:inset(0 0 0 0)}}@keyframes callsign-row-type{0%{clip-path:inset(0 100% 0 0)}to{clip-path:inset(0 0 0 0)}}@media(prefers-reduced-motion:reduce){.callsign:before,.callsign .row{animation:none;opacity:1;clip-path:none;transform:none}}.nav{display:flex;flex-direction:column;gap:1px;border-top:1px solid var(--rule);padding-top:18px;counter-reset:navnum}.nav a{display:flex;align-items:baseline;gap:12px;padding:6px 0;font-family:var(--sans);font-size:14.5px;color:var(--ink-2);border:0;font-weight:500}.nav a:before{content:counter(navnum,decimal-leading-zero);counter-increment:navnum;font-family:var(--mono);font-size:10.5px;color:var(--ink-3);letter-spacing:.04em;margin-right:auto}.nav a:hover{color:var(--accent)}.nav a[aria-current]{color:var(--ink)}.nav a[aria-current]:after{content:"←";font-family:var(--mono);color:var(--accent);font-size:12px}.sidebar-foot{font-family:var(--mono);font-size:10.5px;color:var(--ink-3);letter-spacing:.02em;border-top:1px solid var(--rule);padding-top:14px;display:flex;flex-direction:column;gap:6px}.sidebar-foot a{color:var(--ink-2);border:0}.sidebar-foot a:hover{color:var(--accent)}.content{min-width:0;max-width:var(--measure)}.eyebrow{font-family:var(--mono);font-size:11.5px;letter-spacing:.04em;color:var(--accent);margin:0 0 10px;text-transform:lowercase}.eyebrow .num{color:var(--ink-3);margin-right:8px}h1.page-title{font-family:var(--sans);font-weight:600;font-size:1.95rem;letter-spacing:-.022em;line-height:1.15;margin:0 0 8px;color:var(--ink)}.page-sub{font-family:var(--sans);font-size:1rem;color:var(--ink-2);margin:0 0 40px;max-width:32rem}.page-sub.lead{font-size:1.5rem;font-weight:400;line-height:1.4;letter-spacing:-.012em;color:var(--ink);max-width:36rem;margin:0 0 48px}.prose{font-size:1rem;line-height:1.7;color:var(--ink)}.prose p{margin:0 0 1.1em}.prose strong{font-weight:600}.prose h2,.prose h3{font-family:var(--sans);font-weight:600;letter-spacing:-.012em;margin:2.2em 0 .6em;color:var(--ink);display:flex;align-items:baseline;gap:12px}.prose h2{font-size:1.2rem}.prose h3{font-size:1.05rem}.prose h2:before{content:"§";font-family:var(--mono);font-weight:400;color:var(--accent);font-size:.95em}.prose code{font-family:var(--mono);font-size:.86em;background:var(--code-bg);padding:.08em .4em;border-radius:2px;color:var(--ink)}.prose pre{font-family:var(--mono);font-size:.83rem;line-height:1.6;background:var(--bg-2);border:1px solid var(--rule);border-left:2px solid var(--accent);padding:14px 18px;overflow-x:auto;margin:1.4em 0;border-radius:2px}.prose pre code{background:transparent;padding:0}.prose blockquote{margin:1.4em 0;padding:.2em 0 .2em 1em;border-left:2px solid var(--rule);color:var(--ink-2)}.prose ul,.prose ol{padding-left:1.4em;margin:0 0 1.1em}.prose li{margin-bottom:.35em}.prose hr{border:0;border-top:1px dashed var(--rule);margin:2.4em 0}.prose img{max-width:100%;height:auto;border-radius:2px}.idx-head{display:flex;align-items:baseline;justify-content:space-between;gap:1rem;margin-bottom:4px}.idx-count{font-family:var(--mono);font-size:11.5px;color:var(--ink-3);letter-spacing:.02em}.year-head{display:grid;grid-template-columns:5rem 1fr;align-items:center;gap:1rem;margin:36px 0 8px;font-family:var(--mono);font-size:11.5px;color:var(--ink-3);letter-spacing:.04em}.year-head:after{content:"";height:1px;background:var(--rule)}.entries{list-style:none;margin:0;padding:0}.entry{display:grid;grid-template-columns:5rem 1fr auto;align-items:baseline;gap:1rem;padding:9px 0;border-bottom:1px solid var(--rule-2);position:relative}.entry:hover{background:var(--bg-2)}.entry:hover:before{content:"";position:absolute;left:-12px;top:0;bottom:0;width:2px;background:var(--accent)}.entry-date{font-family:var(--mono);font-size:11.5px;color:var(--ink-3);letter-spacing:.02em}.entry-title{font-family:var(--sans);font-size:.98rem;font-weight:500;line-height:1.35;color:var(--ink);border:0;letter-spacing:-.005em}.entry-title:hover{color:var(--accent)}.entry-meta{font-family:var(--mono);font-size:10.5px;color:var(--ink-3);letter-spacing:.04em;white-space:nowrap}article.post header{margin-bottom:36px;padding-bottom:22px;border-bottom:1px solid var(--rule)}article.post h1{font-family:var(--sans);font-weight:600;font-size:clamp(1.6rem,3vw,2.1rem);line-height:1.15;letter-spacing:-.022em;margin:6px 0 14px}.byline{display:flex;flex-wrap:wrap;gap:0 1.25rem;font-family:var(--mono);font-size:11.5px;color:var(--ink-3);letter-spacing:.02em}.byline .k{color:var(--ink-3);margin-right:6px}.byline .v{color:var(--ink-2)}.post-foot{margin-top:64px;padding-top:18px;border-top:1px solid var(--rule);display:flex;justify-content:space-between;gap:1rem;font-family:var(--mono);font-size:11.5px;letter-spacing:.02em;color:var(--ink-2)}.post-foot a{border:0;color:var(--ink-2)}.post-foot a:hover{color:var(--accent)}.site-foot{border-top:1px solid var(--rule);margin-top:80px;background:var(--bg)}.site-foot-inner{max-width:1080px;margin:0 auto;padding:18px var(--gutter) 28px;display:flex;justify-content:space-between;align-items:center;font-family:var(--mono);font-size:11px;color:var(--ink-3);letter-spacing:.02em}.site-foot a{color:var(--ink-2);border:0;margin-left:1.25rem}.site-foot a:hover{color:var(--accent)}.site-foot .build{font-variant-numeric:tabular-nums}@media(max-width:760px){:root{--gutter: 1.25rem}.topbar-inner{font-size:11px;gap:1rem}.topbar .meta{gap:1rem}.layout{grid-template-columns:1fr;gap:32px;padding:28px var(--gutter) 32px}.sidebar{position:static;flex-direction:column;gap:18px}.nav{flex-direction:row;flex-wrap:wrap;gap:14px;padding-top:12px}.nav a:after{display:none}.entry{grid-template-columns:4.5rem 1fr}.entry-meta{display:none}.site-foot-inner{flex-direction:column;gap:8px;align-items:flex-start}.site-foot a{margin-left:0;margin-right:1.25rem}}
