:root{color-scheme:light;--bg: #f0eee9;--surface: #fbfaf7;--text: #26221b;--muted: #67645e;--line: #d9d6ce;--link: var(--accent);--link-hover: oklch(.47 .12 48);--code-bg: #e8e5de;--code-text: #24221f;--sans: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--serif: "Source Serif 4", ui-serif, Georgia, Cambria, "Times New Roman", Times, serif;--slab: "Roboto Slab", ui-serif, Georgia, Cambria, "Times New Roman", Times, serif;--ink: var(--text);--faint: #8a8273;--rule: rgba(38, 34, 27, .13);--rule-strong: rgba(38, 34, 27, .22);--tint: rgba(38, 34, 27, .035);--tint-2: rgba(38, 34, 27, .05);--accent: oklch(.55 .11 48)}*{box-sizing:border-box}html{font-family:var(--serif);background:var(--bg);color:var(--text);scrollbar-gutter:stable}body{margin:0;min-height:100vh;font-size:18px;line-height:1.7;text-rendering:optimizeLegibility}a{color:var(--link);text-decoration-thickness:.08em;text-underline-offset:.18em}a:hover{color:var(--link-hover)}time{font-variant-numeric:tabular-nums}img,iframe,video{max-width:100%}img{display:block;height:auto;border-radius:6px}code,pre{font-family:ui-monospace,SF Mono,Cascadia Code,JetBrains Mono,Menlo,monospace}.site-shell{width:100%;max-width:680px;margin-inline:auto;padding:64px 24px 72px}.site-header{display:flex;align-items:baseline;justify-content:space-between;gap:24px;padding-bottom:34px;font-family:var(--sans)}.site-title{font-size:15px;font-weight:600;letter-spacing:.02em;color:var(--ink);text-decoration:none}.intro{max-width:620px;padding:14px 0 38px}.eyebrow,.post-date,.post-meta,.back-link,.tag-list,.post-item time{font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}.eyebrow,.post-date{margin:0 0 10px;color:var(--muted);font-size:14px}h1,h2,h3{line-height:1.18;letter-spacing:0}.intro h1{max-width:720px;margin:0;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:21px;font-weight:650;line-height:1.45}.intro p:last-child{max-width:620px;margin:10px 0 0;color:var(--muted);font-size:17px}.list-header{display:flex;align-items:baseline;justify-content:space-between;gap:18px;border-top:1px solid var(--line);padding-top:22px;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}.list-header h2{margin:0;font-size:14px;font-weight:600;text-transform:uppercase}.list-header span{color:var(--muted);font-size:14px}.post-list{display:grid;gap:22px;padding-top:20px}.post-item{padding-bottom:28px;border-bottom:1px solid var(--line)}.post-item a{display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:baseline;gap:18px;color:var(--text);text-decoration:none}.post-item span{font-size:24px;font-weight:600;line-height:1.25}.post-item time{color:var(--muted);font-size:14px;white-space:nowrap}.post-item p{margin:8px 0 0;color:var(--muted)}.post-header{padding-bottom:18px;border-bottom:1px solid var(--line)}.post-header h1{max-width:720px;margin:0;font-family:var(--slab);font-size:32px;font-weight:600}.back-link{display:inline-flex;align-items:center;gap:5px;margin-bottom:26px;margin-left:-4px;padding:4px 4px 4px 2px;border-radius:6px;color:var(--muted);font-size:13px;font-weight:500;letter-spacing:.02em;text-decoration:none;transition:color .15s ease,transform .15s ease}.back-link__arrow{transition:transform .15s ease}.back-link:hover{color:var(--accent)}.back-link:hover .back-link__arrow{transform:translate(-2px)}.post-meta{display:flex;align-items:baseline;flex-wrap:wrap;gap:8px;margin:22px 0 0;color:var(--muted);font-size:14px}.post-meta-sep{color:var(--faint)}.post-description{max-width:620px;margin:18px 0 0;color:var(--muted);font-size:21px}.tag-list{display:flex;flex-wrap:wrap;align-items:baseline;gap:10px 14px;padding:0;margin:32px 0 0;list-style:none}.tag-list:before{content:"Tagged";font-size:11px;font-weight:650;letter-spacing:.12em;text-transform:uppercase;color:var(--faint)}.tag-list li{color:var(--muted);font-size:13px;font-weight:550}.tag-list li a{color:inherit;display:inline-flex;align-items:baseline;gap:1px;text-decoration:none;text-underline-offset:3px;transition:color .13s ease,text-decoration-color .13s ease}.tag-list li a:before{content:"#";color:var(--accent);opacity:.72}.tag-list li:hover a{color:var(--accent);text-decoration:underline;text-decoration-color:color-mix(in oklab,var(--accent) 45%,transparent)}.prose{padding-top:22px;font-family:var(--serif);font-size:19px;line-height:1.65;max-width:68ch}.prose>*+*{margin-top:1.25em}.prose h2{font-family:var(--slab);font-weight:600;font-size:26px;margin-top:2.5em;margin-bottom:.5em}.prose h3{font-family:var(--slab);font-weight:600;font-size:20px;margin-top:1.8em}.prose p,.prose li{color:var(--text)}.prose ul,.prose ol{padding-left:1.3em}.prose table{display:block;width:100%;overflow-x:auto;border-collapse:collapse;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:15px;line-height:1.5}.prose th,.prose td{border-bottom:1px solid var(--line);padding:10px 12px;text-align:left;vertical-align:top}.prose th{color:var(--text);font-weight:700}.prose pre{overflow-x:auto;border:1px solid var(--line);border-radius:6px;padding:18px;background:var(--code-bg);color:var(--code-text);font-size:15px;line-height:1.6;font-family:ui-monospace,SF Mono,Cascadia Code,JetBrains Mono,Menlo,monospace}.prose :not(pre)>code{border-radius:4px;padding:2px 5px;background:#26221b14;color:var(--code-text);font-size:.9em;line-height:inherit}.comments{margin-top:56px;padding-top:26px;border-top:1px solid var(--line)}.comments[data-theme-file="/giscus-theme-reactions.css"] .giscus,.comments[data-theme-file="/giscus-theme-reactions.css"] .giscus-frame{min-height:6.5rem}.comments[data-theme-file="/giscus-theme-reactions.css"] .giscus{position:relative;z-index:1;overflow:visible}.comments[data-theme-file="/giscus-theme-reactions.css"] .giscus-frame{position:absolute;inset:0 auto auto 0;height:6.5rem!important}.comments[data-theme-file="/giscus-theme-reactions.css"] .giscus:hover .giscus-frame,.comments[data-theme-file="/giscus-theme-reactions.css"] .giscus:focus-within .giscus-frame,.comments[data-theme-file="/giscus-theme-reactions.css"] .giscus-frame:hover,.comments[data-theme-file="/giscus-theme-reactions.css"] .giscus-frame:focus{min-height:16rem}.comments[data-theme-file="/giscus-theme-reactions.css"] .giscus:hover .giscus-frame,.comments[data-theme-file="/giscus-theme-reactions.css"] .giscus:focus-within .giscus-frame,.comments[data-theme-file="/giscus-theme-reactions.css"] .giscus-frame:hover,.comments[data-theme-file="/giscus-theme-reactions.css"] .giscus-frame:focus{height:16rem!important}.comments h2{margin:0 0 18px;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:18px;font-weight:600;line-height:1.3}.comments-disabled p{margin:0;color:var(--muted);font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:14px;line-height:1.5}.architecture-diagram{width:min(1120px,calc(100vw - 48px));margin:1.8em 0 1.8em 50%;overflow-x:auto;transform:translate(-50%)}.architecture-diagram svg{display:block;min-width:1040px;width:100%;height:auto;border:1px solid var(--line);border-radius:6px;background:var(--surface)}.architecture-diagram img{min-width:1040px;width:100%;border:1px solid var(--line);background:var(--surface)}.diagram-node rect{fill:var(--code-bg);stroke:var(--rule-strong);stroke-width:1.5}.diagram-store rect{fill:#26221b0f}.diagram-node text,.diagram-label{font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;fill:var(--text);font-size:16px;font-weight:700;text-anchor:middle}.diagram-sub,.diagram-label{fill:var(--muted);font-size:13px;font-weight:500}.diagram-line{fill:none;stroke:var(--accent);stroke-width:2;marker-end:url(#arrow)}.diagram-muted{stroke:var(--muted);stroke-dasharray:6 6;marker-end:url(#arrow-muted)}.architecture-diagram marker path{fill:var(--accent)}.architecture-diagram #arrow-muted path{fill:var(--muted)}.video-embed{position:relative;aspect-ratio:16 / 9;overflow:hidden;border-radius:6px;background:var(--code-bg)}.video-embed iframe{position:absolute;inset:0;width:100%;height:100%;border:0}@media(max-width:640px){body{font-size:17px}.site-shell{padding-top:40px}.site-header{padding-bottom:30px}.post-item a{grid-template-columns:1fr;gap:4px}.post-item span{font-size:23px}.intro p:last-child,.post-description{font-size:18px}}
