body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}:root{--bg:#0d0d1a;--surface:#1a1a2e;--surface2:#222240;--border:#2a2a4a;--text:#e0e0f0;--text-dim:#88a;--accent:#60a5fa}*{box-sizing:border-box;margin:0;padding:0}body{background:#0d0d1a;background:var(--bg);color:#e0e0f0;color:var(--text);font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;font-size:14px;line-height:1.5}.app{margin:0 auto;max-width:1100px;padding:16px 24px}.loading{align-items:center;color:#88a;color:var(--text-dim);display:flex;justify-content:center;min-height:60vh}.top-bar{align-items:baseline;border-bottom:1px solid #2a2a4a;border-bottom:1px solid var(--border);display:flex;gap:16px;margin-bottom:16px;padding-bottom:12px}.logo{font-family:Zalando Sans Expanded,sans-serif;font-size:22px;font-weight:500;letter-spacing:.5px}.file-name{color:#88a;color:var(--text-dim);font-family:SF Mono,Fira Code,monospace;font-size:13px}.voice-type{background:#222240;background:var(--surface2);border-radius:4px;color:#60a5fa;color:var(--accent);font-size:11px;letter-spacing:.5px;padding:2px 8px;text-transform:uppercase}.frame-count{font-size:12px;margin-left:auto}.frame-count,.record-btn{color:#88a;color:var(--text-dim)}.record-btn{align-items:center;background:#0000;border:1px solid #2a2a4a;border:1px solid var(--border);border-radius:50%;cursor:pointer;display:flex;height:32px;justify-content:center;padding:0;transition:all .15s;width:32px}.record-btn:hover{background:#222240;background:var(--surface2);border-color:#60a5fa;border-color:var(--accent)}.record-btn.recording{animation:pulse-record 1s infinite;background:#dc2626;border-color:#dc2626;color:#fff}@keyframes pulse-record{0%,to{opacity:1}50%{opacity:.7}}.record-btn:disabled{cursor:default;opacity:.3}.waveform-container{background:#1a1a2e;background:var(--surface);border:1px solid #2a2a4a;border:1px solid var(--border);border-radius:10px;margin-bottom:8px;padding:12px 0}.waveform-controls{gap:12px;margin-bottom:8px;padding-left:16px;padding-right:16px}.play-btn,.waveform-controls{align-items:center;display:flex}.play-btn{background:#60a5fa;background:var(--accent);border:none;border-radius:50%;color:#fff;cursor:pointer;font-size:14px;height:36px;justify-content:center;transition:background .15s;width:36px}.play-btn:hover{background:#3b82f6}.control-btn{align-items:center;background:#0000;border:1px solid #2a2a4a;border:1px solid var(--border);border-radius:50%;color:#88a;color:var(--text-dim);cursor:pointer;display:flex;height:32px;justify-content:center;padding:0;transition:all .15s;width:32px}.control-btn:hover{background:#222240;background:var(--surface2);border-color:#60a5fa;border-color:var(--accent);color:#e0e0f0;color:var(--text)}.control-btn.recording{animation:pulse-record 1s infinite;background:#dc2626;border-color:#dc2626;color:#fff}.control-btn:disabled{cursor:default;opacity:.3}.waveform-filename{color:#88a;color:var(--text-dim);font-family:SF Mono,Fira Code,monospace;font-size:11px;max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.waveform-spacer{flex:1 1}.waveform-time{font-size:11px;white-space:nowrap}.time-display,.waveform-time{color:#88a;color:var(--text-dim);font-family:SF Mono,Fira Code,monospace}.time-display{font-size:13px}.waveform-empty{align-items:center;border-top:1px solid #2a2a4a;border-top:1px solid var(--border);color:#88a;color:var(--text-dim);display:flex;font-size:12px;height:80px;justify-content:center}.waveform-canvas{border-radius:6px;cursor:pointer;display:block;height:80px;width:100%}.piano-roll-container{background:#1a1a2e;background:var(--surface);border:1px solid #2a2a4a;border:1px solid var(--border);border-radius:10px;margin-bottom:8px;overflow:hidden}.piano-roll-canvas{cursor:pointer;display:block;height:200px;width:100%}.shape-legend{display:flex;gap:16px;margin-bottom:16px;padding:0 4px}.legend-item{align-items:center;color:#88a;color:var(--text-dim);display:flex;font-size:12px;gap:5px}.legend-dot{border-radius:50%;height:10px;width:10px}.legend-gradient{border-radius:5px;height:10px;width:80px}.analysis-panels{display:flex;gap:8px;margin-bottom:8px}.vowel-chart-container{background:#1a1a2e;background:var(--surface);border:1px solid #2a2a4a;border:1px solid var(--border);border-radius:10px;flex:0 0 300px;overflow:hidden}.vowel-chart-header{align-items:center;display:flex;justify-content:space-between;padding:6px 8px 4px}.vowel-chart-title{color:#88a;color:var(--text-dim);font-size:10px;letter-spacing:.3px}.vowel-tabs{background:#0d0d1a;background:var(--bg);border-radius:6px;display:flex;gap:1px;padding:2px}.vowel-tab{background:#0000;border:none;border-radius:4px;color:#88a;color:var(--text-dim);cursor:pointer;font-size:10px;letter-spacing:.3px;padding:3px 10px;transition:all .15s}.vowel-tab.active{background:#2a2a4a;background:var(--border)}.vowel-tab.active,.vowel-tab:hover:not(.active){color:#e0e0f0;color:var(--text)}.analysis-tab-content{display:flex;height:100%}.analysis-tab-placeholder{color:#88a;color:var(--text-dim);font-size:12px;margin:auto}.vowel-chart-controls{align-items:center;display:flex;gap:4px}.ruler-toggle-btn{align-items:center;background:#0000;border:1px solid #2a2a4a;border:1px solid var(--border);border-radius:50%;color:#88a;color:var(--text-dim);cursor:pointer;display:flex;height:22px;justify-content:center;padding:0;width:22px}.ruler-toggle-btn.active,.ruler-toggle-btn:hover{background:#222240;background:var(--surface2);border-color:#60a5fa;border-color:var(--accent)}.ruler-toggle-btn.active{color:#60a5fa;color:var(--accent)}.vt-dropdown{align-items:center;background:#222240;background:var(--surface2);border:1px solid #2a2a4a;border:1px solid var(--border);border-radius:4px;color:#88a;color:var(--text-dim);cursor:pointer;display:flex;font-size:10px;gap:4px;padding:3px 8px;position:relative;text-transform:capitalize}.vt-dropdown:hover{border-color:#60a5fa;border-color:var(--accent)}.vt-dropdown-label{min-width:50px}.vt-dropdown-arrow{color:#88a;color:var(--text-dim);font-size:7px}.vt-dropdown-menu{background:#1a1a2e;background:var(--surface);border:1px solid #2a2a4a;border:1px solid var(--border);border-radius:6px;box-shadow:0 4px 12px #0006;margin-top:2px;min-width:100%;overflow:hidden;position:absolute;right:0;top:100%;z-index:10}.vt-dropdown-item{color:#88a;color:var(--text-dim);cursor:pointer;font-size:11px;padding:5px 10px;text-transform:capitalize}.vt-dropdown-item:hover{background:#222240;background:var(--surface2);color:#e0e0f0;color:var(--text)}.vt-dropdown-item.active{color:#60a5fa;color:var(--accent)}.vowel-chart-canvas{display:block;height:250px;width:100%}.spectrogram-container{background:#1a1a2e;background:var(--surface);border:1px solid #2a2a4a;border:1px solid var(--border);border-radius:10px;flex:1 1;min-width:0;overflow:hidden}.spectrogram-canvas{display:block;height:280px;width:100%}.harmonic-bars-container{background:#1a1a2e;background:var(--surface);border:1px solid #2a2a4a;border:1px solid var(--border);border-radius:10px;flex:1 1;min-width:0;overflow:hidden;position:relative}.spectrum-toolbar{display:flex;gap:4px;padding:4px 8px;position:absolute;right:0;top:0;z-index:1}.spectrum-btn{background:#0000;border:1px solid #2a2a4a;border:1px solid var(--border);border-radius:4px;color:#88a;color:var(--text-dim);cursor:pointer;font-size:10px;padding:2px 8px}.spectrum-btn:hover{background:#222240;background:var(--surface2);color:#e0e0f0;color:var(--text)}.spectrum-btn.active{background:#60a5fa;background:var(--accent);border-color:#60a5fa;border-color:var(--accent);color:#fff}.spectrum-btn.cassette-btn:hover{background:#60a5fa0d;border-color:#60a5fa;border-color:var(--accent);color:#60a5fa;color:var(--accent)}.cassette-fade-in{animation:cassetteFadeIn .3s ease-out}@keyframes cassetteFadeIn{0%{opacity:0;transform:scale(.8)}to{opacity:1;transform:scale(1)}}.live-saved-toast{animation:toastFade 2s ease-out forwards;color:#88a;color:var(--text-dim);font-size:11px;padding:2px 8px}@keyframes toastFade{0%{opacity:0;transform:translateX(-4px)}15%{opacity:1;transform:translateX(0)}70%{opacity:1}to{opacity:0}}.spectrum-btn.live-active{animation:pulse-record 1.5s infinite;background:#facc15;border-color:#facc15;color:#000}.spectrum-btn:disabled{cursor:default;opacity:.3}.spectrum-btn.filter-x{border-color:#4a2a2a;color:#f87171;font-size:12px;padding:2px 5px}.spectrum-btn.filter-x:hover{background:#2a1a1a}.harmonic-bars-canvas{display:block;height:280px;width:100%}.lane{margin-bottom:16px;position:relative}.lane-empty{padding:24px}.lane-header{align-items:center;background:#222240;background:var(--surface2);border-bottom:1px solid #2a2a4a;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;padding:4px 8px}.lane-title{font-family:SF Mono,Fira Code,monospace;font-size:11px}.lane-delete,.lane-title{color:#88a;color:var(--text-dim)}.lane-delete{align-items:center;background:#0000;border:1px solid #2a2a4a;border:1px solid var(--border);border-radius:50%;cursor:pointer;display:flex;height:24px;justify-content:center;opacity:.4;padding:0;position:absolute;right:-32px;top:8px;transition:opacity .15s;width:24px}.lane:hover .lane-delete{opacity:.7}.lane-delete:hover{background:#f871711a;border-color:#f87171;color:#f87171}.lane-remove{background:none;border:none;color:#88a;color:var(--text-dim);cursor:pointer;font-size:16px;line-height:1;padding:0 4px}.lane-remove:hover{color:#f87171}.lane-upload-prompt{align-items:center;display:flex;flex-direction:column;gap:8px;padding:24px}.lane-upload-prompt .control-btn{display:inline-flex}.add-lane-btn{background:#0000;border:2px dashed #2a2a4a;border:2px dashed var(--border);border-radius:10px;color:#88a;color:var(--text-dim);cursor:pointer;font-size:13px;margin-bottom:16px;padding:12px;transition:all .15s;width:100%}.add-lane-btn:hover{background:#60a5fa0d;border-color:#60a5fa;border-color:var(--accent);color:#60a5fa;color:var(--accent)}.hint{color:#88a;color:var(--text-dim);font-size:13px;padding:24px;text-align:center}.note-detail{animation:slideIn .15s ease-out;background:#1a1a2e;background:var(--surface);border:1px solid #2a2a4a;border:1px solid var(--border);border-radius:10px;border-top:3px solid;padding:20px}@keyframes slideIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.nd-header{align-items:baseline;display:flex;gap:12px;margin-bottom:16px}.nd-note-name{font-size:28px;font-weight:700;letter-spacing:-1px}.nd-shape{font-size:14px;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.nd-time{font-family:SF Mono,Fira Code,monospace}.nd-conf,.nd-time{color:#88a;color:var(--text-dim);font-size:12px}.nd-conf{margin-left:auto}.nd-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(auto-fill,minmax(110px,1fr));margin-bottom:16px}.nd-metric{display:flex;flex-direction:column;gap:1px}.nd-label{color:#88a;color:var(--text-dim);font-size:10px;letter-spacing:.5px;text-transform:uppercase}.nd-value{font-size:16px;font-weight:500}.nd-unit{color:#88a;color:var(--text-dim);font-size:11px}.nd-harmonics{margin-bottom:16px}.h-bars{align-items:stretch;display:flex;gap:6px;margin-top:6px}.h-bar-col{align-items:center;display:flex;flex:1 1;flex-direction:column}.h-bar-area{align-items:flex-end;display:flex;height:70px;justify-content:center;width:100%}.h-bar{border-radius:3px 3px 0 0;max-width:28px;transition:height .2s;width:100%}.h-label{margin-top:3px}.h-label,.h-val{color:#88a;color:var(--text-dim);font-size:10px;line-height:1}.nd-evidence{border-radius:8px;font-size:12px;margin-bottom:8px;padding:10px 14px}.nd-evidence.converging{background:#0d2818;border:1px solid #1a4a2e}.nd-evidence.conflicting{background:#2a1a0d;border:1px solid #4a2a0d}.ev-title{display:block;font-size:10px;font-weight:600;letter-spacing:.5px;margin-bottom:4px;text-transform:uppercase}.nd-evidence.converging .ev-title{color:#4ade80}.nd-evidence.conflicting .ev-title{color:#fbbf24}.ev-line{color:#e0e0f0;color:var(--text);display:block;font-family:SF Mono,Fira Code,monospace;font-size:11px;padding:1px 0}.nd-flags{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}.flag-tag{background:#2a1a1a;border:1px solid #4a2a2a;border-radius:4px;color:#f87171;display:inline-block;font-family:SF Mono,Fira Code,monospace;font-size:11px;padding:2px 8px}
/*# sourceMappingURL=main.be5fa168.css.map*/