: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)}}body{margin:0}#app{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}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%}:root{--color-bg:#1a1a2e;--color-surface:#16213e;--color-primary:#e94560;--color-primary-hover:#c73652;--color-text:#eaeaea;--color-text-muted:#888;--color-border:#333;--color-active:#e94560;--radius:8px;--font:"Segoe UI", system-ui, sans-serif}*,:before,:after{box-sizing:border-box;margin:0;padding:0}body{background:var(--color-bg);color:var(--color-text);font-family:var(--font);justify-content:center;align-items:flex-start;min-height:100vh;padding:2rem 1rem;display:flex}#app{width:100%;max-width:720px}.config-panel{flex-direction:column;gap:1.5rem;display:flex}.config-panel h1{text-align:center;font-size:1.8rem}.config-panel h2{color:var(--color-text-muted);text-align:center;font-size:1.1rem;font-weight:400}section{flex-direction:column;gap:.5rem;display:flex}label{color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em;font-size:.85rem}.btn-group{flex-wrap:wrap;gap:.5rem;display:flex}.btn-toggle{border:1px solid var(--color-border);border-radius:var(--radius);background:var(--color-surface);color:var(--color-text);cursor:pointer;padding:.4rem .9rem;font-size:1rem;transition:border-color .15s,background .15s}.btn-toggle:hover{border-color:var(--color-primary)}.btn-toggle.active{background:var(--color-primary);border-color:var(--color-primary);color:#fff}.btn-music-glyph{justify-content:center;align-items:flex-end;min-width:2.4rem;min-height:37px;padding:.15rem .7rem .2rem;font-family:Bravura,Academico,serif;font-size:1.6rem;line-height:1;display:inline-flex}input[type=range]{width:100%;accent-color:var(--color-primary)}.btn-primary{background:var(--color-primary);color:#fff;border-radius:var(--radius);cursor:pointer;border:none;margin-top:.5rem;padding:.8rem 1.5rem;font-size:1.1rem;font-weight:600;transition:background .15s}.btn-primary:hover{background:var(--color-primary-hover)}.placeholder{text-align:center;color:var(--color-text-muted);padding:3rem}.dictation-view{flex-direction:column;gap:1.25rem;display:flex}.dictation-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.5rem;display:flex}.dictation-meta{flex-wrap:wrap;gap:.5rem;display:flex}.badge{background:var(--color-surface);border:1px solid var(--color-border);color:var(--color-text-muted);border-radius:99px;padding:.25rem .65rem;font-size:.8rem}.badge-deaf{border-color:var(--color-primary);color:var(--color-primary)}.deaf-mode-section{flex-direction:column;gap:.3rem;display:flex}.btn-ghost{border:1px solid var(--color-border);color:var(--color-text-muted);border-radius:var(--radius);cursor:pointer;background:0 0;padding:.3rem .75rem;font-size:.85rem;transition:border-color .15s,color .15s}.btn-ghost:hover{border-color:var(--color-primary);color:var(--color-text)}.measure-tabs{gap:.5rem;display:flex}.measure-tab{text-align:center;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);color:var(--color-text-muted);flex:1;justify-content:center;align-items:center;gap:.3rem;padding:.5rem;font-size:.85rem;display:flex}.measure-tab.active{border-color:var(--color-primary);color:var(--color-text);font-weight:600}.measure-tab.heard{border-color:#4caf50}.tab-dot{color:#4caf50;font-size:.5rem}.staff-wrapper{border-radius:var(--radius);background:#fff;min-height:100px;overflow:hidden}.staff-container{width:100%;overflow-x:auto}.staff-container svg{width:100%;height:auto;display:block}.staff-empty{height:120px}.playback-controls{flex-wrap:wrap;align-items:center;gap:.75rem;display:flex}.btn-play{background:var(--color-primary);color:#fff;border-radius:var(--radius);cursor:pointer;border:none;flex:1;padding:.75rem 1.5rem;font-size:1rem;font-weight:600;transition:background .15s}.btn-play:hover:not(:disabled){background:var(--color-primary-hover)}.btn-play:disabled{opacity:.4;cursor:not-allowed}.btn-play.btn-stop{background:#555}.btn-secondary{background:var(--color-surface);color:var(--color-text);border:1px solid var(--color-border);border-radius:var(--radius);cursor:pointer;padding:.75rem 1.25rem;font-size:.95rem;transition:border-color .15s}.btn-secondary:hover{border-color:var(--color-primary)}.sprint3-placeholder{border:1px dashed var(--color-border);border-radius:var(--radius);text-align:center;padding:1.5rem}.muted{color:var(--color-text-muted);font-size:.9rem}.note-entry{flex-direction:column;gap:1rem;display:flex}.entry-actions{justify-content:flex-start;display:flex}.figure-palette{flex-direction:column;gap:.5rem;display:flex}.palette-label{color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em;font-size:.8rem}.palette-hint{color:var(--color-text-muted);font-size:.8rem;font-style:italic}.palette-buttons{flex-wrap:wrap;gap:.5rem;display:flex}.btn-figure{background:var(--color-surface);border:2px solid var(--color-border);border-radius:var(--radius);width:56px;height:56px;color:var(--color-text);cursor:pointer;justify-content:center;align-items:center;font-size:1.6rem;transition:border-color .15s,background .15s;display:flex}.btn-figure:hover:not(:disabled){border-color:var(--color-primary)}.btn-figure.active{border-color:var(--color-primary);background:var(--color-primary);color:#fff}.btn-figure:disabled{opacity:.3;cursor:not-allowed}.piano-keyboard{flex-direction:column;gap:.5rem;display:flex}.piano-octaves{flex-wrap:wrap;gap:1.25rem;display:flex}.piano-octave{flex-direction:column;align-items:flex-start;gap:.25rem;display:flex}.piano-keys{gap:3px;display:flex}.piano-key{cursor:pointer;background:#f5f5f0;border:1px solid #888;border-radius:0 0 6px 6px;justify-content:center;align-items:flex-end;width:52px;height:96px;padding-bottom:6px;transition:background .1s,transform 50ms;display:flex}.piano-key:hover:not(:disabled){background:#e0e0d8}.piano-key:active:not(:disabled){background:#c8c8c0;transform:translateY(1px)}.piano-key:disabled{opacity:.4;cursor:not-allowed}.key-label{color:#333;letter-spacing:-.02em;font-size:.65rem;font-weight:700}.octave-label{color:var(--color-text-muted);padding-left:2px;font-size:.7rem}.correction-view{flex-direction:column;gap:1.5rem;display:flex}.correction-header{justify-content:space-between;align-items:center;display:flex}.correction-header h2{font-size:1.4rem}.correction-staff-wrap{flex-direction:column;gap:.4rem;display:flex}.correction-legend{gap:1rem;padding-left:4px;font-size:.75rem;display:flex}.legend-item{color:var(--color-text-muted)}.legend-correct{color:#4caf50}.legend-wrong{color:var(--color-primary)}.legend-missing{color:#888}.playback-row{flex-wrap:wrap;align-items:center;gap:.75rem;display:flex}.playing-label{color:var(--color-text-muted);font-size:.8rem;font-style:italic}.score-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);align-items:center;gap:1.25rem;padding:1.25rem 1.5rem;display:flex}.score-pct{text-align:center;min-width:5rem;font-size:2.8rem;font-weight:700;line-height:1}.score-great{color:#4caf50}.score-ok{color:#ff9800}.score-bad{color:var(--color-primary)}.score-detail{flex-direction:column;flex:1;gap:.5rem;display:flex}.score-fraction{color:var(--color-text-muted);font-size:1rem}.score-bar{background:var(--color-border);border-radius:99px;height:8px;overflow:hidden}.score-bar-fill{background:var(--color-primary);border-radius:99px;height:100%;transition:width .6s}.measure-breakdown{flex-direction:column;gap:1rem;display:flex}.measure-result{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);overflow:hidden}.measure-result-header{border-bottom:1px solid var(--color-border);background:#ffffff08;justify-content:space-between;align-items:center;padding:.6rem 1rem;display:flex}.measure-result-label{text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-muted);font-size:.85rem;font-weight:600}.measure-result-score{color:var(--color-text-muted);font-size:.85rem}.note-results{flex-wrap:wrap;gap:.5rem;padding:.75rem 1rem;display:flex}.note-result{border-radius:var(--radius);border:1px solid #0000;flex-direction:column;gap:.2rem;min-width:90px;padding:.5rem .75rem;display:flex}.note-result--correct{background:#4caf501f;border-color:#4caf5066}.note-result--wrong{background:#e945601f;border-color:#e9456066}.note-result--missing{background:#ff98001a;border-color:#ff980059}.note-result-row{align-items:baseline;gap:.4rem;display:flex}.note-result-label{color:var(--color-text-muted);min-width:1.2rem;font-size:.7rem}.note-result-value{font-size:.9rem;font-weight:500}.note-result-solution{color:#4caf50}.note-result-solution .note-result-value{font-size:.85rem}.note-result-detail{gap:.3rem;margin-top:.15rem;display:flex}.tag-ok{color:#4caf50;background:#4caf5033;border-radius:99px;padding:.1rem .4rem;font-size:.65rem}.tag-err{color:var(--color-primary);background:#e9456033;border-radius:99px;padding:.1rem .4rem;font-size:.65rem}.btn-new{text-align:center;width:100%}.note-staff-picker{flex-direction:column;gap:.75rem;display:flex}.nsp-octave-row{flex-wrap:wrap;align-items:center;gap:.5rem;display:flex}.nsp-label{color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em;margin-right:.25rem;font-size:.8rem}.nsp-oct-btn{padding:.3rem .7rem;font-size:.9rem}.nsp-legend{flex-wrap:wrap;gap:.4rem;display:flex}.nsp-legend-note{border:1px solid var(--color-border);color:var(--color-text-muted);background:var(--color-surface);border-radius:99px;padding:.2rem .6rem;font-size:.8rem;transition:border-color .15s,color .15s,background .15s}.nsp-legend-note.active{border-color:var(--color-primary);color:#fff;background:var(--color-primary)}.nsp-staff-wrapper{border:1px solid var(--color-border);border-radius:var(--radius);background:#111827;padding:.5rem;overflow-x:auto}.nsp-staff-area{position:relative;overflow:hidden}.nsp-vexflow{line-height:0;display:block}.nsp-vexflow svg{pointer-events:none;display:block}.nsp-note-btn{cursor:pointer;background:0 0;border:none;border-radius:50%;width:28px;height:24px;padding:0;transition:background .12s;position:absolute;transform:translate(-50%,-50%)}.nsp-note-btn:hover{background:#e9456040}.nsp-note-btn.active:hover{background:#e9456059}.nsp-empty{text-align:center;color:var(--color-text-muted);padding:2rem;font-size:.9rem}.nsp-hint{color:var(--color-text-muted);font-size:.8rem;font-style:italic}
