: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: ui-serif, Georgia, Cambria, "Times New Roman", Times, serif;--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:ui-serif,Georgia,Cambria,Times New Roman,Times,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)}img,iframe,video{max-width:100%}img{display:block;height:auto;border-radius:6px}code,pre{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,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:700;letter-spacing:.01em;color:var(--ink);text-decoration:none}.site-header nav{display:flex;align-items:baseline;gap:18px}.site-header nav a{font-size:13px;font-weight:500;letter-spacing:.08em;color:var(--muted);text-decoration:none;transition:color .15s ease}.site-header nav a:hover{color:var(--accent)}.intro{max-width:620px;padding:14px 0 38px}.eyebrow,.post-date,.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:700;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:700;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-size:40px;font-weight:700}.back-link{display:inline-block;margin-bottom:20px;color:var(--muted);font-size:13px;text-decoration:none;transition:color .15s ease}.back-link:hover{color:var(--accent)}.post-header .post-date{margin:26px 0 0}.post-description{max-width:620px;margin:18px 0 0;color:var(--muted);font-size:21px}.tag-list{display:flex;flex-wrap:wrap;gap:8px;padding:0;margin:22px 0 0;list-style:none}.tag-list li{border:1px solid var(--rule-strong);border-radius:999px;padding:3px 11px;color:var(--muted);font-size:12px;transition:border-color .13s ease}.tag-list li a{color:inherit;text-decoration:none}.tag-list li:hover{border-color:var(--accent)}.tag-list li:hover a{color:var(--accent)}.prose{padding-top:22px}.prose>*+*{margin-top:1.25em}.prose h2{margin-top:2.1em;font-size:34px}.prose h3{margin-top:1.8em;font-size:24px}.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.55}.prose :not(pre)>code{border-radius:4px;padding:.1em .35em;background:#26221b14;color:var(--code-text);font-size:.9em;line-height:inherit}.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)}.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}}
