.astro-route-announcer{position:absolute;left:0;top:0;clip:rect(0 0 0 0);clip-path:inset(50%);overflow:hidden;white-space:nowrap;width:1px;height:1px}.logo[data-astro-cid-tvrurpns]{display:inline-flex;align-items:center;gap:.55rem;text-decoration:none;white-space:nowrap}.tick[data-astro-cid-tvrurpns]{color:var(--cool);flex-shrink:0;filter:drop-shadow(0 0 4px var(--cool-dim))}.logo__name[data-astro-cid-tvrurpns]{font-family:var(--font-sans);font-size:1.02rem;font-weight:600;letter-spacing:-.02em;color:var(--text)}.logo__tag[data-astro-cid-tvrurpns]{font-family:var(--font-mono);font-size:.7rem;letter-spacing:.1em;color:var(--text-3)}.logo[data-astro-cid-tvrurpns]:hover .logo__tag[data-astro-cid-tvrurpns]{color:var(--text-2)}nav[data-astro-cid-dmqpwcec]{display:flex;gap:1.75rem;align-items:center}a[data-astro-cid-dmqpwcec]{position:relative;font-size:.92rem;font-weight:500;color:var(--text-3);text-decoration:none;padding:.25rem 0;transition:color var(--dur-fast) var(--ease)}a[data-astro-cid-dmqpwcec]:after{content:"";position:absolute;left:0;right:0;bottom:-2px;height:2px;background:var(--cool);box-shadow:0 0 8px var(--cool-dim);transform:scaleX(0);transform-origin:left;transition:transform var(--dur) var(--ease)}a[data-astro-cid-dmqpwcec]:hover{color:var(--text)}a[data-astro-cid-dmqpwcec]:hover:after,a[data-astro-cid-dmqpwcec].active:after{transform:scaleX(1)}a[data-astro-cid-dmqpwcec].active{color:var(--text)}header[data-astro-cid-3ef6ksr2]{position:sticky;top:0;z-index:100;border-bottom:1px solid var(--border);background:color-mix(in srgb,var(--bg) 72%,transparent);backdrop-filter:blur(12px) saturate(140%);-webkit-backdrop-filter:blur(12px) saturate(140%)}.header-inner[data-astro-cid-3ef6ksr2]{max-width:var(--max-width-wide);margin:0 auto;min-height:var(--header-height);padding:.75rem 1.5rem;display:flex;align-items:center;justify-content:space-between;gap:1.5rem}@media(max-width:560px){.header-inner[data-astro-cid-3ef6ksr2]{flex-direction:column;gap:.6rem;padding:.85rem 1.5rem}}@keyframes astroFadeInOut{0%{opacity:1}to{opacity:0}}@keyframes astroFadeIn{0%{opacity:0;mix-blend-mode:plus-lighter}to{opacity:1;mix-blend-mode:plus-lighter}}@keyframes astroFadeOut{0%{opacity:1;mix-blend-mode:plus-lighter}to{opacity:0;mix-blend-mode:plus-lighter}}@keyframes astroSlideFromRight{0%{transform:translate(100%)}}@keyframes astroSlideFromLeft{0%{transform:translate(-100%)}}@keyframes astroSlideToRight{to{transform:translate(100%)}}@keyframes astroSlideToLeft{to{transform:translate(-100%)}}@media(prefers-reduced-motion){::view-transition-group(*),::view-transition-old(*),::view-transition-new(*){animation:none!important}[data-astro-transition-scope]{animation:none!important}}.social-icons[data-astro-cid-dv46nlzh]{display:flex;gap:.5rem;align-items:center}a[data-astro-cid-dv46nlzh]{display:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;border:1px solid var(--control-border);border-radius:var(--r-sm);color:var(--text-3);background:var(--control-bg);transition:color var(--dur-fast) var(--ease),border-color var(--dur-fast) var(--ease),background var(--dur-fast) var(--ease),box-shadow var(--dur-fast) var(--ease),transform var(--dur-fast) var(--ease)}a[data-astro-cid-dv46nlzh]:hover{color:var(--cool);border-color:var(--cool);background:var(--cool-dim);box-shadow:var(--glow-cool);transform:translateY(-1px);text-decoration:none}.signal[data-astro-cid-uy7raj4m]{position:relative;width:100%;height:var(--h);overflow:hidden;pointer-events:none}svg[data-astro-cid-uy7raj4m]{width:100%;height:100%;display:block}.grid[data-astro-cid-uy7raj4m] line[data-astro-cid-uy7raj4m]{stroke:var(--border-subtle);stroke-width:1;vector-effect:non-scaling-stroke}.grid[data-astro-cid-uy7raj4m] .baseline[data-astro-cid-uy7raj4m]{stroke:var(--border)}.trace[data-astro-cid-uy7raj4m]{fill:none;stroke-width:1.5;vector-effect:non-scaling-stroke;stroke-linecap:round;stroke-linejoin:round}.trace--cool[data-astro-cid-uy7raj4m]{stroke:var(--cool)}.trace--warm[data-astro-cid-uy7raj4m]{stroke:var(--warm)}.signal--hero[data-astro-cid-uy7raj4m]{mask-image:linear-gradient(90deg,transparent,#000 12%,#000 88%,transparent)}.signal--hero[data-astro-cid-uy7raj4m] .trace--cool[data-astro-cid-uy7raj4m]{opacity:.5}.signal--hero[data-astro-cid-uy7raj4m] .trace--warm[data-astro-cid-uy7raj4m]{opacity:.32;transform:translateY(10px)}.signal--divider[data-astro-cid-uy7raj4m]{mask-image:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent)}.signal--divider[data-astro-cid-uy7raj4m] .trace--cool[data-astro-cid-uy7raj4m]{opacity:.65}.signal--divider[data-astro-cid-uy7raj4m] .trace--warm[data-astro-cid-uy7raj4m]{opacity:.4;transform:translateY(3px)}footer[data-astro-cid-sz7xmlte]{margin-top:auto;background:var(--bg);position:relative;z-index:2}.footer-inner[data-astro-cid-sz7xmlte]{max-width:var(--max-width-wide);margin:0 auto;padding:2.5rem 1.5rem}.footer-top[data-astro-cid-sz7xmlte]{display:flex;align-items:center;justify-content:space-between;gap:1.5rem;flex-wrap:wrap}.footer-brand[data-astro-cid-sz7xmlte]{display:flex;flex-direction:column;gap:.15rem}.footer-name[data-astro-cid-sz7xmlte]{font-weight:600;letter-spacing:-.02em}.footer-role[data-astro-cid-sz7xmlte]{font-size:.85rem;color:var(--text-3)}.footer-bottom[data-astro-cid-sz7xmlte]{display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap;margin-top:1.75rem;padding-top:1.25rem;border-top:1px solid var(--border);font-family:var(--font-mono);font-size:.76rem;color:var(--text-muted)}.footer-bottom[data-astro-cid-sz7xmlte] a[data-astro-cid-sz7xmlte]{color:var(--text-3)}.footer-bottom[data-astro-cid-sz7xmlte] a[data-astro-cid-sz7xmlte]:hover{color:var(--cool)}.sep[data-astro-cid-sz7xmlte]{margin:0 .4rem;color:var(--text-muted)}@font-face{font-family:General Sans;src:url(/fonts/general-sans-400.woff2) format("woff2");font-weight:400;font-style:normal;font-display:swap}@font-face{font-family:General Sans;src:url(/fonts/general-sans-500.woff2) format("woff2");font-weight:500;font-style:normal;font-display:swap}@font-face{font-family:General Sans;src:url(/fonts/general-sans-600.woff2) format("woff2");font-weight:600;font-style:normal;font-display:swap}@font-face{font-family:General Sans;src:url(/fonts/general-sans-700.woff2) format("woff2");font-weight:700;font-style:normal;font-display:swap}@font-face{font-family:JetBrains Mono;src:url(/fonts/jetbrains-mono-400.woff2) format("woff2");font-weight:400;font-style:normal;font-display:swap}@font-face{font-family:JetBrains Mono;src:url(/fonts/jetbrains-mono-500.woff2) format("woff2");font-weight:500;font-style:normal;font-display:swap}@font-face{font-family:JetBrains Mono;src:url(/fonts/jetbrains-mono-600.woff2) format("woff2");font-weight:600;font-style:normal;font-display:swap}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #0a0d12;--surface-1: #0f141b;--surface-2: #151c25;--surface-3: #1c2530;--text: #eef2f6;--text-2: #aeb9c7;--text-3: #76828f;--text-muted: #4d5662;--border-subtle: rgba(255, 255, 255, .05);--border: rgba(255, 255, 255, .08);--border-strong: rgba(255, 255, 255, .14);--control-bg: rgba(255, 255, 255, .02);--control-border: rgba(255, 255, 255, .1);--cool: #46d4e0;--cool-bright: #7fe6ef;--cool-dim: rgba(70, 212, 224, .14);--warm: #ff8a5c;--warm-bright: #ffa980;--warm-dim: rgba(255, 138, 92, .14);--glow-cool: 0 0 44px rgba(70, 212, 224, .16);--font-sans: "General Sans", system-ui, -apple-system, sans-serif;--font-mono: "JetBrains Mono", ui-monospace, "SFMono-Regular", monospace;--step--1: clamp(.82rem, .79rem + .15vw, .9rem);--step-0: 1rem;--step-1: clamp(1.1rem, 1.05rem + .3vw, 1.25rem);--step-2: clamp(1.35rem, 1.2rem + .6vw, 1.65rem);--step-3: clamp(1.7rem, 1.45rem + 1.1vw, 2.25rem);--step-4: clamp(2.2rem, 1.75rem + 2.1vw, 3.1rem);--step-5: clamp(2.9rem, 2rem + 3.8vw, 4.6rem);--r-sm: 6px;--r-md: 10px;--r-lg: 16px;--ease: cubic-bezier(.22, .61, .36, 1);--dur-fast: .15s;--dur: .24s;--dur-slow: .4s;--max-width: 720px;--max-width-wide: 1040px;--header-height: 64px;--text-secondary: var(--text-2);--text-faint: var(--text-3);--accent: var(--cool);--accent-strong: var(--cool-bright);--accent-dim: var(--cool-dim);--bg-elev: var(--surface-1);--bg-secondary: var(--surface-1);--bg-subtle: var(--surface-2)}html{font-family:var(--font-sans);color:var(--text);background:var(--bg);line-height:1.7;font-size:17px;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;scroll-behavior:smooth}body{min-height:100vh;display:flex;flex-direction:column;position:relative}body:before{content:"";position:fixed;inset:0;z-index:1;pointer-events:none;opacity:.035;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}main{flex:1;width:100%;max-width:var(--max-width);margin:0 auto;padding:3.5rem 1.5rem 5rem;position:relative;z-index:2}main.wide{max-width:var(--max-width-wide)}a{color:var(--cool);text-decoration:none;transition:color var(--dur-fast) var(--ease)}a:hover{color:var(--cool-bright)}h1,h2,h3,h4{font-weight:600;letter-spacing:-.025em;line-height:1.12;color:var(--text)}::selection{background:var(--cool-dim);color:var(--text)}img{max-width:100%;height:auto}:focus-visible{outline:2px solid var(--cool);outline-offset:3px;border-radius:3px}.mono,code,kbd,.tnum{font-variant-numeric:tabular-nums}.container{max-width:var(--max-width);margin:0 auto}.container-wide{max-width:var(--max-width-wide);margin:0 auto}.kicker{font-family:var(--font-mono);font-size:.74rem;font-weight:500;letter-spacing:.2em;text-transform:uppercase;color:var(--cool)}.page-title{font-size:var(--step-4);line-height:1.05;margin-bottom:.6rem}.page-intro{color:var(--text-2);margin-bottom:3rem;font-size:1.05rem;max-width:42rem}.skip-link{position:absolute;left:-999px;top:0;z-index:200;padding:.6rem 1rem;background:var(--surface-2);border:1px solid var(--border-strong);border-radius:var(--r-sm);color:var(--text)}.skip-link:focus{left:1rem;top:1rem}@media(prefers-reduced-motion:no-preference){.reveal{opacity:0;transform:translateY(14px);animation:reveal-in var(--dur-slow) var(--ease) forwards;animation-delay:calc(var(--i, 0) * 90ms + 60ms)}}@keyframes reveal-in{to{opacity:1;transform:none}}@media(prefers-reduced-motion:no-preference){::view-transition-old(root),::view-transition-new(root){animation-duration:var(--dur)}}#lightbox{position:fixed;inset:0;z-index:300;display:none;align-items:center;justify-content:center;padding:4vmin;background:#05070adb;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);cursor:zoom-out}#lightbox.open{display:flex}#lightbox img{max-width:100%;max-height:100%;border-radius:var(--r-md);border:1px solid var(--border-strong);box-shadow:0 24px 70px #0009}.astro-code{border-radius:var(--r-md)}.prose{font-size:1.06rem;line-height:1.8;color:var(--text)}.prose>*+*{margin-top:1.4rem}.prose h1{font-size:var(--step-3);line-height:1.2;margin-top:2.5rem}.prose h2{font-size:var(--step-2);line-height:1.25;margin-top:2.75rem;padding-bottom:.5rem;position:relative}.prose h2:after{content:"";position:absolute;left:0;right:0;bottom:0;height:1.5px;background:linear-gradient(90deg,var(--cool) 0%,var(--cool) 50%,var(--warm) 82%,var(--warm) 100%);-webkit-mask-image:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent);mask-image:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent)}.prose h3{font-size:var(--step-1);line-height:1.3;margin-top:2rem}.prose h4{font-size:1.05rem;margin-top:1.5rem;color:var(--text-secondary)}.prose a{color:var(--accent);text-decoration:none;background-image:linear-gradient(var(--accent),var(--accent));background-size:100% 1px;background-position:left bottom;background-repeat:no-repeat;transition:color .2s ease}.prose a:hover{color:var(--accent-strong)}.prose pre{position:relative;border:1px solid var(--border);border-left:3px solid var(--accent);border-radius:8px;padding:1rem 1.25rem;overflow-x:auto;font-size:.9rem;line-height:1.6}.copy-btn{position:absolute;top:.5rem;right:.5rem;padding:.25rem .6rem;font-family:var(--font-mono);font-size:.7rem;letter-spacing:.04em;color:var(--text-2);background:var(--surface-2);border:1px solid var(--border-strong);border-radius:var(--r-sm);cursor:pointer;opacity:0;transition:opacity var(--dur-fast) var(--ease),color var(--dur-fast) var(--ease),border-color var(--dur-fast) var(--ease)}.prose pre:hover .copy-btn,.copy-btn:focus-visible{opacity:1}.copy-btn:hover{color:var(--cool);border-color:var(--cool)}.copy-btn.copied{opacity:1;color:var(--cool);border-color:var(--cool)}@media(hover:none){.copy-btn{opacity:1}}.prose :not(pre)>code{font-family:var(--font-mono);font-size:.88em;padding:.15em .4em;border-radius:4px;border:1px solid var(--border);background:var(--bg-subtle);color:var(--text)}.prose blockquote{border-left:3px solid var(--accent);padding:.5rem 1.1rem;color:var(--text-secondary);background:var(--bg-elev);border-radius:0 8px 8px 0}.prose blockquote p{margin:0}.prose img{border-radius:8px;margin:1.75rem auto;display:block;border:1px solid var(--border);box-shadow:0 2px 16px #00000073;cursor:zoom-in;transition:border-color var(--dur-fast) var(--ease)}.prose img:hover{border-color:var(--cool)}.prose table{width:100%;border-collapse:collapse;font-size:.95rem;overflow-x:auto;display:block}.prose thead tr{border-bottom:2px solid var(--accent)}.prose th,.prose td{padding:.55rem .8rem;text-align:left;border-bottom:1px solid var(--border)}.prose th{font-weight:600;font-size:.85rem;letter-spacing:.02em;color:var(--text-secondary)}.prose hr{border:none;height:1px;background:var(--border);margin:2.5rem 0}.prose ul,.prose ol{padding-left:1.4rem}.prose li{margin-top:.35rem}.prose li>ul,.prose li>ol{margin-top:.35rem}.prose li::marker{color:var(--text-faint)}.prose strong{font-weight:600;color:var(--text)}
