*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg:#f8f9fa;--surface:#fff;--border:#ddd;--border-subtle:#f0f0f0;--text:#1a1a1a;--text-muted:#6b7280;--text-subtle:#9ca3af;--accent:#2563eb;--accent-hover:#1d4ed8;--danger:#dc2626;--danger-hover:#b91c1c;--badge-bg:#e5e7eb;--badge-fg:#374151;--badge-ready-bg:#dcfce7;--badge-ready-fg:#15803d;--badge-error-bg:#fee2e2;--badge-error-fg:#b91c1c;--badge-pending-bg:#fef9c3;--badge-pending-fg:#854d0e}[data-theme=dark]{--bg:#0f1115;--surface:#1a1d23;--border:#2a2e37;--border-subtle:#23272f;--text:#e8eaed;--text-muted:#9aa0ab;--text-subtle:#6b7280;--accent:#3b82f6;--accent-hover:#60a5fa;--danger:#ef4444;--danger-hover:#f87171;--badge-bg:#2a2e37;--badge-fg:#9aa0ab;--badge-ready-bg:#14532d;--badge-ready-fg:#4ade80;--badge-error-bg:#450a0a;--badge-error-fg:#f87171;--badge-pending-bg:#422006;--badge-pending-fg:#fbbf24}body{background:var(--bg);color:var(--text);font-family:system-ui,-apple-system,sans-serif;font-size:15px;line-height:1.5}.app{max-width:960px;margin:0 auto;padding:1.5rem 1rem}.app-header{align-items:center;gap:.75rem;margin-bottom:1.5rem;display:flex}.app-header h1{font-size:1.5rem;font-weight:700}.app-subtitle{color:var(--text-muted);font-size:.9rem}.controls{background:var(--surface);border:1px solid var(--border);border-radius:8px;flex-wrap:wrap;align-items:center;gap:.75rem;margin-bottom:1rem;padding:1rem;display:flex}.control-group{color:var(--text-muted);flex-direction:column;gap:.25rem;font-size:.8rem;display:flex}.control-group select{border:1px solid var(--border);background:var(--surface);color:var(--text);cursor:pointer;border-radius:4px;padding:.35rem .5rem;font-size:.9rem}.control-group select:disabled{opacity:.5;cursor:not-allowed}.btn{cursor:pointer;border:none;border-radius:6px;padding:.45rem 1.25rem;font-size:.9rem;font-weight:600;transition:opacity .15s}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-start{background:var(--accent);color:#fff}.btn-start:not(:disabled):hover{background:var(--accent-hover)}.btn-stop{background:var(--danger);color:#fff}.btn-stop:not(:disabled):hover{background:var(--danger-hover)}.transport-badge{background:var(--badge-bg);color:var(--badge-fg);text-transform:lowercase;border-radius:999px;padding:.2rem .6rem;font-size:.75rem}.transport-badge[data-state=ready]{background:var(--badge-ready-bg);color:var(--badge-ready-fg)}.transport-badge[data-state=error]{background:var(--badge-error-bg);color:var(--badge-error-fg)}.transport-badge[data-state=connecting],.transport-badge[data-state=authenticating],.transport-badge[data-state=initializing]{background:var(--badge-pending-bg);color:var(--badge-pending-fg)}.tabs{border-bottom:2px solid var(--border);gap:0;margin-bottom:1rem;display:flex}.tab{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;margin-bottom:-2px;padding:.5rem 1.25rem;font-size:.9rem;font-weight:500;transition:color .15s}.tab:hover{color:var(--text)}.tab.active{color:var(--accent);border-bottom-color:var(--accent)}.captions{grid-template-columns:1fr 1fr;gap:1rem;display:grid}.caption-col{background:var(--surface);border:1px solid var(--border);border-radius:8px;min-height:320px;max-height:480px;padding:1rem;overflow-y:auto}.caption-col h2{text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);border-bottom:1px solid var(--border-subtle);margin-bottom:.75rem;padding-bottom:.5rem;font-size:.85rem;font-weight:600}.line{margin-bottom:.5rem;line-height:1.6}.line.partial{color:var(--text-subtle);font-style:italic}.line.final{color:var(--text)}.empty{color:var(--text-subtle);margin-top:.5rem;font-size:.875rem}.metrics{flex-direction:column;gap:1.5rem;display:flex}.metrics-empty{margin-top:.5rem}.metrics-card{max-width:560px}.metrics-card h3{color:var(--text-muted);margin-bottom:.5rem;font-size:.875rem;font-weight:600}.metrics-chart{height:160px;margin-bottom:.5rem}.metrics-table{border-collapse:collapse;width:100%;max-width:560px;font-size:.875rem}.metrics-table th,.metrics-table td{text-align:left;border-bottom:1px solid var(--border-subtle);padding:.4rem .75rem}.metrics-table th{color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;font-size:.8rem;font-weight:600}.metric-value{font-variant-numeric:tabular-nums;font-family:monospace}.theme-toggle{border:1px solid var(--border);background:var(--surface);color:var(--text);cursor:pointer;border-radius:6px;margin-left:auto;padding:.35rem .6rem;font-size:1rem;line-height:1;transition:background .15s,border-color .15s}.theme-toggle:hover{background:var(--border)}.mic-waveform{align-items:center;display:flex}.mic-waveform canvas{border-radius:4px;display:block}
