*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-text-size-adjust:100%;scroll-behavior:smooth;font-size:16px}:root{--bg:#09090b;--bg-2:#18181b;--bg-3:#27272a;--border:#3f3f46;--border-l:#ffffff12;--text:#fafafa;--text-2:#d4d4d8;--text-3:#a1a1aa;--muted:#71717a;--primary:#8b5cf6;--primary-l:#a78bfa;--primary-ll:#c4b5fd;--green:#4ade80;--blue:#60a5fa;--orange:#fb923c;--red:#f87171;--font:"Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Helvetica, Arial, sans-serif;--font-mono:"JetBrains Mono", "Fira Code", ui-monospace, "Cascadia Code", Consolas, monospace;--r-sm:4px;--r-md:8px;--r-lg:12px;--r-xl:20px;--shadow-sm:0 1px 2px #0006;--shadow-md:0 4px 16px #0006;--shadow-glow:0 0 40px #8b5cf626}body{background:var(--bg);color:var(--text);font-family:var(--font);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:15px;line-height:1.65}a{color:var(--primary-l);text-decoration:none;transition:color .15s}a:hover{color:var(--primary-ll)}.site-header{z-index:100;-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--border-l);background:#09090bd9;align-items:center;height:56px;padding:0 24px;display:flex;position:sticky;top:0}.site-header .inner{align-items:center;gap:32px;width:100%;max-width:1200px;margin:0 auto;display:flex}.logo{letter-spacing:-.3px;align-items:center;gap:9px;font-size:17px;font-weight:600;display:flex;color:var(--text)!important}.logo-mark{background:linear-gradient(135deg, var(--primary) 0%, var(--primary-l) 100%);color:#fff;border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;width:26px;height:26px;font-size:12px;font-weight:700;display:flex}.header-nav{flex:1;align-items:center;gap:4px;display:flex}.header-nav a{color:var(--text-3);border-bottom:2px solid #0000;margin:0 8px;padding:4px 2px;font-size:14px;font-weight:450;transition:color .15s,border-color .15s}.header-nav a:hover{color:var(--text-2)}.header-nav a.active{color:var(--text);border-bottom-color:var(--primary)}.header-right{align-items:center;gap:12px;margin-left:auto;display:flex}.github-link{align-items:center;gap:6px;padding:4px 0;font-size:13px;font-weight:450;transition:color .15s;display:flex;color:var(--text-3)!important}.github-link:hover{color:var(--text-2)!important}.btn{border-radius:var(--r-md);cursor:pointer;white-space:nowrap;letter-spacing:-.1px;align-items:center;gap:6px;padding:9px 18px;font-size:14px;font-weight:500;text-decoration:none;transition:all .15s;display:inline-flex}.btn-primary{background:var(--primary);color:#fff;border:1px solid var(--primary)}.btn-primary:hover{background:var(--primary-l);border-color:var(--primary-l);color:#fff;box-shadow:0 0 20px #8b5cf659}.btn-secondary{color:var(--text-2);border:1px solid var(--border);background:0 0}.btn-secondary:hover{background:var(--bg-2);color:var(--text);border-color:var(--text-3)}.code-block{border-radius:var(--r-lg);max-width:100%;font-family:var(--font-mono);background:#0d0d17;border:1px solid #ffffff0f;font-size:13px;line-height:1.75;overflow:hidden}.code-block-header{background:#ffffff05;border-bottom:1px solid #ffffff0d;justify-content:space-between;align-items:center;padding:8px 14px;display:flex}.code-block-title{color:var(--muted);font-size:11.5px;font-family:var(--font-mono)}.code-block-dots{align-items:center;gap:5px;display:flex}.code-block-dots span{border-radius:50%;width:6px;height:6px}.code-block-dots span:first-child{background:#6b4c4c}.code-block-dots span:nth-child(2){background:#5e5030}.code-block-dots span:nth-child(3){background:#2e5240}.code-block pre{margin:0;padding:18px 20px;overflow-x:auto}.code-block code{color:#e2e8f0;font-family:var(--font-mono);tab-size:2}.kw{color:#c4b5fd}.fn{color:#93c5fd}.str{color:#86efac}.cmt{color:#64748b;font-style:italic}.num{color:#fda4af}.op{color:#94a3b8}.typ{color:#67e8f9}.prop{color:#fcd34d}code:not(.code-block code){font-family:var(--font-mono);color:var(--primary-ll);background:#ffffff14;border:1px solid #ffffff1a;border-radius:4px;padding:1px 6px;font-size:12.5px}.badge{letter-spacing:.03em;text-transform:uppercase;color:var(--primary-l);background:#8b5cf61a;border:1px solid #8b5cf640;border-radius:100px;align-items:center;gap:6px;padding:4px 12px;font-size:11px;font-weight:500;display:inline-flex}.badge-dot{background:var(--primary-l);border-radius:50%;width:5px;height:5px}.hero{align-items:center;min-height:calc(100vh - 56px);display:flex;position:relative;overflow:hidden}.hero-bg{pointer-events:none;background:radial-gradient(80% 60% at 50% -10%,#8b5cf621 0%,#0000 60%),radial-gradient(40% 40% at 80% 80%,#6366f112 0%,#0000 50%);position:absolute;inset:0}.hero-grid{pointer-events:none;background-image:linear-gradient(#ffffff04 1px,#0000 1px),linear-gradient(90deg,#ffffff04 1px,#0000 1px);background-size:56px 56px;position:absolute;inset:0;-webkit-mask-image:radial-gradient(90% 80% at 50% 0,#000 0%,#0000 70%);mask-image:radial-gradient(90% 80% at 50% 0,#000 0%,#0000 70%)}.hero-inner{text-align:center;width:100%;max-width:800px;margin:0 auto;padding:72px 24px 96px;position:relative}.hero-badge{margin-bottom:28px}.hero-title{letter-spacing:-1.5px;color:var(--text);margin-bottom:20px;font-size:clamp(40px,7vw,68px);font-weight:700;line-height:1.1}.gradient-text{background:linear-gradient(135deg, var(--primary-l) 0%, var(--primary-ll) 50%, #e0d7ff 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.hero-sub{color:var(--text-3);max-width:500px;margin:0 auto 36px;font-size:17px;font-weight:400;line-height:1.7}.hero-sub strong{color:var(--text-2);font-weight:500}.hero-actions{flex-wrap:wrap;justify-content:center;gap:10px;display:flex}.hero-code{text-align:left;max-width:680px;margin-top:64px;margin-left:auto;margin-right:auto}.hero-code-label{color:var(--muted);font-size:11.5px;font-family:var(--font-mono);text-align:center;margin-bottom:10px}.section{padding:72px 24px}.section-inner{max-width:1100px;margin:0 auto}.section-eyebrow{letter-spacing:.08em;text-transform:uppercase;color:var(--primary-l);margin-bottom:10px;font-size:11.5px;font-weight:600}.section-title{letter-spacing:-.6px;color:var(--text);margin-bottom:12px;font-size:clamp(26px,4vw,36px);font-weight:650}.section-sub{color:var(--text-3);max-width:500px;font-size:15.5px;line-height:1.7}.features-grid{grid-template-columns:repeat(3,1fr);gap:12px;margin-top:40px;display:grid}@media (width<=900px){.features-grid{grid-template-columns:repeat(2,1fr)}}@media (width<=600px){.features-grid{grid-template-columns:1fr}}.feature-card{border:1px solid var(--border-l);border-radius:var(--r-lg);background:#ffffff05;padding:22px;transition:border-color .2s,box-shadow .2s,transform .2s}.feature-card:hover{border-color:#8b5cf64d;transform:translateY(-1px);box-shadow:0 0 24px #8b5cf60f,0 4px 12px #00000040}.feature-icon{border-radius:var(--r-md);width:36px;height:36px;color:var(--primary-l);background:#8b5cf61a;border:1px solid #8b5cf626;justify-content:center;align-items:center;margin-bottom:14px;display:flex}.feature-card h3{color:var(--text);letter-spacing:-.2px;margin-bottom:7px;font-size:14.5px;font-weight:600}.feature-card p{color:var(--text-3);font-size:13px;line-height:1.65}.modes-section{background:var(--bg-2);border-top:1px solid var(--border-l);border-bottom:1px solid var(--border-l)}.modes-grid{background:var(--border-l);border:1px solid var(--border-l);border-radius:var(--r-lg);grid-template-columns:repeat(4,1fr);gap:1px;margin-top:40px;display:grid;overflow:hidden}@media (width<=800px){.modes-grid{grid-template-columns:repeat(2,1fr)}}@media (width<=480px){.modes-grid{grid-template-columns:1fr}}.mode-card{background:var(--bg);padding:24px 20px;transition:background .2s}.mode-card:hover{background:#8b5cf60d}.mode-tag{font-family:var(--font-mono);border-radius:var(--r-sm);letter-spacing:.04em;margin-bottom:10px;padding:2px 7px;font-size:10.5px;font-weight:600;display:inline-block}.mode-tag.ssg{color:var(--green);background:#4ade801f;border:1px solid #4ade8033}.mode-tag.ssr{color:var(--blue);background:#60a5fa1f;border:1px solid #60a5fa33}.mode-tag.isg{color:var(--orange);background:#fb923c1f;border:1px solid #fb923c33}.mode-tag.spa{color:var(--primary-l);background:#8b5cf61f;border:1px solid #8b5cf633}.mode-card h3{color:var(--text);letter-spacing:-.1px;margin-bottom:6px;font-size:13.5px;font-weight:600}.mode-card p{color:var(--text-3);font-size:12.5px;line-height:1.65}.data-loading-section{grid-template-columns:minmax(0,1fr) minmax(0,1fr);align-items:center;gap:64px;display:grid}.data-loading-section>*{min-width:0}.data-loading-title{margin-bottom:16px}.data-loading-copy{color:var(--text-3);margin-bottom:16px;line-height:1.75}.data-loading-copy-last{margin-bottom:24px}.data-loading-link{display:inline-flex}.data-loading-code{min-width:0}@media (width<=768px){.data-loading-section{grid-template-columns:1fr;gap:32px}}.getstarted-section{text-align:center}.install-block{border-radius:var(--r-md);font-family:var(--font-mono);color:var(--text-2);background:#0d0d17;border:1px solid #ffffff14;align-items:center;gap:12px;margin:28px auto;padding:11px 18px;font-size:13.5px;display:inline-flex}.install-prompt{color:var(--primary-l);-webkit-user-select:none;user-select:none}.docs-links{flex-wrap:wrap;justify-content:center;gap:10px;margin-top:16px;display:flex}.doc-link-card{background:var(--bg-2);border:1px solid var(--border-l);border-radius:var(--r-md);text-align:left;flex-direction:column;gap:4px;min-width:136px;padding:14px 18px;transition:border-color .15s,background .15s;display:flex}.doc-link-card:hover{background:#8b5cf60a;border-color:#8b5cf659}.doc-link-card .dlc-icon{color:var(--primary-l);margin-bottom:6px}.doc-link-card .dlc-title{color:var(--text);letter-spacing:-.1px;font-size:13px;font-weight:600}.doc-link-card .dlc-sub{color:var(--muted);font-size:11.5px}.site-footer{border-top:1px solid var(--border-l);padding:28px 24px}.site-footer .inner{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;max-width:1100px;margin:0 auto;display:flex}.footer-copy{color:var(--muted);letter-spacing:-.1px;font-size:12.5px}.footer-links{gap:20px;display:flex}.footer-links a{color:var(--muted);font-size:12.5px}.footer-links a:hover{color:var(--text-3)}.docs-layout{min-height:100vh}.docs-body{max-width:1200px;min-height:calc(100vh - 56px);margin:0 auto;padding:0 24px;display:flex}.docs-sidebar{flex-shrink:0;width:240px;height:calc(100vh - 56px);padding:28px 0 32px;position:sticky;top:56px;overflow-y:auto}.sidebar-section{margin-bottom:24px}.sidebar-label{letter-spacing:.06em;text-transform:uppercase;color:var(--muted);margin-bottom:4px;padding:0 10px;font-size:11px;font-weight:600}.sidebar-nav{flex-direction:column;gap:1px;display:flex}.sidebar-nav a{border-radius:var(--r-sm);color:var(--text-3);align-items:center;gap:7px;padding:6px 10px;font-size:13px;transition:color .15s,background .15s;display:flex}.sidebar-nav a:hover{color:var(--text-2);background:#ffffff0a}.sidebar-nav a.active{color:var(--primary-l);background:#8b5cf617;font-weight:500}.sidebar-icon{opacity:.75;flex-shrink:0;align-items:center;display:flex}.sidebar-nav a.active .sidebar-icon{opacity:1}.docs-divider{background:var(--border-l);height:1px;margin:10px 0}.docs-content{border-left:1px solid var(--border-l);flex:1;min-width:0;padding:44px 0 80px 44px}@media (width<=768px){.docs-sidebar{display:none}.docs-content{border-left:none;padding:28px 0}.docs-body{padding:0 16px}}.doc-page{max-width:680px}.doc-page .breadcrumb{color:var(--muted);align-items:center;gap:6px;margin-bottom:22px;font-size:12.5px;display:flex}.doc-page .breadcrumb a{color:var(--muted)}.doc-page .breadcrumb a:hover{color:var(--text-3)}.doc-page .breadcrumb-sep{opacity:.4}.doc-title{letter-spacing:-.8px;color:var(--text);margin-bottom:10px;font-size:clamp(26px,4vw,34px);font-weight:700;line-height:1.2}.doc-lead{color:var(--text-3);border-bottom:1px solid var(--border-l);margin-bottom:36px;padding-bottom:36px;font-size:16px;line-height:1.75}.doc-page h2{letter-spacing:-.3px;color:var(--text);margin:44px 0 14px;padding-top:8px;font-size:20px;font-weight:650}.doc-page h2:first-of-type{margin-top:0}.doc-page h3{color:var(--text);margin:24px 0 8px;font-size:15px;font-weight:600}.doc-page p{color:var(--text-2);margin-bottom:14px;line-height:1.8}.doc-page ul,.doc-page ol{color:var(--text-2);margin-bottom:14px;padding-left:20px}.doc-page li{margin-bottom:4px;line-height:1.8}.doc-page .code-block{border-radius:0 var(--r-md) var(--r-md) 0;border-left:2px solid #8b5cf666;margin:18px 0}.doc-table-wrap{border-radius:var(--r-md);border:1px solid var(--border-l);margin:18px 0;overflow-x:auto}.doc-table{border-collapse:collapse;width:100%;font-size:13px}.doc-table th{text-align:left;letter-spacing:.05em;text-transform:uppercase;color:var(--muted);border-bottom:1px solid var(--border-l);background:#ffffff06;padding:9px 14px;font-size:11px;font-weight:600}.doc-table td{color:var(--text-2);vertical-align:top;border-bottom:1px solid #ffffff0a;padding:9px 14px}.doc-table tr:last-child td{border-bottom:none}.doc-table tr:hover td{background:#ffffff05}.doc-table td:first-child{font-family:var(--font-mono);color:var(--primary-ll);font-size:12px}.callout{border-radius:var(--r-md);gap:12px;margin:18px 0;padding:12px 14px;font-size:13px;line-height:1.65;display:flex}.callout-info{color:var(--text-2);background:#60a5fa0f;border:1px solid #60a5fa2e}.callout-note{color:var(--text-2);background:#8b5cf60f;border:1px solid #8b5cf62e}.callout-icon{flex-shrink:0;margin-top:1px}.doc-sep{background:var(--border-l);height:1px;margin:36px 0}.doc-nav{border-top:1px solid var(--border-l);gap:12px;margin-top:56px;padding-top:28px;display:flex}.doc-nav-card{background:var(--bg-2);border:1px solid var(--border-l);border-radius:var(--r-md);flex:1;padding:14px 16px;transition:border-color .15s}.doc-nav-card:hover{border-color:#8b5cf659}.doc-nav-dir{letter-spacing:.06em;text-transform:uppercase;color:var(--muted);align-items:center;gap:4px;margin-bottom:4px;font-size:10.5px;font-weight:600;display:flex}.doc-nav-card.next .doc-nav-dir{justify-content:flex-end}.doc-nav-title{color:var(--text);font-size:13.5px;font-weight:550}.doc-nav-card.next{text-align:right}
