:root.dev-active body{padding-top:28px;transition:padding-top .25s ease}:root.dev-active .nav{top:28px;transition:top .25s ease}:root.dev-active.dev-collapsed body{padding-top:0}:root.dev-active.dev-collapsed .nav{top:0}.dev-banner,.dev-panel{--dt-bg-card: rgba(20, 20, 24, .96);--dt-bg-secondary: rgba(255, 255, 255, .04);--dt-bg-card-hover: rgba(255, 255, 255, .06);--dt-border-color: rgba(255, 255, 255, .1);--dt-text-primary: rgba(255, 255, 255, .92);--dt-text-muted: rgba(255, 255, 255, .55);--dt-cyan: var(--cyan-500, #06b6d4)}.dev-banner{position:fixed;top:0;left:0;right:0;height:28px;background:linear-gradient(90deg,#0e7490,#06b6d4);color:#fff;font-size:.7rem;font-family:ui-monospace,SF Mono,monospace;display:flex;align-items:center;gap:12px;padding:0 12px;z-index:99999;transition:transform .25s ease}.dev-banner.collapsed{transform:translateY(-100%)}.dev-banner a{color:inherit}.dev-banner a:hover{color:inherit;text-decoration:none}.dev-banner-link{color:#fff;text-decoration:none;font-weight:700;opacity:.7;padding:2px 6px;border-radius:4px;transition:opacity .15s,background .15s}.dev-banner-link:hover{opacity:1;background:#ffffff26;text-decoration:none}.dev-banner-deployed{opacity:.6;font-size:.6rem;font-weight:500;white-space:nowrap}.dev-banner-right{margin-left:auto;display:flex;align-items:center;gap:8px}.dev-breakpoint{opacity:.6;font-size:.65rem;font-weight:700;white-space:nowrap}.dev-hamburger{background:none;border:none;color:#fff;cursor:pointer;padding:2px 6px;font-size:1rem;line-height:1;border-radius:4px;opacity:.7;transition:opacity .15s,background .15s}.dev-hamburger:hover{opacity:1;background:#ffffff26}.dev-hamburger[aria-expanded=true]{opacity:1;background:#fff3}.dev-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:99998}.dev-panel{position:fixed;top:28px;right:0;width:max-content;min-width:420px;max-width:calc(100vw - 16px);max-height:calc(100vh - 28px);overflow-y:auto;background:var(--dt-bg-card);border:1px solid var(--dt-border-color);border-top:none;border-radius:0 0 0 8px;box-shadow:0 8px 32px #0006;z-index:99999;padding:8px;display:flex;flex-direction:column;gap:4px;font-family:ui-monospace,SF Mono,monospace;color:var(--dt-text-primary)}.dev-panel-section{border-bottom:1px solid var(--dt-border-color);padding-bottom:4px}.dev-panel-section:last-child{border-bottom:none;padding-bottom:0}.dev-section-header{cursor:pointer;display:flex;align-items:center;gap:4px;padding:4px 2px;border-radius:4px;-webkit-user-select:none;user-select:none;margin:0;font-size:.65rem;text-transform:uppercase;letter-spacing:.08em;color:var(--dt-text-muted);font-weight:600}.dev-section-header:hover{color:var(--dt-text-primary)}.dev-section-arrow{font-size:.5rem;transition:transform .15s}.dev-section-arrow.expanded{transform:rotate(90deg)}.dev-section-actions{margin-left:auto;display:flex;gap:3px}.dev-mini{background:var(--dt-bg-secondary);border:1px solid var(--dt-border-color);color:var(--dt-text-muted);cursor:pointer;padding:1px 6px;border-radius:3px;font-size:.6rem;font-family:inherit;letter-spacing:.04em;text-transform:uppercase}.dev-mini:hover{color:var(--dt-text-primary);background:var(--dt-bg-card-hover)}.dev-mini:disabled{opacity:.5;cursor:wait}.dev-mini.dev-mini--accent{color:#001114;background:var(--dt-cyan);border-color:var(--dt-cyan)}.dev-mini.dev-mini--accent:hover{background:#22d3ee}.dev-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:4px 6px;border-radius:4px;font-size:.75rem;min-height:28px}.dev-row:hover{background:var(--dt-bg-card-hover)}.dev-row-label{color:var(--dt-text-muted);font-weight:500}.dev-row-label.dirty{color:var(--dt-cyan)}.dev-row-value{color:var(--dt-text-primary);font-family:inherit;font-size:.7rem}.dev-row-path{text-align:right;white-space:nowrap}.dev-toggle{background:var(--dt-bg-secondary);border:1px solid var(--dt-border-color);color:var(--dt-text-muted);cursor:pointer;padding:2px 8px;border-radius:4px;font-size:.7rem;font-weight:500;transition:all .15s}.dev-toggle:hover{color:var(--dt-text-primary)}.dev-toggle.active{background:var(--dt-cyan);border-color:var(--dt-cyan);color:#001114}.dev-select{background:var(--dt-bg-secondary);border:1px solid var(--dt-border-color);color:var(--dt-text-primary);padding:2px 6px;border-radius:4px;font-size:.7rem;cursor:pointer;font-family:inherit}.dev-action{background:var(--dt-bg-secondary);border:1px solid var(--dt-border-color);color:var(--dt-text-muted);cursor:pointer;padding:2px 8px;border-radius:4px;font-size:.7rem;font-weight:500;transition:all .15s;text-decoration:none;font-family:inherit}.dev-action:hover{color:var(--dt-text-primary)}.dev-action.danger{color:#ef4444}.dev-action.danger:hover{background:#ef44441a;border-color:#ef4444}.dev-tunable{display:grid;grid-template-columns:7rem 1fr auto;align-items:center;gap:6px;padding:2px 6px;border-radius:4px;font-size:.7rem}.dev-tunable:hover{background:var(--dt-bg-card-hover)}.dev-tunable__ctl{display:grid;grid-template-columns:1fr 2.6rem;align-items:center;gap:6px;min-width:0}.dev-tunable__ctl input[type=range]{width:100%;accent-color:var(--dt-cyan)}.dev-tunable__ctl input[type=text],.dev-tunable__ctl input[type=color]{background:var(--dt-bg-secondary);border:1px solid var(--dt-border-color);color:var(--dt-text-primary);padding:1px 4px;font:inherit;border-radius:3px;width:100%;min-width:0}.dev-tunable__ctl input[type=color]{padding:0;height:22px}.dev-tunable__val{color:var(--dt-text-primary);text-align:right;font-size:.65rem}.dev-tunable__reset{background:transparent;border:0;color:var(--dt-text-muted);cursor:pointer;padding:0 4px;font-size:.85rem;border-radius:3px}.dev-tunable__reset:hover{color:var(--dt-text-primary);background:var(--dt-bg-card-hover)}.dt-tokens{padding:0 4px 4px}.dt-tokens__bar{display:flex;gap:4px;padding:4px 0;position:sticky;top:0;background:var(--dt-bg-card);z-index:1}.dt-tokens__filter{flex:1 1 auto;background:var(--dt-bg-secondary);border:1px solid var(--dt-border-color);color:var(--dt-text-primary);padding:3px 6px;border-radius:4px;font:.7rem ui-monospace,SF Mono,monospace;min-width:0}.dt-tokens__list{display:flex;flex-direction:column;gap:6px}.dt-tokens__cat{display:flex;flex-direction:column;gap:1px}.dt-tokens__cat-h{padding:6px 4px 2px;font-size:.6rem;text-transform:uppercase;letter-spacing:.06em;color:var(--dt-text-muted);font-weight:600}.dt-token-row{display:grid;grid-template-columns:7.5rem 1fr auto;align-items:center;gap:4px;padding:2px 4px;border-radius:3px;font-size:.7rem}.dt-token-row:hover{background:var(--dt-bg-card-hover)}.dt-token-name{color:var(--dt-text-muted);font-family:inherit;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.dt-token-name.dirty{color:var(--dt-cyan)}.dt-token-color{display:grid;grid-template-columns:22px 1fr;gap:4px;align-items:center;min-width:0}.dt-token-color input[type=color]{width:22px;height:22px;padding:0;border:1px solid var(--dt-border-color);border-radius:3px;background:transparent;cursor:pointer}.dt-token-text{background:var(--dt-bg-secondary);border:1px solid var(--dt-border-color);color:var(--dt-text-primary);padding:2px 5px;border-radius:3px;font:inherit;font-size:.65rem;width:100%;min-width:0}.dt-token-text:disabled{opacity:.5}.dt-token-actions{display:flex;gap:2px}.dt-mini-icon{background:transparent;border:0;color:var(--dt-text-muted);cursor:pointer;padding:0 4px;font-size:.85rem;border-radius:3px}.dt-mini-icon:hover:not(:disabled){color:var(--dt-text-primary);background:var(--dt-bg-card-hover)}.dt-mini-icon:disabled{opacity:.35;cursor:default}.dt-empty{color:var(--dt-text-muted);padding:8px;font-style:italic;margin:0}.dt-viewport{padding:4px 6px 6px}.dt-viewport__hint{color:var(--dt-text-muted);font-size:.65rem;margin:0 0 6px;line-height:1.45}.dt-viewport__grid{display:grid;grid-template-columns:1fr 1fr;gap:4px}.dt-viewport__btn{display:flex;flex-direction:column;align-items:flex-start;gap:2px;background:var(--dt-bg-secondary);border:1px solid var(--dt-border-color);color:var(--dt-text-primary);cursor:pointer;padding:6px 8px;border-radius:4px;font:inherit;font-size:.7rem}.dt-viewport__btn:hover{background:var(--dt-bg-card-hover)}.dt-viewport__name{color:var(--dt-text-primary);font-weight:600}.dt-viewport__size{color:var(--dt-text-muted);font-size:.6rem}.dt-sections-panel{padding:0 4px 4px}.dt-spacing-pop{position:fixed;left:16px;bottom:16px;z-index:99997;width:320px;background:var(--dt-bg-card);border:1px solid var(--dt-border-color);border-radius:8px;box-shadow:0 24px 60px -20px #000000b3;color:var(--dt-text-primary);font:.7rem ui-monospace,SF Mono,monospace;padding:8px 10px;display:flex;flex-direction:column;gap:6px}.dt-spacing-pop--idle{width:auto;max-width:320px;flex-direction:column;gap:2px;padding:10px 12px;color:var(--dt-text-muted)}.dt-spacing-pop__hint{font-size:.6rem;color:var(--dt-text-muted);opacity:.7}.dt-spacing-pop__head{display:flex;align-items:center;gap:6px}.dt-spacing-pop__tag{flex:1 1 auto;display:flex;gap:6px;align-items:baseline;min-width:0}.dt-spacing-pop__classes{color:var(--dt-cyan);font-size:.65rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.dt-spacing-pop__src{color:var(--dt-text-muted);font-size:.6rem;margin-bottom:2px}.dt-spacing-pop__group{border:1px solid var(--dt-border-color);border-radius:4px;padding:4px 8px 6px;margin:0}.dt-spacing-pop__group legend{padding:0 4px;font-size:.6rem;text-transform:uppercase;letter-spacing:.06em;color:var(--dt-text-muted)}.dt-spacing-pop__sides{display:grid;grid-template-columns:1fr 1fr;gap:4px 8px}.dt-spacing-pop__side{display:grid;grid-template-columns:14px 1fr 22px;align-items:center;gap:4px}.dt-spacing-pop__sidelabel{color:var(--dt-text-muted);font-size:.62rem;text-align:center}.dt-spacing-pop__row{display:grid;grid-template-columns:70px 1fr 22px;align-items:center;gap:6px}.dt-spacing-pop__rowlabel{color:var(--dt-text-muted);font-size:.62rem}.dt-spacing-pop__input{background:var(--dt-bg-secondary);border:1px solid var(--dt-border-color);color:var(--dt-text-primary);border-radius:3px;padding:2px 5px;font:inherit;font-size:.65rem;width:100%;min-width:0}body.dev-outlines *{outline:1px solid rgba(6,182,212,.32)!important}body.dev-outlines *:hover{outline:1px solid rgba(6,182,212,.85)!important}body.dev-inline-edit *:not(.dev-panel):not(.dev-panel *):not(.dev-banner):not(.dev-banner *):not(.dev-inspect-tooltip):not(.dev-inspect-tooltip *){cursor:text}.dev-editing{outline:2px solid #06b6d4!important;outline-offset:2px!important;background:#06b6d414!important;border-radius:2px}.dev-editing:focus{outline-color:#22d3ee!important}.dev-flash{animation:dev-flash .4s ease-out}@keyframes dev-flash{0%{outline:2px solid rgba(6,182,212,.7);outline-offset:-1px}to{outline:2px solid transparent;outline-offset:-1px}}@media (max-width: 768px){.dev-banner-link,.dev-banner-deployed{display:none}.dev-panel{width:100%;border-radius:0;min-width:unset}}:root,[data-theme=dark]{--app-bg: #0a0a0a;--app-bg-secondary: rgba(255, 255, 255, .025);--app-bg-hover: rgba(255, 255, 255, .06);--app-bg-input: rgba(255, 255, 255, .06);--app-popover: rgba(40, 40, 45, .6);--glass-bg: rgba(18, 18, 24, .72);--glass-bg-elevated: rgba(28, 28, 38, .65);--glass-border: rgba(255, 255, 255, .08);--glass-border-bright: rgba(255, 255, 255, .14);--glass-specular: linear-gradient( 135deg, rgba(255, 255, 255, .12) 0%, rgba(255, 255, 255, .02) 40%, rgba(255, 255, 255, 0) 60%, rgba(255, 255, 255, .03) 100% );--hairline: rgba(255, 255, 255, .08);--hairline-bright: rgba(255, 255, 255, .14);--hover-lift: rgba(255, 255, 255, .06);--text-primary: rgba(255, 255, 255, .92);--text-secondary: rgba(255, 255, 255, .55);--text-tertiary: rgba(255, 255, 255, .32);--cyan-300: #22d3ee;--cyan-500: #06b6d4;--cyan-400: #0891b2;--cyan-600: #0b7492;--emerald-400: #4ade80;--emerald-500: #10b981;--red-500: #ef4444;--coral: #ff6b6b;--amber-500: #f59e0b;--sky-500: #0ea5e9;--purple-500: #a855f7;--yellow-500: #eab308;--c-bg: var(--app-bg);--c-bg-raised: #1c1c20;--c-bg-elevated: #1d1d24;--c-bg-card: var(--glass-bg-elevated);--c-bg-glass: var(--glass-bg);--c-line: var(--glass-border);--c-line-strong: var(--glass-border-bright);--c-line-soft: rgba(255, 255, 255, .04);--c-text: var(--text-primary);--c-text-muted: var(--text-secondary);--c-text-dim: var(--text-tertiary);--c-text-faint: rgba(255, 255, 255, .2);--c-cyan: var(--cyan-500);--c-cyan-soft: var(--cyan-300);--c-cyan-deep: var(--cyan-400);--c-indigo: var(--cyan-500);--c-violet: var(--cyan-300);--c-emerald: var(--emerald-500);--c-amber: var(--amber-500);--c-rose: var(--red-500);--c-brand-grad: var(--cyan-500);--c-brand-grad-soft: rgba(6, 182, 212, .12);--halo-cyan: 0 0 90px -20px rgba(6, 182, 212, .55), 0 0 200px -40px rgba(6, 182, 212, .3);--halo-violet: 0 0 90px -20px rgba(6, 182, 212, .45), 0 0 220px -40px rgba(6, 182, 212, .25);--font-display: -apple-system, BlinkMacSystemFont, "SF Pro Display", "SF Pro Text", system-ui, sans-serif;--font-text: -apple-system, BlinkMacSystemFont, "SF Pro Display", "SF Pro Text", system-ui, sans-serif;--font-mono: -apple-system, BlinkMacSystemFont, "SF Pro Display", "SF Pro Text", system-ui, sans-serif;--font-numeric: -apple-system, BlinkMacSystemFont, "SF Pro Display", "SF Pro Text", system-ui, sans-serif;--font-code: ui-monospace, "SF Mono", "JetBrains Mono", "Cascadia Code", Menlo, Consolas, monospace;--t-display: clamp(3rem, 5.6vw + .5rem, 5.5rem);--t-h1: clamp(2.25rem, 3.4vw + .75rem, 3.5rem);--t-h2: clamp(1.625rem, 1.4vw + 1rem, 2.125rem);--t-h3: 1.25rem;--t-body: 1rem;--t-small: .875rem;--t-tiny: .78125rem;--s-1: .25rem;--s-2: .5rem;--s-3: .75rem;--s-4: 1rem;--s-5: 1.5rem;--s-6: 2rem;--s-7: 3rem;--s-8: 4rem;--s-9: 6rem;--s-10: 9rem;--s-11: 12rem;--max-w: 1200px;--max-w-text: 720px;--gutter: clamp(1.25rem, 4vw, 2.5rem);--r-sm: 2px;--r-md: 6px;--r-lg: 8px;--r-xl: 12px;--r-2xl: 16px;--r-pill: 9999px;--ease-out: cubic-bezier(.4, 0, .2, 1);--ease-soft: cubic-bezier(.4, 0, .2, 1);--d-fast: .15s;--d-base: .22s;--d-slow: .42s;--shadow-card: 0 1px 0 rgba(255,255,255,.04) inset, 0 24px 60px -28px rgba(0,0,0,.7);--shadow-pop: 0 1px 0 rgba(255,255,255,.05) inset, 0 30px 80px -20px rgba(0,0,0,.85), 0 0 0 1px rgba(255,255,255,.06)}[data-theme=light]{--app-bg: #f5f5f7;--app-bg-secondary: rgba(0, 0, 0, .03);--app-bg-hover: rgba(0, 0, 0, .06);--app-bg-input: rgba(0, 0, 0, .05);--app-popover: rgba(248, 248, 250, .96);--glass-bg: rgba(255, 255, 255, .72);--glass-bg-elevated: rgba(245, 245, 247, .65);--glass-border: rgba(0, 0, 0, .08);--glass-border-bright: rgba(0, 0, 0, .14);--hairline: rgba(0, 0, 0, .08);--hairline-bright: rgba(0, 0, 0, .14);--hover-lift: rgba(0, 0, 0, .06);--text-primary: rgba(0, 0, 0, .88);--text-secondary: rgba(0, 0, 0, .55);--text-tertiary: rgba(0, 0, 0, .3)}*,*:before,*:after{box-sizing:border-box}html,body{margin:0;padding:0;background:var(--app-bg);color:var(--text-primary);font-family:var(--font-text);font-size:var(--t-body);line-height:1.55;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility;font-synthesis-weight:none;scrollbar-gutter:stable}body{min-height:100dvh;background:var(--app-bg)}#root{isolation:isolate}a{color:inherit;text-decoration:none;transition:color var(--d-fast) var(--ease-out),opacity var(--d-fast) var(--ease-out)}a:not(.btn):hover{color:var(--cyan-300)}button{font:inherit;color:inherit;background:none;border:0;padding:0;cursor:pointer}img,svg{display:block;max-width:100%}h1,h2,h3,h4,h5,h6{font-family:var(--font-display);font-weight:600;letter-spacing:-.022em;line-height:1.08;margin:0 0 var(--s-4);color:var(--c-text)}h1{font-size:var(--t-h1);letter-spacing:-.028em}h2{font-size:var(--t-h2);letter-spacing:-.022em}h3{font-size:var(--t-h3);letter-spacing:-.012em;font-weight:600}p{margin:0 0 var(--s-4);color:var(--c-text-muted)}::selection{background:#06b6d44d;color:var(--text-primary)}.container{width:100%;max-width:var(--max-w);margin-inline:auto;padding-inline:var(--gutter)}.section{padding-block:clamp(4rem,8vw,9rem)}.section-tight{padding-block:clamp(3rem,5vw,6rem)}.btn{--bg: rgba(255,255,255,.06);--fg: var(--c-text);--bd: rgba(255,255,255,.08);display:inline-flex;align-items:center;gap:.55rem;padding:.7rem 1.05rem;border-radius:var(--r-md);background:var(--bg);color:var(--fg);border:1px solid var(--bd);font-family:var(--font-text);font-size:.9375rem;font-weight:500;letter-spacing:-.005em;line-height:1;cursor:pointer;transition:background var(--d-fast) var(--ease-out),color var(--d-fast) var(--ease-out),border-color var(--d-fast) var(--ease-out),transform var(--d-base) var(--ease-out);white-space:nowrap}.btn:hover{--bg: rgba(255,255,255,.09);--bd: rgba(255,255,255,.14)}.btn .arrow{transition:transform var(--d-base) var(--ease-out)}.btn:hover .arrow{transform:translate(2px)}.btn-primary{--bg: var(--c-text);--fg: #0a0a0c;--bd: var(--c-text);font-weight:550}.btn-primary:hover{--bg: #fff;--fg: #000}.btn-cyan{--bg: var(--cyan-500);--fg: #ffffff;--bd: var(--cyan-500);font-weight:500;box-shadow:0 0 0 1px #06b6d440}.btn-cyan:hover{--bg: var(--cyan-300);--bd: var(--cyan-300);box-shadow:0 0 14px #06b6d459}.btn-cyan:active{--bg: var(--cyan-400);--bd: var(--cyan-400)}.btn-ghost{--bg: transparent;--bd: var(--c-line-strong)}.btn-ghost:hover{--bg: rgba(255,255,255,.04);--bd: rgba(255,255,255,.18)}.pill{display:inline-flex;align-items:center;gap:.4rem;padding:.32rem .7rem;border-radius:var(--r-pill);border:1px solid var(--c-line);background:#14151ab8;backdrop-filter:blur(18px) saturate(140%);-webkit-backdrop-filter:blur(18px) saturate(140%);color:var(--c-text-muted);font-size:var(--t-tiny);font-weight:500;letter-spacing:-.005em}.pill.cyan{color:var(--cyan-300);border-color:#06b6d459;background:linear-gradient(#14151ab3,#14151ab3),#06b6d41f}.pill.amber{color:var(--amber-500);border-color:#f59e0b59;background:linear-gradient(#14151ab3,#14151ab3),#f59e0b1f}.pill.emerald{color:var(--emerald-400);border-color:#4ade8059;background:linear-gradient(#14151ab3,#14151ab3),#4ade801f}.card{background:var(--c-bg-card);border:1px solid var(--c-line);border-radius:var(--r-xl);box-shadow:var(--shadow-card)}.card-flat{background:var(--c-bg-raised);border:1px solid var(--c-line);border-radius:var(--r-lg)}@keyframes rise{0%{opacity:0;transform:translateY(14px);filter:blur(8px)}to{opacity:1;transform:translateY(0);filter:blur(0)}}.rise{animation:rise .7s var(--ease-out) both}.rise-1{animation-delay:0ms}.rise-2{animation-delay:80ms}.rise-3{animation-delay:.16s}.rise-4{animation-delay:.24s}.rise-5{animation-delay:.32s}.rise-6{animation-delay:.42s}@media (prefers-reduced-motion: reduce){.rise{animation:none!important}*{transition-duration:.01ms!important}}:focus-visible{outline:2px solid rgba(6,182,212,.7);outline-offset:2px;box-shadow:0 0 0 3px #06b6d42e;border-radius:var(--r-md)}.prose{max-width:var(--max-w-text);color:var(--c-text-muted);font-size:1.0625rem;line-height:1.75}.prose h2{color:var(--c-text);margin-top:var(--s-7)}.prose h3{color:var(--c-text);margin-top:var(--s-6)}.prose a{color:var(--cyan-500);border-bottom:1px solid rgba(6,182,212,.3)}.prose a:hover{border-color:var(--cyan-300);color:var(--cyan-300)}.prose code{font-family:var(--font-code);font-size:.92em;background:#ffffff0d;padding:.1em .35em;border-radius:4px}.prose pre{font-family:var(--font-code);font-size:.875rem;line-height:1.6;margin:1rem 0;padding:1rem 1.1rem;background:#ffffff06;border:1px solid var(--c-line);border-radius:var(--r-md);color:var(--c-text-muted);overflow-x:auto}.prose pre code{background:transparent;padding:0;border-radius:0;font-size:inherit}.prose ul{padding-left:1.2rem}.prose li{margin-bottom:.4rem}.tabular{font-variant-numeric:tabular-nums}
