:root{--bg: #11131a;--panel: #1a1d28;--panel-2: #232735;--text: #e9e9ee;--text-muted: #8a8fa3;--accent: #7aa2ff;--accent-2: #a37aff;--matched: #5fd47a;--pending: #595e72;--cursor: #ffe17a;--user-bg: #1f2a40;--partner-bg: #2a1f30;--border: #2a2e3d;color-scheme:dark;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,system-ui,sans-serif;background:var(--bg);color:var(--text)}*{box-sizing:border-box}body{margin:0;min-height:100vh}button{font-family:inherit;font-size:inherit;border:1px solid var(--border);background:var(--panel-2);color:var(--text);border-radius:8px;padding:.5rem 1rem;cursor:pointer;transition:background .1s,border-color .1s}button:hover:not(:disabled){border-color:var(--accent)}button:disabled{opacity:.5;cursor:not-allowed}button.primary{background:var(--accent);color:#0d1020;border-color:var(--accent);font-weight:600}button.primary:hover:not(:disabled){background:#5b8cff}.app{max-width:980px;margin:0 auto;padding:2rem 1.5rem 6rem}.app-header{display:flex;align-items:baseline;justify-content:space-between;gap:1rem;border-bottom:1px solid var(--border);padding-bottom:1rem;margin-bottom:1.5rem}.app-header h1{font-size:1.25rem;margin:0;font-weight:600}.app-header .scene-title{font-style:italic;color:var(--text-muted)}.role-toggle{display:flex;gap:.25rem;border:1px solid var(--border);border-radius:999px;padding:3px}.role-toggle button{border:none;background:transparent;border-radius:999px;padding:.25rem .75rem;font-size:.85rem;color:var(--text-muted)}.role-toggle button.active{background:var(--accent);color:#0d1020}.scene{display:flex;flex-direction:column;gap:.75rem}.line{border:1px solid transparent;border-radius:12px;padding:1rem 1.25rem;transition:border-color .15s,background .15s}.line.user{background:var(--user-bg)}.line.partner{background:var(--partner-bg)}.line.current{border-color:var(--accent);box-shadow:0 0 0 3px #7aa2ff26}.line.completed{opacity:.55}.line .character{font-size:.75rem;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);margin-bottom:.4rem}.line .text{font-family:Iowan Old Style,Palatino,Georgia,serif;font-size:1.25rem;line-height:1.5}.word{transition:color .1s,background .1s}.word.pending{color:var(--pending)}.word.matched{color:var(--matched)}.word.cursor{color:var(--cursor);text-decoration:underline;text-decoration-color:var(--cursor);text-underline-offset:4px}.transcript-row{margin-top:.6rem;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:.78rem;color:var(--text-muted);display:flex;gap:.5rem;flex-wrap:wrap}.transcript-row .interim{font-style:italic}.transcript-row .final{color:var(--text)}.silence-bar{margin-top:.5rem;height:4px;background:var(--panel-2);border-radius:999px;overflow:hidden}.silence-bar>div{height:100%;background:var(--cursor);transition:width .1s linear}.control-bar{position:fixed;bottom:0;left:0;right:0;display:flex;justify-content:center;padding:1rem;background:linear-gradient(to top,var(--bg),transparent)}.control-bar .controls{display:flex;gap:.5rem;background:var(--panel);border:1px solid var(--border);border-radius:16px;padding:.5rem;align-items:center}.control-bar .listening{display:flex;align-items:center;gap:.4rem;color:var(--matched);font-size:.85rem;margin-right:.5rem;padding:0 .5rem}.listening .dot{width:8px;height:8px;border-radius:50%;background:currentColor;animation:pulse 1.2s ease-in-out infinite}@keyframes pulse{0%,to{opacity:.4}50%{opacity:1}}.debug-panel{margin-top:2rem;border:1px solid var(--border);border-radius:12px;padding:1rem;background:var(--panel);font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:.78rem}.debug-panel h3{font-family:-apple-system,sans-serif;margin:0 0 .5rem;font-size:.85rem;text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted)}.debug-panel .grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.debug-panel .col{min-width:0}.debug-panel pre{margin:0;white-space:pre-wrap;word-break:break-word;color:var(--text-muted)}.debug-panel .stat{display:flex;justify-content:space-between;padding:.15rem 0}.debug-panel .stat span:first-child{color:var(--text-muted)}.match-log{max-height:180px;overflow-y:auto}.match-log .entry{padding:.2rem 0;border-bottom:1px dashed var(--border)}.match-log .entry:last-child{border-bottom:none}.match-type{display:inline-block;padding:1px 6px;border-radius:4px;font-size:.7rem;margin-right:.4rem}.match-type.exact{background:#1e3a2a;color:#6fd48a}.match-type.fuzzy{background:#2a2e3a;color:#8fa8e0}.match-type.concatenated{background:#3a2d1e;color:#d4a36f}.match-type.phonetic{background:#3a1e2e;color:#d46f8a}.error-banner{background:#3a1e1e;border:1px solid #d46f6f;color:#f0b0b0;padding:.75rem 1rem;border-radius:8px;margin-bottom:1rem;font-size:.9rem}
