:root{--bg: #050816;--panel: #0f1228;--panel-2: #181d3a;--panel-3: #232a4d;--accent: #22d3ee;--accent-2: #c084fc;--accent-glow: rgba(34, 211, 238, .35);--text: #ecf1ff;--text-dim: #7c8aaa;--border: #1f2647;--fn-T: #34d399;--fn-SD: #fbbf24;--fn-D: #f43f5e;--rec: #f43f5e}*{box-sizing:border-box}html,body{width:100%}body{margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:radial-gradient(ellipse at top left,#0d1230 0%,transparent 55%),radial-gradient(ellipse at bottom right,#1a0d30 0%,transparent 55%),var(--bg);background-attachment:fixed;color:var(--text);min-height:100vh;width:100vw;padding:14px;line-height:1.5}.container{max-width:none;width:100%;margin:0}.app-header{margin-bottom:14px;display:flex;align-items:baseline;gap:14px}h1{font-weight:700;margin:0;font-size:22px;letter-spacing:-.4px;background:linear-gradient(90deg,var(--accent),var(--accent-2));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.app-header-tag{color:var(--text-dim);font-size:11px;letter-spacing:.5px;text-transform:uppercase;font-family:ui-monospace,monospace;border:1px solid var(--border);padding:2px 8px;border-radius:4px}.main-grid{display:grid;grid-template-columns:7fr 3fr;gap:20px;align-items:start}.main-left{position:sticky;top:20px;height:calc(100vh - 40px);display:flex;flex-direction:column;gap:12px;min-width:0;overflow:hidden}.main-right{display:flex;flex-direction:column;gap:16px;min-width:0}.main-left-top{display:grid;grid-template-columns:1fr 1fr;gap:12px;flex:4 1 0;min-height:0}.main-left-top>*{min-width:0;min-height:0}.main-left-top>.panel{display:flex;flex-direction:column;min-height:0;overflow:hidden;padding:14px}.main-left-top h2{margin:0 0 8px;font-size:11px}.main-left-top .compare-help,.main-left-top .wheel-help{display:none}.main-left-top .wheel3d-container{flex:1 1 0;min-height:220px;height:auto;margin-bottom:6px}.main-left-top .mode-toggle{margin-top:6px}.main-left-top .mode-toggle button{padding:5px 14px;font-size:11px}.main-left-top .function-legend{margin-top:6px;gap:10px;font-size:10px}.wave-canvas-host{position:relative;width:100%;height:380px;margin-bottom:8px;border-radius:8px;border:1px solid var(--border);overflow:hidden;background:var(--bg)}.wave-canvas-host .wave-canvas{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;display:block;background:var(--bg);border:none;border-radius:0;margin:0}.main-left-top .wave-canvas-host{flex:1 1 0;min-height:220px;height:auto;margin-bottom:6px}.main-left>.chord-display-panel{flex:0 0 auto;padding:10px 14px}.main-left>.chord-display-panel h2{display:none}.main-left>.chord-display-panel .chord-info{display:flex;flex-direction:row;align-items:center;gap:12px;padding:0;background:transparent;margin:0}.main-left>.chord-display-panel .chord-name{font-size:18px;margin:0;white-space:nowrap;flex-shrink:0}.main-left>.chord-display-panel .chord-meta{margin:0;flex-shrink:0}.main-left>.chord-display-panel .notes-row{margin:0;flex:1 1 auto;justify-content:flex-start;flex-wrap:wrap;gap:4px}.main-left>.chord-display-panel .note-box{min-width:52px;padding:5px 7px}.main-left>.chord-display-panel .note-name{font-size:14px}.main-left>.chord-display-panel .note-freq{font-size:9px;margin-top:1px}.main-left>.chord-display-panel .note-label{display:none}.main-left>.chord-display-panel .note-tuning{display:none}.main-left>.chord-display-panel .chord-degree{display:none}.main-left>.chord-display-panel .chord-name-block{display:flex;flex-direction:column;align-items:flex-start;margin:0;flex-shrink:0;gap:1px}.main-left>.chord-display-panel .play-row{flex-shrink:0;flex-wrap:nowrap;gap:4px}.main-left>.chord-display-panel .play-btn{padding:6px 10px;font-size:11px;flex:0 0 auto}.main-left>.timeline-recorder{display:flex;flex-direction:column;flex:3 1 0;min-height:0;overflow:hidden;padding:12px 14px}.main-left>.timeline-recorder h2{margin:0 0 6px;font-size:11px;flex-shrink:0}.main-left>.timeline-recorder .compare-help{display:none}.main-left>.timeline-recorder .timeline-controls{margin-bottom:6px;flex-shrink:0;gap:4px}.main-left>.timeline-recorder .timeline-btn{padding:5px 9px;font-size:11px}.main-left>.timeline-recorder .timeline-zoom{padding:2px}.main-left>.timeline-recorder .timeline-zoom button{width:22px;height:22px;font-size:12px}.main-left>.timeline-recorder .timeline-zoom span{font-size:10px;min-width:40px;padding:0 4px}.main-left>.timeline-recorder .timeline-time{padding:4px 8px;font-size:11px}.main-left>.timeline-recorder .timeline-overview{position:relative;flex:1 1 0;min-height:60px;height:auto;margin-bottom:4px}.main-left>.timeline-recorder .timeline-canvas-overview{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%}.main-left>.timeline-recorder .timeline-detail{position:relative;flex:1.3 1 0;min-height:80px;margin-bottom:0}.main-left>.timeline-recorder .timeline-canvas-detail{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%}.section-spacer{margin:0}@media(max-width:1280px){.main-grid{grid-template-columns:1fr}.main-left{position:static;height:auto;overflow:visible}.main-left-top{flex:none}.main-left-top .wheel3d-container{height:460px;flex:none;min-height:0}.main-left-top .wave-canvas-host{height:380px;flex:none;min-height:0}.main-left-top .compare-help,.main-left-top .wheel-help{display:block}.main-left>.chord-display-panel{padding:20px}.main-left>.chord-display-panel h2{display:block}.main-left>.chord-display-panel .chord-info{display:block;background:var(--panel-2);padding:14px}.main-left>.chord-display-panel .chord-name{font-size:28px;margin-bottom:8px}.main-left>.chord-display-panel .chord-meta{margin-bottom:14px}.main-left>.chord-display-panel .notes-row{margin-bottom:14px}.main-left>.chord-display-panel .note-box{min-width:80px;padding:12px 14px}.main-left>.chord-display-panel .note-name{font-size:22px}.main-left>.chord-display-panel .note-freq{font-size:12px}.main-left>.chord-display-panel .note-label{display:block}.main-left>.chord-display-panel .play-row{flex-wrap:wrap;gap:6px}.main-left>.chord-display-panel .play-btn{padding:9px 12px;font-size:13px}.main-left>.timeline-recorder{display:block;padding:20px;flex:none;overflow:visible}.main-left>.timeline-recorder h2{margin-bottom:14px;font-size:12px}.main-left>.timeline-recorder .compare-help{display:block}.main-left>.timeline-recorder .timeline-overview{position:relative;height:auto;flex:none;min-height:0;margin-bottom:8px}.main-left>.timeline-recorder .timeline-canvas-overview{position:static;width:100%;height:130px}.main-left>.timeline-recorder .timeline-detail{position:relative;height:auto;flex:none;min-height:0}.main-left>.timeline-recorder .timeline-canvas-detail{position:static;width:100%;height:170px}}@media(max-width:820px){.main-left-top{grid-template-columns:1fr}}.panel{background:var(--panel);border:1px solid var(--border);border-radius:12px;padding:20px}.main-right .panel{padding:16px}.panel h2{margin:0 0 14px;font-size:12px;font-weight:600;color:var(--accent);text-transform:uppercase;letter-spacing:.8px}.freq-buttons{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:14px}.freq-btn{background:var(--panel-2);border:1px solid var(--border);color:var(--text);padding:8px 10px;border-radius:7px;cursor:pointer;font-size:12px;transition:all .15s;font-family:inherit;text-align:left;flex:1 1 90px;min-width:80px}.freq-btn:hover{border-color:var(--accent)}.freq-btn.active{background:var(--accent);color:var(--bg);border-color:var(--accent);font-weight:600}.freq-btn-label{display:block;font-size:10px;opacity:.7;margin-top:2px}.freq-slider{width:100%;margin:8px 0;accent-color:var(--accent)}.freq-display{font-size:24px;font-weight:700;text-align:center;color:var(--accent);margin:4px 0;font-variant-numeric:tabular-nums}.instrument-category-block{margin-bottom:12px}.instrument-category-label{font-size:10px;color:var(--accent-2);text-transform:uppercase;letter-spacing:.8px;margin-bottom:6px;font-weight:700}.instrument-list{display:flex;flex-direction:column;gap:4px;margin-bottom:4px}.instrument-btn{background:var(--panel-2);border:1px solid var(--border);color:var(--text);padding:7px 10px;border-radius:6px;cursor:pointer;font-family:inherit;text-align:left;transition:all .15s}.instrument-btn:hover{border-color:var(--accent)}.instrument-btn.active{background:var(--accent);color:var(--bg);border-color:var(--accent)}.instrument-row{display:flex;align-items:center;justify-content:space-between;gap:8px}.instrument-name{font-size:13px;font-weight:600}.instrument-tag{font-size:9px;background:var(--accent-2);color:var(--bg);padding:1px 6px;border-radius:3px;font-weight:700;letter-spacing:.5px}.instrument-btn.active .instrument-tag{background:var(--bg);color:var(--accent-2)}.instrument-desc{font-size:10px;margin-top:2px;opacity:.7}.instrument-btn.active .instrument-desc{opacity:.8}.instrument-section-label{font-size:10px;color:var(--text-dim);text-transform:uppercase;letter-spacing:.6px;margin:12px 0 6px}.instrument-loading{font-size:12px;color:var(--accent-2);text-align:center;padding:8px;background:var(--panel-2);border-radius:6px;margin-bottom:10px;animation:pulse 1.4s ease-in-out infinite}.piano-keyboard{width:100%;background:var(--bg);border:1px solid var(--border);border-radius:7px;padding:5px;margin:10px 0 12px}.piano-svg{width:100%;height:auto;display:block}.main-left>.chord-display-panel .piano-keyboard{display:none}.pedal-controls{display:flex;flex-direction:column;gap:10px}.pedal-row{display:flex;align-items:center;justify-content:space-between;gap:10px}.pedal-select{min-width:80px;flex:1}.pedal-octave{margin:0}.pedal-quick-set{display:flex;gap:6px}.pedal-quick-btn{background:var(--panel-2);border:1px solid var(--border);color:var(--text);padding:6px 10px;border-radius:6px;cursor:pointer;font-size:11px;font-family:inherit;font-weight:600;flex:1;transition:all .15s}.pedal-quick-btn:hover{border-color:var(--accent);color:var(--accent)}.pedal-current{display:flex;justify-content:space-between;align-items:baseline;padding:8px 12px;background:var(--bg);border:1px solid var(--border);border-radius:6px;font-family:ui-monospace,monospace}.pedal-current>span:first-child{font-size:18px;font-weight:700;color:var(--accent)}.pedal-hz{font-size:12px;color:var(--text-dim)}.pedal-toggle{background:var(--panel-2);border:1px solid var(--border);color:var(--text);padding:10px;border-radius:7px;cursor:pointer;font-family:inherit;font-size:13px;font-weight:600;transition:all .15s}.pedal-toggle:hover{border-color:var(--accent)}.pedal-toggle.active{background:var(--accent);color:var(--bg);border-color:var(--accent);box-shadow:0 0 14px #22d3ee66;animation:pulse 2s ease-in-out infinite}.prog-options{margin-bottom:10px;padding:8px 10px;background:var(--panel-2);border-radius:6px}.prog-checkbox{display:flex;align-items:center;gap:8px;cursor:pointer;font-size:12px;color:var(--text)}.prog-checkbox input{accent-color:var(--accent)}.prog-save-row{display:flex;gap:5px;margin-bottom:10px}.prog-name-input{flex:1;background:var(--bg);border:1px solid var(--border);color:var(--text);padding:7px 10px;border-radius:6px;font-family:inherit;font-size:12px;min-width:0}.prog-name-input:focus{outline:none;border-color:var(--accent)}.prog-save-row .play-btn{padding:7px 9px;font-size:11px;flex:0 1 auto}.prog-saved{margin-top:8px;padding-top:10px;border-top:1px solid var(--border)}.prog-saved-list{display:flex;flex-direction:column;gap:4px;max-height:200px;overflow-y:auto}.prog-saved-item{display:flex;gap:4px;align-items:stretch}.prog-saved-load{flex:1;background:var(--panel-2);border:1px solid var(--border);color:var(--text);padding:7px 10px;border-radius:6px;cursor:pointer;text-align:left;font-family:inherit;transition:all .15s}.prog-saved-load:hover{border-color:var(--accent)}.prog-saved-name{display:block;font-size:12px;font-weight:600}.prog-saved-meta{display:block;font-size:10px;color:var(--text-dim);margin-top:2px}.prog-saved-delete{background:var(--panel-2);border:1px solid var(--border);color:var(--text-dim);width:28px;border-radius:6px;cursor:pointer;font-family:inherit;font-size:14px}.prog-saved-delete:hover{background:var(--fn-D);color:#fff;border-color:var(--fn-D)}.advanced-cadence-card{position:relative;display:flex}.advanced-cadence-main{text-align:left;width:100%}.advanced-cadence-chords{display:flex;flex-wrap:wrap;gap:3px;margin-top:6px}@keyframes pulse{0%,to{opacity:.6}50%{opacity:1}}.wheel-panel{display:flex;flex-direction:column}.wheel3d-container{width:100%;height:460px;background:radial-gradient(ellipse at center,#1a2050,#050816 78%),var(--bg);border-radius:12px;overflow:hidden;position:relative;border:1px solid var(--border);margin-bottom:10px;touch-action:none;box-shadow:inset 0 0 60px #22d3ee0d}@media(max-width:980px){.wheel3d-container{height:380px}}.wheel3d-container canvas{display:block}.wave-controls{display:flex;gap:6px;justify-content:center;flex-wrap:wrap}.wave-btn{background:var(--panel-2);border:1px solid var(--border);color:var(--text-dim);padding:5px 11px;border-radius:6px;cursor:pointer;font-size:12px;font-family:inherit;transition:all .15s}.wave-btn:hover{border-color:var(--accent);color:var(--text)}.wave-btn.active{background:var(--bg);color:var(--accent);border-color:var(--accent)}.mode-select-row{display:flex;align-items:center;justify-content:center;gap:8px;margin-top:10px;flex-wrap:wrap}.mode-select-label{font-size:11px;color:var(--text-dim);text-transform:uppercase;letter-spacing:.6px;font-weight:600}.mode-select{background:var(--panel-2);border:1px solid var(--border);color:var(--text);padding:6px 10px;border-radius:6px;font-family:inherit;font-size:13px;font-weight:600;cursor:pointer;min-width:180px}.mode-select:focus{outline:none;border-color:var(--accent)}.key-sig-badge{font-family:ui-monospace,monospace;font-size:12px;font-weight:700;padding:4px 8px;border-radius:5px;background:var(--panel-2);border:1px solid var(--border)}.key-sig-badge.sharps{color:var(--accent);border-color:#22d3ee52}.key-sig-badge.flats{color:var(--accent-2);border-color:#c084fc52}.key-sig-badge.natural{color:var(--text-dim)}.function-legend{display:flex;flex-wrap:wrap;justify-content:center;gap:12px;margin-top:12px;font-size:11px;color:var(--text-dim)}.function-item{display:flex;align-items:center;gap:5px}.function-dot{width:9px;height:9px;border-radius:50%}.wheel-help{font-size:11px;color:var(--text-dim);text-align:center;margin:10px 0 0;line-height:1.5}.wheel-help strong{color:var(--text)}.chord-group-tabs{display:flex;gap:3px;margin-bottom:10px;background:var(--panel-2);padding:3px;border-radius:7px}.chord-group-tab{flex:1;background:transparent;border:none;color:var(--text-dim);padding:6px 4px;border-radius:5px;cursor:pointer;font-size:11px;font-family:inherit;font-weight:600;transition:all .15s}.chord-group-tab:hover{color:var(--text)}.chord-group-tab.active{background:var(--bg);color:var(--accent-2)}.chord-types{display:flex;flex-wrap:wrap;gap:5px;margin-bottom:14px}.chord-btn{background:var(--panel-2);border:1px solid var(--border);color:var(--text);padding:7px 11px;border-radius:6px;cursor:pointer;font-size:12px;transition:all .15s;font-family:inherit;font-variant-numeric:tabular-nums}.chord-btn:hover{border-color:var(--accent-2)}.chord-btn.active{background:var(--accent-2);color:var(--bg);border-color:var(--accent-2);font-weight:600}.inversion-section{margin-bottom:14px}.inversion-buttons{display:flex;gap:4px;background:var(--panel-2);padding:3px;border-radius:6px}.inversion-btn{flex:1;background:transparent;border:none;color:var(--text-dim);padding:6px;border-radius:4px;cursor:pointer;font-size:11px;font-family:inherit;font-weight:600;transition:all .15s}.inversion-btn:hover{color:var(--text)}.inversion-btn.active{background:var(--bg);color:var(--accent)}.chord-info{background:var(--panel-2);border-radius:8px;padding:14px}.chord-name{font-size:28px;font-weight:700;text-align:center;margin-bottom:6px;color:var(--accent)}.chord-meta{text-align:center;margin-bottom:12px;display:flex;justify-content:center;gap:8px;align-items:center}.chord-roman{font-size:16px;font-weight:700;color:var(--text-dim)}.notes-row{display:flex;justify-content:center;gap:6px;margin-bottom:14px;flex-wrap:wrap}.note-box{background:var(--bg);border:1px solid var(--border);border-radius:7px;padding:9px 10px;text-align:center;min-width:64px}.note-name{font-size:18px;font-weight:700;color:var(--accent)}.note-freq{font-size:11px;color:var(--text-dim);margin-top:2px;font-variant-numeric:tabular-nums}.note-label{font-size:9px;color:var(--text-dim);text-transform:uppercase;letter-spacing:.5px;margin-top:2px;opacity:.7}.note-tuning{display:flex;flex-direction:column;gap:1px;margin-top:4px;border-top:1px dashed var(--border);padding-top:4px}.note-ratio{font-size:9px;font-family:ui-monospace,monospace;color:var(--text-dim)}.note-cents{font-size:9px;font-family:ui-monospace,monospace;color:var(--accent-2);font-weight:700}.note-cents.small{color:var(--text-dim);font-weight:400;opacity:.6}.note-box.is-bass{border-color:var(--accent);box-shadow:0 0 0 1px #22d3ee2e}.note-box.is-bass .note-name{color:var(--accent)}.chord-degree{font-size:11px;color:var(--text-dim);font-style:italic}.chord-name-block{margin-bottom:14px;text-align:center}.tuning-legend{display:flex;flex-direction:column;gap:4px;margin-bottom:12px;font-size:11px;color:var(--text-dim);background:var(--panel-2);padding:10px 12px;border-radius:7px;border-left:3px solid var(--accent)}.tuning-legend-item strong{color:var(--text)}.tuning-table th{background:var(--panel-2)}.tuning-cell{display:flex;flex-direction:column;align-items:center;gap:1px}.tuning-hz{font-weight:600;color:var(--text);font-size:12px}.tuning-ratio{font-size:10px;color:var(--text-dim);font-family:ui-monospace,monospace}.tuning-cents{font-size:10px;font-family:ui-monospace,monospace;color:var(--text-dim);font-weight:600}.tuning-cents.big{color:var(--accent-2);font-weight:700}.tuning-cell-interval{font-size:11px;color:var(--text-dim);font-style:italic}.tuning-cell-eq{font-family:ui-monospace,monospace;color:var(--text)}.play-btn{background:var(--accent);color:var(--bg);border:none;padding:9px 12px;border-radius:7px;font-size:13px;font-weight:600;cursor:pointer;transition:all .15s;font-family:inherit;flex:1}.play-btn:hover{opacity:.9}.play-btn:active{transform:scale(.98)}.play-btn:disabled{opacity:.4;cursor:not-allowed}.play-row{display:flex;gap:6px;flex-wrap:wrap}.play-row .play-btn.secondary{background:var(--panel);color:var(--text);border:1px solid var(--border)}.octave-selector{display:flex;align-items:center;gap:10px;justify-content:center}.octave-btn{width:32px;height:32px;border-radius:50%;background:var(--panel-2);border:1px solid var(--border);color:var(--text);cursor:pointer;font-weight:600;font-size:16px;font-family:inherit}.octave-btn:hover{border-color:var(--accent)}.octave-label{color:var(--text-dim);font-size:13px}.octave-label strong{color:var(--text);font-size:16px;margin:0 4px}.waveform-toggle{display:flex;gap:3px;background:var(--panel-2);padding:3px;border-radius:6px}.waveform-toggle button{flex:1;background:transparent;border:none;color:var(--text-dim);padding:5px;border-radius:4px;cursor:pointer;font-size:11px;font-family:inherit;transition:all .15s}.waveform-toggle button.active{background:var(--bg);color:var(--accent)}.fn-chip,.fn-chip-mini{display:inline-flex;align-items:center;gap:4px;padding:2px 7px;border-radius:5px;font-weight:600;font-size:11px}.fn-chip-roman{font-size:10px;font-weight:700;opacity:.85}.fn-chip-name{font-size:10px}.fn-chip-mini{font-size:10px;padding:2px 5px}.fn-T{background:#34d39926;color:var(--fn-T);border:1px solid rgba(52,211,153,.32)}.fn-SD{background:#fbbf2426;color:var(--fn-SD);border:1px solid rgba(251,191,36,.32)}.fn-D{background:#f43f5e26;color:var(--fn-D);border:1px solid rgba(244,63,94,.32)}.fn-D-border{border-color:#f43f5e73!important}.cadence-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:8px}.cadence-card{position:relative;display:flex}.cadence-main{background:var(--panel-2);border:1px solid var(--border);color:var(--text);padding:10px;border-radius:7px;cursor:pointer;text-align:left;font-family:inherit;transition:all .15s;flex:1}.cadence-main:hover{border-color:var(--accent);transform:translateY(-1px)}.cadence-name{font-size:12px;font-weight:700;color:var(--text)}.cadence-desc{font-size:10px;color:var(--text-dim);margin:3px 0 8px;font-family:ui-monospace,monospace}.cadence-chords{display:flex;flex-wrap:wrap;gap:3px}.cadence-add{position:absolute;top:6px;right:6px;width:22px;height:22px;border-radius:50%;background:var(--bg);border:1px solid var(--border);color:var(--accent);cursor:pointer;font-size:15px;font-weight:700;line-height:1;font-family:inherit}.cadence-add:hover{background:var(--accent);color:var(--bg);border-color:var(--accent)}.related-list{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:8px}.related-btn{background:var(--panel-2);border:1px solid var(--border);color:var(--text);padding:10px;border-radius:7px;cursor:pointer;text-align:center;font-family:inherit;transition:all .15s}.related-btn:hover{border-color:var(--accent-2);transform:translateY(-1px)}.related-label{font-size:10px;color:var(--accent-2);text-transform:uppercase;letter-spacing:.5px;font-weight:600}.related-name{font-size:16px;font-weight:700;margin:3px 0;color:var(--accent)}.related-mode{font-size:11px;font-weight:500;color:var(--text);margin-left:3px}.related-desc{font-size:10px;color:var(--text-dim);font-style:italic}.related-shared{margin-top:6px;padding-top:6px;border-top:1px solid var(--border)}.related-shared-label{font-size:9px;color:var(--text-dim);text-transform:uppercase;letter-spacing:.5px;display:block;margin-bottom:3px}.related-shared-chords{display:flex;flex-wrap:wrap;gap:2px;justify-content:center}.progression-list{min-height:72px;background:var(--panel-2);border-radius:7px;padding:12px;margin-bottom:10px;display:flex;flex-wrap:wrap;gap:8px;align-items:center}.progression-empty{width:100%;text-align:center;color:var(--text-dim);font-size:12px;padding:6px}.progression-item{display:flex;flex-direction:column;align-items:center;gap:1px;padding:8px 12px;border-radius:7px;position:relative;min-width:64px}.progression-roman{font-size:15px;font-weight:800;line-height:1}.progression-name{font-size:11px;opacity:.9}.progression-remove{position:absolute;top:-5px;right:-5px;background:var(--bg);border:1px solid var(--border);color:var(--text);width:18px;height:18px;border-radius:50%;cursor:pointer;font-size:12px;line-height:1;display:flex;align-items:center;justify-content:center;padding:0;font-family:inherit}.progression-remove:hover{background:var(--fn-D);color:#fff;border-color:var(--fn-D)}.resources-section{margin-bottom:14px}.resources-section:last-child{margin-bottom:0}.resources-title{font-size:10px;color:var(--accent-2);text-transform:uppercase;letter-spacing:.7px;margin-bottom:8px;font-weight:600}.resources-list{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:6px}.resource-btn{background:var(--panel-2);border:1px solid var(--border);color:var(--text);padding:8px 10px;border-radius:6px;cursor:pointer;text-align:left;font-family:inherit;font-size:11px;transition:all .15s}.resource-btn:hover{border-color:var(--accent-2);transform:translateY(-1px)}.resource-label{font-size:10px;font-weight:700;color:var(--accent-2)}.resource-name{font-size:14px;color:var(--accent);font-weight:700;margin:3px 0}.resource-desc{font-size:10px;color:var(--text-dim);font-style:italic}.timeline-controls{display:flex;flex-wrap:wrap;gap:6px;align-items:center;margin-bottom:10px}.timeline-btn{background:var(--panel-2);border:1px solid var(--border);color:var(--text);padding:7px 13px;border-radius:6px;cursor:pointer;font-size:12px;font-weight:600;font-family:inherit;transition:all .15s}.timeline-btn:hover:not(:disabled){border-color:var(--accent)}.timeline-btn:disabled{opacity:.35;cursor:not-allowed}.timeline-btn.rec{background:var(--rec);color:#fff;border-color:var(--rec);animation:blink 1.2s ease-in-out infinite}.timeline-btn.ghost{background:transparent;color:var(--text-dim)}@keyframes blink{0%,to{opacity:1}50%{opacity:.6}}.timeline-zoom{display:flex;align-items:center;gap:4px;margin-left:auto;background:var(--panel-2);border:1px solid var(--border);border-radius:6px;padding:3px}.timeline-zoom button{background:transparent;border:none;color:var(--text);width:24px;height:24px;border-radius:4px;cursor:pointer;font-weight:700;font-family:inherit}.timeline-zoom button:hover{background:var(--bg)}.timeline-zoom span{font-size:11px;color:var(--text-dim);padding:0 6px;font-family:ui-monospace,monospace;min-width:50px;text-align:center}.timeline-time{font-family:ui-monospace,monospace;font-size:13px;color:var(--text);font-weight:600;background:var(--bg);border:1px solid var(--border);border-radius:6px;padding:6px 12px;display:flex;align-items:center;gap:6px}.rec-dot{color:var(--rec);animation:blink 1s ease-in-out infinite}.timeline-overview{width:100%;cursor:crosshair;border-radius:8px;overflow:hidden;border:1px solid var(--border);margin-bottom:8px}.timeline-canvas-overview{width:100%;height:130px;display:block}.timeline-detail{width:100%;border-radius:8px;overflow:hidden;border:1px solid var(--border)}.timeline-canvas-detail{width:100%;height:170px;display:block}table.compare{width:100%;border-collapse:collapse;font-size:13px;font-variant-numeric:tabular-nums}table.compare th,table.compare td{padding:9px;text-align:center;border-bottom:1px solid var(--border)}table.compare th{color:var(--text-dim);font-weight:500;font-size:11px;text-transform:uppercase;letter-spacing:.5px}table.compare tr:last-child td{border-bottom:none}table.compare td.highlight{color:var(--accent-2);font-weight:700}.compare-help{color:var(--text-dim);font-size:12px;margin:0 0 10px;line-height:1.5}.compare-help strong{color:var(--text)}.formula{font-family:ui-monospace,SF Mono,Monaco,monospace;background:var(--bg);padding:10px;border-radius:6px;font-size:11px;margin-top:14px;color:var(--text-dim);line-height:1.7}.experiment-container{max-width:1100px;margin:0 auto;padding:20px}.experiment-header{display:flex;align-items:center;gap:16px;margin-bottom:16px;padding-bottom:16px;border-bottom:1px solid var(--border)}.experiment-header h1{margin:0;font-size:22px;background:linear-gradient(90deg,var(--accent),var(--accent-2));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.experiment-back{background:var(--panel-2);border:1px solid var(--border);color:var(--text);padding:8px 14px;border-radius:7px;cursor:pointer;font-family:inherit;font-size:13px;font-weight:600}.experiment-back:hover{border-color:var(--accent);color:var(--accent)}.experiment-intro{color:var(--text-dim);font-size:13px;line-height:1.6;background:var(--panel);border:1px solid var(--border);border-left:3px solid var(--accent-2);border-radius:8px;padding:14px 18px;margin-bottom:20px}.experiment-intro strong{color:var(--accent-2)}.thx-presets{margin-bottom:20px}.thx-presets-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:8px;margin-bottom:10px}.thx-preset-card{background:var(--panel);border:1px solid var(--border);color:var(--text);padding:10px 12px;border-radius:8px;cursor:pointer;text-align:left;font-family:inherit;transition:all .15s}.thx-preset-card:hover{border-color:var(--accent);transform:translateY(-1px)}.thx-preset-card.active{border-color:var(--accent);background:linear-gradient(135deg,var(--panel) 0%,rgba(34,211,238,.08) 100%);box-shadow:0 0 14px #22d3ee33}.thx-preset-name{font-size:12px;font-weight:700;color:var(--accent);margin-bottom:4px}.thx-preset-card.active .thx-preset-name{color:var(--accent)}.thx-preset-short{font-size:11px;color:var(--text-dim);line-height:1.4}.thx-preset-detail{background:var(--panel);border:1px solid var(--border);border-left:3px solid var(--accent-2);border-radius:8px;padding:12px 16px;font-size:13px;color:var(--text);line-height:1.6}.thx-preset-detail strong{color:var(--accent-2)}.experiment-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:18px}@media(max-width:800px){.experiment-grid{grid-template-columns:1fr}}.thx-state-card{background:var(--panel);border:1px solid var(--border);border-radius:10px;padding:16px;display:flex;flex-direction:column;gap:10px}.thx-state-label{font-size:11px;color:var(--accent-2);text-transform:uppercase;letter-spacing:1px;font-weight:700}.thx-row{display:flex;align-items:center;justify-content:space-between;gap:10px}.thx-row-label{font-size:11px;color:var(--text-dim);text-transform:uppercase;letter-spacing:.6px;font-weight:600;flex-shrink:0;width:60px}.thx-row select,.thx-row .octave-selector{flex:1;background:var(--panel-2);border:1px solid var(--border);color:var(--text);padding:6px 8px;border-radius:6px;font-family:inherit;font-size:12px}.thx-row select:focus{outline:none;border-color:var(--accent)}.thx-notes{margin-top:8px;padding-top:10px;border-top:1px dashed var(--border);display:flex;flex-direction:column;gap:4px}.thx-note-row{display:grid;grid-template-columns:60px 1fr 60px;gap:8px;font-family:ui-monospace,monospace;font-size:12px}.thx-note-name{font-weight:700;color:var(--accent)}.thx-note-hz{color:var(--text);text-align:right}.thx-note-ratio{color:var(--text-dim);text-align:right;font-size:11px}.thx-analysis{margin-bottom:18px}.thx-analysis-table{background:var(--panel);border-radius:8px}.thx-analysis-table td{padding:6px 10px;font-family:ui-monospace,monospace;font-size:12px}.thx-arrow{color:var(--accent-2)}.thx-params{margin-bottom:16px}.thx-params-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;background:var(--panel);border:1px solid var(--border);border-radius:8px;padding:14px}@media(max-width:700px){.thx-params-grid{grid-template-columns:1fr}}.thx-param{display:grid;grid-template-columns:1fr auto;align-items:center;gap:8px}.thx-param span{font-size:11px;color:var(--text-dim);text-transform:uppercase;letter-spacing:.5px;font-weight:600;grid-column:1 / 3}.thx-param input[type=range]{width:100%;accent-color:var(--accent);grid-column:1}.thx-param strong{font-family:ui-monospace,monospace;font-size:13px;color:var(--accent);grid-column:2;min-width:50px;text-align:right}.thx-mode-grid{display:grid;grid-template-columns:1fr 1fr;gap:6px;margin-top:10px;padding-top:10px;border-top:1px dashed var(--border)}@media(max-width:700px){.thx-mode-grid{grid-template-columns:1fr}}.thx-mode-btn{background:var(--panel-2);border:1px solid var(--border);color:var(--text);padding:9px 11px;border-radius:7px;cursor:pointer;text-align:left;font-family:inherit;transition:all .15s}.thx-mode-btn:hover{border-color:var(--accent)}.thx-mode-btn.active{border-color:var(--accent);background:linear-gradient(135deg,var(--panel-2) 0%,rgba(34,211,238,.1) 100%);box-shadow:0 0 10px #22d3ee33}.thx-mode-name{font-size:12px;font-weight:700;color:var(--accent);margin-bottom:3px}.thx-mode-desc{font-size:10px;color:var(--text-dim);line-height:1.4}.thx-actions{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:18px}.thx-actions .play-btn{flex:1;min-width:130px}.thx-tracer{margin-bottom:20px}.thx-tracer-canvas{width:100%;height:320px;display:block;background:var(--bg);border:1px solid var(--border);border-radius:8px;margin-bottom:8px}.thx-tracer-help{font-size:12px;color:var(--text-dim);line-height:1.5;margin:0}.experiment-tabs{display:flex;gap:4px;margin-bottom:12px;flex-wrap:wrap;background:var(--panel);border:1px solid var(--border);border-radius:10px;padding:5px}.experiment-tab-btn{background:transparent;border:none;color:var(--text-dim);padding:9px 18px;border-radius:7px;cursor:pointer;font-family:inherit;font-size:13px;font-weight:600;transition:all .15s;flex:1;min-width:140px}.experiment-tab-btn:hover{color:var(--text);background:var(--panel-2)}.experiment-tab-btn.active{background:linear-gradient(135deg,var(--panel-2) 0%,rgba(34,211,238,.18) 100%);color:var(--accent);box-shadow:0 0 14px #22d3ee33}.experiment-tab-desc{color:var(--text-dim);font-size:12px;margin:0 0 16px;padding:6px 12px;background:var(--panel);border-left:3px solid var(--accent-2);border-radius:4px;font-style:italic}.tab-content{display:flex;flex-direction:column;gap:16px}.chain-presets{margin-bottom:8px}.chain-presets-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:8px;margin-bottom:10px}.chain-state-list{background:var(--panel);border:1px solid var(--border);border-radius:10px;padding:14px}.chain-state-list .instrument-section-label{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}.chain-add-btn{background:var(--panel-2);border:1px solid var(--border);color:var(--accent);padding:4px 10px;border-radius:5px;cursor:pointer;font-family:inherit;font-size:11px}.chain-add-btn:hover{background:var(--accent);color:var(--bg);border-color:var(--accent)}.chain-state-row{display:flex;gap:5px;align-items:center;padding:4px 6px;border-radius:5px;margin-bottom:3px;transition:background .15s}.chain-state-row.playing{background:#22d3ee1f;box-shadow:inset 0 0 0 1px var(--accent)}.chain-state-row select{background:var(--bg);border:1px solid var(--border);color:var(--text);padding:4px 6px;border-radius:4px;font-family:inherit;font-size:11px;flex:1;min-width:0}.chain-state-idx{font-family:ui-monospace,monospace;color:var(--text-dim);font-size:11px;font-weight:700;width:22px;text-align:center}.chain-remove-btn{background:transparent;border:1px solid var(--border);color:var(--text-dim);width:24px;height:24px;border-radius:4px;cursor:pointer;font-family:inherit;font-size:14px}.chain-remove-btn:hover{background:var(--fn-D);color:#fff;border-color:var(--fn-D)}.chain-analysis,.systems-chord-bar{background:var(--panel);border:1px solid var(--border);border-radius:10px;padding:14px}.systems-chord-bar .thx-row{flex-wrap:wrap}.systems-chord-bar select{background:var(--panel-2);border:1px solid var(--border);color:var(--text);padding:5px 8px;border-radius:5px;font-family:inherit;font-size:12px}.systems-section{background:var(--panel);border:1px solid var(--border);border-radius:10px;padding:16px}.systems-slider-wrap{display:flex;align-items:center;gap:12px;margin-bottom:12px;padding:10px;background:var(--panel-2);border-radius:8px}.systems-slider{flex:1;accent-color:var(--accent)}.systems-slider-label{font-size:12px;color:var(--text-dim);text-transform:uppercase;letter-spacing:.5px;font-weight:600}.systems-slider-readout{font-family:ui-monospace,monospace;font-size:15px;color:var(--accent);min-width:50px;text-align:right}.systems-temp-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:8px;margin-bottom:10px}.systems-temp-card{background:var(--panel-2);border:1px solid var(--border);color:var(--text);padding:10px 12px;border-radius:7px;cursor:pointer;text-align:left;font-family:inherit;transition:all .15s}.systems-temp-card:hover{border-color:var(--accent);transform:translateY(-1px)}.systems-temp-name{font-size:13px;font-weight:700;color:var(--accent);margin-bottom:2px}.systems-temp-period{font-size:9px;color:var(--accent-2);text-transform:uppercase;letter-spacing:.6px;margin-bottom:4px}.systems-temp-desc{font-size:10px;color:var(--text-dim);line-height:1.4}.systems-compare-controls{display:grid;grid-template-columns:1fr 1fr auto;gap:8px;margin-bottom:12px;align-items:end}.systems-compare-controls label{display:flex;flex-direction:column;gap:4px}.systems-compare-controls label span{font-size:10px;color:var(--text-dim);text-transform:uppercase;letter-spacing:.5px;font-weight:600}.systems-compare-controls select{background:var(--panel-2);border:1px solid var(--border);color:var(--text);padding:7px 10px;border-radius:6px;font-family:inherit;font-size:12px}.lab-meter-canvas{width:100%;height:180px;display:block;background:var(--bg);border:1px solid var(--border);border-radius:8px;margin-bottom:10px}.lab-spectrum-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:8px;margin-bottom:10px}.lab-curve-canvas{width:100%;height:220px;display:block;background:var(--bg);border:1px solid var(--border);border-radius:8px;margin-top:10px;margin-bottom:10px}.footer-experiments{display:flex;justify-content:center;margin-bottom:14px}.experiment-launch-btn{background:var(--panel);border:1px solid var(--accent);color:var(--accent);padding:10px 22px;border-radius:8px;font-family:inherit;font-size:13px;font-weight:700;cursor:pointer;letter-spacing:.3px;transition:all .2s;box-shadow:0 0 14px #22d3ee26}.experiment-launch-btn:hover{background:var(--accent);color:var(--bg);box-shadow:0 0 24px #22d3ee73;transform:translateY(-1px)}footer{text-align:center;color:var(--text-dim);font-size:11px;margin-top:28px;padding-top:14px;border-top:1px solid var(--border);line-height:1.8}footer kbd{background:var(--panel-2);border:1px solid var(--border);border-radius:4px;padding:2px 6px;font-family:ui-monospace,SF Mono,Monaco,monospace;font-size:10px;color:var(--text);margin:0 2px}.legend-T{color:var(--fn-T);font-weight:600}.legend-SD{color:var(--fn-SD);font-weight:600}.legend-D{color:var(--fn-D);font-weight:600}
