:root{--color-primary: #e53e3e;--color-primary-hover: #c53030;--color-primary-glow: rgba(229, 62, 62, .35);--color-success: #38a169;--color-danger: #e53e3e;--color-danger-hover: #c53030;--color-bg: #f8f8fa;--color-text: #1a1a1f;--color-text-muted: #6b6b80;--color-text-secondary: #4a4a5a;--color-text-label: #4a4a5a;--color-border: #d8d8e0;--color-surface: #ffffff;--color-surface-alt: #f0f0f4;--color-error-bg: #fef2f2;--color-error-border: #fecaca;--color-badge-bg: #fef2f2;--color-badge-text: #b91c1c;--color-success-bg: #fef2f2;--radius-sm: 6px;--radius-md: 8px;--radius-pill: 999px;--font-mono: "SF Mono", "Fira Code", "JetBrains Mono", "Cascadia Code", monospace;--font-sans: "DM Sans", system-ui, -apple-system, sans-serif}.section-title{font-family:var(--font-mono);font-size:1rem;font-weight:400;letter-spacing:.04em;color:var(--color-text-secondary);margin:0 0 1rem}h2:not(.section-title),h3{font-family:var(--font-sans)}*,*: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;background-image:radial-gradient(circle at 50% 0%,rgba(229,62,62,.08) 0%,transparent 60%);background-attachment:fixed}.btn{padding:.65rem 1.75rem;font-size:1rem;border:1px solid transparent;border-radius:var(--radius-md);cursor:pointer;font-weight:500;transition:background .2s,opacity .2s,box-shadow .2s,border-color .2s;font-family:var(--font-mono);letter-spacing:.02em}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary{background:var(--color-primary);color:#fff;font-weight:600;box-shadow:0 0 20px var(--color-primary-glow)}.btn-primary:hover:not(:disabled){background:var(--color-primary-hover);box-shadow:0 0 30px var(--color-primary-glow)}.btn-ghost{background:transparent;color:var(--color-text);border:1px solid var(--color-border)}.btn-ghost:hover:not(:disabled){border-color:var(--color-primary);color:var(--color-primary);box-shadow:0 0 12px var(--color-primary-glow)}.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%}.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, var(--color-badge-bg));color:var(--color-badge-text);border-color:var(--color-badge-text)}.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 var(--color-border)}.waterfall-explain{margin-top:.5rem;font-size:.8rem;line-height:1.5;color:var(--color-text-muted)}.measurement-panel{width:100%}.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}.background-waves{position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:0;overflow:hidden;mask-image:radial-gradient(ellipse 80% 60% at 50% 40%,black 20%,transparent 75%);-webkit-mask-image:radial-gradient(ellipse 80% 60% at 50% 40%,black 20%,transparent 75%)}.wave-orb{position:absolute;border-radius:50%;background:radial-gradient(circle,rgba(229,62,62,.15) 0%,rgba(229,62,62,.04) 40%,transparent 70%);filter:blur(40px);animation:orb-float 14s ease-in-out infinite}.wave-orb-1{width:280px;height:280px;top:10%;left:15%;animation-delay:0s;animation-duration:15s}.wave-orb-2{width:200px;height:200px;top:60%;right:20%;animation-delay:-7s;animation-duration:17s}.wave-orb-3{width:160px;height:160px;bottom:20%;left:30%;animation-delay:-14s;animation-duration:12s}.wave-orb-4{width:120px;height:120px;top:35%;right:35%;animation-delay:-3s;animation-duration:19s}@keyframes orb-float{0%,to{transform:translate(0) scale(1);opacity:.8}25%{transform:translate(30px,-20px) scale(1.05);opacity:1}50%{transform:translate(-20px,25px) scale(.95);opacity:.9}75%{transform:translate(15px,15px) scale(1.02);opacity:1}}.waves-svg{width:100%;height:100%;object-fit:cover;animation:wave-pulse 5s ease-in-out infinite}@keyframes wave-pulse{0%,to{opacity:1}50%{opacity:.85}}.wave-group{animation:wave-flow 10s linear infinite}.wave-group-2{animation-delay:-3s;animation-duration:12s}.wave-group-3{animation-delay:-6s;animation-duration:8s}.wave-group-saw{animation:wave-flow 9s linear infinite}.wave-group-saw path{animation:saw-fade 10s ease-in-out infinite}.wave-group-saw path:last-child{animation-delay:2s}@keyframes saw-fade{0%,35%{opacity:0}45%,75%{opacity:1}85%,to{opacity:0}}.wave-group-diag{animation:wave-flow-diag 14s linear infinite}@keyframes wave-flow{0%{transform:translate(0)}to{transform:translate(-400px)}}@keyframes wave-flow-diag{0%{transform:translate(0)}to{transform:translate(-200px)}}.app{max-width:720px;margin:0 auto;padding:2rem 1rem;min-height:100vh;display:flex;flex-direction:column;font-family:system-ui,-apple-system,sans-serif;position:relative}.app>*{position:relative;z-index:1}.app>.background-waves{z-index:0}.header{text-align:center;margin-bottom:2.5rem;padding-bottom:1.5rem;border-bottom:1px solid var(--color-border)}.header h1{font-size:2.8rem;margin:0;letter-spacing:-.03em;font-family:var(--font-mono);background:linear-gradient(135deg,var(--color-primary) 0%,#c53030 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;text-shadow:none;filter:drop-shadow(0 0 20px var(--color-primary-glow))}.subtitle{color:var(--color-text-secondary);margin:.4rem 0 0;font-size:1rem;font-family:var(--font-mono);letter-spacing:.04em}.range{color:var(--color-text-muted);font-size:.85rem;margin-top:.5rem;font-variant-numeric:tabular-nums;font-family:var(--font-mono)}.range:before{content:"> ";color:var(--color-primary)}.main{flex:1;display:flex;flex-direction:column;align-items:center;gap:1rem}.landing{display:flex;flex-direction:column;align-items:center;gap:1.5rem;text-align:center;max-width:500px;padding:2rem 0}.landing-intro{color:var(--color-text-secondary);font-size:1rem;line-height:1.65;margin:0}.how-it-works{list-style:none;counter-reset:step;padding:0;margin:0;display:flex;flex-direction:column;gap:.5rem;width:100%;text-align:left}.how-it-works li{counter-increment:step;display:flex;align-items:baseline;gap:.65rem;font-size:.9rem;color:var(--color-text-secondary);font-family:var(--font-mono);line-height:1.5}.how-it-works li:before{content:"0" counter(step);color:var(--color-primary);font-size:.75rem;font-weight:700;flex-shrink:0;opacity:.7}.how-it-works strong{color:var(--color-text)}.landing-actions{display:flex;flex-direction:column;align-items:center;gap:.75rem;width:100%;margin-top:.5rem}.btn-github{display:inline-flex;align-items:center;gap:.5rem;padding:.6rem 1.5rem;font-size:.95rem;font-family:var(--font-mono);font-weight:500;color:var(--color-text);background:transparent;border:1px solid var(--color-border);border-radius:var(--radius-md);text-decoration:none;cursor:pointer;transition:border-color .2s,color .2s,box-shadow .2s,background .2s;letter-spacing:.02em}.btn-github:hover{border-color:var(--color-primary);color:var(--color-primary);box-shadow:0 0 16px var(--color-primary-glow);background:#e53e3e0d}.btn-github svg{width:18px;height:18px;fill:currentColor;flex-shrink:0}.tech-badge{display:inline-flex;align-items:center;gap:.5rem;font-family:var(--font-mono);font-size:.75rem;color:var(--color-text-muted);padding:.3rem .75rem;border:1px solid var(--color-border);border-radius:var(--radius-pill);margin-top:.5rem}.tech-badge .dot{width:6px;height:6px;border-radius:50%;background:var(--color-primary);box-shadow:0 0 6px var(--color-primary-glow);animation:pulse-dot 2s ease-in-out infinite}@keyframes pulse-dot{0%,to{opacity:1;box-shadow:0 0 6px var(--color-primary-glow)}50%{opacity:.5;box-shadow:0 0 12px var(--color-primary-glow)}}.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);font-family:var(--font-mono)}.footer a{color:var(--color-primary);text-decoration:none;transition:text-shadow .2s}.footer a:hover{text-decoration:underline;text-shadow:0 0 8px var(--color-primary-glow)}
