﻿@font-face{font-family:"JetBrains Mono";font-style:normal;font-weight:400;font-display:swap;src:url("/fonts/JetBrainsMono-Regular.woff2") format("woff2")}@font-face{font-family:"JetBrains Mono";font-style:normal;font-weight:700;font-display:swap;src:url("/fonts/JetBrainsMono-Bold.woff2") format("woff2")}@font-face{font-family:"IBM Plex Sans";font-style:normal;font-weight:400;font-display:swap;src:url("/fonts/IBMPlexSans-Regular.woff2") format("woff2")}@font-face{font-family:"IBM Plex Sans";font-style:normal;font-weight:600;font-display:swap;src:url("/fonts/IBMPlexSans-SemiBold.woff2") format("woff2")}:root{--bg: #0E0E10;--fg: #E8E6E3;--fg-dim: #8A8A86;--accent: #FFB000;--code-bg: #17171A;--rule: #26262A;--font-mono: "JetBrains Mono", ui-monospace, SFMono-Regular, Consolas, monospace;--font-sans: "IBM Plex Sans", system-ui, -apple-system, sans-serif;--line-prose: 1.7;--line-ui: 1.4;--measure: 70ch;--max-content: 720px;--max-section: 960px}[data-theme=light]{--bg: #FAFAF7;--fg: #1A1A1A;--fg-dim: #6B6B68;--accent: #C77D00;--code-bg: #F1EFE9;--rule: #E2DFD8}*,*::before,*::after{box-sizing:border-box}html{background:var(--bg);color:var(--fg);font-family:var(--font-sans);font-size:16px;line-height:var(--line-prose);-webkit-text-size-adjust:100%}body{margin:0;min-height:100vh}a{color:var(--accent);text-decoration:none;border-bottom:1px solid rgba(0,0,0,0);transition:border-color .12s ease}a:hover{border-bottom-color:var(--accent)}a:focus-visible{outline:2px solid var(--accent);outline-offset:2px}h1,h2,h3,h4,h5,h6{font-family:var(--font-mono);font-weight:700;line-height:var(--line-ui);margin:2.5rem 0 1rem}h1{font-size:2rem}h2{font-size:1.5rem}h3{font-size:1.15rem}p{margin:0 0 1.2rem}code,pre{font-family:var(--font-mono);font-size:.92em}code{background:var(--code-bg);padding:.1rem .35rem;border-radius:2px}pre{background:var(--code-bg);border-left:2px solid var(--accent);padding:1rem 1.2rem;overflow-x:auto;line-height:1.5;margin:1.5rem 0}pre code{background:rgba(0,0,0,0);padding:0}blockquote{border-left:2px solid var(--rule);padding-left:1rem;color:var(--fg-dim);margin:1.5rem 0}hr{border:none;border-top:1px solid var(--rule);margin:3rem 0}table{width:100%;border-collapse:collapse;margin:1.5rem 0;font-size:.95em}th,td{text-align:left;padding:.5rem .75rem;border-bottom:1px solid var(--rule)}th{font-family:var(--font-mono);font-weight:700;color:var(--fg-dim)}.container{max-width:var(--max-content);margin:0 auto;padding:0 1.5rem}.container-wide{max-width:var(--max-section);margin:0 auto;padding:0 1.5rem}.site-header{border-bottom:1px solid var(--rule);padding:1.25rem 0}.site-header__inner{display:flex;align-items:center;justify-content:space-between;gap:2rem}.site-header__brand{display:inline-flex;align-items:center;border-bottom:none;line-height:0}.site-header__logo{height:28px;width:auto;display:none}:root:not([data-theme=light]) .site-header__logo--dark{display:block}[data-theme=light] .site-header__logo--light{display:block}.site-nav{display:flex;gap:1.5rem;font-family:var(--font-mono);font-size:.95rem;align-items:center}.site-nav a{color:var(--fg);border-bottom:none;white-space:nowrap}.site-nav a:hover{color:var(--accent)}.theme-toggle{background:rgba(0,0,0,0);border:1px solid var(--rule);color:var(--fg);font-family:var(--font-mono);font-size:1rem;line-height:1;padding:.35rem .55rem;border-radius:2px;cursor:pointer;min-width:2rem;display:inline-flex;align-items:center;justify-content:center}.theme-toggle:hover{border-color:var(--accent);color:var(--accent)}.theme-toggle__moon,.theme-toggle__sun{display:none}:root:not([data-theme=light]) .theme-toggle__moon{display:inline}[data-theme=light] .theme-toggle__sun{display:inline}.site-footer{border-top:1px solid var(--rule);margin-top:4rem;padding:1.5rem 0;font-family:var(--font-mono);font-size:.85rem;color:var(--fg-dim)}.hero{padding:4rem 0 2rem}.hero-box{font-family:var(--font-mono);color:var(--accent);white-space:pre;line-height:1.3;margin-bottom:1.5rem;overflow-x:auto}.hero-box--diagram{color:var(--fg-dim);border-left:2px solid var(--accent);padding:1rem 1.2rem;background:var(--code-bg);margin:1.5rem 0;font-size:.88rem;line-height:1.5;overflow-x:auto;white-space:pre}.recent-posts__all{margin-top:1.5rem;font-family:var(--font-mono);font-size:.95rem}.hero-frame{border:1px solid var(--accent);border-radius:2px;padding:1.5rem 1.75rem;margin-bottom:1.75rem;font-family:var(--font-mono);position:relative}.hero-frame__label{position:absolute;top:0;left:1.25rem;transform:translateY(-50%);background:var(--bg);color:var(--accent);padding:0 .5rem;font-weight:700;font-size:.95rem;letter-spacing:.02em}.hero-frame__line{color:var(--fg);font-size:1.15rem;font-weight:700;line-height:1.45;margin:0}.hero-frame__line+.hero-frame__line{margin-top:.45rem}.hero-frame__line--dim{color:var(--fg-dim);font-weight:400}@media (max-width: 540px){.hero-frame{padding:1.25rem 1rem 1.25rem 1.1rem}.hero-frame__line{font-size:1.02rem}.hero-frame__label{font-size:.85rem}}.hero-install pre{display:inline-block;margin:.25rem 0}.cta-group{display:flex;gap:1rem;margin-top:1.5rem;flex-wrap:wrap}.cta{font-family:var(--font-mono);font-size:.95rem;color:var(--fg);border:1px solid var(--accent);padding:.6rem 1.2rem;border-radius:2px;transition:background .12s ease}.cta:hover{background:var(--accent);color:var(--bg);border-bottom:1px solid var(--accent)}.features{display:grid;grid-template-columns:repeat(auto-fit, minmax(220px, 1fr));gap:1.5rem;margin:3rem 0}.feature{border-left:2px solid var(--accent);padding:.5rem 0 .5rem 1rem}.feature__head{font-family:var(--font-mono);font-weight:700;color:var(--fg);margin-bottom:.3rem}.feature__body{color:var(--fg-dim);font-size:.95rem;line-height:1.5;margin:0}.landing-section{margin-top:4rem;margin-bottom:4rem}.landing-section__rule{font-family:var(--font-mono);color:var(--fg-dim);font-size:.9rem;margin-bottom:1rem;letter-spacing:.05em}.code-cols{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}@media (max-width: 720px){.code-cols{grid-template-columns:1fr}}.code-col__title{font-family:var(--font-mono);font-size:.85rem;color:var(--fg-dim);margin-bottom:.5rem;letter-spacing:.04em;text-transform:lowercase}.posts-list{list-style:none;padding:0;margin:0}.posts-list>li{padding:1rem 0;border-bottom:1px solid var(--rule)}.posts-list>li:last-child{border-bottom:none}.posts-list .post-title{font-family:var(--font-mono);font-weight:700;font-size:1.05rem;color:var(--fg);border-bottom:none}.posts-list .post-title:hover{color:var(--accent)}.posts-list .post-date{font-family:var(--font-mono);font-size:.85rem;color:var(--fg-dim);margin-left:.75rem}.posts-list .post-excerpt{color:var(--fg-dim);font-size:.95rem;margin-top:.4rem}.post-header{margin:3rem 0 2rem}.post-header__title{margin:0 0 .75rem}.post-header__meta{font-family:var(--font-mono);font-size:.9rem;color:var(--fg-dim)}.post-body{max-width:var(--measure)}.post-nav{display:flex;justify-content:space-between;gap:2rem;border-top:1px solid var(--rule);margin-top:4rem;padding-top:1.5rem;font-family:var(--font-mono);font-size:.9rem}@media (max-width: 540px){.site-nav{gap:.9rem;font-size:.85rem}.site-nav a[href^="https://"]{display:none}.hero{padding:2rem 0 1rem}h1{font-size:1.5rem}h2{font-size:1.25rem}}@media (max-width: 400px){.site-nav{gap:.7rem}.site-nav a[href="/how-it-works/"]{display:none}}.z-code{color:var(--fg) !important;background:rgba(0,0,0,0) !important}.z-keyword,.z-storage{color:var(--accent) !important;font-weight:700}.z-entity{color:var(--fg) !important;font-weight:700}.z-string{color:var(--fg) !important;font-style:italic}.z-constant{color:var(--fg) !important}.z-comment{color:var(--fg-dim) !important;font-style:italic}.z-variable,.z-support,.z-source{color:var(--fg) !important}.giallo-ln{color:var(--fg-dim) !important}.post-layout{display:grid;grid-template-columns:minmax(0, 1fr);gap:2.5rem;max-width:1100px;margin:0 auto;padding:0 1.5rem}@media (min-width: 1024px){.post-layout{grid-template-columns:minmax(0, 1fr) 240px}}.post-toc{font-family:var(--font-mono);font-size:.88rem}.post-toc__heading{color:var(--fg-dim);font-size:.85rem;letter-spacing:.05em;margin:0 0 .75rem;text-transform:lowercase}.post-toc ul{list-style:none;padding:0;margin:0}.post-toc li{margin:.35rem 0;line-height:1.4}.post-toc li ul{margin-left:1rem;margin-top:.25rem}.post-toc a{color:var(--fg-dim);border-bottom:none}.post-toc a:hover{color:var(--accent)}@media (min-width: 1024px){.post-toc--sidebar{position:sticky;top:2rem;align-self:start;max-height:calc(100vh - 4rem);overflow-y:auto;padding-left:1rem;border-left:1px solid var(--rule)}.post-toc--mobile{display:none}}@media (max-width: 1023px){.post-toc--sidebar{display:none}.post-toc--mobile{margin:1.5rem 0 2.5rem;padding:.75rem 1rem;border:1px solid var(--rule);border-radius:2px}.post-toc--mobile summary{font-family:var(--font-mono);font-size:.9rem;color:var(--fg);cursor:pointer;padding:.25rem 0}.post-toc--mobile[open] summary{margin-bottom:.5rem}}.tag-list{list-style:none;padding:0;margin:.75rem 0 2rem;display:flex;flex-wrap:wrap;gap:.5rem}.tag-list li{margin:0}.tag-pill{display:inline-block;font-family:var(--font-mono);font-size:.78rem;line-height:1;padding:.35rem .6rem;border:1px solid var(--rule);border-radius:999px;color:var(--fg-dim);border-bottom:1px solid var(--rule)}.tag-pill:hover{color:var(--accent);border-color:var(--accent)}.post-body .zola-anchor{margin-left:.4rem;color:var(--fg-dim);opacity:0;transition:opacity .15s ease;border-bottom:none;font-weight:400}.post-body h2:hover .zola-anchor,.post-body h3:hover .zola-anchor,.post-body .zola-anchor:focus-visible{opacity:1;color:var(--accent)}.code-block{position:relative}.code-block .copy-button{position:absolute;top:.5rem;right:.5rem;background:var(--bg);border:1px solid var(--rule);color:var(--fg-dim);font-family:var(--font-mono);font-size:.75rem;line-height:1;padding:.3rem .55rem;border-radius:2px;cursor:pointer;opacity:0;transition:opacity .15s ease,color .15s ease,border-color .15s ease}.code-block:hover .copy-button,.code-block .copy-button:focus-visible{opacity:1}.code-block .copy-button:hover{color:var(--accent);border-color:var(--accent)}.code-block .copy-button[data-copied=true]{color:var(--accent);border-color:var(--accent);opacity:1}.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0, 0, 0, 0);white-space:nowrap;border:0}.posts-list .post-meta{display:flex;flex-wrap:wrap;gap:.4rem .75rem;align-items:baseline;margin-top:.25rem;font-family:var(--font-mono);font-size:.85rem;color:var(--fg-dim)}.posts-list .post-meta__reading-time::before{content:"·";margin-right:.5rem;color:var(--fg-dim)}.posts-list .post-meta__tags{list-style:none;padding:0;margin:0;display:flex;flex-wrap:wrap;gap:.3rem}.posts-list .post-meta__tag{font-size:.72rem;padding:.15rem .5rem}.diagram{margin:2rem 0;padding:0}.diagram svg{width:100%;height:auto;display:block;background:var(--code-bg);border-left:2px solid var(--accent);border-radius:2px;overflow:visible}.diagram figcaption{font-family:var(--font-mono);font-size:.85rem;color:var(--fg-dim);margin-top:.5rem;text-align:center}.diagram script[type="application/json"]{display:none}.diagram-actor{fill:var(--fg);font-family:var(--font-mono);font-size:14px;font-weight:700}.diagram-lifeline{stroke:var(--rule);stroke-width:1;stroke-dasharray:4 4}.diagram-message-line{stroke:var(--accent);stroke-width:1.5;fill:none}.diagram-message-label{fill:var(--fg-dim);font-family:var(--font-mono);font-size:12px}.diagram-node{stroke:var(--accent);stroke-width:2;fill:var(--code-bg)}.diagram-node--leader{fill:var(--accent)}.diagram-node-label{fill:var(--fg);font-family:var(--font-mono);font-size:12px;text-anchor:middle;dominant-baseline:middle}.diagram-window{stroke:var(--accent);stroke-width:1;fill:var(--code-bg)}.diagram-window--active{fill:rgba(255,176,0,.15)}.diagram-window-label{fill:var(--fg-dim);font-family:var(--font-mono);font-size:11px;text-anchor:middle}.diagram-controls{display:flex;gap:.5rem;justify-content:center;margin-top:.6rem;flex-wrap:wrap}.diagram-controls button{background:rgba(0,0,0,0);border:1px solid var(--rule);color:var(--fg);font-family:var(--font-mono);font-size:.85rem;padding:.35rem .8rem;border-radius:2px;cursor:pointer;transition:border-color .12s ease,color .12s ease}.diagram-controls button:hover{border-color:var(--accent);color:var(--accent)}.diagram-controls button[hidden]{display:none}