:root{--text:#6b6375;--text-h:#08060d;--bg:#fff;--border:#e5e4e7;--code-bg:#f4f3ec;--accent:#aa3bff;--accent-bg:#aa3bff1a;--accent-border:#aa3bff80;--social-bg:#f4f3ec80;--shadow:#0000001a 0 10px 15px -3px, #0000000d 0 4px 6px -2px;--sans:system-ui, "Segoe UI", Roboto, sans-serif;--heading:system-ui, "Segoe UI", Roboto, sans-serif;--mono:ui-monospace, Consolas, monospace;font:18px/145% var(--sans);letter-spacing:.18px;--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light dark;color:var(--text);background:var(--bg);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}@media (prefers-color-scheme:dark){:root{--lightningcss-light: ;--lightningcss-dark:initial}}@media (width<=1024px){:root{font-size:16px}}@media (prefers-color-scheme:dark){:root{--text:#9ca3af;--text-h:#f3f4f6;--bg:#16171d;--border:#2e303a;--code-bg:#1f2028;--accent:#c084fc;--accent-bg:#c084fc26;--accent-border:#c084fc80;--social-bg:#2f303a80;--shadow:#0006 0 10px 15px -3px, #00000040 0 4px 6px -2px}#social .button-icon{filter:invert()brightness(2)}}#root{text-align:center;border-inline:1px solid var(--border);box-sizing:border-box;flex-direction:column;width:1126px;max-width:100%;min-height:100svh;margin:0 auto;display:flex}body{overscroll-behavior:none;touch-action:manipulation;min-width:320px;margin:0}button,input,select{font:inherit}h1,h2{font-family:var(--heading);color:var(--text-h);font-weight:500}h1{letter-spacing:-1.68px;margin:32px 0;font-size:56px}@media (width<=1024px){h1{margin:20px 0;font-size:36px}}h2{letter-spacing:-.24px;margin:0 0 8px;font-size:24px;line-height:118%}@media (width<=1024px){h2{font-size:20px}}p{margin:0}code,.counter{font-family:var(--mono);color:var(--text-h);border-radius:4px;display:inline-flex}code{background:var(--code-bg);padding:4px 8px;font-size:15px;line-height:135%}.trainer{box-sizing:border-box;place-items:center;min-height:100svh;padding:24px;display:grid}.readout-panel,.settings-panel,.intro-panel{gap:24px;width:min(720px,100%);display:grid}.intro-panel{text-align:left}.intro-copy{gap:10px;display:grid}.intro-copy h1{letter-spacing:0;margin:0;font-size:clamp(2rem,7vw,3.4rem);line-height:1.02}.intro-copy p{max-width:560px;color:var(--text);font-size:1.05rem}.intro-steps{gap:10px;display:grid}.intro-steps div{border:1px solid var(--border);border-radius:8px;grid-template-columns:34px minmax(0,1fr);align-items:center;gap:12px;min-height:56px;padding:12px;display:grid}.intro-steps strong{border:1px solid var(--accent-border);width:32px;height:32px;color:var(--accent);background:var(--accent-bg);border-radius:999px;place-items:center;display:grid}.intro-steps span{color:var(--text-h);font-weight:700}.intro-actions{justify-content:start}.practice-panel{gap:16px}.eyebrow{color:var(--accent);letter-spacing:0;text-transform:uppercase;font-size:.86rem;font-weight:700}.top-bar{justify-content:space-between;align-items:center;gap:16px;display:flex}.status{min-height:1.5em;color:var(--text)}.level-switch{border:1px solid var(--border);border-radius:8px;grid-template-columns:repeat(6,minmax(0,1fr));justify-self:center;gap:6px;width:100%;padding:6px;display:grid}.level-switch button{min-height:38px;color:var(--text-h);font:inherit;cursor:pointer;background:0 0;border:1px solid #0000;border-radius:6px;font-weight:700}.level-switch button.active{border-color:var(--accent-border);color:var(--accent);background:var(--accent-bg)}.played-note{justify-items:center;gap:8px;display:grid}.played-note span{color:var(--text);font-size:.9rem;font-weight:700}.played-note strong{min-height:1em;color:var(--accent);font-size:clamp(2rem,8vw,4rem);line-height:1}.staff-stack{gap:12px;display:grid}.staff-lane{gap:8px;display:grid}.staff-lane>span{color:var(--text);text-transform:uppercase;justify-self:start;font-size:.76rem;font-weight:700}.staff{border-block:1px solid var(--border);place-items:center;width:100%;min-height:380px;display:grid;overflow:hidden}.combined-staff .staff{box-sizing:border-box;min-height:600px;padding-left:12px}.staff svg{transform-origin:0;width:min(620px,100%);height:auto;display:block}.staff path:not([style]),.staff text:not([style]){fill:var(--text-h);stroke:var(--text-h)}.staff [fill=\#d92d20],.staff [stroke=\#d92d20],.staff [style*=d92d20]{fill:#d92d20!important;stroke:#d92d20!important}.position-cue{color:var(--text);font-size:.9rem;font-weight:700}.key-cue{color:var(--text-h);justify-self:center;align-items:center;gap:8px;font-size:.9rem;font-weight:700;display:inline-flex}.key-cue span{border:1px solid var(--accent-border);color:var(--accent);background:var(--accent-bg);text-transform:uppercase;border-radius:999px;padding:3px 8px;font-size:.72rem}.settings-grid{text-align:left;grid-template-columns:repeat(2,minmax(0,1fr));gap:18px;display:grid}.settings-grid section{border:1px solid var(--border);border-radius:8px;gap:14px;padding:16px;display:grid}.settings-grid h2{margin:0;font-size:1rem}.settings-note{color:var(--text);font-size:.86rem}.device-picker{text-align:left;gap:8px;display:grid}.device-picker span{color:var(--text);font-size:.86rem;font-weight:700}.device-picker select,.device-picker input{border:1px solid var(--border);width:100%;min-height:44px;color:var(--text-h);background:var(--bg);font:inherit;border-radius:8px;padding:0 12px}.toggle-row{min-height:44px;color:var(--text-h);align-items:center;gap:10px;font-weight:700;display:flex}.toggle-row input{width:18px;height:18px}.info-button{border:1px solid var(--accent-border);width:28px;height:28px;color:var(--accent);background:var(--accent-bg);font:inherit;cursor:pointer;border-radius:999px;flex:none;place-items:center;margin-left:auto;font-size:.84rem;font-weight:800;line-height:1;display:inline-grid}.info-panel{border:1px solid var(--accent-border);color:var(--text);background:var(--accent-bg);border-radius:8px;gap:8px;padding:12px;font-size:.86rem;display:grid}.roadmap{flex-wrap:wrap;gap:8px;display:flex}.roadmap span{border:1px solid var(--border);color:var(--text);border-radius:999px;padding:6px 10px;font-size:.84rem}.mini-diagnostics{grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;margin:0;display:grid}.mini-diagnostics div{border:1px solid var(--border);border-radius:8px;gap:4px;padding:10px;display:grid}.mini-diagnostics dt,.mini-diagnostics dd{margin:0}.mini-diagnostics dt{color:var(--text);font-size:.72rem}.mini-diagnostics dd{color:var(--text-h);overflow-wrap:anywhere;font-weight:700}.meters{grid-template-columns:repeat(auto-fit,minmax(108px,1fr));gap:12px;display:grid}.meters div{border:1px solid var(--border);background:var(--social-bg);border-radius:8px;gap:8px;padding:16px;display:grid}.meters span{color:var(--text);font-size:.8rem}.meters strong{color:var(--text-h);font-size:1.2rem;font-weight:700}.diagnostics{grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;margin:0;display:grid}.diagnostics div{border:1px solid var(--border);border-radius:8px;gap:4px;padding:12px;display:grid}.diagnostics dt,.diagnostics dd{margin:0}.diagnostics dt{color:var(--text);font-size:.75rem}.diagnostics dd{color:var(--text-h);overflow-wrap:anywhere;font-size:.92rem;font-weight:700}.actions{flex-wrap:wrap;justify-content:center;gap:12px;display:flex}.primary-actions{flex-wrap:nowrap;justify-content:flex-end}.secondary-actions{justify-content:center}.actions button{border:1px solid var(--border);min-width:108px;min-height:44px;color:var(--text-h);background:var(--bg);font:inherit;cursor:pointer;border-radius:8px;font-weight:700}.text-button{border:1px solid var(--border);min-height:44px;color:var(--text-h);background:var(--bg);font:inherit;cursor:pointer;border-radius:8px;padding:0 14px;font-weight:700}.actions button:first-child{border-color:var(--accent-border);background:var(--accent-bg);color:var(--accent)}.actions button:disabled{cursor:not-allowed;opacity:.45}@media (width<=640px){.trainer{align-items:start;padding:10px}.settings-panel,.intro-panel{gap:10px}.intro-copy h1{font-size:2rem}.intro-copy p{font-size:.95rem}.intro-steps{gap:8px}.intro-steps div{min-height:48px;padding:10px}.practice-panel{gap:8px}.top-bar{flex-direction:column;align-items:stretch;gap:8px}.eyebrow{font-size:.78rem}.actions{gap:8px}.primary-actions{grid-template-columns:minmax(0,1.35fr) minmax(0,1fr);display:grid}.actions button,.text-button{min-height:38px}.level-switch{grid-template-columns:repeat(2,minmax(0,1fr))}.staff{justify-items:start;min-height:64svh}.combined-staff .staff{min-height:82svh;padding-left:18px}.staff-stack{gap:6px}.staff-lane{gap:4px}.staff-lane>span{font-size:.68rem}.staff svg{width:100%;max-width:none;transform:scale(2.45)}.combined-staff .staff svg{transform:scale(1.55)}.status{min-height:2.8em}.played-note strong{font-size:2rem}.device-picker{display:none}.settings-panel .device-picker{display:grid}.meters div{padding:12px}.meters,.diagnostics,.settings-grid,.mini-diagnostics{grid-template-columns:1fr}.actions:not(.primary-actions){flex-direction:column}.actions button,.text-button{width:100%}}
