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:300px}*{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{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: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;min-height:240px;padding:8px}.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}.tools-panel{background:var(--surface);border:1px solid var(--border);border-radius:10px;flex-direction:column;flex:1;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);justify-content:space-between;align-items:center;padding:2px 12px;font-size:.65rem;display:flex}.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{height:var(--keyboard-height);padding:0 8px 6px;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:8px;right:8px}.key{cursor:pointer;border:1px solid #444;padding:0}.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}.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:400px;margin:16px;padding:24px}.onboarding-card h2{margin-top:0;font-size:1.1rem}.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}
