body{margin:0}:root{--bg:#08080f;--surface:#101018;--surface-2:#16161f;--border:#252532;--text:#e8eaed;--muted:#7a7f8e;--accent:#5efc82;--accent-dim:#22c55e;--white-key-width:34px;--black-key-width:20px;--keyboard-height:120px;--side-width:340px}*{box-sizing:border-box}html,body,#root{background:var(--bg);height:100%;color:var(--text);margin:0;font-family:system-ui,-apple-system,Segoe UI,sans-serif}.app{flex-direction:column;height:100%;display:flex;overflow:hidden}.header{background:var(--surface);border-bottom:1px solid var(--border);flex-shrink:0;align-items:center;gap:16px;padding:10px 16px;display:flex}.header-brand h1{color:var(--accent);letter-spacing:.02em;margin:0;font-size:1.1rem;font-weight:600}.subtitle{color:var(--muted);font-size:.7rem}.header-view-mode,.header-app-nav{flex-shrink:0}.view-mode-group button{padding:6px 14px;font-size:.78rem}.header-primary{flex:1;justify-content:center;display:flex}.header-actions{gap:4px;display:flex}.btn-group{background:var(--bg);border:1px solid var(--border);border-radius:8px;gap:2px;padding:2px;display:flex}.btn-group button,.btn-ghost,.chip{color:var(--muted);cursor:pointer;background:0 0;border:none;border-radius:6px;padding:6px 12px;font-size:.8rem;transition:background .15s,color .15s}.btn-group button:hover,.btn-ghost:hover,.chip:hover:not(:disabled){background:var(--surface-2);color:var(--text)}.btn-group button.active{color:var(--accent);box-shadow:inset 0 0 0 1px var(--accent-dim);background:#0d2818}.btn-ghost{padding:6px 10px}.chip{background:var(--surface-2);border:1px solid var(--border);color:var(--text);padding:5px 10px;font-size:.75rem}.chip-muted{color:var(--muted)}.chip-stop:not(:disabled){color:#fca5a5;border-color:#7f1d1d}.chip-stop:not(:disabled):hover{color:#fecaca;background:#2a0f0f}.chip:disabled{opacity:.4;cursor:default}.workspace{min-height:0;padding:12px;padding-bottom:calc(var(--keyboard-height) + 28px);flex:1;gap:12px;display:flex}.viz-column{flex-direction:column;flex:1;gap:8px;min-width:0;display:flex}.side-column{width:var(--side-width);flex-direction:column;flex-shrink:0;gap:8px;min-height:0;display:flex}@media (width<=960px){.workspace{flex-direction:column;overflow-y:auto}.side-column{width:100%}}.scope-panel{background:var(--surface);border:1px solid var(--border);border-radius:10px;flex-direction:column;flex:1;min-height:280px;display:flex;overflow:hidden}.scope-toolbar{border-bottom:1px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:center;gap:12px;padding:8px 12px;display:flex}.scope-toolbar-left{align-items:baseline;gap:12px;min-width:0;display:flex}.scope-label{color:var(--accent-dim);letter-spacing:.12em;flex-shrink:0;font-family:SF Mono,Consolas,monospace;font-size:.7rem}.scope-insight{color:var(--muted);white-space:nowrap;text-overflow:ellipsis;font-size:.75rem;overflow:hidden}.scope-toolbar-right{flex-shrink:0;align-items:center;gap:8px;display:flex}.scope-control-label{color:var(--muted);font-family:SF Mono,Consolas,monospace;font-size:.65rem}.scope-btn-group{background:0 0;border:none;padding:0}.scope-btn-group button{padding:4px 8px;font-family:SF Mono,Consolas,monospace;font-size:.75rem}.scope-display{background:#000;flex:1 1 0;min-height:0;padding:8px;position:relative;overflow:hidden}.scope-canvas{width:100%;height:100%;display:block}.progression-view{background:var(--surface);border:1px solid var(--border);border-radius:10px;flex-direction:column;flex:1;min-height:280px;display:flex;overflow:hidden}.progression-toolbar{border-bottom:1px solid var(--border);flex-wrap:wrap;flex-shrink:0;justify-content:space-between;align-items:center;gap:12px;padding:8px 12px;display:flex}.progression-toolbar-left{flex:1;align-items:baseline;gap:12px;min-width:0;display:flex}.progression-toolbar-right{flex-wrap:wrap;flex-shrink:0;align-items:center;gap:8px;display:flex}.align-toggle{margin-right:4px}.progression-actions-bar{border-bottom:1px solid var(--border);flex-wrap:wrap;flex-shrink:0;gap:6px;padding:8px 12px;display:flex}.progression-empty{color:var(--muted);text-align:center;flex-direction:column;flex:1;justify-content:center;align-items:center;padding:32px;display:flex}.progression-empty p{margin:0 0 12px;font-size:.9rem}.progression-empty ol{text-align:left;margin:0;padding-left:1.2rem;font-size:.85rem;line-height:1.8}.progression-strip{flex:1;align-items:stretch;gap:10px;min-height:220px;padding:12px;display:flex;overflow:auto hidden}.progression-strip>div{flex:none}.mini-scope-cell{border:1px solid var(--border);cursor:pointer;text-align:left;width:200px;height:100%;min-height:200px;color:var(--text);background:#020a04;border-radius:8px;flex-direction:column;padding:0;transition:border-color .15s,box-shadow .15s;display:flex;overflow:hidden}.mini-scope-cell:hover{border-color:var(--accent-dim)}.mini-scope-cell.active{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent-dim), 0 0 16px #22c55e26}.mini-scope-header{background:var(--surface-2);border-bottom:1px solid var(--border);flex-shrink:0;align-items:center;gap:8px;padding:6px 8px;display:flex}.mini-scope-index{color:var(--accent-dim);background:#0d2818;border-radius:4px;padding:2px 6px;font-family:SF Mono,Consolas,monospace;font-size:.65rem}.mini-scope-label{color:var(--accent);text-overflow:ellipsis;white-space:nowrap;font-size:.85rem;font-weight:600;overflow:hidden}.mini-scope-canvas-wrap{flex:1;min-height:0}.mini-scope-canvas-wrap canvas{width:100%;height:100%;display:block}.spectrum-compact{background:var(--surface);border:1px solid var(--border);border-radius:10px;flex-direction:column;flex-shrink:0;height:100px;display:flex;overflow:hidden}.spectrum-label{color:var(--accent-dim);letter-spacing:.1em;border-bottom:1px solid var(--border);padding:4px 12px;font-family:SF Mono,Consolas,monospace;font-size:.65rem}.spectrum-display{flex:1;min-height:0}.spectrum-display canvas{width:100%;height:100%;display:block}.chord-sidebar{background:var(--surface);border:1px solid var(--border);border-radius:10px;flex-shrink:0;padding:12px}.chord-header{justify-content:space-between;align-items:flex-start;margin-bottom:8px;display:flex}.chord-label{color:var(--muted);text-transform:uppercase;letter-spacing:.08em;font-size:.65rem}.chord-name{color:var(--accent);margin:2px 0 0;font-size:1.75rem;font-weight:600;line-height:1.1}.badge{color:var(--accent-dim);background:#0d2818;border:1px solid #1a4d2a;border-radius:999px;padding:3px 8px;font-size:.65rem}.chord-empty{color:var(--muted);margin:0;font-size:.8rem}.note-list{margin:0;padding:0;list-style:none}.note-list li{border-bottom:1px solid var(--border);grid-template-columns:1fr auto;gap:2px 8px;padding:6px 0;font-size:.8rem;display:grid}.note-list li:last-child{border-bottom:none}.note-list li.root .note-name{color:var(--accent)}.note-name{font-weight:500}.root-mark{color:var(--accent);background:#0d2818;border-radius:3px;margin-left:4px;padding:1px 4px;font-size:.6rem;display:inline-block}.note-hz{color:var(--muted);text-align:right;font-family:SF Mono,Consolas,monospace;font-size:.75rem}.note-degree,.note-ratio,.note-cents{color:var(--muted);font-family:SF Mono,Consolas,monospace;font-size:.7rem}.note-degree{grid-column:1}.note-ratio{text-align:right;grid-column:2}.note-cents{text-align:right;color:#f472b6;grid-column:2}.learning-panel,.progression-theory-panel{background:var(--surface);border:1px solid var(--border);border-radius:10px;flex:1;min-height:0;padding:12px;overflow-y:auto}.learning-panel-title{color:var(--muted);text-transform:uppercase;letter-spacing:.08em;margin:0 0 10px;font-size:.72rem;font-weight:500}.learning-block{margin-bottom:14px}.learning-block:last-child{margin-bottom:0}.learning-subtitle{color:var(--accent-dim);margin:0 0 6px;font-size:.75rem;font-weight:500}.learning-text{color:var(--text);margin:0 0 6px;font-size:.8rem;line-height:1.5}.learning-text:last-child{margin-bottom:0}.learning-table{margin-bottom:6px}.theory-key-row{align-items:center;gap:8px;margin-bottom:8px;display:flex}.theory-key-label{color:var(--muted);font-size:.7rem}.theory-key-value{color:var(--accent);font-size:1rem;font-weight:600}.theory-preset-badge{color:#a78bfa;background:#1a1a2e;border:1px solid #4c1d95;border-radius:999px;padding:2px 8px;font-size:.65rem}.theory-roman-line{color:var(--accent);word-break:break-word;margin:0 0 8px;font-family:SF Mono,Consolas,monospace;font-size:.85rem}.theory-step-cards{flex-direction:column;gap:8px;margin-top:12px;display:flex}.theory-step-card{background:var(--surface-2);border:1px solid var(--border);border-radius:8px;padding:8px 10px}.theory-step-header{align-items:center;gap:8px;margin-bottom:4px;display:flex}.theory-step-index{color:var(--accent-dim);background:#0d2818;border-radius:4px;padding:2px 6px;font-family:SF Mono,Consolas,monospace;font-size:.65rem}.theory-step-chord{color:var(--text);font-size:.85rem;font-weight:600}.theory-step-roman{color:var(--accent);margin-left:auto;font-family:SF Mono,Consolas,monospace;font-size:.75rem}.theory-fn-label{color:#a78bfa;font-size:.7rem;font-weight:500}.theory-fn-tip{color:var(--muted);margin:4px 0 0;font-size:.72rem;line-height:1.4}.tools-panel{background:var(--surface);border:1px solid var(--border);border-radius:10px;flex-direction:column;flex:0 42%;min-height:0;display:flex;overflow:hidden}.tab-bar{border-bottom:1px solid var(--border);flex-shrink:0;display:flex}.tab-bar button{color:var(--muted);cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;flex:1;padding:8px;font-size:.8rem}.tab-bar button.active{color:var(--accent);border-bottom-color:var(--accent-dim);background:#0a140d}.tab-content{flex:1;padding:10px;overflow-y:auto}.progression-library-list{flex-direction:column;gap:6px;max-height:280px;margin:0;padding:0;list-style:none;display:flex;overflow-y:auto}.progression-library-item{text-align:left;background:var(--surface-2);border:1px solid var(--border);cursor:pointer;width:100%;color:var(--text);border-radius:8px;flex-direction:column;gap:2px;padding:8px 10px;display:flex}.progression-library-item:hover{border-color:var(--accent-dim);background:#0a140d}.progression-library-name{color:var(--accent);font-size:.85rem;font-weight:600}.progression-library-numerals{color:var(--muted);font-family:SF Mono,Consolas,monospace;font-size:.7rem}.progression-library-desc{color:var(--muted);font-size:.7rem}.panel-section{margin-bottom:14px}.panel-section:last-child{margin-bottom:0}.panel-section-title{color:var(--muted);text-transform:uppercase;letter-spacing:.06em;margin:0 0 8px;font-size:.72rem;font-weight:500}.presets-tab .hint{margin:0 0 8px}.preset-chips{flex-wrap:wrap;gap:6px;display:flex}.degree-builder-compact .root-slider{color:var(--muted);flex-direction:column;gap:4px;margin-bottom:10px;font-size:.8rem;display:flex}.degree-builder-compact input[type=range]{width:100%;accent-color:var(--accent-dim)}.progression-compact .progression-actions{gap:6px;margin-bottom:8px;display:flex}.progression-steps{flex-wrap:wrap;gap:6px;display:flex}.step{background:var(--surface-2);border:1px solid var(--border);border-radius:6px;align-items:center;display:flex}.step.active{border-color:var(--accent-dim)}.step-label{color:var(--text);cursor:pointer;background:0 0;border:none;padding:5px 10px;font-size:.8rem}.step-remove{color:var(--muted);cursor:pointer;background:0 0;border:none;padding:2px 6px}.analysis-stack{flex-direction:column;gap:12px;display:flex}.analysis-block h3{color:var(--muted);margin:0 0 6px;font-size:.75rem;font-weight:500}.data-table{border-collapse:collapse;width:100%;font-size:.72rem}.data-table th,.data-table td{text-align:left;border-bottom:1px solid var(--border);padding:4px 6px}.data-table th{color:var(--muted);font-weight:500}.data-table tr.highlight td{color:#f472b6}.hint{color:var(--muted);margin:0;font-size:.75rem}.drawer-overlay{z-index:50;background:#0009;justify-content:flex-end;display:flex;position:fixed;inset:0}.settings-drawer{background:var(--surface);border-left:1px solid var(--border);width:300px;max-width:90vw;height:100%;padding:16px;overflow-y:auto}.drawer-header{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.drawer-header h2{margin:0;font-size:1rem}.icon-btn{color:var(--muted);cursor:pointer;background:0 0;border:none;padding:4px 8px;font-size:1.25rem}.drawer-section{margin-bottom:20px}.drawer-section h3{color:var(--muted);text-transform:uppercase;letter-spacing:.06em;margin:0 0 8px;font-size:.75rem}.drawer-row{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;gap:12px;padding:8px 0;font-size:.85rem;display:flex}.drawer-btn-group{width:100%}.drawer-btn-group button{flex:1}.num-input{background:var(--bg);border:1px solid var(--border);width:72px;color:var(--text);border-radius:4px;padding:4px 6px}select{background:var(--bg);border:1px solid var(--border);color:var(--text);border-radius:4px;padding:4px 6px;font-size:.8rem}.keyboard-container{background:var(--surface);border-top:1px solid var(--border);z-index:10;position:fixed;bottom:0;left:0;right:0}.keyboard-toolbar{color:var(--muted);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:8px;padding:4px 12px;font-size:.65rem;display:flex}.keyboard-body{align-items:stretch;gap:10px;padding:0 8px 6px;display:flex}.keyboard-toolbar-left{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.scale-toggle{cursor:pointer;color:var(--text);align-items:center;gap:4px;display:inline-flex}.scale-toggle input{accent-color:var(--accent-dim)}.scale-notes-preview{text-overflow:ellipsis;white-space:nowrap;color:#60a5fa;max-width:200px;font-size:.6rem;overflow:hidden}.keyboard-shift{align-items:center;gap:6px;display:flex}.keyboard-shift button{background:var(--surface-2);border:1px solid var(--border);color:var(--text);cursor:pointer;border-radius:4px;padding:2px 6px;font-size:.65rem}.keyboard-clear{align-items:center;gap:4px;display:inline-flex}.keyboard-clear:disabled{opacity:.4;cursor:default}.keyboard-clear-count{color:var(--accent);background:#0d2818;border-radius:3px;padding:0 4px;font-family:SF Mono,Consolas,monospace;font-size:.6rem}.piano-wrapper{min-width:0;height:var(--keyboard-height);flex:1;position:relative;overflow-x:auto}.piano-white-row{min-width:max-content;height:100%;display:flex}.piano-black-row{pointer-events:none;height:58%;position:absolute;top:0;left:0;right:0}.key{cursor:pointer;border:1px solid #444;padding:0;position:relative}.key.white{width:var(--white-key-width);background:linear-gradient(#e8eaed,#b0b5bf);border-radius:0 0 3px 3px;justify-content:center;align-items:flex-end;height:100%;padding-bottom:3px;display:flex}.key.black{width:var(--black-key-width);pointer-events:auto;z-index:2;background:linear-gradient(#2a2a35,#0a0a0f);border-radius:0 0 2px 2px;height:58%;position:absolute}.key.selected.white{background:linear-gradient(#86efac,#22c55e)}.key.selected.black{background:linear-gradient(#4ade80,#15803d)}.key.root.white{box-shadow:inset 0 -3px #ea580c}.key.root.black{box-shadow:inset 0 -2px #fb923c}.key-label{color:#444;font-size:.5rem}.key.selected .key-label{color:#052e16}.key.in-scale.white:not(.selected){background:linear-gradient(#dbeafe,#93c5fd)}.key.in-scale.black:not(.selected){background:linear-gradient(#1e3a5f,#1e40af)}.scale-degree{color:#1d4ed8;pointer-events:none;font-family:SF Mono,Consolas,monospace;font-size:.45rem;font-weight:600;position:absolute;top:3px;left:50%;transform:translate(-50%)}.key.black .scale-degree{color:#bfdbfe}.key.onboarding-hint{animation:1.6s ease-in-out infinite onboarding-pulse;box-shadow:0 0 0 2px #fbbf24,0 0 12px #fbbf2473}.keyboard-onboarding{box-shadow:0 -4px 24px #fbbf2426}@keyframes onboarding-pulse{0%,to{box-shadow:0 0 0 2px #fbbf24,0 0 8px #fbbf2459}50%{box-shadow:0 0 0 3px #fbbf24,0 0 16px #fbbf248c}}.learn-main{flex:1;min-height:0;padding:16px;overflow-y:auto}.learn-hub-header h2{color:var(--accent);margin:0 0 8px;font-size:1.35rem}.learn-hub-intro{color:var(--muted);max-width:720px;margin:0 0 24px;line-height:1.6}.learn-hub-intro strong{color:var(--text)}.learn-levels{grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:16px;max-width:1200px;display:grid}.learn-level-card{background:var(--surface);border:1px solid var(--border);border-radius:12px;flex-direction:column;gap:8px;padding:16px;display:flex}.learn-level-beginner{border-top:3px solid #34d399}.learn-level-intermediate{border-top:3px solid #60a5fa}.learn-level-advanced{border-top:3px solid #a78bfa}.learn-level-header{justify-content:space-between;align-items:baseline;gap:8px;display:flex}.learn-level-header h3{margin:0;font-size:1.05rem}.learn-level-count{color:var(--muted);font-size:.72rem}.learn-level-desc{color:var(--muted);margin:0;font-size:.82rem;line-height:1.5}.learn-article-list{flex-direction:column;gap:6px;margin:8px 0 0;padding:0;list-style:none;display:flex}.learn-article-link{text-align:left;border:1px solid var(--border);background:var(--surface-2);cursor:pointer;width:100%;color:var(--text);border-radius:8px;padding:10px 12px;transition:border-color .15s,background .15s}.learn-article-link:hover{border-color:var(--accent-dim);background:#0d2818}.learn-article-title{margin-bottom:4px;font-size:.88rem;font-weight:600;display:block}.learn-article-meta{color:var(--muted);font-size:.72rem;line-height:1.4;display:block}.learn-article{max-width:720px;margin:0 auto;padding-bottom:32px}.learn-back-btn{color:var(--muted);cursor:pointer;background:0 0;border:none;margin-bottom:16px;padding:4px 0;font-size:.85rem}.learn-back-btn:hover{color:var(--accent)}.learn-article-header h2{margin:8px 0;font-size:1.4rem;line-height:1.35}.learn-level-badge{border-radius:4px;padding:3px 8px;font-size:.7rem;font-weight:600;display:inline-block}.learn-level-badge.learn-level-beginner{color:#34d399;background:#0d2818}.learn-level-badge.learn-level-intermediate{color:#60a5fa;background:#0f1a2e}.learn-level-badge.learn-level-advanced{color:#a78bfa;background:#1a0f2e}.learn-article-summary{color:var(--muted);margin:0 0 8px;line-height:1.6}.learn-read-time{color:var(--muted);font-size:.75rem}.learn-section{margin-top:28px}.learn-section h3{color:var(--text);margin:0 0 10px;font-size:1rem}.learn-section p{color:#c8cad0;margin:0 0 12px;font-size:.92rem;line-height:1.7}.learn-freq-box{border:1px solid #1a4d2e;border-left:3px solid var(--accent);background:#0d1a14;border-radius:8px;margin:16px 0;padding:12px 14px}.learn-freq-label{color:var(--accent);letter-spacing:.04em;margin-bottom:6px;font-size:.7rem;font-weight:600;display:block}.learn-freq-box p{color:#b8dcc4;margin:0;font-size:.85rem}.learn-try-box{background:var(--surface);border:1px solid var(--border);border-radius:10px;margin-top:32px;padding:16px}.learn-try-label{color:#fbbf24;margin-bottom:8px;font-size:.72rem;font-weight:600;display:block}.learn-try-box p{color:var(--muted);margin:0 0 12px;font-size:.88rem;line-height:1.5}.learn-try-btn{width:100%}@media (width<=960px){.learn-levels{grid-template-columns:1fr}}.onboarding-overlay{z-index:100;background:#000000bf;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.onboarding-card{background:var(--surface);border:1px solid var(--border);border-radius:12px;max-width:420px;margin:16px;padding:24px;box-shadow:0 16px 48px #00000080}.onboarding-card h2{margin-top:0;font-size:1.1rem}.onboarding-progress{gap:6px;margin:16px 0 0;display:flex}.onboarding-dot{background:var(--border);border-radius:50%;width:8px;height:8px}.onboarding-dot.active{background:var(--accent);box-shadow:0 0 6px #5efc8280}.onboarding-dot.done{background:var(--accent-dim)}.onboarding-actions{justify-content:flex-end;gap:8px;margin-top:16px;display:flex}.btn-primary,.btn-secondary{border:1px solid var(--border);background:var(--surface-2);color:var(--text);cursor:pointer;border-radius:6px;padding:8px 14px;font-size:.85rem}.btn-primary{border-color:var(--accent-dim);color:var(--accent);background:#0d2818}.cof-nav{background:var(--surface-2);border:1px solid var(--border);border-radius:8px;flex-direction:column;flex-shrink:0;gap:4px;width:148px;padding:4px 6px 2px;display:flex}.cof-header{flex-direction:column;gap:2px;display:flex}.cof-title{color:var(--muted);letter-spacing:.04em;font-size:.6rem}.cof-key-meta{color:var(--text);font-size:.72rem;font-weight:600}.cof-sig{color:#60a5fa;margin-left:6px;font-size:.6rem;font-weight:400}.cof-wheel-wrap{width:136px;height:136px;margin:0 auto;position:relative}.cof-svg{width:100%;height:100%}.cof-ring-guide{fill:none;stroke:var(--border);stroke-width:1px}.cof-ring-guide.inner{stroke-dasharray:3 4;opacity:.7}.cof-keys{position:absolute;inset:0}.cof-key{border:1px solid var(--border);background:var(--bg);color:var(--muted);cursor:pointer;border-radius:999px;justify-content:center;align-items:center;padding:0;line-height:1;display:inline-flex;position:absolute;transform:translate(-50%,-50%)}.cof-key.major{width:22px;height:22px;font-size:.52rem;font-weight:600}.cof-key.minor{opacity:.85;width:18px;height:18px;font-size:.45rem}.cof-key:hover{border-color:var(--accent-dim);color:var(--text)}.cof-key.active{border-color:var(--accent);color:var(--accent);background:#0d2818;box-shadow:0 0 8px #22c55e59}.cof-key.highlight{color:#93c5fd;background:#0f1a2e;border-color:#60a5fa}.cof-actions{flex-wrap:wrap;gap:4px;display:flex}.cof-step-btn,.cof-fifth-btn{border:1px solid var(--border);background:var(--bg);min-width:0;color:var(--muted);cursor:pointer;border-radius:4px;flex:auto;padding:3px 4px;font-size:.55rem}.cof-fifth-btn{color:#fbbf24;border-color:#854d0e;flex-basis:100%}.cof-step-btn:hover,.cof-fifth-btn:hover{color:var(--text);border-color:var(--accent-dim)}.cof-hint{color:var(--muted);margin:0;font-size:.55rem;line-height:1.3}.cof-progression-hint{margin-top:6px}.score-main-wrap{flex:1;min-height:0;overflow:hidden}.score-workspace{gap:12px;height:100%;min-height:0;padding:12px;display:flex}.score-main{flex-direction:column;flex:1;gap:12px;min-width:0;min-height:0;display:flex;overflow-y:auto}.score-panel{background:var(--surface);border:1px solid var(--border);border-radius:10px;flex-shrink:0;padding:12px}.score-preset-bar{flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:12px;display:flex}.score-preset-label{color:var(--muted);font-size:.72rem;font-weight:600}.score-preset-chips{flex-wrap:wrap;gap:6px;display:flex}.score-preset-chips button{border:1px solid var(--border);background:var(--surface-2);color:var(--muted);cursor:pointer;border-radius:6px;padding:5px 10px;font-size:.78rem}.score-preset-chips button:hover{border-color:var(--accent-dim);color:var(--text)}.score-preset-chips button.active{border-color:var(--accent);color:var(--accent);background:#0d2818}.score-notation-wrap{overflow-x:auto}.score-notation-header h2{color:var(--text);margin:0 0 4px;font-size:1rem}.score-notation-meta{color:var(--muted);margin:0 0 8px;font-size:.75rem}.score-notation-canvas{min-height:220px}.score-notation-canvas svg{display:block}.score-notation-hint{color:var(--muted);margin:8px 0 0;font-size:.72rem}.score-controls{border-top:1px solid var(--border);flex-wrap:wrap;align-items:center;gap:12px;margin-top:12px;padding-top:12px;display:flex}.score-playback{align-items:center;gap:8px;display:flex}.score-silence-btn{color:#fca5a5;border-color:#7f1d1d}.score-silence-btn:hover{color:#fecaca;border-color:#ef4444}.score-measure-nav{align-items:center;gap:8px;display:flex}.score-measure-indicator{color:var(--text);text-align:center;min-width:90px;font-size:.82rem;font-weight:600}.score-focus-group{margin-left:auto}.score-editor{border-top:1px solid var(--border);margin-top:12px;padding-top:12px}.score-editor-title{color:var(--text);margin:0 0 12px;font-size:.9rem}.score-editor-section{margin-bottom:16px}.score-editor-section h4{color:var(--muted);letter-spacing:.04em;margin:0 0 8px;font-size:.78rem}.score-editor-section-header{justify-content:space-between;align-items:center;gap:8px;margin-bottom:8px;display:flex}.score-editor-section-header h4{margin:0}.score-editor-slider{color:var(--muted);flex-direction:column;gap:4px;margin-bottom:10px;font-size:.8rem;display:flex}.score-editor-slider input[type=range]{width:100%}.score-editor-chips{flex-wrap:wrap;gap:6px;margin-bottom:8px;display:flex}.score-editor-chips .chip{border:1px solid var(--border);background:var(--surface-2);color:var(--muted);cursor:pointer;border-radius:6px;padding:4px 10px;font-size:.75rem}.score-editor-chips .chip:hover{border-color:var(--accent-dim);color:var(--text)}.score-editor-chips .chip.active{border-color:var(--accent);color:var(--accent);background:#0d2818}.score-editor-intervals{margin-top:8px}.score-editor-sublabel{color:var(--muted);margin-bottom:6px;font-size:.72rem;display:block}.score-editor-chord-result{color:var(--text);margin:8px 0 0;font-size:.82rem}.score-editor-chord-result strong{color:var(--accent)}.score-editor-chord-notes{color:var(--muted);margin-top:4px;font-family:ui-monospace,monospace;font-size:.75rem;display:block}.score-beat-total{font-size:.72rem;font-weight:600}.score-beat-total.ok{color:var(--accent-dim)}.score-beat-total.warn{color:#fbbf24}.score-melody-list{flex-direction:column;gap:6px;margin:0 0 8px;padding:0;list-style:none;display:flex}.score-melody-list li{border:1px solid var(--border);background:var(--bg);border-radius:8px;align-items:center;gap:8px;padding:6px 8px;display:flex}.score-melody-list li.active{background:#0f1a2e;border-color:#60a5fa}.score-melody-select{color:var(--text);cursor:pointer;text-align:left;background:0 0;border:none;flex:0 0 72px;padding:0;font-family:ui-monospace,monospace;font-size:.85rem;font-weight:600}.score-melody-select:hover{color:#93c5fd}.score-melody-controls{align-items:center;gap:4px;margin-left:auto;display:flex}.score-melody-controls select{border:1px solid var(--border);background:var(--surface-2);color:var(--text);border-radius:4px;padding:3px 4px;font-size:.72rem}.btn-icon{border:1px solid var(--border);background:var(--surface-2);width:28px;height:28px;color:var(--text);cursor:pointer;border-radius:4px;padding:0;font-size:.9rem;line-height:1}.btn-icon:hover{border-color:var(--accent-dim)}.btn-icon.danger:hover{color:#fca5a5;border-color:#ef4444}.score-add-note{width:100%}.score-editor-hint{color:var(--muted);margin:8px 0 0;font-size:.72rem}.score-editor-hint.warn{color:#fbbf24}.score-melody-picker{flex-wrap:wrap;align-items:center;gap:10px;margin-top:10px;display:flex}.score-melody-label{color:var(--muted);font-size:.72rem;font-weight:600}.score-melody-chips{flex-wrap:wrap;gap:6px;display:flex}.score-melody-chips button{border:1px solid var(--border);background:var(--bg);color:var(--muted);cursor:pointer;border-radius:999px;padding:4px 10px;font-family:ui-monospace,monospace;font-size:.78rem}.score-melody-chips button:hover{color:#93c5fd;border-color:#60a5fa}.score-melody-chips button.active{color:#93c5fd;background:#0f1a2e;border-color:#60a5fa}.score-viz{flex-direction:column;flex:none;gap:8px;height:clamp(240px,36vh,380px);max-height:380px;display:flex;overflow:hidden}.score-viz-top .scope-panel,.score-viz-top .scope-display{flex:1 1 0;min-height:0}.score-viz-top .spectrum-compact{flex:0 0 96px;height:96px}.score-notation-interactive{cursor:crosshair}.score-input-toolbar{border-bottom:1px solid var(--border);flex-wrap:wrap;align-items:flex-end;gap:12px;margin-bottom:12px;padding-bottom:12px;display:flex}.score-input-group{flex-direction:column;gap:6px;display:flex}.score-input-label{color:var(--muted);font-size:.72rem;font-weight:600}.score-duration-buttons{gap:6px;display:flex}.score-duration-buttons button{border:1px solid var(--border);background:var(--surface-2);color:var(--muted);cursor:pointer;border-radius:6px;flex-direction:column;align-items:center;gap:2px;min-width:44px;padding:4px 8px;display:flex}.score-duration-buttons button:hover{border-color:var(--accent-dim);color:var(--text)}.score-duration-buttons button.active{color:#93c5fd;background:#0f1a2e;border-color:#60a5fa}.score-duration-glyph{font-size:1.1rem;line-height:1}.score-duration-name{font-size:.62rem}.score-delete-btn{margin-left:auto}.score-sidebar{width:var(--side-width);flex-direction:column;flex-shrink:0;gap:12px;min-height:0;display:flex;overflow-y:auto}.score-analysis-card{background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:12px}.score-analysis-card h3{color:var(--muted);letter-spacing:.04em;margin:0 0 10px;font-size:.85rem}.score-analysis-dl{gap:8px;margin:0;display:grid}.score-analysis-dl div{grid-template-columns:72px 1fr;gap:8px;font-size:.82rem;display:grid}.score-analysis-dl dt{color:var(--muted);margin:0}.score-analysis-dl dd{color:var(--text);margin:0;font-weight:500}.score-analysis-desc{color:var(--muted);margin:12px 0 0;font-size:.78rem;line-height:1.5}.btn-accent{border:1px solid var(--accent-dim);color:var(--accent);cursor:pointer;background:#0d2818;border-radius:6px;padding:6px 14px;font-size:.82rem}.btn-accent:hover{background:#0f3320}@media (width<=960px){.score-workspace{flex-direction:column;overflow-y:auto}.score-sidebar{width:100%}.score-focus-group{margin-left:0}}
