*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #0a0a0f;--surface: #14141f;--border: #2a2a3a;--text: #e0e0e8;--text-dim: #888;--accent: #ff6b35;--accent-dim: #663015}body{font-family:SF Mono,Fira Code,Consolas,monospace;background:var(--bg);color:var(--text);line-height:1.5;padding:1rem;max-width:1280px;margin:0 auto}header{text-align:center;margin-bottom:1.5rem}h1{font-size:1.4rem;font-weight:600;color:var(--accent)}.subtitle{font-size:.8rem;color:var(--text-dim);margin-top:.25rem}h2{font-size:.95rem;font-weight:600;margin-bottom:.75rem;color:var(--text)}h3{font-size:.85rem;font-weight:500;margin:.75rem 0 .5rem;color:var(--text-dim)}.panel{background:var(--surface);border:1px solid var(--border);border-radius:6px;padding:1rem;margin-bottom:1rem}.hidden{display:none!important}.source-mode{margin-bottom:.75rem;font-size:.8rem;color:var(--text-dim)}.source-mode input[type=checkbox]{accent-color:var(--accent);margin-right:.4rem}.drop-target{border:2px dashed var(--border);border-radius:6px;padding:2rem;text-align:center;cursor:pointer;transition:border-color .2s}.drop-target:hover,.drop-target.drag-over{border-color:var(--accent)}.drop-target p{font-size:.9rem}.file-label{color:var(--accent);cursor:pointer;text-decoration:underline}.hint{font-size:.75rem;color:var(--text-dim);margin-top:.5rem}#file-info,#structure-file-info{display:flex;align-items:center;gap:1rem;font-size:.85rem;margin-top:.5rem}#file-info span,#structure-file-info span{color:var(--text-dim)}#file-name,#structure-file-name{color:var(--accent)!important;font-weight:600}.dual{display:flex;gap:1rem}.drop-col{flex:1;min-width:0}.drop-col h3{margin-bottom:.5rem}.btn-small{padding:.1rem .5rem;font-size:.75rem;border-radius:3px}#corpus-file-list{margin-top:.5rem}.corpus-file-entry{display:flex;align-items:center;justify-content:space-between;font-size:.8rem;padding:.2rem .4rem;border-bottom:1px solid var(--border)}.corpus-file-entry span{color:var(--accent)}#corpus-summary{font-size:.75rem;color:var(--text-dim);margin-top:.3rem}.record-controls{display:flex;align-items:center;gap:.5rem;margin-top:.75rem}.record-status{font-size:.8rem;color:var(--text-dim)}.btn-record{border-color:#c33}.btn-record:hover:not(:disabled){color:#f44;border-color:#f44}.btn-record.recording{color:#f44;border-color:#f44;animation:pulse-record 1s infinite}@keyframes pulse-record{0%,to{opacity:1}50%{opacity:.6}}.btn-rerecord{border-color:#c93}.btn-rerecord:hover:not(:disabled){color:#fa3;border-color:#fa3}.corpus-manage{display:flex;gap:.5rem;margin-top:.5rem}.session-controls{display:flex;align-items:center;gap:.75rem;margin-top:.75rem;padding-top:.75rem;border-top:1px solid var(--border)}.session-upload-label{font-size:.85rem;padding:.4rem 1.2rem;border:1px solid var(--border);border-radius:4px;background:var(--surface);transition:all .15s}.session-upload-label:hover{border-color:var(--accent)}#session-status{font-size:.8rem;color:var(--text-dim)}.piano-tuner-row{display:flex;gap:0;margin-bottom:.5rem}.piano-tuner-row #piano-canvas{flex:1;min-width:0;height:90px;max-width:none}#note-display{width:90px;min-width:90px;height:90px;display:flex;flex-direction:column;align-items:center;justify-content:center;border:1px solid var(--border);border-radius:4px;background:var(--bg)}#note-letter{font-size:2rem;font-weight:700;line-height:1;color:var(--text-dim)}#note-cents{font-size:.65rem;color:var(--text-dim);margin-top:.2rem}#waveform-canvas{width:100%;height:200px;background:var(--bg);border-radius:4px;cursor:crosshair}#output-canvas{width:100%;height:150px;background:var(--bg);border-radius:4px;margin-top:.5rem}.waveform-controls{display:flex;gap:1.5rem;margin-top:.5rem;font-size:.8rem}.waveform-controls label{display:flex;align-items:center;gap:.5rem;color:var(--text-dim)}.controls-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}.control-group{display:flex;flex-direction:column;gap:.25rem}.control-group label{font-size:.8rem;color:var(--text-dim)}.control-group span{font-size:.75rem;color:var(--accent);text-align:right}input[type=range]{-webkit-appearance:none;appearance:none;width:100%;height:4px;background:var(--border);border-radius:2px;outline:none}input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:14px;height:14px;border-radius:50%;background:var(--accent);cursor:pointer}.transport{display:flex;gap:.5rem;margin-top:1rem}button{font-family:inherit;font-size:.85rem;padding:.4rem 1.2rem;border:1px solid var(--border);border-radius:4px;background:var(--surface);color:var(--text);cursor:pointer;transition:all .15s}button:hover:not(:disabled){border-color:var(--accent);color:var(--accent)}button:disabled{opacity:.4;cursor:not-allowed}button:active:not(:disabled){background:var(--accent-dim)}.viz-row{display:flex;gap:1.5rem;flex-wrap:wrap}.viz-col{min-width:300px}.viz-col-main{flex:2 1 600px}.viz-col-stats{flex:1 1 300px}#tonnetz-canvas{width:100%;height:520px;background:var(--bg);border-radius:4px}#piano-canvas{background:var(--bg);border-radius:4px;cursor:pointer}#histogram-canvas{width:100%;max-width:400px;background:var(--bg);border-radius:4px}#stats-panel{display:grid;grid-template-columns:1fr 1fr;gap:.3rem}.stat{font-size:.8rem}.stat-label{color:var(--text-dim)}.pitch-shift-control{display:flex;align-items:center;gap:.5rem;margin-top:.4rem;font-size:.8rem;color:var(--text-dim)}.pitch-shift-control input[type=range]{width:100px}.pitch-shift-control span{min-width:3em;color:var(--accent);font-size:.75rem}footer{text-align:center;padding:1.5rem 0;font-size:.75rem;color:var(--text-dim)}.loading{position:relative}.loading:after{content:"Processing...";position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:#0a0a0fd9;color:var(--accent);font-size:.9rem;border-radius:6px}
