@font-face{font-family:"Space Grotesk";font-style:normal;font-weight:500;font-display:swap;src:url("/fonts/SpaceGrotesk-Medium.woff2") format("woff2")}@font-face{font-family:"Space Grotesk";font-style:normal;font-weight:700;font-display:swap;src:url("/fonts/SpaceGrotesk-Bold.woff2") format("woff2")}@font-face{font-family:"Inter";font-style:normal;font-weight:400;font-display:swap;src:url("/fonts/Inter-Regular.woff2") format("woff2")}@font-face{font-family:"Inter";font-style:normal;font-weight:600;font-display:swap;src:url("/fonts/Inter-SemiBold.woff2") format("woff2")}@font-face{font-family:"Inter";font-style:normal;font-weight:700;font-display:swap;src:url("/fonts/Inter-Bold.woff2") format("woff2")}@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")}:root{--base: #1e1e2e;--mantle: #181825;--crust: #11111b;--surface0: #313244;--surface1: #45475a;--surface2: #585b70;--text: #cdd6f4;--subtext0: #a6adc8;--overlay0: #6c7086;--mauve: #cba6f7;--blue: #89b4fa;--sapphire: #74c7ec;--green: #a6e3a1;--peach: #fab387;--pink: #f5c2e7;--yellow: #f9e2af;--red: #f38ba8;--bg: var(--base);--fg: var(--text);--muted: var(--subtext0);--faint: var(--overlay0);--accent: var(--mauve);--link: var(--blue);--border: var(--surface0);--border-strong: var(--surface1);--font-head: "Space Grotesk", ui-sans-serif, system-ui, "Segoe UI", Roboto, sans-serif;--font-body: "Inter", ui-sans-serif, system-ui, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;--font-mono: "JetBrains Mono", ui-monospace, "Fira Code", Menlo, monospace;--fs-h1: clamp(34px, 5vw, 56px);--fs-h2: clamp(24px, 3.4vw, 34px);--fs-h3: 17px;--fs-body: 16px;--fs-lede: clamp(17px, 2.2vw, 21px);--fs-small: 13.5px;--lh-body: 1.6;--lh-head: 1.08;--sp-1: 8px;--sp-2: 16px;--sp-3: 24px;--sp-4: 32px;--sp-6: 48px;--sp-8: 64px;--r-sm: 10px;--r-md: 14px;--r-lg: 16px;--r-pill: 999px;--container: 1080px;--container-wide: 1200px;--ease-out: cubic-bezier(0.22, 1, 0.36, 1);--ease-in-out: cubic-bezier(0.65, 0, 0.35, 1);--dur-fast: 150ms;--dur: 220ms;--shadow-stage: 0 30px 80px -40px #000;--grid-line: var(--surface0)}*,*::before,*::after{box-sizing:border-box}html{scroll-behavior:smooth;scroll-padding-top:76px}@media (prefers-reduced-motion: reduce){html{scroll-behavior:auto}}body{margin:0;background:var(--bg);color:var(--fg);font-family:var(--font-body);font-size:var(--fs-body);line-height:var(--lh-body);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}h1,h2,h3,h4{font-family:var(--font-head);line-height:var(--lh-head);font-weight:700;margin:0 0 var(--sp-1)}h1{font-size:var(--fs-h1);letter-spacing:-1px}h2{font-size:var(--fs-h2);letter-spacing:-.5px}h3{font-size:var(--fs-h3)}p{margin:0 0 var(--sp-2)}a{color:var(--link);text-decoration:none}a:hover{text-decoration:underline}code,pre,kbd,samp{font-family:var(--font-mono)}img,svg,video{max-width:100%;height:auto}:focus-visible{outline:2px solid var(--mauve);outline-offset:2px;border-radius:4px}.skip-link{position:absolute;left:-9999px;top:0;z-index:100;background:var(--mauve);color:var(--crust);padding:10px 16px;border-radius:0 0 var(--r-sm) 0;font-weight:600}.skip-link:focus{left:0}.wrap{max-width:var(--container);margin:0 auto;padding:0 var(--sp-3)}.accent{color:var(--accent)}.mono{font-family:var(--font-mono)}.nowrap{white-space:nowrap}.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}.grid-bg{background-image:linear-gradient(var(--grid-line) 1px, rgba(0,0,0,0) 1px),linear-gradient(90deg, var(--grid-line) 1px, rgba(0,0,0,0) 1px);background-size:46px 46px}.logo{font-family:var(--font-mono);font-weight:700;font-size:18px;letter-spacing:.5px;color:var(--text)}.logo .dot{color:var(--mauve)}.nav{position:sticky;top:0;z-index:30;backdrop-filter:blur(8px);background:color-mix(in srgb, var(--mantle) 82%, rgba(0,0,0,0));border-bottom:1px solid var(--border)}.nav__inner{display:flex;align-items:center;gap:var(--sp-3);height:60px}.nav__links{margin-left:auto;display:flex;align-items:center;gap:22px;font-size:14px}.nav__links a{color:var(--subtext0)}.nav__links a:hover{color:var(--text);text-decoration:none}.langswitch{display:inline-flex;align-items:center;gap:2px;font-family:var(--font-mono);font-size:12px;border:1px solid var(--border);border-radius:var(--r-pill);padding:3px 4px}.langswitch a{color:var(--faint);padding:3px 7px;border-radius:var(--r-pill);text-transform:uppercase;letter-spacing:.5px;transition:color var(--dur-fast) var(--ease-out),background var(--dur-fast) var(--ease-out)}.langswitch a:hover{color:var(--text);text-decoration:none}.langswitch a[aria-current=true]{color:var(--crust);background:var(--mauve)}.nav__toggle{display:none;margin-left:auto;background:rgba(0,0,0,0);border:1px solid var(--border-strong);border-radius:var(--r-sm);color:var(--text);width:40px;height:36px;cursor:pointer;align-items:center;justify-content:center}.nav__toggle svg{width:20px;height:20px}@media (max-width: 860px){.nav__toggle{display:inline-flex}.nav__links{position:absolute;top:60px;left:0;right:0;flex-direction:column;align-items:flex-start;gap:var(--sp-2);padding:var(--sp-3);background:var(--mantle);border-bottom:1px solid var(--border);display:none}.nav__links.is-open{display:flex}.langswitch{align-self:stretch;justify-content:center}}.btn{display:inline-block;padding:10px 18px;border-radius:var(--r-sm);font-weight:600;font-family:var(--font-body);font-size:15px;background:var(--mauve);color:var(--crust);border:1px solid rgba(0,0,0,0);cursor:pointer;transition:transform var(--dur-fast) var(--ease-out),filter var(--dur-fast) var(--ease-out)}.btn:hover{filter:brightness(1.08);text-decoration:none;transform:translateY(-1px)}.btn--ghost{background:rgba(0,0,0,0);color:var(--text);border-color:var(--border-strong)}.btn--ghost:hover{filter:none;border-color:var(--mauve)}@media (prefers-reduced-motion: reduce){.btn:hover{transform:none}}.pill{display:inline-flex;gap:8px;align-items:center;font-size:13px;color:var(--subtext0);border:1px solid var(--border);border-radius:var(--r-pill);padding:5px 12px}.pill b{color:var(--green);font-weight:700}.pills{display:flex;flex-wrap:wrap;gap:10px}.card{background:var(--mantle);border:1px solid var(--border);border-radius:var(--r-md);padding:22px}.card h3{margin:0 0 6px}.card p{margin:0;color:var(--subtext0);font-size:14.5px}.card__ic{display:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;margin-bottom:var(--sp-2);border-radius:var(--r-sm);background:color-mix(in srgb, var(--mauve) 12%, rgba(0,0,0,0));color:var(--mauve)}.card__ic svg{width:20px;height:20px}.grid{display:grid;gap:18px;grid-template-columns:repeat(auto-fit, minmax(240px, 1fr))}pre{background:var(--crust);border:1px solid var(--border);border-radius:var(--r-md);padding:18px;overflow:auto;font-size:13.5px;line-height:1.55;margin:0 0 var(--sp-2)}pre code{background:none;padding:0;font-size:inherit;color:var(--text)}:not(pre)>code{background:var(--crust);border:1px solid var(--border);border-radius:6px;padding:1px 6px;font-size:.9em;color:var(--peach)}.tok-c{color:var(--overlay0)}.tok-k{color:var(--mauve)}.tok-s{color:var(--green)}.tok-n{color:var(--peach)}.viewport-frame{position:relative;border:2px solid var(--mauve);border-radius:var(--r-lg);background:linear-gradient(180deg, var(--mantle), var(--crust));padding:10px;overflow:hidden}.viewport-frame__tab{position:absolute;top:-1px;left:16px;transform:translateY(-50%);background:var(--mauve);color:var(--crust);font-family:var(--font-mono);font-size:10px;font-weight:700;letter-spacing:.5px;padding:3px 10px;border-radius:var(--r-pill);z-index:2}.viewport-frame__inner{border-radius:8px;overflow:hidden;background:var(--base)}.media-slot{display:flex;align-items:center;justify-content:center;min-height:200px;text-align:center;padding:20px;color:var(--overlay0);font-size:13.5px;background:repeating-linear-gradient(45deg, var(--mantle), var(--mantle) 12px, var(--crust) 12px, var(--crust) 24px)}.media-slot b{color:var(--subtext0);display:block;margin-bottom:4px}.section{padding:var(--sp-8) 0;border-top:1px solid var(--border)}.section__sub{color:var(--subtext0);max-width:62ch;margin:0 0 var(--sp-4)}.caption{color:var(--overlay0);font-size:13px;text-align:center;margin:var(--sp-2) 0 0}@media (max-width: 760px){.section{padding:40px 0}}.reveal{opacity:0;transform:translateY(14px);transition:opacity 500ms var(--ease-out),transform 500ms var(--ease-out)}.reveal.is-in{opacity:1;transform:none}@media (prefers-reduced-motion: reduce){.reveal{opacity:1;transform:none;transition:none}}.hero{padding:72px 0 40px;background:radial-gradient(1200px 500px at 70% -10%, color-mix(in srgb, var(--mauve) 14%, rgba(0,0,0,0)), rgba(0,0,0,0)),radial-gradient(900px 500px at 0% 10%, color-mix(in srgb, var(--blue) 10%, rgba(0,0,0,0)), rgba(0,0,0,0))}.hero h1{font-weight:700;margin:0 0 var(--sp-2)}.hero__lede{font-size:var(--fs-lede);color:var(--subtext0);max-width:48ch;margin:0 0 28px}.hero__cta{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:var(--sp-2)}.hero .pills{margin-top:var(--sp-2)}.stage{margin:44px 0 8px;border:1px solid var(--border);border-radius:var(--r-lg);overflow:hidden;background:linear-gradient(180deg, var(--mantle), var(--crust));box-shadow:var(--shadow-stage)}.stage svg{display:block;width:100%;height:auto}@keyframes plane-pan{0%{transform:translate(40px, 38px)}20%{transform:translate(330px, 40px)}42%{transform:translate(350px, 150px)}64%{transform:translate(120px, 168px)}84%{transform:translate(70px, 70px)}100%{transform:translate(40px, 38px)}}.viewport-roam{animation:plane-pan 16s var(--ease-in-out) infinite}@media (prefers-reduced-motion: reduce){.viewport-roam{animation:none}}.compare{display:grid;gap:20px;grid-template-columns:1fr 1fr;align-items:start}@media (max-width: 760px){.compare{grid-template-columns:1fr}}.compare__lbl{font-size:13px;color:var(--overlay0);text-transform:uppercase;letter-spacing:1px;margin-bottom:8px}.compare svg{width:100%;border:1px solid var(--border);border-radius:var(--r-md);background:var(--mantle);display:block}.recipes{display:grid;gap:22px;grid-template-columns:repeat(2, 1fr)}@media (max-width: 860px){.recipes{grid-template-columns:1fr}}.recipe{background:var(--mantle);border:1px solid var(--border);border-radius:var(--r-md);padding:22px;display:flex;flex-direction:column;gap:var(--sp-2)}.recipe__name{display:flex;align-items:baseline;gap:10px;margin:0}.recipe__name .tag{font-family:var(--font-mono);font-size:11px;color:var(--mauve);border:1px solid color-mix(in srgb, var(--mauve) 40%, rgba(0,0,0,0));border-radius:var(--r-pill);padding:1px 8px}.recipe__one{color:var(--subtext0);font-size:14.5px;margin:0}.recipe__uses{font-size:12px;color:var(--overlay0)}.recipe__uses .mono{color:var(--subtext0)}.recipe pre{margin:0;font-size:12.5px}.recipe__media{margin-top:auto}.recipe__media .media-slot{min-height:140px}.recipe__link{font-size:13.5px;font-weight:600}.recipes-closing{text-align:center;margin:var(--sp-4) 0 0;font-family:var(--font-head);font-size:clamp(18px,2.4vw,24px);color:var(--text)}.recipes-closing .accent{color:var(--mauve)}.demos{display:grid;gap:18px;grid-template-columns:1fr 1fr}@media (max-width: 760px){.demos{grid-template-columns:1fr}}.start__block+.start__block{margin-top:var(--sp-3)}.start__label{font-size:13.5px;color:var(--subtext0);margin:0 0 8px}.docs-entry{text-align:center}.docs-entry .section__sub{margin-left:auto;margin-right:auto}.footer{padding:48px 0;border-top:1px solid var(--border);color:var(--overlay0);font-size:14px}.footer__inner{display:flex;gap:var(--sp-3);flex-wrap:wrap;align-items:center}.footer__links{margin-left:auto;display:flex;gap:var(--sp-3)}.footer__links a{color:var(--subtext0)}.docs{display:grid;grid-template-columns:240px minmax(0, 1fr);gap:var(--sp-6);max-width:var(--container);margin:0 auto;padding:var(--sp-6) var(--sp-3) var(--sp-8);align-items:start}@media (max-width: 920px){.docs{grid-template-columns:1fr;gap:var(--sp-4)}}.docs-sidebar{position:sticky;top:76px;align-self:start}@media (max-width: 920px){.docs-sidebar{position:static;border:1px solid var(--border);border-radius:var(--r-md);padding:var(--sp-2)}}.docs-sidebar h2{font-size:13px;text-transform:uppercase;letter-spacing:1px;color:var(--overlay0);margin:0 0 var(--sp-2)}.docs-nav{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:2px}.docs-nav a{display:block;padding:6px 10px;border-radius:8px;color:var(--subtext0);font-size:14px;border-left:2px solid rgba(0,0,0,0)}.docs-nav a:hover{color:var(--text);background:var(--mantle);text-decoration:none}.docs-nav a[aria-current=page]{color:var(--mauve);background:color-mix(in srgb, var(--mauve) 8%, rgba(0,0,0,0));border-left-color:var(--mauve)}.docs-content{min-width:0}.docs-content h1{font-size:clamp(28px,4vw,40px);margin-bottom:var(--sp-2)}.docs-content h2{font-size:24px;margin-top:var(--sp-6);margin-bottom:var(--sp-2);padding-top:var(--sp-1)}.docs-content h3{font-size:18px;margin-top:var(--sp-4)}.docs-content p,.docs-content li{color:var(--text)}.docs-content a{color:var(--blue);text-decoration:underline;text-underline-offset:2px}.docs-content ul,.docs-content ol{padding-left:1.3em;margin:0 0 var(--sp-2)}.docs-content li{margin-bottom:6px}.docs-content blockquote{margin:0 0 var(--sp-2);padding:12px 18px;border-left:3px solid var(--mauve);background:var(--mantle);border-radius:0 var(--r-sm) var(--r-sm) 0;color:var(--subtext0)}.docs-content table{width:100%;border-collapse:collapse;margin:0 0 var(--sp-2);font-size:14px}.docs-content th,.docs-content td{text-align:left;padding:8px 12px;border:1px solid var(--border)}.docs-content th{background:var(--mantle);font-family:var(--font-head)}.docs-content hr{border:none;border-top:1px solid var(--border);margin:var(--sp-4) 0}.docs-lede{color:var(--subtext0);font-size:var(--fs-lede);margin-bottom:var(--sp-4)}.docs-note{font-size:13.5px;color:var(--overlay0);border:1px dashed var(--border-strong);border-radius:var(--r-sm);padding:10px 14px;margin-top:var(--sp-6)}.docs-toc{margin-top:var(--sp-4);font-size:13px}.docs-toc h2{font-size:12px;text-transform:uppercase;letter-spacing:1px;color:var(--overlay0);margin:0 0 8px}.docs-toc ul{list-style:none;margin:0;padding:0}.docs-toc a{color:var(--subtext0);display:block;padding:3px 0}.docs-toc a:hover{color:var(--text);text-decoration:none}