:root{--color-primary: #2563eb;--color-primary-hover: #1d4ed8;--color-success: #16a34a;--color-danger: #dc2626;--color-danger-hover: #b91c1c;--color-bg: #fafafa;--color-text: #1a1a1a;--color-text-muted: #888;--color-text-secondary: #555;--color-text-label: #555;--color-border: #e5e7eb;--color-surface: #fff;--color-surface-alt: #f3f4f6;--color-error-bg: #fef2f2;--color-error-border: #fecaca;--color-badge-bg: #dcfce7;--color-badge-text: #166534;--radius-sm: 6px;--radius-md: 8px;--radius-pill: 999px}@media(prefers-color-scheme:dark){:root{--color-bg: #0f0f0f;--color-text: #e5e5e5;--color-text-muted: #888;--color-text-secondary: #aaa;--color-text-label: #aaa;--color-border: #333;--color-surface: #1a1a1a;--color-surface-alt: #1a1a1a;--color-error-bg: #1f0a0a;--color-error-border: #5c1a1a;--color-badge-bg: #052e16;--color-badge-text: #86efac;--color-primary: #3b82f6;--color-primary-hover: #2563eb;--color-danger: #f87171;--color-danger-hover: #ef4444}}*,*:before,*:after{box-sizing:border-box}body{margin:0;background:var(--color-bg);color:var(--color-text);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.btn{padding:.65rem 1.75rem;font-size:1rem;border:none;border-radius:var(--radius-md);cursor:pointer;font-weight:500;transition:background .2s,opacity .2s}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary{background:var(--color-primary);color:#fff}.btn-primary:hover:not(:disabled){background:var(--color-primary-hover)}.btn-lg{padding:.75rem 2rem;font-size:1.1rem}.hint{color:var(--color-text-muted);font-size:.9rem}.error{color:var(--color-danger);background:var(--color-error-bg);border:1px solid var(--color-error-border);border-radius:var(--radius-sm);padding:.5rem 1rem;font-size:.9rem}.good{color:var(--color-success)}.warn{color:var(--color-danger);font-weight:600}.settings-table{width:100%;border-collapse:collapse;font-size:.9rem}.settings-table th,.settings-table td{text-align:left;padding:.4rem .75rem;border-bottom:1px solid var(--color-border)}.settings-table th{font-weight:600;color:var(--color-text-label);font-size:.8rem;text-transform:uppercase;letter-spacing:.04em}.settings-panel{width:100%;margin-top:1.5rem}.settings-panel h2,.settings-panel h3{font-size:1rem;margin:0 0 .25rem}.settings-note{font-size:.8rem;color:var(--color-text-muted);margin:0 0 .75rem}.audio-setup{width:100%}.audio-setup h2{font-size:1.3rem;margin:0 0 1rem}.setup-step{display:flex;flex-direction:column;align-items:center;gap:.75rem}.permission-badge{display:inline-flex;align-items:center;gap:.4rem;padding:.35rem .75rem;border-radius:var(--radius-pill);font-size:.85rem;font-weight:500;background:var(--color-badge-bg);color:var(--color-badge-text);margin:0 0 1rem}.setup-field{margin-bottom:1.25rem}.setup-field label{display:block;font-size:.85rem;font-weight:600;color:var(--color-text-label);margin-bottom:.35rem;text-transform:uppercase;letter-spacing:.04em}.setup-field select{width:100%;padding:.5rem .75rem;font-size:.95rem;border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-surface);color:var(--color-text);cursor:pointer;-webkit-appearance:auto;-moz-appearance:auto;appearance:auto}.setup-field select:focus{outline:2px solid var(--color-primary);outline-offset:1px}.audio-setup .settings-panel{margin-top:0}.audio-setup .settings-panel h3{font-size:1rem;margin:0 0 .25rem}.setup-proceed{margin-top:1.5rem;text-align:center}.ir-plot{margin-top:1.5rem}.ir-plot h3{font-size:1.1rem;margin:0 0 .25rem;color:var(--color-text)}.ir-plot-subtitle{font-size:.8rem;color:var(--color-text-muted);margin:0 0 .75rem}.ir-waveform{position:relative;display:flex;gap:1px;height:120px;width:100%;background:var(--color-surface-alt);border-radius:var(--radius-sm);padding:4px}.ir-bar-col{flex:1;display:flex;align-items:flex-end;min-width:0;height:50%;align-self:flex-start}.ir-bar-col:has(.ir-bar-neg){align-items:flex-start;align-self:flex-end}.ir-bar{width:100%;min-height:.5px;border-radius:1px}.ir-bar-pos{background:var(--color-primary)}.ir-bar-neg{background:var(--color-danger)}.ir-zero-line{position:absolute;top:50%;left:4px;right:4px;height:1px;background:var(--color-text-muted);opacity:.3;pointer-events:none}.ir-time-axis{display:flex;justify-content:space-between;font-size:.7rem;color:var(--color-text-muted);margin-top:.25rem;margin-bottom:.75rem;padding:0 4px}.ir-stats{margin-top:0}.fr-chart{margin-top:1.5rem;width:100%}.fr-chart-header{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:.5rem;margin-bottom:.5rem}.fr-chart-header h3{font-size:1.1rem;margin:0;color:var(--color-text)}.fr-controls{display:flex;gap:.75rem;align-items:center}.fr-control{display:flex;align-items:center;gap:.35rem;font-size:.8rem;color:var(--color-text-muted)}.fr-control select{font-size:.8rem;padding:.2rem .4rem;border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-surface);color:var(--color-text);cursor:pointer}.fr-canvas{display:block;width:100%;border-radius:var(--radius-sm);cursor:crosshair}.fr-readout{text-align:center;font-size:.85rem;font-weight:600;color:var(--color-text-secondary);margin-top:.35rem;font-variant-numeric:tabular-nums}.fr-legend{display:flex;flex-wrap:wrap;gap:.5rem 1rem;align-items:center;margin-top:.5rem;padding:.5rem .75rem;background:var(--color-surface-alt);border-radius:var(--radius-sm);font-size:.75rem;color:var(--color-text-muted)}.fr-legend-item{display:inline-flex;align-items:center;gap:.35rem;white-space:nowrap}.fr-legend-swatch{display:inline-block;width:16px;height:3px;border-radius:1px;flex-shrink:0}.fr-legend-swatch--line{background:var(--color-primary)}.fr-legend-tag{padding:.15rem .4rem;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:.7rem}.fr-legend-tag--active{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.resonance-list{margin-top:1.5rem;width:100%}.resonance-list h3{font-size:1.1rem;margin:0 0 .5rem;color:var(--color-text)}.resonance-empty{color:var(--color-text-muted);font-size:.9rem}.resonance-table{width:100%;border-collapse:collapse;font-size:.85rem;font-variant-numeric:tabular-nums}.resonance-table th{text-align:left;font-weight:600;color:var(--color-text-muted);padding:.4rem .6rem;border-bottom:2px solid var(--color-border);white-space:nowrap}.resonance-table td{padding:.4rem .6rem;border-bottom:1px solid var(--color-border)}.resonance-row{cursor:pointer;transition:background-color .15s ease,box-shadow .15s ease;outline:none}.resonance-row:hover{background-color:var(--color-surface-alt)}.resonance-row:focus-visible{box-shadow:inset 0 0 0 2px var(--color-primary)}.resonance-row--selected{background-color:var(--color-primary-light, rgba(37, 99, 235, .1));font-weight:600}.resonance-row--selected td{color:var(--color-primary, #2563eb)}.resonance-rank{width:2rem;text-align:center;color:var(--color-text-muted)}.resonance-freq{font-weight:600;white-space:nowrap}.resonance-db{white-space:nowrap}.resonance-prom{white-space:nowrap;color:var(--color-text-muted)}.resonance-band{white-space:nowrap}.resonance-play{width:3.5rem;text-align:center}.resonance-play-btn{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;padding:0;font-size:.7rem;border-radius:50%;background:var(--color-surface-alt);color:var(--color-text-muted);border:1px solid var(--color-border);cursor:pointer;transition:background-color .15s ease,color .15s ease,border-color .15s ease}.resonance-play-btn:hover{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.resonance-play-btn--active{background:var(--color-danger, #ef4444);color:#fff;border-color:var(--color-danger, #ef4444);animation:pulse-play 1s ease-in-out infinite}@keyframes pulse-play{0%,to{opacity:1}50%{opacity:.7}}.resonance-tip{margin-top:.75rem;font-size:.8rem;line-height:1.5;color:var(--color-text-muted)}.resonance-clear{margin-top:.5rem}.calibration-upload{display:flex;align-items:center;gap:.6rem;flex-wrap:wrap;margin-bottom:.75rem}.calibration-badge{display:inline-block;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;padding:.2rem .5rem;border-radius:var(--radius-sm);background:var(--color-surface-alt);color:var(--color-text-muted);border:1px solid var(--color-border)}.calibration-badge--active{background:var(--color-success-bg, #dcfce7);color:var(--color-success, #15803d);border-color:var(--color-success, #15803d)}.calibration-info{display:flex;align-items:center;gap:.4rem;font-size:.85rem}.calibration-filename{font-weight:500;color:var(--color-text);max-width:180px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.calibration-points{color:var(--color-text-muted);font-size:.8rem}.calibration-clear{margin-left:.25rem}.calibration-label{cursor:pointer}.calibration-input{display:none}.rt60-display{margin-top:1.5rem;width:100%}.rt60-display h3{font-size:1.1rem;margin:0 0 .75rem;color:var(--color-text)}.rt60-empty{color:var(--color-text-muted);font-size:.9rem}.rt60-cards{display:flex;flex-wrap:wrap;gap:.75rem}.rt60-card{display:flex;flex-direction:column;gap:.2rem;padding:.75rem 1rem;background:var(--color-surface-alt);border:1px solid var(--color-border);border-radius:var(--radius-sm);min-width:130px}.rt60-card--primary{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.rt60-card--primary .rt60-label{color:#fffc}.rt60-card--primary .rt60-hint{color:#ffffffb3}.rt60-label{font-size:.7rem;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-muted);font-weight:600}.rt60-value{font-size:1.5rem;font-weight:700;font-variant-numeric:tabular-nums;line-height:1.2}.rt60-hint{font-size:.75rem;color:var(--color-text-muted)}.export-toolbar{display:flex;flex-wrap:wrap;align-items:center;gap:.5rem;margin-top:1.25rem;padding:.6rem .75rem;background:var(--color-surface-alt);border:1px solid var(--color-border);border-radius:var(--radius-sm)}.export-label{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-muted);margin-right:.25rem}.export-btn{font-size:.78rem;padding:.3rem .6rem}.waterfall-chart{margin-top:1.5rem;width:100%}.waterfall-header{display:flex;align-items:baseline;gap:.5rem;margin-bottom:.5rem}.waterfall-header h3{font-size:1.1rem;margin:0;color:var(--color-text)}.waterfall-subtitle{font-size:.8rem;color:var(--color-text-muted)}.waterfall-canvas{display:block;width:100%;border-radius:var(--radius-sm);border:1px solid #1e2030}.waterfall-explain{margin-top:.5rem;font-size:.8rem;line-height:1.5;color:var(--color-text-muted)}.measurement-panel{width:100%}.measurement-panel h2{font-size:1.3rem;margin:0 0 1rem}.sweep-duration-control{display:flex;align-items:center;gap:.5rem;font-size:.85rem;color:var(--color-text-muted);margin-bottom:.75rem}.sweep-duration-control select{font-size:.85rem;padding:.25rem .5rem;border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-surface);color:var(--color-text);cursor:pointer}.measurement-controls{display:flex;flex-direction:column;align-items:center;gap:.75rem;margin-bottom:1.25rem}.measurement-panel .countdown{display:flex;flex-direction:column;align-items:center;gap:.25rem}.measurement-panel .countdown-number{font-size:4rem;font-weight:700;line-height:1;color:var(--color-primary);font-variant-numeric:tabular-nums}.measurement-panel .countdown-label{font-size:.9rem;color:var(--color-text-muted);margin:0}.measurement-active{display:flex;flex-direction:column;align-items:center;gap:.75rem;width:100%;max-width:400px}.phase-indicator{display:inline-flex;align-items:center;gap:.5rem;font-size:1rem;font-weight:500}.playing-dot{width:10px;height:10px;border-radius:50%;background:var(--color-primary);animation:pulse 1s ease-in-out infinite}.recording-dot{width:10px;height:10px;border-radius:50%;background:var(--color-danger);animation:pulse 1s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.3}}.phase-label{color:var(--color-text)}.btn-measure{background:var(--color-primary);color:#fff;padding:.75rem 2rem;font-size:1.1rem}.btn-measure:hover:not(:disabled){background:var(--color-primary-hover)}.level-meter{width:100%}.level-meter-track{position:relative;width:100%;height:16px;background:var(--color-surface-alt);border-radius:var(--radius-sm);overflow:hidden}.level-meter-rms{position:absolute;top:0;left:0;height:100%;background:var(--color-success);transition:width .05s linear;border-radius:var(--radius-sm)}.level-meter-rms.level-clipping{background:var(--color-danger)}.level-meter-peak{position:absolute;top:0;width:2px;height:100%;background:var(--color-text);transition:left .05s linear}.level-meter-labels{display:flex;justify-content:space-between;font-size:.75rem;color:var(--color-text-muted);margin-top:.25rem}.clipping-warning{text-align:center;font-weight:600}.measurement-result{margin-top:.5rem}.measurement-result h3{font-size:1.1rem;margin:0 0 .75rem;color:var(--color-success)}.measurement-result .waveform{display:flex;align-items:flex-end;gap:1px;height:80px;width:100%;background:var(--color-surface-alt);border-radius:var(--radius-sm);padding:4px;margin-bottom:1rem}.measurement-result .waveform-bar{flex:1;min-height:1px;background:var(--color-primary);border-radius:1px}.measurement-stats{margin-top:0}.app{max-width:640px;margin:0 auto;padding:2rem 1rem;min-height:100vh;display:flex;flex-direction:column;font-family:system-ui,-apple-system,sans-serif}.header{text-align:center;margin-bottom:2rem}.header h1{font-size:2.4rem;margin:0;letter-spacing:-.02em}.subtitle{color:var(--color-text-muted);margin:.25rem 0 0;font-size:1.1rem}.range{color:var(--color-text-secondary);font-size:.9rem;margin-top:.5rem;font-variant-numeric:tabular-nums}.main{flex:1;display:flex;flex-direction:column;align-items:center;gap:1rem}.landing{display:flex;flex-direction:column;align-items:center;gap:1rem;text-align:center;max-width:440px}.landing-intro{color:var(--color-text-secondary);font-size:.95rem;line-height:1.55;margin:0}.footer{text-align:center;margin-top:3rem;padding-top:1rem;border-top:1px solid var(--color-border);font-size:.8rem;color:var(--color-text-muted)}.footer a{color:var(--color-primary);text-decoration:none}.footer a:hover{text-decoration:underline}
