:root{--bg:#fff;--bg-subtle:#f7f7f5;--text:#1a1a1a;--text-muted:#6b6b6b;--border:#e8e8e6;--accent:#2563eb;--accent-hover:#1d4ed8;--code-bg:#f6f8fa;--max-width:680px;--font-sans:ui-sans-serif,system-ui,-apple-system,"Segoe UI",Roboto,Helvetica,Arial,"Apple Color Emoji",sans-serif;--font-mono:ui-monospace,SFMono-Regular,"SF Mono",Menlo,Consolas,"Liberation Mono",monospace}*{box-sizing:border-box}html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}body{margin:0;background:var(--bg);color:var(--text);font-family:var(--font-sans);font-size:17px;line-height:1.7;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}.container{max-width:var(--max-width);margin:0 auto;padding:0 24px}.dataflow-bg{position:fixed;inset:0;width:100%;height:100%;z-index:-1;pointer-events:none}.container--wide{max-width:1080px}a{color:var(--accent);text-decoration:none;transition:color .15s ease}a:hover{color:var(--accent-hover);text-decoration:underline;text-underline-offset:3px}.site-nav{display:flex;align-items:center;justify-content:space-between;padding:28px 0 0;font-size:15px}.site-nav .brand{font-weight:600;color:var(--text)}.site-nav .brand:hover{text-decoration:none}.site-nav .links{display:flex;gap:22px}.site-nav .links a{color:var(--text-muted);font-weight:500}.site-nav .links a:hover{color:var(--text);text-decoration:none}.hero{display:flex;align-items:center;gap:28px;margin:56px 0 8px}.hero .avatar{flex:0 0 auto;width:104px;height:104px;border-radius:50%;object-fit:cover;background:var(--bg-subtle);border:1px solid var(--border)}.hero h1{margin:0 0 6px;font-size:28px;letter-spacing:-.02em}.hero .tagline{margin:0;color:var(--text-muted);font-size:16px}.bio{margin:28px 0 0}.bio p{margin:0 0 16px}.socials{display:flex;flex-wrap:wrap;gap:18px;margin:28px 0 0;font-size:15px}.socials a{display:inline-flex;align-items:center;gap:7px;color:var(--text-muted);font-weight:500}.socials a:hover{color:var(--accent);text-decoration:none}.socials svg{width:17px;height:17px}.section{margin:64px 0 0}.section h2{font-size:14px;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);margin:0 0 20px;font-weight:600}.post-list{list-style:none;margin:0;padding:0}.post-list li{padding:16px 0;border-bottom:1px solid var(--border)}.post-list li:first-child{padding-top:0}.post-row{display:flex;justify-content:space-between;align-items:baseline;gap:16px}.post-row .title{font-weight:600;color:var(--text);font-size:17px}.post-row a:hover .title{color:var(--accent)}.post-row .date{flex:0 0 auto;color:var(--text-muted);font-size:14px;font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.post-row a{display:flex;justify-content:space-between;align-items:baseline;gap:16px;width:100%}.post-row a:hover{text-decoration:none}.post-summary{margin:6px 0 0;font-size:15px}.post-summary,.tag{color:var(--text-muted)}.tag{display:inline-block;font-size:12px;background:var(--bg-subtle);border:1px solid var(--border);border-radius:999px;padding:1px 9px;margin-right:6px}.site-footer{margin:80px 0 48px;padding-top:24px;border-top:1px solid var(--border);color:var(--text-muted);font-size:14px;display:flex;justify-content:space-between}.article{margin:48px 0 0}.article-header{margin-bottom:36px}.article-header h1{font-size:32px;letter-spacing:-.02em;margin:0 0 12px;line-height:1.25}.article-meta,.back-link{color:var(--text-muted);font-size:15px}.back-link{display:inline-block;margin-top:32px}.prose{font-size:17px;line-height:1.75}.prose h2{font-size:22px;margin:40px 0 14px;letter-spacing:-.01em}.prose h3{font-size:18px;margin:30px 0 10px}.prose p{margin:0 0 18px}.prose ol,.prose ul{margin:0 0 18px;padding-left:24px}.prose li{margin:6px 0}.prose blockquote{margin:0 0 18px;padding:4px 18px;border-left:3px solid var(--border);color:var(--text-muted)}.prose code{font-family:var(--font-mono);font-size:.88em;padding:2px 6px;border-radius:5px}.prose code,.prose pre{background:var(--code-bg)}.prose pre{border:1px solid var(--border);border-radius:10px;padding:16px 18px;overflow-x:auto;margin:0 0 18px;font-size:14px;line-height:1.6}.prose pre code{background:none;padding:0;font-size:inherit}.prose img{display:block;max-width:100%;margin:24px auto;border-radius:10px}.prose .mermaid-diagram{margin:28px 0;text-align:center}.prose .mermaid-diagram svg{max-width:100%;height:auto}.prose .mermaid-error{white-space:pre-wrap;color:var(--text)}.prose .callout-note{display:block;margin:24px 0;padding:4px 20px;background:var(--bg-subtle);border:1px solid var(--border);border-left:3px solid var(--accent);border-radius:8px}.prose .callout-note>:first-child{margin-top:14px}.prose .callout-note>:last-child{margin-bottom:14px}.prose .excalidraw-figure{display:block;margin:28px 0;text-align:center}.prose .excalidraw-figure svg{max-width:100%;height:auto}.prose .excalidraw-figure-error{display:block;margin:28px 0;color:var(--text-muted);font-size:14px}.prose table{width:100%;border-collapse:collapse;margin:0 0 18px;font-size:15px}.prose td,.prose th{border:1px solid var(--border);padding:8px 12px;text-align:left}.prose hr{border:none;border-top:1px solid var(--border);margin:36px 0}.hljs{color:#24292e;background:var(--code-bg)}.hljs-comment,.hljs-quote{color:#6a737d}.hljs-built_in,.hljs-doctag,.hljs-keyword,.hljs-name,.hljs-selector-tag{color:#d73a49}.hljs-addition,.hljs-attr,.hljs-regexp,.hljs-string,.hljs-template-tag,.hljs-template-variable{color:#032f62}.hljs-class .hljs-title,.hljs-literal,.hljs-number,.hljs-type,.hljs-variable{color:#005cc5}.hljs-function .hljs-title,.hljs-section,.hljs-title{color:#6f42c1}.hljs-attribute,.hljs-bullet,.hljs-meta,.hljs-symbol{color:#e36209}.hljs-deletion{color:#b31d28}.hljs-emphasis{font-style:italic}.hljs-strong{font-weight:600}@media (max-width:560px){body{font-size:16px}.hero{align-items:flex-start;gap:18px;margin-top:40px}.hero,.post-row a{flex-direction:column}.post-row a{gap:2px}.article-header h1{font-size:26px}}