:root{--ds-paper: #c8c4bc;--ds-paper-2: #b8b4ab;--ds-paper-3: #9a958b;--ds-ink: #5c2318;--ds-accent: #a75331;--ds-canvas-grid: rgba(200, 196, 188, .06);--ds-ink-94: color-mix(in srgb, var(--ds-ink) 94%, transparent);--ds-ink-85: color-mix(in srgb, var(--ds-ink) 85%, transparent);--ds-ink-65: color-mix(in srgb, var(--ds-ink) 65%, transparent);--ds-ink-44: color-mix(in srgb, var(--ds-ink) 44%, transparent);--ds-ink-24: color-mix(in srgb, var(--ds-ink) 24%, transparent);--ds-ink-15: color-mix(in srgb, var(--ds-ink) 15%, transparent);--ds-ink-10: color-mix(in srgb, var(--ds-ink) 10%, transparent);--ds-ink-06: color-mix(in srgb, var(--ds-ink) 6%, transparent);--ds-bg-dark: #0a0a0a;--ds-fg-dark: #ededed;--ds-accent-dark: #e8703a;--ds-font-sans: "Geist", ui-sans-serif, system-ui, sans-serif;--ds-font-mono: "Geist Mono", ui-monospace, Menlo, Monaco, monospace;--ds-t-micro: .16s ease;--ds-t-spring: .3s cubic-bezier(.34, 1.56, .64, 1);--ds-t-smooth: .25s cubic-bezier(.4, 0, .2, 1);--ds-t-layout: .4s cubic-bezier(.175, .885, .32, 1);--ds-t-color: .6s cubic-bezier(.5, 0, .25, 1);--ds-max-width: 1100px;--ds-gap: 4px;--ds-radius: 4px;--ds-radius-pill: 999px}[data-ds-theme=dark]{--ds-paper: var(--ds-bg-dark);--ds-paper-2: #15151a;--ds-ink: var(--ds-fg-dark);--ds-accent: var(--ds-accent-dark)}.ds-mono{font-family:var(--ds-font-mono);font-size:10px;letter-spacing:.18em;text-transform:uppercase}.ds-label{font-family:var(--ds-font-mono);font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--ds-ink-44)}.ds-metadata{font-family:var(--ds-font-mono);font-size:9px;letter-spacing:.15em;color:var(--ds-ink-44);text-transform:uppercase}.ds-button{display:inline-flex;align-items:center;gap:6px;font-family:var(--ds-font-mono);font-size:11px;font-weight:500;letter-spacing:.18em;text-transform:uppercase;padding:10px 20px;color:var(--ds-ink);background:transparent;border:1px solid var(--ds-ink-24);cursor:pointer;transition:background var(--ds-t-micro),color var(--ds-t-micro),border-color var(--ds-t-micro)}.ds-button:hover{background:var(--ds-ink);color:var(--ds-paper);border-color:var(--ds-ink)}.ds-button:active{opacity:.88}.ds-button--primary{background:var(--ds-ink);color:var(--ds-paper);border-color:var(--ds-ink)}.ds-button--primary:hover{background:color-mix(in srgb,var(--ds-ink) 85%,transparent)}.ds-button--ghost{border-color:transparent;padding:8px 12px;color:var(--ds-ink-65)}.ds-button--ghost:hover{background:transparent;color:var(--ds-ink);border-color:transparent}.ds-link{display:inline-flex;align-items:center;gap:4px;color:inherit;text-decoration:underline;text-decoration-color:color-mix(in srgb,currentColor 30%,transparent);text-underline-offset:2px;transition:opacity var(--ds-t-micro),text-decoration-color var(--ds-t-micro)}.ds-link:hover{text-decoration-color:color-mix(in srgb,currentColor 80%,transparent)}.ds-link--icon:after{content:"→";display:inline-block;width:0;overflow:hidden;transition:width .25s ease-out,margin-left .25s ease-out,transform .25s ease-out}.ds-link--icon:hover:after{width:12px;margin-left:2px;transform:translate(2px)}.ds-rule{border:0;border-bottom:1px solid var(--ds-ink-24);opacity:.8;margin:16px 0}.ds-rule--loose{margin:64px 0}.ds-card{display:block;background:var(--ds-paper);padding:24px;border-top:1px solid var(--ds-ink-15);transition:background var(--ds-t-micro);color:inherit;text-decoration:none}.ds-card:hover{background:color-mix(in srgb,var(--ds-ink) 4%,var(--ds-paper))}.ds-card+.ds-card{border-top:1px solid var(--ds-ink-15)}.ds-pill{display:inline-flex;align-items:center;font-family:var(--ds-font-mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;padding:2px 8px;border:1px solid var(--ds-ink-24);border-radius:var(--ds-radius-pill);color:var(--ds-ink-65)}.ds-pill--solid{background:var(--ds-ink);color:var(--ds-paper);border-color:var(--ds-ink)}.ds-slider{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:100%;height:18px;background:transparent;cursor:ew-resize}.ds-slider::-webkit-slider-runnable-track{height:3px;background:var(--ds-ink-15);border-radius:999px}.ds-slider::-moz-range-track{height:3px;background:var(--ds-ink-15);border-radius:999px}.ds-slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;margin-top:-3px;width:10px;height:10px;border-radius:50%;background:var(--ds-ink);border:none;transition:transform var(--ds-t-smooth)}.ds-slider::-moz-range-thumb{width:10px;height:10px;border-radius:50%;background:var(--ds-ink);border:none}.ds-slider:hover::-webkit-slider-thumb{transform:scale(1.2)}.ds-swatch{width:28px;height:28px;border-radius:50%;padding:0;cursor:pointer;background:var(--ds-swatch-fill, var(--ds-ink));border:2px solid transparent;transition:transform var(--ds-t-smooth)}.ds-swatch:hover{transform:scale(1.1)}.ds-swatch[aria-pressed=true],.ds-swatch.is-active{box-shadow:0 0 0 2px var(--ds-paper),0 0 0 3px var(--ds-ink)}.ds-select{position:relative;font-family:var(--ds-font-mono);font-size:11px;letter-spacing:.04em}.ds-select-trigger{display:inline-flex;align-items:center;gap:6px;padding:6px 10px;background:var(--ds-ink-06);border:1px solid var(--ds-ink-15);border-radius:var(--ds-radius);cursor:pointer;transition:background var(--ds-t-micro),border-color var(--ds-t-micro);color:var(--ds-ink)}.ds-select-trigger:hover{background:var(--ds-ink-10);border-color:var(--ds-ink-24)}.ds-select-chevron{display:inline-block;transition:transform .15s ease}.ds-select[data-open=true] .ds-select-chevron{transform:rotate(180deg)}.ds-select-menu{position:absolute;top:calc(100% + 4px);left:0;min-width:160px;background:var(--ds-paper);border:1px solid var(--ds-ink-15);border-radius:var(--ds-radius);box-shadow:0 8px 24px #0000001f;padding:4px;opacity:0;transform:translateY(-8px) scale(.96);pointer-events:none;transition:opacity var(--ds-t-spring),transform var(--ds-t-spring);z-index:100}.ds-select[data-open=true] .ds-select-menu{opacity:1;transform:translateY(0) scale(1);pointer-events:auto}.ds-select-option{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;border-radius:var(--ds-radius);cursor:pointer;color:var(--ds-ink);transition:background var(--ds-t-micro)}.ds-select-option:hover{background:var(--ds-ink-10)}.ds-select-option[aria-selected=true]:after{content:"✓";color:var(--ds-accent)}.ds-toggle-switch{position:relative;display:inline-flex;align-items:center;gap:10px;cursor:pointer;-webkit-user-select:none;user-select:none;font-family:var(--ds-font-mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--ds-ink-65);transition:color var(--ds-t-micro)}.ds-toggle-switch:hover{color:var(--ds-ink)}.ds-toggle-switch input{position:absolute;opacity:0;pointer-events:none}.ds-toggle-track{position:relative;width:30px;height:16px;border-radius:999px;background:var(--ds-ink-06);border:1px solid var(--ds-ink-24);flex-shrink:0;transition:background var(--ds-t-micro),border-color var(--ds-t-micro)}.ds-toggle-thumb{position:absolute;top:2px;left:2px;width:10px;height:10px;border-radius:50%;background:var(--ds-ink-44);transition:transform var(--ds-t-spring),background var(--ds-t-spring)}.ds-toggle-switch input:checked~.ds-toggle-track{background:var(--ds-ink-24);border-color:var(--ds-ink-65)}.ds-toggle-switch input:checked~.ds-toggle-track .ds-toggle-thumb{transform:translate(14px);background:var(--ds-ink)}.ds-toggle-switch:hover .ds-toggle-track{border-color:var(--ds-ink-65)}.ds-widget-panel{position:fixed;width:288px;padding:20px;background:var(--ds-paper);border:1px solid var(--ds-ink-15);border-radius:8px;box-shadow:0 20px 50px #00000026;opacity:0;transform:translateY(-8px) scale(.95);pointer-events:none;transition:opacity var(--ds-t-spring),transform var(--ds-t-spring);z-index:9998}.ds-widget-panel[data-open=true]{opacity:1;transform:translateY(0) scale(1);pointer-events:auto}.ds-page-frame{position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:1}.ds-page-border{position:absolute;top:16px;right:16px;bottom:16px;left:16px;border:1px solid var(--ds-ink);opacity:.15}.ds-reg-mark{position:absolute;width:16px;height:16px;opacity:.3}.ds-reg-mark--tl{top:16px;left:16px;border-top:1px solid var(--ds-ink);border-left:1px solid var(--ds-ink)}.ds-reg-mark--tr{top:16px;right:16px;border-top:1px solid var(--ds-ink);border-right:1px solid var(--ds-ink)}.ds-reg-mark--bl{bottom:16px;left:16px;border-bottom:1px solid var(--ds-ink);border-left:1px solid var(--ds-ink)}.ds-reg-mark--br{bottom:16px;right:16px;border-bottom:1px solid var(--ds-ink);border-right:1px solid var(--ds-ink)}@media(max-width:768px){.ds-reg-mark{display:none}}.ds-grain{position:fixed;top:0;right:0;bottom:0;left:0;width:100%;height:100%;pointer-events:none;z-index:3;opacity:.45;mix-blend-mode:multiply}.ds-hero-title{font-family:var(--ds-font-sans);font-weight:500;font-size:clamp(3rem,10vw,8rem);line-height:.85;letter-spacing:-.04em;margin-left:-.06em;color:var(--ds-ink);text-transform:uppercase;overflow:visible}@media(prefers-reduced-motion:reduce){.ds-button,.ds-link,.ds-toggle-thumb,.ds-toggle-track,.ds-widget-panel,.ds-select-menu{transition:none!important}}.ds-button:focus-visible,.ds-link:focus-visible,.ds-swatch:focus-visible,.ds-pill:focus-visible,.ds-select-trigger:focus-visible,.ds-toggle-switch:focus-visible,.ds-toggle-switch input:focus-visible~.ds-toggle-track{outline:2px solid var(--ds-accent);outline-offset:2px}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}:root{--paper: #c8c4bc;--paper-2: #b8b4ab;--paper-3: #9a958b;--ink: #5c2318;--accent: #a75331;--stage: #0e0e0e;--lamp-live: #6a8e4e;--lamp-idle: #8a7a5e;--ink-88: color-mix(in srgb, var(--ink) 88%, transparent);--ink-65: color-mix(in srgb, var(--ink) 65%, transparent);--ink-40: color-mix(in srgb, var(--ink) 40%, transparent);--ink-22: color-mix(in srgb, var(--ink) 22%, transparent);--ink-12: color-mix(in srgb, var(--ink) 12%, transparent);--ink-06: color-mix(in srgb, var(--ink) 6%, transparent);--ink-03: color-mix(in srgb, var(--ink) 3%, transparent);--paper-60: color-mix(in srgb, var(--paper) 60%, transparent);--paper-30: color-mix(in srgb, var(--paper) 30%, transparent);--t-micro: .16s ease;--t-spring: .22s cubic-bezier(.175, .885, .32, 1.1);--t-layout: .4s cubic-bezier(.175, .885, .32, 1);--t-bounce: .26s cubic-bezier(.34, 1.56, .64, 1);--t-color: .6s cubic-bezier(.5, 0, .25, 1);--hairline: inset 0 0 0 .5px var(--ink-22);--hairline-hover: inset 0 0 0 .5px var(--ink-65);--hairline-strong: inset 0 0 0 .5px var(--ink);--font-sans: "Geist", system-ui, sans-serif;--font-mono: "Geist Mono", ui-monospace, Menlo, monospace}[data-theme=ink]{--paper: #5c2318;--paper-2: #481a11;--paper-3: #6b3023;--ink: #c8c4bc;--accent: #d08e60;--stage: #2a0f08}[data-theme=dark]{--paper: #1a1a1a;--paper-2: #141414;--paper-3: #2a2a2a;--ink: #e0d8cc;--accent: #e8703a;--stage: #050505}[data-theme=sepia]{--paper: #f4ecd8;--paper-2: #ede5d0;--paper-3: #d4c9b4;--ink: #5c4033;--accent: #b85c2e;--stage: #2a1d15}[data-theme=paperwhite]{--paper: #ffffff;--paper-2: #fafafa;--paper-3: #e5e5e5;--ink: #1a1a1a;--accent: #d4612e;--stage: #050505}[data-theme=midnight]{--paper: #0f172a;--paper-2: #020617;--paper-3: #1e293b;--ink: #94a3b8;--accent: #f59e0b;--stage: #020617}[data-theme=rosepine]{--paper: #1f1d2e;--paper-2: #191724;--paper-3: #26233a;--ink: #e0def4;--accent: #c4a7e7;--stage: #15131f}html,body{width:100%;height:100%;overflow:hidden;background:var(--paper);color:var(--ink-88);font-family:var(--font-sans);font-weight:400;-webkit-font-smoothing:antialiased;transition:background var(--t-color),color var(--t-color)}button{font-family:inherit;color:inherit;cursor:pointer;background:transparent;border:none;transition:color var(--t-micro),background var(--t-micro),box-shadow var(--t-micro),opacity var(--t-micro)}h1,h2,h3{font-weight:500}input,select,textarea{font-family:inherit}.btn{font-family:var(--font-mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;padding:9px 18px;color:var(--ink);background:transparent;border:1px solid var(--ink-22);border-radius:0;transition:background var(--t-micro),color var(--t-micro),box-shadow var(--t-micro),transform var(--t-bounce)}.btn:hover{border-color:var(--ink-65);background:var(--ink-06)}.btn:active{transform:scale(.97)}.btn--solid{background:var(--ink);color:var(--paper);box-shadow:none}.btn--solid:hover{background:color-mix(in srgb,var(--ink) 88%,transparent)}.btn--bare{padding:6px 10px;box-shadow:none;border-radius:0;color:var(--ink-65)}.btn--bare:hover{color:var(--ink);background:transparent}.btn--chip{font-size:10px;padding:6px 12px;letter-spacing:.12em;height:26px;display:inline-flex;align-items:center}.toggle-switch+.toggle-switch{margin-top:8px}.toggle-switch{position:relative;display:inline-flex;align-items:center;justify-content:space-between;gap:10px;padding:9px 14px;width:100%;font-family:var(--font-mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink);border:1px solid var(--ink-22);cursor:pointer;-webkit-user-select:none;user-select:none;transition:background var(--t-micro),color var(--t-micro),border-color var(--t-micro)}.toggle-switch input{position:absolute;opacity:0;pointer-events:none}.toggle-track,.toggle-thumb{display:none}.toggle-switch:after{content:"";width:8px;height:8px;border:1px solid currentColor;background:transparent;transition:background var(--t-micro);flex-shrink:0}.toggle-switch:has(input:checked){background:var(--ink);color:var(--paper);border-color:var(--ink)}.toggle-switch:has(input:checked):after{background:currentColor}.toggle-switch:hover{border-color:var(--ink-65)}.toggle-switch:has(input:checked):hover{border-color:var(--ink)}.segmented{display:inline-flex;background:var(--ink-03);border:1px solid var(--ink-22);border-radius:0;padding:3px;gap:0}.segmented>button{font-family:var(--font-mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;padding:6px 12px;color:var(--ink-65);border-radius:0;transition:color var(--t-micro),background var(--t-spring);flex:1;text-align:center}.segmented>button:hover{color:var(--ink)}.segmented>button.active{color:var(--paper);background:var(--ink);box-shadow:0 1px 2px #0000001f}.swatches{display:flex;gap:10px;flex-wrap:wrap}.swatch{width:28px;height:28px;border-radius:50%;padding:0;position:relative;background:var(--sw-fill, var(--paper-2));border:1px solid var(--ink-22);transition:transform var(--t-bounce),border-color var(--t-spring)}.swatch:hover{transform:scale(1.12);border-color:var(--ink-65)}.swatch.active{transform:scale(1.08);border-color:var(--ink);box-shadow:0 0 0 2px var(--paper),0 0 0 3.5px var(--ink)}.swatch-label{font-family:var(--font-mono);font-size:9px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-40);margin-top:6px;display:block;text-align:center}.lamp{display:inline-block;width:8px;height:8px;border-radius:50%;background:var(--ink-12);border:1px solid var(--ink-22);vertical-align:middle;margin-right:6px;transition:background var(--t-micro)}.lamp.live{background:var(--lamp-live);border-color:color-mix(in srgb,var(--lamp-live) 60%,var(--ink))}.lamp.idle{background:var(--ink-12)}input[type=range]{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:100%;height:18px;background:transparent;cursor:ew-resize}input[type=range]::-webkit-slider-runnable-track{height:3px;background:var(--ink-12);border-radius:0}input[type=range]::-moz-range-track{height:3px;background:var(--ink-12);border-radius:0}input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;margin-top:-4px;width:11px;height:11px;border-radius:50%;background:var(--paper);box-shadow:inset 0 0 0 1.5px var(--ink),0 1px 3px #0000003d;transition:transform var(--t-bounce)}input[type=range]::-moz-range-thumb{width:11px;height:11px;border:1.5px solid var(--ink);border-radius:50%;background:var(--paper);box-shadow:0 1px 3px #0000003d}input[type=range]:hover::-webkit-slider-thumb{transform:scale(1.2)}input[type=range]:active::-webkit-slider-thumb{transform:scale(1.1)}.chip{display:inline-flex;align-items:center;gap:8px;height:26px;padding:0 10px;font-family:var(--font-mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-65);background:transparent;border:1px solid var(--ink-22);border-radius:6px;transition:color var(--t-micro),background var(--t-micro),box-shadow var(--t-micro)}.chip:hover{color:var(--ink);background:var(--ink-06);border-color:var(--ink-65)}.chip.active{color:var(--ink);background:var(--ink-12);border-color:var(--ink)}#camera{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:cover;transform:scaleX(-1);filter:grayscale(.4) contrast(1.02) brightness(.93)}.page-frame{position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:1}.page-border{position:absolute;top:16px;right:16px;bottom:16px;left:16px;border:1px solid var(--ink-22);opacity:.6}.reg-mark{position:absolute;width:14px;height:14px;opacity:.4}.rm-tl{top:16px;left:16px;border-top:1px solid var(--ink);border-left:1px solid var(--ink)}.rm-tr{top:16px;right:16px;border-top:1px solid var(--ink);border-right:1px solid var(--ink)}.rm-bl{bottom:16px;left:16px;border-bottom:1px solid var(--ink);border-left:1px solid var(--ink)}.rm-br{bottom:16px;right:16px;border-bottom:1px solid var(--ink);border-right:1px solid var(--ink)}@media(max-width:640px){.reg-mark{display:none}}.grain{position:fixed;top:0;right:0;bottom:0;left:0;width:100%;height:100%;pointer-events:none;z-index:3;opacity:.5;mix-blend-mode:multiply}#start-screen{position:fixed;top:0;right:0;bottom:0;left:0;z-index:100;display:flex;align-items:center;justify-content:center;background:var(--paper);padding:48px}.start-inner{max-width:720px;width:100%}.start-topline{display:flex;justify-content:space-between;font-family:var(--font-mono);font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-40);margin-bottom:32px;padding-bottom:12px;border-bottom:1px solid var(--ink-22)}.hero-title{font-family:var(--font-sans);font-weight:500;font-size:clamp(3rem,9vw,7rem);line-height:.88;letter-spacing:-.04em;margin-left:-.06em;color:var(--ink);margin-bottom:28px}.start-sub{margin-bottom:36px}.start-sub-label{font-family:var(--font-mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-65)}.start-rule{height:1px;background:var(--ink-22);margin-bottom:28px}.start-specs{display:flex;flex-direction:column;gap:6px;margin-bottom:44px}.spec-row{display:grid;grid-template-columns:44px 1fr;align-items:baseline;font-size:1.05rem;color:var(--ink-88)}.spec-k{font-family:var(--font-mono);font-size:10px;letter-spacing:.15em;text-transform:uppercase;color:var(--ink-40)}.start-actions{display:flex;align-items:center;gap:24px}#start-btn{font-family:var(--font-mono);font-size:12px;font-weight:500;letter-spacing:.2em;text-transform:uppercase;padding:14px 30px;color:var(--ink);background:transparent;border-color:var(--ink-65);border-radius:0;transition:background var(--t-micro),color var(--t-micro),box-shadow var(--t-micro),transform var(--t-bounce)}#start-btn:hover{background:var(--ink);color:var(--paper);box-shadow:none}#start-btn:active{transform:scale(.97)}.start-note{font-family:var(--font-mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-40)}#loading{position:fixed;top:0;right:0;bottom:0;left:0;z-index:99;display:flex;align-items:center;justify-content:center;background:var(--paper)}.loading-inner{text-align:center;font-family:var(--font-mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-65)}.spinner{width:64px;height:1px;background:var(--ink-22);position:relative;overflow:hidden;margin:0 auto 18px}.spinner:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:var(--ink);animation:slide 1.3s ease-in-out infinite}@keyframes slide{0%{transform:translate(-100%)}to{transform:translate(100%)}}#app{--gutter: 24px;height:100vh;display:grid;grid-template-columns:var(--left-w, 320px) 1fr var(--right-w, 0px);grid-template-rows:56px 1fr 40px;grid-template-areas:"header header header" "sidebar stage panel" "footer footer footer";padding:32px;column-gap:var(--gutter);position:relative;z-index:2;transition:grid-template-columns var(--t-layout),column-gap var(--t-layout)}#app[data-right=open]{--right-w: 380px}#app[data-left=collapsed]{--left-w: 0px}.app-header{grid-area:header;display:flex;align-items:center;justify-content:space-between;padding:0 4px 16px;border-bottom:1px solid var(--ink-22)}.hdr-left{display:flex;align-items:center;gap:14px;min-width:0}.hdr-title{font-family:var(--font-sans);font-weight:500;font-size:14px;letter-spacing:.01em;color:var(--ink);white-space:nowrap}.hdr-sep{color:var(--ink-22);font-family:var(--font-mono);font-size:11px}.hdr-meta{font-family:var(--font-mono);font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-40);display:inline-flex;align-items:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0}.hdr-btn{font-family:var(--font-mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;padding:8px 16px;color:var(--ink);border:1px solid var(--ink-22);border-radius:0;transition:all var(--t-micro);white-space:nowrap;flex-shrink:0}.hdr-btn:hover{background:var(--ink);color:var(--paper);box-shadow:none}.hdr-btn .mb-full{display:inline}.hdr-btn .mb-short{display:none}.app-sidebar{grid-area:sidebar;padding:20px 0;border-right:1px solid var(--ink-22);display:flex;flex-direction:column;gap:24px;overflow-y:auto;overflow-x:hidden;position:relative;transition:opacity var(--t-micro)}#app[data-left=collapsed] .app-sidebar{opacity:0;pointer-events:none;border-right:0;padding:0}#app[data-left=open] #toggle-left,#app[data-right=open] #menu-btn{background:var(--ink);color:var(--paper)}.sb-block{display:flex;flex-direction:column}.sb-label{font-family:var(--font-mono);font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-40);margin-bottom:8px;padding-bottom:6px;border-bottom:1px solid var(--ink-12)}#note-name{font-family:var(--font-sans);font-weight:400;font-size:3.6rem;letter-spacing:-.03em;line-height:1;color:var(--ink);font-variant-numeric:tabular-nums;transition:color var(--t-micro)}#note-detail{font-family:var(--font-mono);font-size:10px;letter-spacing:.12em;color:var(--ink-65);margin-top:6px;min-height:14px}#gesture-indicators{display:flex;flex-wrap:wrap;gap:4px;min-height:20px}.g-badge{font-family:var(--font-mono);font-size:10px;letter-spacing:.12em;padding:3px 8px;border:1px solid currentColor;text-transform:uppercase;font-variant-numeric:tabular-nums}.g-vib,.g-cut{color:var(--ink)}.g-mute{color:color-mix(in srgb,var(--ink) 70%,#ff5a44)}#gesture-indicators:empty:before{content:"idle";font-family:var(--font-mono);font-size:10px;color:var(--ink-22);letter-spacing:.14em;text-transform:uppercase}.sb-viz{display:flex;flex-direction:column}#viz-canvas{width:100%;aspect-ratio:1 / 1;height:auto;background:var(--paper-2);border:1px solid var(--ink);display:block;transition:background var(--t-color)}.vol-row{display:flex;align-items:stretch;gap:10px;height:80px}#vol-meter{width:4px;height:100%;background:var(--ink-12);position:relative;overflow:hidden}#vol-fill{position:absolute;bottom:0;width:100%;height:0%;background:var(--ink);transition:height .05s}.vol-ticks{display:flex;flex-direction:column;justify-content:space-between;font-family:var(--font-mono);font-size:9px;letter-spacing:.08em;color:var(--ink-40)}.app-stage{grid-area:stage;padding:0;min-width:0;position:relative}.stage-frame{position:relative;width:100%;height:100%;min-height:320px;border:1px solid var(--ink);background:var(--stage);overflow:hidden}#overlay{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;pointer-events:none}.stage-vol-rail{position:absolute;right:14px;top:32px;bottom:32px;width:3px;background:#c8c4bc1f;pointer-events:none;z-index:2}.stage-vol-fill{position:absolute;left:0;right:0;bottom:0;height:0%;background:#c8c4bc9e;transition:height 60ms linear}.stage-vol-label{position:absolute;top:-16px;left:-6px;font-family:var(--font-mono);font-size:8px;letter-spacing:.22em;color:#c8c4bc8c}.stage-labels{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none}.stage-label{position:absolute;font-family:var(--font-mono);font-size:9px;letter-spacing:.18em;text-transform:uppercase;color:#f0ede58c;padding:10px 14px}.sl-tl{top:0;left:0}.sl-tr{top:0;right:0}.sl-bl{bottom:0;left:0}.sl-br{bottom:0;right:0}.app-footer{grid-area:footer;display:flex;align-items:center;padding:0 4px;border-top:1px solid var(--ink-22)}.foot-stat{display:flex;align-items:baseline;gap:8px;padding:0 20px;font-variant-numeric:tabular-nums;white-space:nowrap;flex-shrink:0}.foot-stat:first-child{padding-left:0}.foot-sep{width:1px;height:14px;background:var(--ink-22);flex-shrink:0}.fk{font-family:var(--font-mono);font-size:10px;letter-spacing:.18em;white-space:nowrap;text-transform:uppercase;color:var(--ink-40)}.fv{font-family:var(--font-mono);font-size:11px;letter-spacing:.06em;color:var(--ink);white-space:nowrap}.foot-spacer{flex:1}.foot-end{font-family:var(--font-mono);font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-40);padding-right:0}#panel{grid-area:panel;background:var(--paper);border-left:1px solid var(--ink-22);overflow-y:auto;overflow-x:hidden;transition:opacity var(--t-micro),background var(--t-color);opacity:1;pointer-events:auto;position:relative}#app:not([data-right=open]) #panel{opacity:0;pointer-events:none;border-left:0;padding:0}@media(max-width:1000px){#panel{position:fixed;top:32px;right:32px;bottom:32px;width:360px;border:1px solid var(--ink);border-left:1px solid var(--ink);padding:0;background:var(--paper);box-shadow:0 12px 40px #0000001a;z-index:50;transform:translate(calc(100% + 48px));transition:transform var(--t-layout),background var(--t-color);opacity:0;pointer-events:none}#app:not([data-right=open]) #panel{opacity:0;padding:0;border:1px solid var(--ink)}#app[data-right=open] #panel{transform:translate(0);opacity:1;pointer-events:auto}}.panel-inner{padding:28px 28px 40px}.panel-header{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:28px;padding-bottom:14px;border-bottom:1px solid var(--ink-22)}.panel-header h2{font-family:var(--font-sans);font-weight:500;font-size:1rem;color:var(--ink)}.panel-header button{font-size:1.4rem;color:var(--ink-65);line-height:1;padding:0 4px}.panel-header button:hover{color:var(--ink)}.panel-section{margin-bottom:26px}.panel-section h3{font-family:var(--font-mono);font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-40);margin-bottom:10px}.subtle-h3{margin-top:14px}#preset-list{display:flex;flex-direction:column}.preset-btn{font-family:var(--font-mono);font-size:11px;letter-spacing:.12em;padding:10px 0;color:var(--ink-65);text-align:left;text-transform:uppercase;display:grid;grid-template-columns:28px 1fr auto;align-items:center;border-top:1px solid var(--ink-12);transition:color var(--t-micro),background var(--t-micro)}.preset-btn:before{content:attr(data-index);color:var(--ink-40);font-size:9px}.preset-btn:last-child{border-bottom:1px solid var(--ink-12)}.preset-btn:hover{color:var(--ink);background:var(--ink-03)}.preset-btn.active{color:var(--ink)}.preset-btn.active:after{content:"●";font-size:7px;color:var(--ink)}#range-options,#viz-modes,#viz-themes{display:grid;grid-template-columns:repeat(4,1fr);gap:4px;margin-bottom:8px}#range-options,#viz-modes{grid-template-columns:repeat(4,1fr)}.range-btn,.viz-mode-btn,.viz-theme-btn{font-family:var(--font-mono);font-size:10px;letter-spacing:.08em;padding:7px 6px;color:var(--ink-65);border:1px solid var(--ink-22);text-transform:uppercase;border-radius:0;transition:all var(--t-micro);min-width:0;text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.range-btn:hover,.viz-mode-btn:hover,.viz-theme-btn:hover{color:var(--ink);border-color:var(--ink-65);background:var(--ink-06)}.range-btn.active,.viz-mode-btn.active,.viz-theme-btn.active{background:var(--ink);color:var(--paper);box-shadow:none}.toggle{display:flex;align-items:center;gap:10px;font-family:var(--font-mono);font-size:11px;letter-spacing:.05em;color:var(--ink-65);cursor:pointer;text-transform:uppercase;padding:6px 0;transition:color var(--t-micro)}.toggle:hover{color:var(--ink)}.toggle input{accent-color:var(--ink)}.inline-btn{margin-top:10px;font-family:var(--font-mono);font-size:10px;letter-spacing:.16em;color:var(--ink);text-align:left;text-transform:uppercase;padding:0;text-decoration:underline;text-decoration-color:var(--ink-40);text-underline-offset:4px;transition:text-decoration-color var(--t-micro)}.inline-btn:hover{text-decoration-color:var(--ink)}.slider-labels{display:flex;justify-content:space-between;font-family:var(--font-mono);font-size:9px;letter-spacing:.15em;color:var(--ink-40);text-transform:uppercase;margin-top:4px}#song-list{display:flex;flex-direction:column}.song-btn{font-family:var(--font-sans);font-size:12px;padding:12px 8px;color:var(--ink);text-align:left;display:grid;grid-template-columns:28px 1fr auto;align-items:center;gap:8px;border-top:1px solid var(--ink-12);transition:color var(--t-micro),background var(--t-micro)}.song-btn:last-child{border-bottom:1px solid var(--ink-12)}.song-btn:hover{color:var(--ink);background:var(--ink-06)}.song-index{font-family:var(--font-mono);font-size:10px;letter-spacing:.12em;color:var(--ink-40)}.song-difficulty{font-family:var(--font-mono);font-size:9px;letter-spacing:.15em;color:var(--ink-40);text-transform:uppercase}#theme-swatches{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-top:6px}.theme-swatch{display:flex;flex-direction:column;align-items:center;cursor:pointer;padding:4px;border-radius:6px;transition:background var(--t-micro)}.theme-swatch:hover{background:var(--ink-03)}.theme-swatch.active{background:var(--ink-06)}.theme-swatch-inner{display:block;width:32px;height:32px;border-radius:50%;border:1px solid var(--ink-22);position:relative;overflow:hidden}.theme-swatch.active .theme-swatch-inner{border-color:var(--ink)}.theme-swatch-inner:before,.theme-swatch-inner:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0}.theme-swatch-inner:before{background:var(--sw-paper);clip-path:polygon(0 0,100% 0,0 100%)}.theme-swatch-inner:after{background:var(--sw-ink);clip-path:polygon(100% 0,100% 100%,0 100%)}.theme-swatch-label{font-family:var(--font-mono);font-size:9px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-65);margin-top:6px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}.theme-swatch.active .theme-swatch-label{color:var(--ink)}#lesson-hud{position:fixed;top:32px;left:32px;right:32px;z-index:20;pointer-events:none}.lesson-bar{display:flex;justify-content:space-between;align-items:center;padding:12px 20px;background:var(--paper);border-bottom:1px solid var(--ink);font-family:var(--font-mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;pointer-events:auto}#lesson-title{color:var(--ink);font-weight:500}#lesson-score-display{color:var(--ink);font-size:14px;font-variant-numeric:tabular-nums}#lesson-quit{color:var(--ink-65);font-size:1.2rem}#lesson-target{text-align:center;padding:16px}#target-note{font-family:var(--font-sans);font-weight:400;font-size:2.2rem;letter-spacing:-.02em;color:var(--ink)}#target-status{display:block;font-family:var(--font-mono);font-size:10px;letter-spacing:.18em;color:var(--ink-65);text-transform:uppercase;margin-top:4px}#results{position:fixed;top:0;right:0;bottom:0;left:0;z-index:90;display:flex;align-items:center;justify-content:center;background:var(--paper-60);backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px)}.results-content{text-align:center;max-width:420px;padding:40px 44px;background:var(--paper);border:1px solid var(--ink);box-shadow:0 12px 40px #0000001f}.results-content h2{font-family:var(--font-mono);font-size:11px;letter-spacing:.22em;color:var(--ink-40);text-transform:uppercase;margin-bottom:24px}#results-grade{font-family:var(--font-sans);font-weight:500;font-size:6rem;line-height:1;margin-bottom:28px;letter-spacing:-.04em;color:var(--ink)}#results-details{font-family:var(--font-mono);font-size:11px;letter-spacing:.08em;color:var(--ink-65);margin-bottom:28px;line-height:2.2;text-transform:uppercase}.results-actions{display:flex;gap:8px;justify-content:center}.results-actions button{font-family:var(--font-mono);font-size:10px;letter-spacing:.18em;padding:10px 24px;color:var(--ink);border-color:var(--ink-65);border-radius:0;text-transform:uppercase;transition:all var(--t-micro)}.results-actions button:first-child{background:var(--ink-06)}.results-actions button:hover{background:var(--ink);color:var(--paper);box-shadow:none}.grade-s{color:var(--accent)}.grade-a{color:#4a7a3a}.grade-b{color:#2c3e5c}.grade-c{color:#b06a2a}.grade-d{color:#8c2a1a}#tutorial{position:fixed;top:0;right:0;bottom:0;left:0;z-index:80;display:flex;align-items:center;justify-content:center;background:var(--paper-60);backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px)}.tutorial-step{background:var(--paper);border:1px solid var(--ink);box-shadow:0 12px 40px #0000001f;padding:36px 40px;max-width:460px}#tutorial-content{margin-bottom:24px}#tutorial-content h3{font-family:var(--font-sans);font-weight:500;font-size:1.5rem;letter-spacing:-.01em;color:var(--ink);margin-bottom:14px}#tutorial-content p{color:var(--ink-65);font-size:.95rem;line-height:1.55}#tutorial-next{font-family:var(--font-mono);font-size:11px;letter-spacing:.2em;padding:10px 24px;color:var(--ink);border-color:var(--ink-65);border-radius:0;text-transform:uppercase;transition:all var(--t-micro)}#tutorial-next:hover{background:var(--ink);color:var(--paper);box-shadow:none}#gesture-guide{position:fixed;top:0;right:0;bottom:0;left:0;z-index:95;display:flex;align-items:center;justify-content:center;background:color-mix(in srgb,var(--paper) 94%,transparent);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);padding:32px;overflow-y:auto}.gg-content{background:var(--paper);border:1px solid var(--ink);box-shadow:0 12px 40px #0000001f;max-width:780px;width:100%}.gg-header{display:flex;justify-content:space-between;align-items:baseline;padding:22px 28px;border-bottom:1px solid var(--ink-22)}.gg-header h2{font-family:var(--font-mono);font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--ink)}#gesture-guide-close{color:var(--ink-65);font-size:1.3rem;line-height:1}.gg-grid{display:grid;grid-template-columns:1fr 1fr}.gg-item{padding:28px 32px;border-right:1px solid var(--ink-22);border-bottom:1px solid var(--ink-22);position:relative}.gg-item:nth-child(2n){border-right:none}.gg-item:nth-last-child(-n+2){border-bottom:none}.gg-num{font-family:var(--font-mono);font-size:10px;letter-spacing:.18em;color:var(--ink-40);margin-bottom:12px}.gg-label{font-family:var(--font-mono);font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-40);margin-bottom:6px}.gg-item h3{font-family:var(--font-sans);font-weight:500;font-size:1.05rem;margin-bottom:8px;letter-spacing:-.005em;color:var(--ink)}.gg-item p{font-size:.88rem;color:var(--ink-65);line-height:1.55}.gg-footer{padding:14px 28px;border-top:1px solid var(--ink-22);text-align:center;font-family:var(--font-mono);font-size:10px;letter-spacing:.14em;color:var(--ink-40);text-transform:uppercase}@media(max-width:900px){.gg-grid{grid-template-columns:1fr}.gg-item{border-right:none}.gg-item:nth-last-child(-n+2){border-bottom:1px solid var(--ink-22)}.gg-item:last-child{border-bottom:none}}@media(max-width:1000px){#app{grid-template-columns:1fr;grid-template-rows:56px 1fr auto 40px;grid-template-areas:"header" "stage" "sidebar" "footer"}#app[data-left=collapsed] .app-sidebar{opacity:1;pointer-events:auto;padding:revert;border-right:0}.app-sidebar{border-right:none;border-top:1px solid var(--ink-22);padding:20px 0;max-height:320px}.app-stage{padding:0;min-height:50vh}}@media(max-width:640px){#app{padding:10px 12px;grid-template-columns:1fr;grid-template-rows:40px minmax(340px,1fr) auto 28px;grid-template-areas:"header" "stage" "sidebar" "footer";gap:0}.page-border{display:none}#panel{top:0;right:0;bottom:0;left:auto;width:100vw;max-width:100vw;border:none;box-shadow:none}.panel-inner{padding:20px 20px 80px}.panel-header{margin-bottom:20px;padding-bottom:14px}.panel-header h2{font-size:1.25rem;letter-spacing:-.01em}.panel-header button{font-size:1.8rem;width:44px;height:44px;padding:0;display:inline-flex;align-items:center;justify-content:center;border:1px solid var(--ink-22);margin-right:-8px}.panel-header button:hover{background:var(--ink-06)}.panel-section{margin-bottom:22px}.panel-section h3{font-size:11px;margin-bottom:12px}#theme-swatches{gap:12px 10px}.theme-swatch-inner{width:40px;height:40px}.theme-swatch-label{font-size:9px}.preset-btn{padding:14px 0;font-size:12px;min-height:48px}.range-btn,.viz-mode-btn,.song-btn{min-height:44px;padding:10px 12px;font-size:12px}.toggle-switch{padding:10px 0;font-size:11px}.toggle-track{width:36px;height:20px}.toggle-thumb{width:16px;height:16px;top:1px;left:1px}.toggle-switch input:checked~.toggle-track .toggle-thumb{transform:translate(16px)}.inline-btn{min-height:44px}.hero-title{font-size:clamp(2.4rem,11vw,4.2rem)}.start-inner{padding:0 8px}.app-header{padding:0 0 8px}.hdr-left{gap:8px;overflow:hidden}.hdr-title{font-size:12px}.hdr-sep{display:none}.hdr-meta{font-size:9px;letter-spacing:.14em}#live-meta-text{display:none}.hdr-meta:after{content:"LIVE";margin-left:6px}.hdr-btn{padding:0;font-size:18px;letter-spacing:0;width:40px;height:40px;display:inline-flex;align-items:center;justify-content:center}.hdr-btn .mb-full{display:none}.hdr-btn .mb-short{display:inline}#toggle-left{display:none}.app-stage{padding:0;min-height:0}.stage-frame{min-height:340px}.app-sidebar{max-height:none;padding:8px 0 6px;gap:8px}.sb-label{margin-bottom:3px;padding-bottom:3px;font-size:9px}.sb-gesture .sb-label{display:none}.sb-gesture{min-height:0}#gesture-indicators{min-height:18px}#note-name{font-size:32px;letter-spacing:-.02em}#note-detail{font-size:10px;margin-top:2px}.sb-vol{display:none}.sb-viz{flex:0 0 auto;min-height:0;align-items:center}#viz-canvas{flex:0 0 auto;aspect-ratio:1 / 1;width:200px;max-width:70vw;height:auto;min-height:0}.stage-vol-rail{right:10px;top:26px;bottom:26px}.app-footer{overflow-x:auto;overflow-y:hidden;padding:0;-webkit-overflow-scrolling:touch;scrollbar-width:none}.app-footer::-webkit-scrollbar{display:none}.foot-stat{padding:0 10px;font-size:9px;gap:5px}.foot-sep{height:10px}.foot-end,.foot-spacer{display:none}.fk,.fv{font-size:9px}#lesson-hud{top:12px;left:12px;right:12px}}.hidden{display:none!important}
