@import"https://fonts.googleapis.com/css2?family=Fraunces:opsz,wght@9..144,700&family=Instrument+Sans:wght@400;500;600&display=swap";:root{--bg: #0a0f1e;--surface: #111831;--surface-2: #182447;--border: #2a3b70;--accent-1: #ff4f8b;--accent-2: #49d6ff;--text: #edf2ff;--muted: #9fb0d9;--success: #2ea043;--code-bg: #0d1117;--code-border: #30363d;--code-text: #c9d1d9;--radius: 16px;--page-max: 920px}*{box-sizing:border-box}body{margin:0;min-height:100vh;font-family:Instrument Sans,system-ui,sans-serif;color:var(--text);background:radial-gradient(ellipse 60% 45% at 15% 10%,rgba(255,79,139,.16),transparent 70%),radial-gradient(ellipse 60% 45% at 85% 85%,rgba(73,214,255,.14),transparent 70%),var(--bg)}.page{width:min(var(--page-max),100% - 2rem);margin:0 auto;padding:2.5rem 0 3rem}.hero{text-align:center;margin-bottom:1.5rem}h1{margin:0;font-family:Fraunces,Georgia,serif;font-size:clamp(2rem,6vw,3.5rem);background:linear-gradient(135deg,#eaf2ff 8%,var(--accent-2) 52%,var(--accent-1) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent}.subtitle{margin:.6rem 0 0;color:var(--muted)}.resource-grid{margin-top:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}.resource-card{background:color-mix(in srgb,var(--surface) 88%,transparent);border:1px solid var(--border);border-radius:var(--radius);padding:1rem}.resource-card h2,.snippet-head h2{margin:0 0 .75rem;font-size:1rem}.snippet-head{margin:0 0 .75rem;display:flex;justify-content:space-between;align-items:center;gap:.6rem}.snippet-head h2{margin:0}.install-row{display:flex;gap:.6rem;align-items:center;flex-wrap:wrap}.install-code{background:var(--code-bg);border:1px solid var(--code-border);color:var(--code-text);border-radius:10px;padding:.5rem .65rem;font:.88rem ui-monospace,SFMono-Regular,Menlo,Consolas,monospace}.copy-btn{width:34px;height:34px;display:inline-flex;align-items:center;justify-content:center;border:1px solid color-mix(in srgb,var(--accent-2) 42%,var(--border));background:color-mix(in srgb,var(--surface-2) 86%,transparent);color:var(--text);border-radius:10px;cursor:pointer}.copy-btn:hover{border-color:color-mix(in srgb,var(--accent-2) 65%,var(--border))}.copy-btn:focus-visible{outline:2px solid var(--accent-2);outline-offset:2px}.copy-btn .icon-copy,.copy-btn .icon-copied{width:16px;height:16px;display:block}.copy-btn .icon-copied,.copy-btn.is-copied .icon-copy{display:none}.copy-btn.is-copied{border-color:var(--success);color:var(--success)}.copy-btn.is-copied .icon-copied{display:block}.repo-link{display:inline-flex;gap:.45rem;align-items:center;color:var(--accent-2);font-weight:600;text-decoration:none}.repo-link .repo-icon{width:16px;height:16px;display:block}.repo-link:focus-visible{outline:2px solid var(--accent-2);outline-offset:2px;border-radius:6px}.code-block{margin:0;border-radius:12px;border:1px solid var(--code-border);background:var(--code-bg);color:var(--code-text);padding:.95rem 1rem;overflow-x:auto;font-size:.86rem;line-height:1.35}.code-block code{font-family:JetBrains Mono,Fira Code,ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;font-feature-settings:"calt" 1,"liga" 1;-webkit-font-smoothing:antialiased;tab-size:2}.code-block code .line{display:block;white-space:pre}.code-block code .line:empty:before{content:" "}input[type=range]:focus-visible{outline:2px solid var(--accent-2);outline-offset:2px;border-radius:999px}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}.panel{display:grid;gap:1rem;grid-template-columns:minmax(260px,340px) minmax(260px,1fr);background:color-mix(in srgb,var(--surface) 88%,transparent);border:1px solid var(--border);border-radius:var(--radius);padding:1rem}.sphere{width:100%;aspect-ratio:1;position:relative;border-radius:calc(var(--radius) - 4px);background:linear-gradient(145deg,#ffffff0a,#ffffff03);border:1px solid color-mix(in srgb,var(--border) 60%,white 8%)}.controls{background:var(--surface-2);border:1px solid var(--border);border-radius:calc(var(--radius) - 4px);padding:1rem;display:grid;gap:.9rem}label{display:grid;gap:.3rem;font-size:.92rem}input[type=range]{width:100%;accent-color:var(--accent-2)}.values{margin:.2rem 0 0;color:var(--muted);font-size:.9rem}@media(max-width:760px){.panel{grid-template-columns:1fr}}.sphere{background:#fff;border:1px solid #d5deef;box-shadow:none}.sphere .ts-tag{display:inline-block;white-space:nowrap;line-height:1.4;box-sizing:border-box;background:#f3f7ff;color:#2a3a57;border:1px solid #aec1df;border-radius:999px;padding:3px 10px;font-size:.78rem;font-weight:600;box-shadow:none}
