@font-face{font-family:Lexend;src:url(./_astro/Lexend-Variable.BcagUYBp.ttf) format("truetype");font-weight:100 900;font-style:normal;font-display:swap}@font-face{font-family:Illinois Mono;src:url(./_astro/IllinoisMono-Regular.BKfjb2qL.ttf) format("truetype");font-weight:400;font-style:normal;font-display:swap}@font-face{font-family:Illinois Mono;src:url(./_astro/IllinoisMono-Medium.3SmCofG4.ttf) format("truetype");font-weight:500;font-style:normal;font-display:swap}@font-face{font-family:Illinois Mono;src:url(./_astro/IllinoisMono-Bold.BX6rgGmt.ttf) format("truetype");font-weight:700;font-style:normal;font-display:swap}:root{--ink: #14151a;--ink-soft: #3a3d47;--ink-muted: #5d616c;--line: #e4e6ec;--line-strong:#cfd2db;--bg: #ffffff;--bg-soft: #f7f8fa;--bg-sunk: #f1f3f6;--accent: #4f5bd5;--accent-strong: #3b46b8;--accent-soft: #eef0fc;--accent-ink: #2b338f;--warn: #b4540a;--warn-soft: #fbeee2;--ok: #1f7a4d;--ok-soft: #e7f4ec;--font-sans: "Lexend", ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;--font-mono: "Illinois Mono", ui-monospace, SFMono-Regular, Consolas, "Liberation Mono", monospace;--text-scale: 1;--maxw: 1280px;--maxw-prose: 760px;--radius: 12px;--radius-sm: 8px;--shadow-sm: 0 1px 2px rgba(20, 21, 26, .04), 0 1px 3px rgba(20, 21, 26, .06);--shadow-md: 0 4px 16px rgba(20, 21, 26, .06), 0 1px 3px rgba(20, 21, 26, .05);--step: clamp(1rem, .95rem + .3vw, 1.0625rem)}@media(prefers-color-scheme:dark){:root:not([data-theme=light]){--ink: #f2f3f7;--ink-soft: #c7cad4;--ink-muted: #969ba8;--line: #262932;--line-strong:#363a45;--bg: #0f1014;--bg-soft: #16181e;--bg-sunk: #1b1e25;--accent: #8c95f0;--accent-strong: #a3aaf5;--accent-soft: #1c1f33;--accent-ink: #b9bdf7;--warn: #e8924e;--warn-soft: #2a2017;--ok: #5cc78d;--ok-soft: #14241b;--shadow-sm: 0 1px 2px rgba(0,0,0,.4);--shadow-md: 0 8px 28px rgba(0,0,0,.45)}}:root[data-theme=dark]{--ink: #f2f3f7;--ink-soft: #c7cad4;--ink-muted: #969ba8;--line: #262932;--line-strong:#363a45;--bg: #0f1014;--bg-soft: #16181e;--bg-sunk: #1b1e25;--accent: #8c95f0;--accent-strong: #a3aaf5;--accent-soft: #1c1f33;--accent-ink: #b9bdf7;--warn: #e8924e;--warn-soft: #2a2017;--ok: #5cc78d;--ok-soft: #14241b;--shadow-sm: 0 1px 2px rgba(0,0,0,.4);--shadow-md: 0 8px 28px rgba(0,0,0,.45)}:root[data-text-size=extra-small]{--text-scale: .88}:root[data-text-size=small]{--text-scale: .94}:root[data-text-size=medium]{--text-scale: 1}:root[data-text-size=large]{--text-scale: 1.3}:root[data-text-size=extra-large]{--text-scale: 1.7}:root[data-text-size=huge]{--text-scale: 2.1}:root[data-accent=green]{--accent: #21824a;--accent-strong: #196a3a;--accent-soft: rgb(33 130 74 / 10%);--accent-ink: #196a3a}:root[data-accent=blue]{--accent: #2a79f3;--accent-strong: #1e5ec3;--accent-soft: rgb(42 121 243 / 10%);--accent-ink: #1e5ec3}:root[data-accent=orange]{--accent: #de8b23;--accent-strong: #bf6e0f;--accent-soft: rgb(222 139 35 / 10%);--accent-ink: #bf6e0f}:root[data-accent=purple]{--accent: #7b44da;--accent-strong: #622fbd;--accent-soft: rgb(123 68 218 / 10%);--accent-ink: #622fbd}:root[data-accent=red]{--accent: #d53e3e;--accent-strong: #b63232;--accent-soft: rgb(213 62 62 / 10%);--accent-ink: #b63232}:root[data-accent=teal]{--accent: #17a398;--accent-strong: #12857a;--accent-soft: rgb(23 163 152 / 10%);--accent-ink: #12857a}:root[data-accent=cyan]{--accent: #1298d8;--accent-strong: #0f79aa;--accent-soft: rgb(18 152 216 / 10%);--accent-ink: #0f79aa}:root[data-accent=pink]{--accent: #d43f86;--accent-strong: #bd3673;--accent-soft: rgb(212 63 134 / 10%);--accent-ink: #bd3673}:root[data-accent=yellow]{--accent: #d6a828;--accent-strong: #bd8f20;--accent-soft: rgb(214 168 40 / 10%);--accent-ink: #bd8f20}:root[data-theme=dark][data-accent=green]{--accent: #87d99b;--accent-strong: #6fcd87;--accent-soft: rgb(135 217 155 / 12%);--accent-ink: #87d99b}:root[data-theme=dark][data-accent=blue]{--accent: #8abefe;--accent-strong: #7aaef7;--accent-soft: rgb(138 190 254 / 12%);--accent-ink: #8abefe}:root[data-theme=dark][data-accent=orange]{--accent: #f1b16d;--accent-strong: #eaa257;--accent-soft: rgb(241 177 109 / 12%);--accent-ink: #f1b16d}:root[data-theme=dark][data-accent=purple]{--accent: #caa2ff;--accent-strong: #b58dff;--accent-soft: rgb(202 162 255 / 12%);--accent-ink: #caa2ff}:root[data-theme=dark][data-accent=red]{--accent: #f19a9a;--accent-strong: #dd7a7a;--accent-soft: rgb(241 154 154 / 12%);--accent-ink: #f19a9a}:root[data-theme=dark][data-accent=teal]{--accent: #6ed9d1;--accent-strong: #5fc3bc;--accent-soft: rgb(110 217 209 / 12%);--accent-ink: #6ed9d1}:root[data-theme=dark][data-accent=cyan]{--accent: #88d2ff;--accent-strong: #79c5f5;--accent-soft: rgb(136 210 255 / 12%);--accent-ink: #88d2ff}:root[data-theme=dark][data-accent=pink]{--accent: #f8a7cf;--accent-strong: #f58cbf;--accent-soft: rgb(248 167 207 / 12%);--accent-ink: #f8a7cf}:root[data-theme=dark][data-accent=yellow]{--accent: #f4cb67;--accent-strong: #edbf53;--accent-soft: rgb(244 203 103 / 12%);--accent-ink: #f4cb67}@media(prefers-color-scheme:dark){:root:not([data-theme=light])[data-accent=green]{--accent: #87d99b;--accent-strong: #6fcd87;--accent-soft: rgb(135 217 155 / 12%);--accent-ink: #87d99b}:root:not([data-theme=light])[data-accent=blue]{--accent: #8abefe;--accent-strong: #7aaef7;--accent-soft: rgb(138 190 254 / 12%);--accent-ink: #8abefe}:root:not([data-theme=light])[data-accent=orange]{--accent: #f1b16d;--accent-strong: #eaa257;--accent-soft: rgb(241 177 109 / 12%);--accent-ink: #f1b16d}:root:not([data-theme=light])[data-accent=purple]{--accent: #caa2ff;--accent-strong: #b58dff;--accent-soft: rgb(202 162 255 / 12%);--accent-ink: #caa2ff}:root:not([data-theme=light])[data-accent=red]{--accent: #f19a9a;--accent-strong: #dd7a7a;--accent-soft: rgb(241 154 154 / 12%);--accent-ink: #f19a9a}:root:not([data-theme=light])[data-accent=teal]{--accent: #6ed9d1;--accent-strong: #5fc3bc;--accent-soft: rgb(110 217 209 / 12%);--accent-ink: #6ed9d1}:root:not([data-theme=light])[data-accent=cyan]{--accent: #88d2ff;--accent-strong: #79c5f5;--accent-soft: rgb(136 210 255 / 12%);--accent-ink: #88d2ff}:root:not([data-theme=light])[data-accent=pink]{--accent: #f8a7cf;--accent-strong: #f58cbf;--accent-soft: rgb(248 167 207 / 12%);--accent-ink: #f8a7cf}:root:not([data-theme=light])[data-accent=yellow]{--accent: #f4cb67;--accent-strong: #edbf53;--accent-soft: rgb(244 203 103 / 12%);--accent-ink: #f4cb67}}*,*:before,*:after{box-sizing:border-box}[hidden]{display:none!important}html{font-size:calc(100% * var(--text-scale))}html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}@media(prefers-reduced-motion:reduce){html{scroll-behavior:auto}*,*:before,*:after{animation-duration:.001ms!important;transition-duration:.001ms!important}}body{margin:0;font-family:var(--font-sans);font-size:var(--step);line-height:1.65;color:var(--ink);background:var(--bg);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}img,svg{max-width:100%;height:auto;display:block}a{color:var(--accent-ink);text-underline-offset:.18em}a:hover{color:var(--accent-strong)}:focus-visible{outline:3px solid var(--accent);outline-offset:2px;border-radius:4px}h1,h2,h3,h4{line-height:1.18;font-weight:680;letter-spacing:-.018em;color:var(--ink);margin:0 0 .5em}h1{font-size:clamp(2.1rem,1.6rem + 2.4vw,3.4rem)}h2{font-size:clamp(1.55rem,1.3rem + 1.1vw,2.1rem)}h3{font-size:clamp(1.15rem,1.05rem + .5vw,1.35rem)}p{margin:0 0 1em}code,kbd,pre{font-family:var(--font-mono);font-size:.92em}:not(pre)>code{background:var(--bg-sunk);border:1px solid var(--line);padding:.12em .4em;border-radius:6px}.container{width:100%;max-width:var(--maxw);margin-inline:auto;padding-inline:24px}.section{padding-block:clamp(3rem,2rem + 5vw,5.5rem)}.lede{font-size:clamp(1.1rem,1.02rem + .5vw,1.3rem);color:var(--ink-soft);line-height:1.55}.muted{color:var(--ink-muted)}.measure{max-width:74ch}.btn{display:inline-flex;align-items:center;gap:.5em;font:inherit;font-weight:620;line-height:1;cursor:pointer;padding:.82em 1.25em;border-radius:var(--radius-sm);border:1px solid transparent;text-decoration:none;transition:transform .12s ease,background .15s ease,border-color .15s ease}.btn:active{transform:translateY(1px)}.btn--primary{background:var(--accent);color:#fff}.btn--primary:hover{background:var(--accent-strong);color:#fff}.btn--ghost{background:transparent;color:var(--ink);border-color:var(--line-strong)}.btn--ghost:hover{border-color:var(--ink-soft);color:var(--ink);background:var(--bg-soft)}.btn-row{display:flex;flex-wrap:wrap;gap:.75rem;align-items:center}.grid{display:grid;gap:1.25rem}.grid--2{grid-template-columns:repeat(auto-fit,minmax(260px,1fr))}.grid--4{grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}.card{background:var(--bg);border:1px solid var(--line);border-radius:var(--radius);padding:1.4rem 1.5rem;box-shadow:var(--shadow-sm)}.card--link{transition:border-color .15s ease,transform .15s ease,box-shadow .15s ease}.card--link:hover{border-color:var(--line-strong);transform:translateY(-2px);box-shadow:var(--shadow-md)}.card h3{margin-bottom:.35rem}.card p:last-child{margin-bottom:0}.card__mark{display:inline-flex;color:var(--accent);margin-bottom:.7rem;transition:color .18s ease,filter .22s ease,transform .22s ease}.card__mark svg{display:block}.card--link:hover .card__mark,.card--link:focus-visible .card__mark{color:var(--accent-strong);filter:drop-shadow(0 0 9px color-mix(in srgb,var(--accent) 55%,transparent));transform:scale(1.06)}.card--link:active .card__mark{transform:scale(.97)}.tile__head{display:flex;align-items:flex-end;gap:.7rem;margin-bottom:.5rem}.tile__head .card__mark{margin-bottom:0}.tile__head h3{margin:0;line-height:1.05}.tile__head--top{align-items:flex-start}.tile__head--top h3{line-height:1.18}.badge{display:inline-flex;align-items:center;gap:.4em;font-size:.78rem;font-weight:620;line-height:1;padding:.4em .7em;border-radius:100px;border:1px solid var(--line-strong);background:var(--bg-soft);color:var(--ink-soft)}.badge--preview{background:var(--warn-soft);border-color:transparent;color:var(--warn)}.table-wrap{overflow-x:auto;border:1px solid var(--line);border-radius:var(--radius);margin:1.5rem 0}table{width:100%;border-collapse:collapse;font-size:.95rem}th,td{text-align:left;padding:.8rem 1rem;vertical-align:top;border-bottom:1px solid var(--line)}thead th{background:var(--bg-sunk);font-weight:650;color:var(--ink);white-space:nowrap}tbody tr:last-child td{border-bottom:none}td strong{color:var(--ink)}.site-header{position:sticky;top:0;z-index:50;background:color-mix(in srgb,var(--bg) 88%,transparent);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}.site-header__inner{display:flex;align-items:center;gap:1.5rem;min-height:64px}.brand{display:inline-flex;align-items:center;gap:.6rem;font-weight:700;letter-spacing:-.02em;color:var(--ink);text-decoration:none;font-size:1.08rem}.brand svg{width:26px;height:26px;color:var(--accent)}.nav{display:flex;align-items:center;gap:.25rem;margin-left:auto;flex-wrap:wrap}.nav a{color:var(--ink-soft);text-decoration:none;font-weight:540;font-size:.95rem;padding:.45em .7em;border-radius:7px}.nav a:hover{color:var(--ink);background:var(--bg-soft)}.nav a[aria-current=page]{color:var(--accent-ink);background:var(--accent-soft)}@media(max-width:860px){.nav{gap:0;font-size:.9rem}.nav a{padding:.4em .5em}}.theme-toggle{display:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;flex:none;padding:0;margin-left:.5rem;background:transparent;border:1px solid var(--line-strong);border-radius:8px;color:var(--ink-soft);cursor:pointer;transition:border-color .15s ease,color .15s ease,background .15s ease}.theme-toggle:hover{color:var(--ink);border-color:var(--ink-soft);background:var(--bg-soft)}:root[data-embedded] .theme-toggle{display:none}.theme-toggle svg{width:18px;height:18px;display:block}.theme-toggle .icon-sun{display:none}.theme-toggle .icon-moon{display:block}:root[data-theme=dark] .theme-toggle .icon-sun{display:block}:root[data-theme=dark] .theme-toggle .icon-moon{display:none}@media(prefers-color-scheme:dark){:root:not([data-theme=light]) .theme-toggle .icon-sun{display:block}:root:not([data-theme=light]) .theme-toggle .icon-moon{display:none}}.hero{position:relative;padding-block:clamp(3.5rem,2.5rem + 6vw,6.5rem);overflow:hidden}.hero__grid{display:grid;gap:2.5rem;align-items:center}@media(min-width:880px){.hero__grid{grid-template-columns:1.05fr .95fr;gap:3rem}}.hero h1{margin-bottom:.6rem}.hero-head{display:flex;align-items:flex-start;gap:.8rem;margin-bottom:.6rem}.hero-head svg{color:var(--accent);flex:none;margin-top:.12em;filter:drop-shadow(0 0 7px color-mix(in srgb,var(--accent) 32%,transparent));transition:filter .22s ease,transform .22s ease}.hero-head h1{margin:0}.hero .lede{margin-bottom:1.6rem}.hero__frame{display:grid;place-items:center;width:min(340px,78vw);aspect-ratio:1;border:1px solid var(--line);border-radius:var(--radius);background:var(--bg-soft);box-shadow:var(--shadow-sm);transition:border-color .2s ease,box-shadow .2s ease}.hero__frame:hover{border-color:color-mix(in srgb,var(--accent) 50%,var(--line));box-shadow:var(--shadow-md)}.hero-mark{transform-origin:50% 50%;will-change:transform,filter;animation:hero-spin 42s linear infinite,hero-glow 5.5s ease-in-out infinite}.hero-mark .hero-mark__fill{fill:#14151a}.hero-mark .hero-mark__line{fill:#fff}:root[data-theme=dark] .hero-mark .hero-mark__fill{fill:#fff}:root[data-theme=dark] .hero-mark .hero-mark__line{fill:#14151a}@media(prefers-color-scheme:dark){:root:not([data-theme=light]) .hero-mark .hero-mark__fill{fill:#fff}:root:not([data-theme=light]) .hero-mark .hero-mark__line{fill:#14151a}}.hero__frame:hover .hero-mark{animation-duration:10s,2.6s}@keyframes hero-spin{to{transform:rotate(360deg)}}@keyframes hero-glow{0%,to{filter:drop-shadow(0 0 5px color-mix(in srgb,var(--accent) 30%,transparent))}50%{filter:drop-shadow(0 0 17px color-mix(in srgb,var(--accent) 60%,transparent))}}@media(prefers-reduced-motion:reduce){.hero-mark{animation:none}}.site-footer{border-top:1px solid var(--line);background:var(--bg-soft);padding-block:2.5rem;margin-top:2rem}.site-footer__brand{display:flex;flex-wrap:wrap;align-items:center;gap:.4rem .8rem}.site-footer__brand .muted{font-size:.92rem}.site-footer__bottom{margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid var(--line);color:var(--ink-muted);font-size:.88rem}.color-picker{position:relative;display:inline-flex;margin-left:.4rem}:root[data-embedded] .color-picker{display:none}.color-picker__toggle{display:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;flex:none;padding:0;background:transparent;border:1px solid var(--line-strong);border-radius:8px;color:var(--ink-soft);cursor:pointer;transition:border-color .15s ease,background .15s ease}.color-picker__toggle:hover{border-color:var(--ink-soft);background:var(--bg-soft)}.color-picker__dot{width:18px;height:18px;border-radius:50%;background:var(--accent);box-shadow:0 0 0 1px var(--line-strong) inset}.color-picker__menu{position:absolute;right:0;top:calc(100% + 8px);display:grid;grid-template-columns:repeat(5,1fr);gap:8px;padding:10px;z-index:60;background:var(--bg);border:1px solid var(--line);border-radius:10px;box-shadow:var(--shadow-md)}.color-picker__menu[hidden]{display:none}.color-picker__swatch{width:26px;height:26px;padding:0;border-radius:50%;border:2px solid transparent;cursor:pointer;box-shadow:0 0 0 1px var(--line-strong) inset;transition:transform .12s ease}.color-picker__swatch:hover{transform:scale(1.12)}.color-picker__swatch[aria-checked=true]{border-color:var(--ink)}.color-picker__swatch--default{background:conic-gradient(#21824a,#2a79f3,#7b44da,#d53e3e,#de8b23,#21824a)}.ext-modal{position:fixed;inset:0;z-index:200;display:grid;place-items:center;padding:1rem}.ext-modal[hidden]{display:none}.ext-modal__backdrop{position:absolute;inset:0;background:#08090c8c;backdrop-filter:blur(2px)}.ext-modal__panel{position:relative;width:min(440px,100%);background:var(--bg);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-md);padding:1.4rem 1.5rem}.ext-modal__x{position:absolute;top:.55rem;right:.6rem;width:32px;height:32px;display:inline-flex;align-items:center;justify-content:center;font-size:1.4rem;line-height:1;color:var(--ink-muted);background:transparent;border:0;border-radius:8px;cursor:pointer}.ext-modal__x:hover{background:var(--bg-soft);color:var(--ink)}.ext-modal__title{font-weight:680;font-size:1.05rem;margin:0 1.5rem .35rem 0;color:var(--ink)}.ext-modal__hint{font-size:.9rem;margin:0 0 .9rem}.ext-modal__url{display:block;word-break:break-all;font-family:var(--font-mono);font-size:.86rem;background:var(--bg-sunk);border:1px solid var(--line);border-radius:var(--radius-sm);padding:.6em .7em;margin-bottom:1rem;color:var(--ink-soft)}.ext-modal__actions{display:flex;gap:.6rem;flex-wrap:wrap}a.qdn-link{font-family:var(--font-mono);font-size:.92em;text-decoration:none;color:var(--accent-ink);background:var(--accent-soft);border:1px solid color-mix(in srgb,var(--accent) 35%,transparent);padding:.12em .45em;border-radius:6px}a.qdn-link:hover{border-color:var(--accent);color:var(--accent-strong);text-decoration:underline}.skip-link{position:absolute;left:-9999px;top:0;background:var(--accent);color:#fff;padding:.6em 1em;border-radius:0 0 8px;z-index:100}.skip-link:focus{left:0}
