@font-face{font-family:GeistSans;src:url(/_next/static/media/27834908180db20f-s.p.woff2) format("woff2");font-display:swap;font-weight:100 900}@font-face{font-family:GeistSans Fallback;src:local("Arial");ascent-override:94.56%;descent-override:27.76%;line-gap-override:0.00%;size-adjust:106.28%}.__className_245d8d{font-family:GeistSans,GeistSans Fallback}.__variable_245d8d{--font-geist-sans:"GeistSans","GeistSans Fallback"}@font-face{font-family:GeistMono;src:url(/_next/static/media/78fec81b34c4a365.p.woff2) format("woff2");font-display:swap;font-weight:100 900}.__className_97c177{font-family:GeistMono,ui-monospace,SFMono-Regular,Roboto Mono,Menlo,Monaco,Liberation Mono,DejaVu Sans Mono,Courier New,monospace}.__variable_97c177{--font-geist-mono:"GeistMono",ui-monospace,SFMono-Regular,Roboto Mono,Menlo,Monaco,Liberation Mono,DejaVu Sans Mono,Courier New,monospace}@font-face{font-family:"Instrument Serif";font-style:italic;font-weight:400;font-display:swap;src:url(/_next/static/media/5ece437c7024c161-s.woff2) format("woff2");unicode-range:u+0100-02ba,u+02bd-02c5,u+02c7-02cc,u+02ce-02d7,u+02dd-02ff,u+0304,u+0308,u+0329,u+1d00-1dbf,u+1e00-1e9f,u+1ef2-1eff,u+2020,u+20a0-20ab,u+20ad-20c0,u+2113,u+2c60-2c7f,u+a720-a7ff}@font-face{font-family:"Instrument Serif";font-style:italic;font-weight:400;font-display:swap;src:url(/_next/static/media/9cc5b37ab1350db7-s.p.woff2) format("woff2");unicode-range:u+00??,u+0131,u+0152-0153,u+02bb-02bc,u+02c6,u+02da,u+02dc,u+0304,u+0308,u+0329,u+2000-206f,u+20ac,u+2122,u+2191,u+2193,u+2212,u+2215,u+feff,u+fffd}@font-face{font-family:"Instrument Serif";font-style:normal;font-weight:400;font-display:swap;src:url(/_next/static/media/35f3de0ebb1cfc70-s.woff2) format("woff2");unicode-range:u+0100-02ba,u+02bd-02c5,u+02c7-02cc,u+02ce-02d7,u+02dd-02ff,u+0304,u+0308,u+0329,u+1d00-1dbf,u+1e00-1e9f,u+1ef2-1eff,u+2020,u+20a0-20ab,u+20ad-20c0,u+2113,u+2c60-2c7f,u+a720-a7ff}@font-face{font-family:"Instrument Serif";font-style:normal;font-weight:400;font-display:swap;src:url(/_next/static/media/e6099e249fd938cc-s.p.woff2) format("woff2");unicode-range:u+00??,u+0131,u+0152-0153,u+02bb-02bc,u+02c6,u+02da,u+02dc,u+0304,u+0308,u+0329,u+2000-206f,u+20ac,u+2122,u+2191,u+2193,u+2212,u+2215,u+feff,u+fffd}@font-face{font-family:"Instrument Serif Fallback";src:local("Times New Roman");ascent-override:117.94%;descent-override:36.93%;line-gap-override:0.00%;size-adjust:83.94%}.__className_1f5468{font-family:"Instrument Serif","Instrument Serif Fallback";font-weight:400}.__variable_1f5468{--font-instrument-serif:"Instrument Serif","Instrument Serif Fallback"}:root{--bg:#0a0a0a;--surface:#111113;--surface-2:#16161a;--surface-3:#1c1c20;--border:#1f1f23;--border-strong:#2a2a30;--ink:#f4f4f5;--ink-soft:#d4d4d8;--ink-mute:#a1a1aa;--ink-dim:#71717a;--ink-whisper:#52525b;--accent:#fa500f;--accent-soft:rgba(250,80,15,0.08);--accent-edge:rgba(250,80,15,0.4);--accent-glow:rgba(250,80,15,0.22);--sans:var(--font-geist-sans),-apple-system,BlinkMacSystemFont,"Segoe UI",system-ui,sans-serif;--mono:var(--font-geist-mono),"JetBrains Mono","SF Mono",ui-monospace,Menlo,Consolas,monospace;--serif:var(--font-instrument-serif),"Iowan Old Style",Georgia,"Times New Roman",serif}*{box-sizing:border-box}body,html{margin:0;padding:0;background:var(--bg);color:var(--ink);font-family:var(--sans);font-size:15px;line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility;text-size-adjust:100%}body{overflow-x:hidden}html{scroll-behavior:smooth;color-scheme:dark}a{color:inherit;text-decoration:none}img,svg{display:block;max-width:100%}::selection{background:var(--accent);color:var(--bg)}.page{min-height:100vh;display:flex;flex-direction:column}.wrap{width:100%;max-width:1120px;margin:0 auto;padding:0 20px}@media (max-width:560px){.wrap{padding:0 18px}}@media (max-width:360px){.wrap{padding:0 14px}}main.main{flex:1 1}.topbar{border-bottom:1px solid var(--border)}.topbar-row{display:flex;align-items:center;justify-content:space-between;gap:18px;padding:16px 0}.brand{display:inline-flex;align-items:center;gap:10px;font-weight:600;font-size:14.5px;letter-spacing:-.01em}.brand img{width:26px;height:26px;image-rendering:pixelated;border-radius:5px}.topbar-links{gap:14px;color:var(--ink-mute);font-size:13.5px}.topbar-links,.topbar-links a{display:inline-flex;align-items:center}.topbar-links a{gap:6px;transition:color .15s}.topbar-links a:hover{color:var(--ink)}.nav-text{font-size:13px;font-weight:500;letter-spacing:-.005em}@media (max-width:720px){.topbar-links .hide-sm{display:none}}@media (max-width:640px){.topbar-row{gap:10px;padding:14px 0}.topbar-links{gap:10px}.star-btn .star-divider,.star-btn .star-label{display:none}.star-btn{padding:8px 10px;gap:6px}.github-btn{padding:8px 12px;font-size:13px}.brand span{font-size:14px}}@media (max-width:400px){.star-btn .star-count{display:none}.star-btn{padding:8px}.brand img{width:24px;height:24px}}.star-btn{display:inline-flex;align-items:center;gap:7px;padding:6px 11px;font-family:var(--sans);font-size:13px;font-weight:600;color:var(--ink-soft);background:var(--surface);border:1px solid var(--border-strong);border-radius:8px;letter-spacing:-.005em;transition:background .15s,border-color .15s,color .15s;line-height:1}.star-btn:hover{background:var(--surface-2);border-color:#3a3a42;color:var(--ink)}.star-btn svg{width:14px;height:14px;color:var(--ink-soft)}.star-btn .star-label{color:var(--ink)}.star-btn .star-divider{width:1px;height:12px;background:var(--border-strong);margin:0 2px}.star-btn .star-count{color:var(--ink-dim);font-weight:500;font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.github-btn{display:inline-flex;align-items:center;gap:8px;padding:7px 14px;font-family:var(--sans);font-size:13.5px;font-weight:600;color:#ffffff;background:var(--accent);border:1px solid transparent;border-radius:8px;letter-spacing:-.005em;box-shadow:0 1px 0 rgba(0,0,0,.2),inset 0 1px 0 rgba(255,255,255,.14);transition:background .15s,transform .05s,box-shadow .15s}.github-btn:hover{background:#f0490a;color:#ffffff}.github-btn:active{background:#d84309;transform:translateY(1px);box-shadow:inset 0 1px 2px rgba(0,0,0,.2)}section{padding:80px 0}section+section{border-top:1px solid var(--border)}@media (max-width:720px){section{padding:64px 0}}@media (max-width:480px){section{padding:48px 0}}.kicker{display:inline-flex;align-items:center;gap:10px;font-family:var(--mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-dim)}.kicker:before{content:"";width:6px;height:6px;border-radius:50%;background:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.section-h{font-family:var(--sans);font-size:clamp(26px,3vw,34px);font-weight:600;letter-spacing:-.02em;line-height:1.15;margin:18px 0;max-width:24ch}.section-h .serif{font-family:var(--serif);font-style:italic;font-weight:400;color:var(--accent)}.lede{color:var(--ink-soft);font-size:16px;line-height:1.6;max-width:58ch;margin:0 0 20px}.hero{padding:88px 0 72px;text-align:center}@media (max-width:720px){.hero{padding:64px 0 56px}}@media (max-width:480px){.hero{padding:48px 0 44px}}.hero-inner{max-width:620px;margin:0 auto}.hero-logo{width:96px;height:96px;image-rendering:pixelated;margin:0 auto 24px}@media (max-width:480px){.hero-logo{width:72px;height:72px;margin-bottom:20px}}.hero h1{font-size:clamp(30px,3.6vw,40px);font-weight:600;letter-spacing:-.02em;line-height:1.12;margin:0 0 10px}.hero-sub{color:var(--ink-mute);font-size:14.5px;margin:0 0 28px}.url-card{display:grid;grid-template-columns:1fr auto;grid-gap:8px;gap:8px;align-items:stretch;padding:14px 16px;text-align:left;background:linear-gradient(180deg,rgba(250,80,15,.04),transparent 40%),var(--surface);border:1px solid var(--accent-edge);border-radius:12px;box-shadow:0 0 0 4px var(--accent-soft),0 14px 40px -18px var(--accent-glow);max-width:540px;margin:0 auto}.url-card-body{min-width:0}.url-card-label{font-family:var(--mono);font-size:10.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-dim);margin-bottom:4px}.url-card-value{font-family:var(--mono);font-size:15px;color:var(--ink);letter-spacing:-.002em;white-space:nowrap;overflow-x:auto;scrollbar-width:none;padding-right:4px}.url-card-value::-webkit-scrollbar{display:none}@media (max-width:520px){.url-card{grid-template-columns:1fr;gap:12px;padding:14px 14px 12px}.url-card-value{white-space:normal;word-break:break-all;font-size:13.5px;padding-right:0}.url-card .copy-btn{justify-self:start;align-self:start}}.copy-btn{align-self:center;display:inline-flex;align-items:center;gap:6px;padding:8px 12px;font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-mute);background:var(--surface-2);border:1px solid var(--border-strong);border-radius:8px;cursor:pointer;transition:color .15s,border-color .15s,background .15s;white-space:nowrap}.copy-btn:hover{color:var(--ink);border-color:#3a3a42;background:var(--surface-3)}.copy-btn[data-copied=true]{color:var(--accent);border-color:var(--accent-edge);background:var(--accent-soft)}.copy-btn svg{width:12px;height:12px}.two-col{display:grid;grid-template-columns:minmax(0,.9fr) minmax(0,1.1fr);grid-gap:48px;gap:48px;align-items:start}@media (max-width:900px){.two-col{grid-template-columns:1fr;gap:32px}}.client-tabs{background:var(--surface);border:1px solid var(--border);border-radius:14px;overflow:hidden}.tab-list{display:flex;flex-wrap:nowrap;overflow-x:auto;scrollbar-width:none;border-bottom:1px solid var(--border);background:var(--surface-2)}.tab-list::-webkit-scrollbar{display:none}.tab-btn{flex:0 0 auto;padding:11px 14px;min-height:42px;font-family:var(--sans);font-size:13px;font-weight:500;color:var(--ink-dim);background:transparent;border:0;border-right:1px solid var(--border);cursor:pointer;transition:color .15s,background .15s;letter-spacing:-.005em;white-space:nowrap}@media (max-width:480px){.tab-btn{padding:12px 13px;font-size:12.5px}.tab-panel{padding:14px 14px 16px}}.tab-btn:last-child{border-right:0}.tab-btn:hover{color:var(--ink-soft);background:var(--surface-3)}.tab-btn.is-active{color:var(--ink);background:var(--surface);box-shadow:inset 0 -2px 0 0 var(--accent)}.tab-panel{padding:16px 18px 18px}.tab-note{font-family:var(--mono);font-size:12px;color:var(--ink-dim);margin-bottom:10px;letter-spacing:.01em;line-height:1.55}.tab-note-mark{color:var(--ink-whisper)}.code{position:relative;display:flex;align-items:stretch;background:var(--bg);border:1px solid var(--border);border-radius:9px;overflow:hidden}.code pre{margin:0;padding:13px 14px;font-family:var(--mono);font-size:12.5px;line-height:1.55;color:var(--ink-soft);overflow-x:auto;flex:1 1;min-width:0;scrollbar-width:thin;scrollbar-color:var(--border-strong) transparent}.code pre::-webkit-scrollbar{height:6px}.code pre::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:3px}.code .copy-btn{margin:8px 8px 8px 0;align-self:flex-start}.code-wide pre{padding:14px 16px}.queries-intro{margin:0 0 14px}.queries-intro,.queries-plain{color:var(--ink-soft);font-size:15px;line-height:1.55}.queries-plain{list-style:disc;padding-left:22px;margin:0;display:grid;grid-gap:10px;gap:10px}.queries-plain li::marker{color:var(--ink-dim)}footer.site-footer{border-top:1px solid var(--border);padding:20px 0 24px;color:var(--ink-dim);font-size:13px}footer .foot-row{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;grid-gap:16px;gap:16px}footer .foot-row .icons{justify-self:start;display:inline-flex;gap:14px;align-items:center}footer .foot-row .icons a{color:var(--ink-mute);display:inline-flex}footer .foot-row .icons a:hover{color:var(--ink)}footer .foot-row .attr{justify-self:center;text-align:center}footer .foot-row .attr a{color:var(--ink-mute);text-decoration:underline;text-underline-offset:3px;-webkit-text-decoration-color:var(--border-strong);text-decoration-color:var(--border-strong)}footer .foot-row .attr a:hover{color:var(--ink);-webkit-text-decoration-color:var(--accent);text-decoration-color:var(--accent)}footer .foot-row .disclaimer{justify-self:end;text-align:right}@media (max-width:720px){footer .foot-row{grid-template-columns:1fr;gap:10px;text-align:center}footer .foot-row .attr,footer .foot-row .disclaimer,footer .foot-row .icons{justify-self:center;text-align:center}}a:focus-visible,button:focus-visible{outline:2px solid var(--accent);outline-offset:3px;border-radius:4px}@media (prefers-reduced-motion:no-preference){main.main>section{opacity:0;transform:translateY(6px);animation:rise .5s ease-out forwards}main.main>section:first-child{animation-delay:.04s}main.main>section:nth-child(2){animation-delay:.12s}main.main>section:nth-child(3){animation-delay:.2s}@keyframes rise{to{opacity:1;transform:none}}}