:root{--bg:#f7f8fa;--bg-alt:#fff;--bg-soft:#eef0f4;--ink:#0b1220;--ink-2:#1e2636;--muted:#5b6473;--muted-2:#8089a0;--line:#dfe3ea;--line-strong:#c8cfdb;--accent:#0a1ce8;--accent-soft:#e8eaff;--code-bg:#0b1220;--code-fg:#e3e6ee;--code-muted:#6f7a93;--code-key:#8fb3ff;--code-str:#b9e6c0;--code-num:#f0c178;--code-cmt:#5b6473;--code-type:#d2b6ff;--maxw:1180px;--pad:clamp(16px, 4vw, 56px);--f-sans:"Geist", ui-sans-serif, system-ui, -apple-system, "Segoe UI", sans-serif;--f-mono:"Geist Mono", ui-monospace, "SF Mono", "Menlo", "Consolas", monospace}[data-theme=dark]{--bg:#0a0e17;--bg-alt:#0f1422;--bg-soft:#141a2b;--ink:#e7ebf3;--ink-2:#c3cad8;--muted:#8089a0;--muted-2:#5b6473;--line:#1f2737;--line-strong:#2b3447;--accent:#6e7bff;--accent-soft:#1a2152;--code-bg:#050811;--code-fg:#e3e6ee}*{box-sizing:border-box}html,body{margin:0;padding:0}html{background:var(--bg);color:var(--ink)}body{font-family:var(--f-sans);letter-spacing:-.005em;color:var(--ink);background:var(--bg);-webkit-font-smoothing:antialiased;text-rendering:optimizelegibility;font-size:16px;line-height:1.55}a{color:var(--ink);text-decoration:none}a:hover{color:var(--accent)}img{max-width:100%;display:block}hr{border:0;border-top:1px solid var(--line);margin:0}.mono{overflow-wrap:anywhere;word-break:break-word}.container{max-width:var(--maxw);padding-left:var(--pad);padding-right:var(--pad);margin:0 auto}.row{display:flex}.col{flex:1}.gap-8{gap:8px}.gap-12{gap:12px}.gap-16{gap:16px}.gap-24{gap:24px}.gap-32{gap:32px}h1,h2,h3,h4{font-family:var(--f-sans);letter-spacing:-.02em;color:var(--ink);text-wrap:balance;margin:0;font-weight:500}h1{letter-spacing:-.035em;font-size:clamp(40px,6vw,68px);font-weight:500;line-height:1.02}h2{letter-spacing:-.025em;font-size:clamp(28px,3.4vw,40px);line-height:1.1}h3{letter-spacing:-.015em;font-size:20px;font-weight:500;line-height:1.3}h4{font-size:14px;font-weight:500;line-height:1.3}p{color:var(--ink-2);text-wrap:pretty;margin:0}p.lead{color:var(--ink-2);letter-spacing:-.01em;max-width:60ch;font-size:20px;line-height:1.45}.eyebrow{font-family:var(--f-mono);letter-spacing:.12em;text-transform:uppercase;color:var(--muted);font-size:11px;font-weight:500}.mono{font-family:var(--f-mono)}.topbar{z-index:50;background:color-mix(in oklab, var(--bg) 88%, transparent);-webkit-backdrop-filter:saturate(180%)blur(10px);border-bottom:1px solid var(--line);position:sticky;top:0}.topbar .inner{justify-content:space-between;align-items:center;height:60px;display:flex}.brand{color:var(--ink);align-items:center;gap:10px;margin-right:auto;display:flex}.brand .mark{width:22px;height:22px;filter:var(--mark-filter,none);background-image:url(/logo.png);background-position:50%;background-repeat:no-repeat;background-size:contain;display:inline-block}[data-theme=dark] .brand .mark{filter:brightness(1.4)}.brand .word{font-family:var(--f-sans);letter-spacing:-.02em;font-size:17px;font-weight:500}.nav{align-items:center;gap:28px;display:flex}.nav a{color:var(--ink-2);white-space:nowrap;font-size:14px;position:relative}.nav a.active{color:var(--ink)}.nav a.active:after{content:"";background:var(--ink);height:1px;position:absolute;bottom:-22px;left:0;right:0}.nav a:hover{color:var(--accent)}.nav .ext:after{content:" ↗";color:var(--muted-2);font-size:12px}.topbar .inner{gap:24px}.theme-toggle{border:1px solid var(--line-strong);background:var(--bg-alt);width:34px;height:34px;color:var(--ink-2);cursor:pointer;border-radius:0;flex:none;justify-content:center;align-items:center;margin:0;padding:0;transition:border-color .15s,color .15s,background .15s;display:inline-flex}.theme-toggle:hover{border-color:var(--ink);color:var(--ink)}.theme-toggle svg{width:16px;height:16px;display:block}.theme-toggle .ic-sun{display:none}.theme-toggle .ic-moon,[data-theme=dark] .theme-toggle .ic-sun{display:block}[data-theme=dark] .theme-toggle .ic-moon{display:none}.btn{font-family:var(--f-sans);border:1px solid var(--line-strong);background:var(--bg-alt);color:var(--ink);cursor:pointer;border-radius:0;align-items:center;gap:8px;padding:9px 14px;font-size:14px;font-weight:500;line-height:1;text-decoration:none;transition:border-color .15s,color .15s,background .15s;display:inline-flex}.btn:hover{border-color:var(--ink);color:var(--ink)}.btn.primary{background:var(--ink);color:var(--bg);border-color:var(--ink)}.btn.primary:hover{background:var(--accent);border-color:var(--accent);color:#fff}.btn .arrow{font-family:var(--f-mono);font-size:14px;line-height:1}.hero{padding:clamp(64px,12vw,140px) 0 clamp(48px,8vw,96px);position:relative}.hero .eyebrow{align-items:center;gap:10px;margin-bottom:28px;display:inline-flex}.hero .eyebrow:before{content:"";background:var(--accent);width:6px;height:6px;display:inline-block}.hero h1 .accent{color:var(--accent)}.hero-actions{flex-wrap:wrap;gap:12px;margin-top:36px;display:flex}.hero-meta{border-top:1px solid var(--line);border-bottom:1px solid var(--line);grid-template-columns:repeat(2,minmax(0,1fr));gap:0;margin-top:72px;display:grid}.hero-meta>div{border-right:1px solid var(--line);padding:20px 24px}.hero-meta>div:nth-child(odd){border-right:1px solid var(--line)}.hero-meta>div:nth-child(2n){border-right:0}.hero-meta>div:nth-child(-n+2){border-bottom:1px solid var(--line)}.hero-meta .label{font-family:var(--f-mono);letter-spacing:.12em;text-transform:uppercase;color:var(--muted);font-size:11px}.hero-meta .value{letter-spacing:-.02em;color:var(--ink);overflow-wrap:anywhere;margin-top:6px;font-size:22px}.hero-meta .value .mono{color:var(--ink-2);font-size:20px}section{padding:clamp(56px,8vw,96px) 0}.section-head{grid-template-columns:220px minmax(0,1fr);align-items:baseline;gap:48px;margin-bottom:48px;display:grid}.section-head>*{min-width:0}.section-head .left .eyebrow{margin-bottom:8px;display:block}.section-head .left .ix{font-family:var(--f-mono);color:var(--muted-2);font-size:12px}.section-head h2{max-width:24ch}.section-head p{max-width:56ch;color:var(--muted);margin-top:14px}@media (width<=760px){.section-head{grid-template-columns:1fr;gap:16px;margin-bottom:32px}.hero-meta{grid-template-columns:repeat(2,1fr);margin-top:48px}.hero-meta>div{border-bottom:1px solid var(--line);padding:16px 18px}.hero-meta>div:nth-child(2){border-right:0}.hero-meta>div:nth-last-child(-n+2){border-bottom:0}.topbar .inner{flex-wrap:wrap;gap:4px 16px;height:auto;padding-top:10px;padding-bottom:6px}.nav{-webkit-overflow-scrolling:touch;scrollbar-width:none;width:100%;margin:0 calc(var(--pad) * -1);padding:6px 0 8px;padding-left:var(--pad);padding-right:var(--pad);gap:18px;overflow-x:auto}.nav::-webkit-scrollbar{display:none}.nav a{font-size:13px}.nav a.active:after{bottom:-6px}.brand{order:1}.theme-toggle{order:2}.nav{order:3}.hero{padding-top:clamp(40px,10vw,64px)}.hero-actions{gap:8px;margin-top:28px}.hero-actions .btn{padding:10px 12px;font-size:13px}.hero-meta .value{font-size:17px}.hero-meta .value .mono{font-size:15px}.hero-meta .label{font-size:10px}.code{padding:14px 16px;font-size:12px;line-height:1.6}.code-card .tabs{gap:8px;height:32px;padding:0 10px;font-size:10px}.code-card .tabs>span:nth-child(2){white-space:nowrap;text-overflow:ellipsis;flex:1;min-width:0;overflow:hidden}}@media (width<=480px){.hero-meta{grid-template-columns:1fr}.hero-meta>div{border-right:0;border-bottom:1px solid var(--line)}.hero-meta>div:last-child{border-bottom:0}}.packages{border-top:1px solid var(--line);border-left:1px solid var(--line);grid-template-columns:repeat(12,minmax(0,1fr));gap:0;display:grid}.pkg{border-right:1px solid var(--line);border-bottom:1px solid var(--line);background:var(--bg-alt);flex-direction:column;grid-column:span 6;min-width:0;min-height:280px;padding:28px 32px 32px;transition:background .2s;display:flex}.pkg.featured{grid-column:span 12;min-height:320px}.pkg.wide{grid-column:span 12;min-height:0}.pkg.third{grid-column:span 4}.pkg:hover{background:color-mix(in oklab, var(--bg-alt) 92%, var(--accent) 8%)}[data-theme=dark] .pkg:hover{background:color-mix(in oklab, var(--bg-alt) 80%, var(--accent) 20%)}.pkg .head{justify-content:space-between;align-items:baseline;display:flex}.pkg .head .ix{font-family:var(--f-mono);color:var(--muted-2);letter-spacing:.08em;font-size:11px}.pkg .name{font-family:var(--f-mono);color:var(--accent);letter-spacing:-.01em;font-size:13px}.pkg h3{letter-spacing:-.02em;margin-top:14px;font-size:24px}.pkg p.desc{color:var(--muted);max-width:52ch;margin-top:10px;font-size:15px}.pkg .spacer{flex:1}.pkg .foot{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px 16px;margin-top:24px;display:flex}.pkg .providers{font-family:var(--f-mono);color:var(--muted-2);letter-spacing:0;flex-wrap:wrap;gap:6px;font-size:11px;display:flex}.pkg .providers span{border:1px solid var(--line);color:var(--ink-2);padding:3px 7px}.pkg .arrow-link{font-family:var(--f-mono);color:var(--ink-2);align-items:center;gap:6px;font-size:12px;display:inline-flex}.pkg .arrow-link:hover{color:var(--accent)}@media (width<=900px){.pkg{min-height:0;grid-column:span 12!important}}@media (width<=540px){.pkg{padding:22px 20px 24px}.pkg h3{font-size:22px}.pkg p.desc{font-size:14px}}.code{background:var(--code-bg);color:var(--code-fg);font-family:var(--f-mono);border:1px solid var(--code-bg);padding:18px 22px;font-size:13px;line-height:1.65;overflow-x:auto}.code .num{color:var(--code-num)}.code .mut{color:var(--code-muted)}.code .ln{color:#3d4763;-webkit-user-select:none;user-select:none;text-align:right;width:22px;padding-right:16px;display:inline-block}.code-card{border:1px solid var(--line);background:var(--bg-alt);max-width:100%;overflow:hidden}.code-card .tabs{border-bottom:1px solid var(--line);height:36px;font-family:var(--f-mono);color:var(--muted);letter-spacing:.08em;text-transform:uppercase;justify-content:space-between;align-items:center;padding:0 14px;font-size:11px;display:flex}.code-card .tabs .dots{gap:5px;display:flex}.code-card .tabs .dots i{background:var(--line-strong);border-radius:50%;width:7px;height:7px;display:block}.code-card .code{border:0}.shiki{font-family:var(--f-mono);margin:0;padding:18px 22px;font-size:13px;line-height:1.65;overflow-x:auto;background:var(--code-bg)!important}.pillars{border-top:1px solid var(--line);border-bottom:1px solid var(--line);grid-template-columns:repeat(4,minmax(0,1fr));gap:0;display:grid}.pillar{border-right:1px solid var(--line);min-width:0;padding:36px 28px}.pillar:last-child{border-right:0}.pillar .ix{font-family:var(--f-mono);color:var(--muted-2);letter-spacing:.12em;font-size:11px}.pillar h3{letter-spacing:-.025em;margin-top:28px;font-size:22px}.pillar p{color:var(--muted);margin-top:10px;font-size:14px}@media (width<=880px){.pillars{grid-template-columns:repeat(2,minmax(0,1fr))}.pillar:nth-child(2){border-right:0}.pillar{border-bottom:1px solid var(--line)}.pillar:nth-last-child(-n+2){border-bottom:0}}footer.site{border-top:1px solid var(--line);background:var(--bg-alt);margin-top:64px;padding:56px 0 32px}footer.site .grid{grid-template-columns:1.5fr minmax(0,1fr) minmax(0,1fr) minmax(0,1fr);gap:48px;display:grid}footer.site .grid>*{min-width:0}footer.site h4{font-family:var(--f-mono);letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin-bottom:14px;font-size:11px;font-weight:500}footer.site ul{flex-direction:column;gap:8px;margin:0;padding:0;list-style:none;display:flex}footer.site a{color:var(--ink-2);font-size:14px}footer.site a:hover{color:var(--accent)}footer.site .bottom{border-top:1px solid var(--line);font-family:var(--f-mono);color:var(--muted-2);justify-content:space-between;align-items:center;margin-top:56px;padding-top:24px;font-size:12px;display:flex}footer.site .bottom .brand{gap:8px}footer.site .bottom .brand .word{font-size:13px;font-family:var(--f-mono);letter-spacing:0}@media (width<=800px){footer.site .grid{grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:32px}footer.site .bottom{text-align:left;flex-direction:column;align-items:flex-start;gap:12px}footer.site .bottom span{overflow-wrap:anywhere}}@media (width<=460px){footer.site .grid{grid-template-columns:minmax(0,1fr);gap:28px}footer.site{padding-top:40px}}.callout{border:1px solid var(--line);background:var(--bg-alt);grid-template-columns:minmax(0,1fr) minmax(0,1fr);display:grid}.callout>*{min-width:0}.callout .l,.callout .r{padding:36px}@media (width<=540px){.callout .l,.callout .r{padding:24px 22px}}.callout .l{border-right:1px solid var(--line)}.callout h3{letter-spacing:-.025em;font-size:24px}.callout p{color:var(--muted);margin-top:10px}.callout .actions{flex-wrap:wrap;gap:10px;margin-top:22px;display:flex}@media (width<=800px){.callout{grid-template-columns:minmax(0,1fr)}.callout .l{border-right:0;border-bottom:1px solid var(--line)}}.pill{font-family:var(--f-mono);border:1px solid var(--line-strong);color:var(--ink-2);letter-spacing:.04em;align-items:center;gap:8px;padding:4px 9px;font-size:11px;display:inline-flex}.pill .dot{background:var(--accent);border-radius:50%;width:6px;height:6px}.hairline-h{border-top:1px solid var(--line)}.spaced>*+*{margin-top:16px}.shot{background:repeating-linear-gradient(45deg, color-mix(in oklab, var(--bg-soft) 92%, var(--ink) 8%) 0 10px, var(--bg-soft) 10px 20px);border:1px solid var(--line);color:var(--muted);font-family:var(--f-mono);letter-spacing:.12em;text-transform:uppercase;text-align:center;place-items:center;min-height:220px;font-size:11px;display:grid}.dot-rule{border-top:1px dashed var(--line-strong);margin:0}.studio{color:#e7ebf3;background:#0b1220;border-top:1px solid #0b1220;border-bottom:1px solid #0b1220}[data-theme=dark] .studio{border-top:1px solid var(--line);border-bottom:1px solid var(--line)}.studio .container{padding-top:96px;padding-bottom:96px}.studio .eyebrow,.studio .ix{color:#8089a0}.studio h2{color:#fff}.studio p{color:#c3cad8}.studio .section-head>div:last-child p{max-width:60ch}.studio-grid{background:#0f1422;border:1px solid #1f2737;grid-template-columns:minmax(0,1.2fr) minmax(0,1fr);gap:0;display:grid}.studio-grid>*{min-width:0}.studio-grid .l{border-right:1px solid #1f2737;padding:40px 40px 44px}.studio-grid .r{flex-direction:column;justify-content:center;gap:28px;padding:40px 40px 44px;display:flex}.studio h3{font-family:var(--f-sans);letter-spacing:-.02em;color:#fff;margin:0 0 14px;font-size:28px;font-weight:400}.studio .lede{color:#c3cad8;max-width:52ch;font-size:16px;line-height:1.6}.studio ul.does{grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:10px 24px;margin:28px 0 0;padding:0;list-style:none;display:grid}.studio ul.does li{font-family:var(--f-mono);color:#c3cad8;padding-left:18px;font-size:13px;position:relative}.studio ul.does li:before{content:"";background:#5b6473;width:8px;height:1px;position:absolute;top:.65em;left:0}.studio .stack-row{flex-wrap:wrap;gap:8px;margin-top:28px;display:flex}.studio .stack-row span{font-family:var(--f-mono);color:#c3cad8;background:0 0;border:1px solid #2b3447;padding:4px 10px;font-size:12px}.studio .stack-row span.muted{color:#8089a0;border-style:dashed}.studio .meta-row{border-top:1px solid #1f2737;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:0;display:grid}.studio .meta-row>div{padding:18px 20px}.studio .meta-row>div+div{border-left:1px solid #1f2737}.studio .meta-row .label{font-family:var(--f-mono);color:#8089a0;text-transform:uppercase;letter-spacing:.08em;font-size:10px}.studio .meta-row .value{color:#fff;overflow-wrap:anywhere;margin-top:6px;font-size:15px}.studio .cta-card{background:#0a0e17;border:1px solid #1f2737;padding:24px}.studio .cta-card .label{font-family:var(--f-mono);color:#8089a0;text-transform:uppercase;letter-spacing:.08em;font-size:10px}.studio .cta-card h4{font-family:var(--f-sans);color:#fff;letter-spacing:-.01em;margin:8px 0 10px;font-size:18px;font-weight:400}.studio .cta-card p{color:#c3cad8;margin:0 0 16px;font-size:14px}.studio .btn-on-dark{color:#0b1220;font-size:14px;font-family:var(--f-sans);background:#fff;border:1px solid #fff;align-items:center;gap:8px;padding:10px 14px;transition:background .15s,color .15s;display:inline-flex}.studio .btn-on-dark:hover{color:#0b1220;background:#c3cad8}.studio .btn-on-dark.ghost{color:#fff;background:0 0;border-color:#2b3447}.studio .btn-on-dark.ghost:hover{background:#1f2737;border-color:#fff}.studio .cta-actions{flex-wrap:wrap;gap:8px;display:flex}@media (width<=880px){.studio-grid{grid-template-columns:minmax(0,1fr)}.studio-grid .l{border-bottom:1px solid #1f2737;border-right:0}}@media (width<=540px){.studio .container{padding-top:64px;padding-bottom:64px}.studio-grid .l,.studio-grid .r{padding:28px 24px}.studio ul.does,.studio .meta-row{grid-template-columns:minmax(0,1fr)}.studio .meta-row>div+div{border-top:1px solid #1f2737;border-left:0}.studio h3{font-size:24px}}.spec{border-collapse:collapse;width:100%;font-family:var(--f-mono);font-size:13px}.spec th,.spec td{text-align:left;border-bottom:1px solid var(--line);vertical-align:top;padding:12px 0}.spec th{width:200px;color:var(--muted);letter-spacing:.04em;text-transform:uppercase;font-size:11px;font-weight:500}.spec td{color:var(--ink-2);overflow-wrap:anywhere}.spec td .tag{border:1px solid var(--line);color:var(--ink-2);margin:0 4px 4px 0;padding:2px 7px;display:inline-block}@media (width<=640px){.spec,.spec tbody,.spec tr,.spec th,.spec td{width:auto;display:block}.spec tr{border-bottom:1px solid var(--line);padding:14px 0}.spec tr:last-child{border-bottom:0}.spec th{border-bottom:0;width:auto;padding:0 0 6px}.spec td{border-bottom:0;padding:0}}#tweaks-panel{z-index:100;background:var(--bg-alt);width:280px;color:var(--ink);border:1px solid var(--line-strong);font-family:var(--f-sans);font-size:13px;display:none;position:fixed;bottom:20px;right:20px;box-shadow:0 12px 40px -16px #0b12202e}#tweaks-panel.open{display:block}#tweaks-panel header{border-bottom:1px solid var(--line);font-family:var(--f-mono);letter-spacing:.12em;text-transform:uppercase;color:var(--muted);justify-content:space-between;align-items:center;padding:12px 14px;font-size:11px;display:flex}#tweaks-panel header button{cursor:pointer;color:var(--muted);font-family:var(--f-mono);background:0 0;border:0;width:18px;height:18px;padding:0;font-size:14px;line-height:1}#tweaks-panel .body{flex-direction:column;gap:16px;padding:14px;display:flex}#tweaks-panel .group .lbl{font-family:var(--f-mono);color:var(--muted);letter-spacing:.12em;text-transform:uppercase;margin-bottom:8px;font-size:10px}#tweaks-panel .opts{gap:6px;display:flex}#tweaks-panel .opts button{font-family:var(--f-sans);background:var(--bg);color:var(--ink-2);border:1px solid var(--line);cursor:pointer;flex:1;padding:8px 6px;font-size:12px}#tweaks-panel .opts button.on{background:var(--ink);color:var(--bg);border-color:var(--ink)}#tweaks-panel .swatches{gap:8px;display:flex}#tweaks-panel .swatches button{border:1px solid var(--line);cursor:pointer;width:32px;height:32px;padding:0;position:relative}#tweaks-panel .swatches button.on{outline:2px solid var(--ink);outline-offset:2px}
