:root{--bg:#0e1116;--bg-2:#161b22;--bg-3:#1f2630;--bg-4:#262d38;--line:#2a313c;--line-2:#38414f;--fg:#e6edf3;--fg-dim:#8b96a6;--fg-mute:#5e6a7a;--accent:#6aa6ff;--accent-2:#4a86e8;--good:#5cd29f;--warn:#f0b952;--bad:#ef6464;--a:#6aa6ff;--b:#f0b952;--shadow:0 6px 20px #00000073;--radius:10px;--mono:ui-monospace, SFMono-Regular, "JetBrains Mono", Menlo, Consolas, monospace;--sans:-apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif}*{box-sizing:border-box}html,body{background:var(--bg);height:100%;color:var(--fg);font-family:var(--sans);-webkit-font-smoothing:antialiased;margin:0}button{cursor:pointer;font-family:inherit}.hidden{display:none!important}.topbar{background:var(--bg-2);border:1px solid var(--line);border-radius:var(--radius);justify-content:space-between;align-items:center;padding:10px 14px;display:flex}.brand{align-items:center;gap:10px;display:flex}.brand h1{letter-spacing:.2px;margin:0;font-size:16px;font-weight:600}.brand .logo{font-size:18px}.brand .tag{letter-spacing:.12em;text-transform:uppercase;color:var(--fg-dim);border:1px solid var(--line-2);border-radius:4px;padding:2px 6px;font-size:10px}.status{color:var(--fg-dim);align-items:center;gap:10px;font-size:12px;display:flex}.model-pill{font-family:var(--mono);background:var(--bg-3);color:var(--fg);border:1px solid var(--line);border-radius:999px;padding:3px 8px}.model-pill em{color:var(--accent);font-style:normal}.icon-btn{border:1px solid var(--line-2);color:var(--fg-dim);background:0 0;border-radius:6px;justify-content:center;align-items:center;width:32px;height:32px;font-size:16px;transition:all .15s;display:inline-flex}.icon-btn:hover{color:var(--fg);border-color:var(--accent)}.icon-btn.spinning{animation:1.4s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.dot{background:var(--bad);border-radius:50%;width:8px;height:8px;box-shadow:0 0 #ef646480}.dot-disconnected{background:var(--bad)}.dot-connecting{background:var(--warn);animation:1.4s infinite pulse}.dot-connected{background:var(--good)}.dot-error{background:var(--bad);animation:1.2s infinite pulse}@keyframes pulse{0%{opacity:1;box-shadow:0 0}70%{opacity:.6;box-shadow:0 0 0 8px #0000}to{opacity:1;box-shadow:0 0 #0000}}.controls{background:var(--bg-2);border:1px solid var(--line);border-radius:var(--radius);flex-wrap:wrap;align-items:end;gap:10px;padding:10px 14px;display:flex}.mode-toggle{background:var(--bg-3);border:1px solid var(--line-2);border-radius:8px;align-self:end;height:38px;padding:2px;display:inline-flex}.mode-btn{color:var(--fg-dim);background:0 0;border:0;border-radius:6px;padding:6px 14px;font-size:13px;font-weight:500;transition:background .15s,color .15s}.mode-btn:hover{color:var(--fg)}.mode-btn.active{background:var(--accent-2);color:#fff;box-shadow:0 2px 8px #4a86e859}.lang-row{align-items:end;gap:8px;display:flex}.field{flex-direction:column;gap:4px;display:flex}.field label{color:var(--fg-dim);letter-spacing:.08em;text-transform:uppercase;font-size:11px}.field select,.field input{background:var(--bg-3);color:var(--fg);border:1px solid var(--line-2);border-radius:6px;outline:none;min-width:160px;padding:8px 10px;font-size:14px}.field select:focus,.field input:focus{border-color:var(--accent)}.swap{background:var(--bg-3);width:38px;height:38px;color:var(--fg);border:1px solid var(--line-2);border-radius:6px;align-self:end;font-size:18px;transition:transform .15s,background .15s}.swap:hover{background:var(--bg);transform:translateY(-1px)}.swap:active{transform:translateY(0)}.auto-arrow{height:38px;color:var(--fg-dim);align-self:end;align-items:center;padding:0 4px;font-size:18px;display:inline-flex}.grow{flex:1;min-width:12px}.checkbox{color:var(--fg-dim);-webkit-user-select:none;user-select:none;cursor:pointer;align-items:center;gap:6px;font-size:13px;display:inline-flex}.checkbox input{accent-color:var(--accent)}button.ghost{color:var(--fg-dim);border:1px solid var(--line-2);background:0 0;border-radius:6px;padding:8px 12px;font-size:13px}button.ghost:hover{color:var(--fg);border-color:var(--accent)}.panes{grid-template-columns:1fr 1fr;gap:12px;min-height:0;display:grid}.pane{background:var(--bg-2);border:1px solid var(--line);border-radius:var(--radius);flex-direction:column;min-height:0;transition:border-color .3s;display:flex;overflow:hidden}.pane header{border-bottom:1px solid var(--line);background:linear-gradient(to bottom, var(--bg-3), var(--bg-2));align-items:center;gap:8px;padding:10px 14px;display:flex}.pane header h2{letter-spacing:.08em;text-transform:uppercase;color:var(--fg-dim);margin:0;font-size:13px;font-weight:600}.pane header .counter{font-family:var(--mono);color:var(--fg-mute);margin-left:auto;font-size:11px}body.mode-auto .pane[data-speaker=a]{border-color:#6aa6ff73}body.mode-auto .pane[data-speaker=b]{border-color:#f0b95273}.transcript{scroll-behavior:smooth;flex:1;padding:18px 20px;font-size:16px;line-height:1.55;overflow-y:auto}.transcript .placeholder{color:var(--fg-mute);font-style:italic}.transcript kbd{font-family:var(--mono);background:var(--bg-3);border:1px solid var(--line-2);border-radius:4px;padding:1px 6px;font-size:13px}.utterance{background:var(--bg-3);border-left:3px solid var(--accent);border-radius:6px;margin:0 0 14px;padding:12px 14px;animation:.25s slideIn}.utterance .meta{color:var(--fg-mute);font-size:11px;font-family:var(--mono);align-items:center;gap:8px;margin-bottom:4px;display:flex}.utterance .meta .lang{background:var(--bg);border:1px solid var(--line-2);border-radius:4px;padding:1px 5px}.utterance .meta .dur{color:var(--fg-dim)}.utterance .meta .audio{background:var(--good);border-radius:50%;width:6px;height:6px;margin-left:4px;display:inline-block}.utterance .meta .fallback{color:var(--warn);background:#f0b9521a;border:1px solid #f0b9524d;border-radius:3px;padding:0 5px}.utterance .text{white-space:pre-wrap}.utterance.partial{opacity:.65;border-left-color:var(--fg-mute)}.utterance.partial .text:after{content:"…";color:var(--fg-mute);margin-left:2px;animation:1s step-end infinite blink}.utterance.playing{border-left-color:var(--good)}.utterance.speaker-a{border-left-color:var(--a)}.utterance.speaker-b{border-left-color:var(--b)}@keyframes slideIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}@keyframes blink{50%{opacity:.2}}.error{border-left:3px solid var(--bad);color:#ffd2d2;font-size:13px;font-family:var(--mono);background:#ef64641a;border-radius:6px;margin:0 0 12px;padding:10px 12px}.dock{background:var(--bg-2);border:1px solid var(--line);border-radius:var(--radius);align-items:center;gap:14px;padding:12px 14px;display:flex}.mic{color:#fff;background:var(--accent-2);border:none;border-radius:999px;align-items:center;gap:10px;padding:10px 22px;font-size:14px;font-weight:600;transition:transform .1s,background .2s,box-shadow .2s,opacity .2s;display:inline-flex;box-shadow:0 4px 14px #4a86e859}.mic:hover{background:var(--accent)}.mic:active{transform:translateY(1px)}.mic[data-on=true]{background:var(--bad);box-shadow:0 4px 14px #ef646459}.mic[data-on=true] .mic-icon{animation:1.4s infinite pulse}.mic:disabled,.mic[data-disabled=true]{opacity:.4;cursor:not-allowed;box-shadow:none}.mic-icon{font-size:14px;line-height:1}.meter{background:var(--bg-3);border-radius:3px;flex:1;height:6px;overflow:hidden}.meter-bar{background:linear-gradient(to right, var(--good), var(--accent), var(--bad));width:0%;height:100%;transition:width 50ms linear}.meta{font-family:var(--mono);color:var(--fg-dim);text-align:right;min-width:220px;font-size:12px}.modal-backdrop{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;background:#080a0eb3;justify-content:center;align-items:center;padding:20px;animation:.15s fadeIn;display:flex;position:fixed;inset:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal{background:var(--bg-2);border:1px solid var(--line);width:100%;max-width:720px;max-height:90vh;box-shadow:var(--shadow);border-radius:12px;flex-direction:column;animation:.2s slideDown;display:flex}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.modal header{border-bottom:1px solid var(--line);justify-content:space-between;align-items:center;padding:14px 20px;display:flex}.modal header h2{margin:0;font-size:16px;font-weight:600}.modal-body{flex-direction:column;gap:22px;padding:20px;display:flex;overflow-y:auto}.modal footer{border-top:1px solid var(--line);justify-content:space-between;align-items:center;padding:14px 20px;display:flex}.modal footer .status{font-size:12px;font-family:var(--mono);color:var(--fg-dim)}.setting h3{color:var(--fg);align-items:baseline;gap:8px;margin:0 0 10px;font-size:13px;font-weight:600;display:flex}.setting h3 .kind{letter-spacing:.12em;text-transform:uppercase;color:var(--fg-dim);font-size:10px;font-weight:500}.setting .grid{grid-template-columns:1fr 1fr;gap:10px;display:grid}.hint{color:var(--fg-dim);font-size:12px;font-family:var(--mono);margin:8px 0 0}.footnote{color:var(--fg-mute);border-top:1px solid var(--line);margin:0;padding-top:12px;font-size:12px;font-style:italic}.voices-grid{grid-template-columns:1fr 1fr;gap:8px 16px;display:grid}.voices-grid .voice-row{grid-template-columns:80px 1fr;align-items:center;gap:8px;font-size:13px;display:grid}.voices-grid .voice-row label{color:var(--fg-dim)}.voices-grid select{background:var(--bg-3);width:100%;color:var(--fg);border:1px solid var(--line-2);border-radius:5px;outline:none;padding:5px 8px;font-size:12px}.voices-grid select:focus{border-color:var(--accent)}.voices-grid select.busy{opacity:.5;pointer-events:none}.toasts{z-index:2000;pointer-events:none;flex-direction:column;gap:8px;display:flex;position:fixed;bottom:20px;right:20px}.toast{background:var(--bg-3);border:1px solid var(--line-2);border-left:3px solid var(--accent);min-width:240px;max-width:360px;box-shadow:var(--shadow);pointer-events:auto;border-radius:6px;padding:10px 14px;font-size:13px;animation:.25s slideInRight}.toast.error{border-left-color:var(--bad)}.toast.warn{border-left-color:var(--warn)}.toast.good{border-left-color:var(--good)}.toast .title{margin-bottom:2px;font-weight:600}.toast .body{color:var(--fg-dim);font-size:12px;font-family:var(--mono)}@keyframes slideInRight{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}@media (width<=800px){.panes{grid-template-rows:1fr 1fr;grid-template-columns:1fr}.controls{flex-direction:column;align-items:stretch}.lang-row{width:100%}.field select,.field input{flex:1;min-width:0}.meta{text-align:left;min-width:0}.voices-grid,.setting .grid{grid-template-columns:1fr}}.transcript::-webkit-scrollbar{width:10px}.modal-body::-webkit-scrollbar{width:10px}.transcript::-webkit-scrollbar-track{background:0 0}.modal-body::-webkit-scrollbar-track{background:0 0}.transcript::-webkit-scrollbar-thumb{background:var(--line-2);border:2px solid var(--bg-2);border-radius:5px}.modal-body::-webkit-scrollbar-thumb{background:var(--line-2);border:2px solid var(--bg-2);border-radius:5px}.transcript::-webkit-scrollbar-thumb:hover{background:var(--fg-mute)}.modal-body::-webkit-scrollbar-thumb:hover{background:var(--fg-mute)}
