:root{--bg: #faf8f4;--text: #111827;--muted: #4b5563;--border: #e8e3d8;--accent: #1e3a8a;--accent-hover: #15296b;--focus-ring: #1e3a8a;--code-bg: #f2efe7;--surface-subtle: #f5f1e8;--mark-bg: #fef3c7;--mark-fg: #111827;--logo-bg: #4e4842;--logo-fg: #faf8f4;--font-sans: system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;--font-mono: ui-monospace, SFMono-Regular, "SF Mono", Menlo, monospace;--content-width: 820px;--breakout-wide: 920px;--breakout-full: 1100px;--transition-fast: .15s;--transition-slow: .2s}@media(prefers-color-scheme:dark){:root{--bg: #1c1917;--text: #ede9e1;--muted: #b0a99e;--border: #2c2926;--accent: #93c5fd;--accent-hover: #bfdbfe;--focus-ring: #93c5fd;--code-bg: #25221f;--surface-subtle: #221f1c;--mark-bg: #422006;--mark-fg: #fef3c7;--logo-bg: #d2ccc0;--logo-fg: #1c1917}}*,*:before,*:after{box-sizing:border-box}html{-webkit-text-size-adjust:100%;scrollbar-gutter:stable}@supports not (scrollbar-gutter: stable){html{overflow-y:scroll}}body{margin:0;font-family:var(--font-sans);background:var(--bg);color:var(--text);font-size:16px;line-height:1.6;min-width:310px;-webkit-font-smoothing:antialiased}a{color:var(--accent);text-decoration:underline;text-decoration-thickness:1.5px;text-underline-offset:3px;text-decoration-color:var(--accent);transition:text-decoration-thickness var(--transition-fast),color var(--transition-fast),text-decoration-color var(--transition-fast)}a:hover{color:var(--accent-hover);text-decoration-color:var(--accent-hover);text-decoration-thickness:2px}a:focus-visible,button:focus-visible{outline:2px solid var(--focus-ring);outline-offset:3px;border-radius:2px}::selection{background:var(--text);color:var(--bg)}.sr-only,.skip-link{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.skip-link:focus{width:auto;height:auto;padding:.5rem 1rem;margin:0;overflow:visible;clip:auto;background:var(--text);color:var(--bg);text-decoration:none;border-radius:0 0 6px;z-index:100}@media(hover:none){a:hover{color:var(--accent);text-decoration-color:var(--accent);text-decoration-thickness:1.5px}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{transition:none!important;animation:none!important}}.container{margin:0 auto;max-width:var(--content-width);padding:1.5rem 1.25rem 4rem}header.site{display:flex;justify-content:space-between;align-items:center;padding:.5rem 0 4rem}.logo{display:inline-flex;align-items:center;justify-content:center;width:30px;height:30px;background:var(--logo-bg);color:var(--logo-fg);border-radius:4px;font-weight:800;font-size:.75rem;letter-spacing:-.02em;text-decoration:none;transition:background var(--transition-fast)}.logo:hover{background:var(--accent-hover);color:var(--bg)}nav.primary{display:flex;gap:.25rem;align-items:center}nav.primary a{color:var(--muted);font-size:.9rem;font-weight:500;padding:.6rem .7rem;text-decoration:none;border-radius:6px}nav.primary a:hover,nav.primary a.active,nav.primary a[aria-current=page]{color:var(--text);background:var(--border)}@media(hover:none){nav.primary a:hover{background:none;color:var(--muted)}}footer.site{margin-top:4rem;padding-top:2rem;border-top:1px solid var(--border);font-size:.85rem;color:var(--muted)}footer.site nav{display:flex;flex-wrap:wrap;gap:.4rem .6rem;align-items:baseline}footer.site a{color:var(--muted);text-decoration:none;border-bottom:1px solid transparent;padding-bottom:1px;transition:color var(--transition-fast),border-color var(--transition-fast)}footer.site a:hover{color:var(--text);border-bottom-color:var(--text)}footer.site .sep{opacity:.5}.intro{margin-bottom:3rem}.intro h1{margin:0;font-size:1.15rem;line-height:1.5;font-weight:inherit}section.block{margin-top:2.5rem}section.block h2{font-size:1.05rem;font-weight:700;letter-spacing:-.01em;margin:0 0 1.25rem;padding-bottom:.5rem;border-bottom:1px solid var(--border)}section.block.minor h2{font-size:.75rem;text-transform:uppercase;letter-spacing:.12em;color:var(--muted);font-weight:600;margin:0 0 1rem}section.block ul{list-style:none;padding:0;margin:0}section.block li{padding:.45rem 0;line-height:1.5}section.block.writing li{padding:1rem 0}.recent li{display:grid;grid-template-columns:1fr;gap:.1rem}.recent time{font-family:var(--font-mono);font-size:.75rem;color:var(--muted);letter-spacing:.02em}.ext{display:inline-block;font-family:var(--font-mono);font-size:.75rem;color:var(--muted);margin-left:.4rem;white-space:nowrap;vertical-align:baseline}.ext:before{content:"↗ ";opacity:.7}.more{display:inline-block;margin-top:1.25rem;font-family:var(--font-mono);font-size:.8rem;color:var(--muted);text-decoration:none;border-bottom:1px solid var(--border);padding-bottom:2px}.more:hover{color:var(--text);border-bottom-color:var(--text)}article+section.block.writing{margin-top:1.5rem}article>.content>:last-child{margin-bottom:0}.pagination{display:grid;grid-template-columns:1fr auto 1fr;align-items:baseline;gap:1rem;margin-top:2.5rem;padding-top:1.5rem;border-top:1px solid var(--border);font-family:var(--font-mono);font-size:.85rem}.pagination a{color:var(--muted);text-decoration:none;border-bottom:1px solid var(--border);padding-bottom:2px}.pagination a:hover{color:var(--text);border-bottom-color:var(--text)}.pagination>a[rel=prev]{justify-self:start}.pagination>a[rel=next]{justify-self:end}.pagination-info{color:var(--muted);font-size:.75rem;letter-spacing:.02em}@media(min-width:600px){.intro h1{font-size:1.2rem}.recent li{grid-template-columns:5.5rem 1fr;gap:1rem;align-items:baseline}}@media(min-width:900px){.intro h1{font-size:1.3rem}.intro{margin-bottom:4rem}section.block{margin-top:3.5rem}}.breadcrumb{font-family:var(--font-mono);font-size:.8rem;color:var(--muted);margin-bottom:1.5rem}.breadcrumb a{color:var(--muted);text-decoration:none}.breadcrumb a:hover{color:var(--text)}.breadcrumb .sep{opacity:.5;margin:0 .4rem}article>h1{font-size:1.75rem;font-weight:800;letter-spacing:-.025em;line-height:1.15;margin:0 0 1rem}.article-meta{font-size:.85rem;color:var(--muted);margin-bottom:3rem;padding-bottom:1.5rem;border-bottom:1px solid var(--border);display:flex;flex-wrap:wrap;gap:.4rem .75rem;align-items:baseline}.article-meta .sep{opacity:.5}.article-meta .tag{font-family:var(--font-mono);font-size:.75rem;color:var(--muted)}.article-meta .tag:before{content:"#";opacity:.5}.article-updated{margin-top:-1.75rem;margin-bottom:3rem;font-size:.8rem;color:var(--muted);font-style:italic}.article-updated time{font-style:normal}.content p{margin:0 0 1.25rem}.content h2{font-size:1.25rem;font-weight:700;letter-spacing:-.01em;margin:3rem 0 1rem;line-height:1.3;position:relative}.content h3{font-size:1.05rem;font-weight:700;margin:2.25rem 0 .75rem;line-height:1.35;position:relative}.content h4{font-size:.95rem;font-weight:700;margin:1.75rem 0 .5rem;color:var(--muted);text-transform:uppercase;letter-spacing:.05em;position:relative}.header-anchor{display:inline-block;margin-left:.4rem;color:var(--muted);text-decoration:none;font-weight:400;opacity:0;transition:opacity var(--transition-fast),color var(--transition-fast)}.content h2:hover .header-anchor,.content h3:hover .header-anchor,.content h4:hover .header-anchor,.header-anchor:focus-visible{opacity:1}.header-anchor:hover{color:var(--text)}@media(hover:none){.header-anchor{opacity:.4}}.content :is(h2,h3,h4)[id]{scroll-margin-top:1.5rem}.copied-note{display:inline-block;margin-left:.5rem;padding:.1em .5em;background:var(--surface-subtle);border:1px solid var(--border);border-radius:4px;font-family:var(--font-mono);font-size:.7rem;color:var(--muted);vertical-align:middle;animation:copied-fade 1.6s ease forwards}@keyframes copied-fade{0%{opacity:0;transform:translateY(2px)}15%,75%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-2px)}}@media(prefers-reduced-motion:reduce){.copied-note{animation:none;opacity:1}}.content :is(ul,ol){margin:0 0 1.25rem;padding-left:1.5rem}.content li{margin-bottom:.4rem}.content li>:is(ul,ol){margin:.4rem 0 0}.content strong{font-weight:700}.content em{font-style:italic}.content hr{border:none;border-top:1px solid var(--border);margin:3rem auto;width:4rem}.content a{overflow-wrap:break-word}.content mark{background:var(--mark-bg);color:var(--mark-fg);padding:.05em .25em;border-radius:2px}.content kbd{font-family:var(--font-mono);font-size:.8em;background:var(--bg);border:1px solid var(--border);border-bottom-width:2px;border-radius:4px;padding:.1em .45em;box-shadow:0 1px 0 var(--border);white-space:nowrap;vertical-align:baseline}.content abbr[title]{text-decoration:underline dotted;text-decoration-thickness:1px;text-underline-offset:2px;cursor:help;border-bottom:none}.content :is(sub,sup){font-size:.75em;line-height:0;position:relative;vertical-align:baseline}.content sup{top:-.5em}.content sub{bottom:-.25em}.content code{font-family:var(--font-mono);font-size:.875em;background:var(--code-bg);padding:.1em .35em;border-radius:4px;border:1px solid var(--border)}.content pre{position:relative;background:transparent;border:2px solid var(--border);border-radius:6px;padding:1rem 1.1rem;overflow-x:auto;font-size:.85rem;line-height:1.55;margin:1.5rem 0;content-visibility:auto;contain-intrinsic-size:auto 200px}.content pre code{background:none;border:none;padding:0;font-size:inherit;border-radius:0}.content pre .copy-button{position:absolute;top:.4rem;right:.4rem;background:var(--bg);color:var(--muted);border:1px solid var(--border);border-radius:4px;padding:.2rem .55rem;font-family:var(--font-mono);font-size:.7rem;text-transform:uppercase;letter-spacing:.05em;cursor:pointer;opacity:0;transition:opacity var(--transition-fast),color var(--transition-fast),border-color var(--transition-fast)}.content pre:hover .copy-button,.content pre:focus-within .copy-button,.content pre .copy-button:focus-visible{opacity:1}.content pre .copy-button:hover{color:var(--text);border-color:var(--muted)}.content pre .copy-button[data-state=copied]{color:var(--text);border-color:var(--text);opacity:1}.content blockquote{margin:2rem 0;padding:.25rem 0 .25rem 1.25rem;border-left:2px solid var(--border);color:var(--muted);font-style:italic;font-size:1.05em}.content blockquote p:last-child{margin-bottom:0}.content blockquote cite{display:block;margin-top:.5rem;font-style:normal;font-size:.85rem}.content blockquote cite:before{content:"— "}.content div[role=note]{border:2px solid var(--border);border-left:3px solid var(--accent);border-radius:4px;padding:1rem 1.1rem;margin:1.75rem 0;font-size:.95em}.content div[role=note]>:first-child{margin-top:0}.content div[role=note]>:last-child{margin-bottom:0}.content figure{margin:2rem 0;content-visibility:auto;contain-intrinsic-size:auto 400px}.content figure img{max-width:100%;height:auto;display:block;border:1px solid var(--border);border-radius:4px}.content figcaption{font-size:.85rem;color:var(--muted);margin-top:.6rem;text-align:center;font-style:italic}@media(prefers-color-scheme:dark){.content figure img{opacity:.85;transition:opacity var(--transition-slow)}.content figure img:hover{opacity:1}}.content table{width:100%;border-collapse:collapse;font-size:.9rem;margin:1.75rem 0 2.5rem}.content .table-wrap>table{margin:0}.content :is(th,td){text-align:left;padding:.6rem .8rem;border-bottom:1px solid var(--border)}.content th{font-weight:700;font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);border-bottom:1px solid var(--text)}.content .table-wrap{overflow-x:auto;margin:1.75rem 0 2.5rem;content-visibility:auto;contain-intrinsic-size:auto 300px}@media(min-width:600px){body{font-size:17px}.container{padding:2rem 1.5rem 5rem}header.site{padding-bottom:5rem}article>h1{font-size:2.1rem}.content h2{font-size:1.4rem}.content h3{font-size:1.15rem}}@media(min-width:900px){body{font-size:18px;line-height:1.7}.container{padding:3rem 2rem 6rem}article>h1{font-size:2.5rem}.content h2{font-size:1.5rem;margin-top:3.5rem}.content h3{font-size:1.2rem}.content figure.wide{width:var(--breakout-wide);max-width:calc(100vw - 4rem);margin-left:50%;transform:translate(-50%)}.content figure.full{width:100vw;max-width:var(--breakout-full);margin-left:50%;transform:translate(-50%);border-radius:0}.content figure.full img{border-radius:0;border-left:none;border-right:none}}:root{--syn-comment: var(--muted);--syn-keyword: #7c3aed;--syn-string: #047857;--syn-number: #b45309;--syn-function: #1d4ed8;--syn-operator: var(--muted);--syn-punctuation: var(--muted)}@media(prefers-color-scheme:dark){:root{--syn-keyword: #c4b5fd;--syn-string: #6ee7b7;--syn-number: #fbbf24;--syn-function: #93c5fd}}.content .token{&:is(.comment,.prolog,.doctype,.cdata){color:var(--syn-comment);font-style:italic}&.punctuation,&:is(.operator,.entity,.url){color:var(--syn-operator)}&.namespace{opacity:.7}&:is(.property,.tag,.boolean,.number,.constant,.symbol,.deleted){color:var(--syn-number)}&:is(.selector,.attr-name,.string,.char,.builtin,.inserted){color:var(--syn-string)}&:is(.atrule,.attr-value,.keyword,.regex,.important,.variable){color:var(--syn-keyword)}&:is(.function,.class-name){color:var(--syn-function)}&:is(.important,.bold){font-weight:700}&.italic{font-style:italic}&.entity{cursor:help}}.content :is(.language-css,.style) .token.string{color:var(--syn-operator)}
