:root{color-scheme:dark;--bg: #0b0d12;--bg-elev: #12151c;--bg-elev-2: #171b24;--border: #232836;--text: #e8eaf0;--muted: #8b93a7;--accent: #5b8def;--accent-2: #34d399;--danger: #ef4444;font-family:ui-sans-serif,system-ui,-apple-system,Inter,BlinkMacSystemFont,sans-serif;background:var(--bg);color:var(--text)}*{box-sizing:border-box}html,body,#root{height:100%}html,body{margin:0;padding:0;height:100%;overflow:hidden}.app{height:100dvh;width:100vw;max-width:860px;margin:0 auto;display:flex;flex-direction:column;padding:8px 10px 0;gap:6px}.topbar{flex:0 0 auto;display:flex;flex-direction:column;gap:6px;background:linear-gradient(180deg,var(--bg-elev) 0%,var(--bg-elev-2) 100%);border:1px solid var(--border);border-radius:12px;padding:8px 10px}.topbar-row{display:flex;align-items:center;gap:10px;min-height:0}.topbar-mid{flex:1 1 0;display:flex;flex-direction:column;gap:4px;min-width:0}.topbar-meta{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--muted);flex-wrap:wrap}.status-text{white-space:nowrap}.dot-sep{opacity:.5}.model-label-static{background:var(--bg-elev-2);border:1px solid var(--border);color:var(--text);border-radius:6px;padding:3px 8px;font-size:11px;font-weight:500;letter-spacing:.3px;white-space:nowrap}.model-switcher{display:inline-flex;align-items:center}.model-switcher select{-moz-appearance:none;appearance:none;-webkit-appearance:none;background:var(--bg-elev-2);border:1px solid var(--border);color:var(--text);border-radius:6px;padding:3px 22px 3px 8px;font-size:11px;font-weight:500;letter-spacing:.3px;line-height:1.4;cursor:pointer;background-image:linear-gradient(45deg,transparent 50%,var(--text) 50%),linear-gradient(135deg,var(--text) 50%,transparent 50%);background-position:calc(100% - 11px) 50%,calc(100% - 7px) 50%;background-size:4px 4px,4px 4px;background-repeat:no-repeat}.model-switcher select:focus{outline:1px solid var(--accent, #6aa);outline-offset:1px}.model-switcher.disabled select{opacity:.55;cursor:not-allowed}.mode-switcher{display:inline-flex;align-items:center;gap:4px}.mode-switcher-label{font-size:10px;color:var(--muted);text-transform:uppercase;letter-spacing:.4px}.mode-switcher select{-moz-appearance:none;appearance:none;-webkit-appearance:none;background:var(--bg-elev-2);border:1px solid var(--border);color:var(--text);border-radius:6px;padding:3px 22px 3px 8px;font-size:11px;font-weight:500;letter-spacing:.3px;line-height:1.4;cursor:pointer;background-image:linear-gradient(45deg,transparent 50%,var(--text) 50%),linear-gradient(135deg,var(--text) 50%,transparent 50%);background-position:calc(100% - 11px) 50%,calc(100% - 7px) 50%;background-size:4px 4px,4px 4px;background-repeat:no-repeat}.mode-switcher select:focus{outline:1px solid var(--accent);outline-offset:1px}.mode-switcher.disabled select{opacity:.55;cursor:not-allowed}.stats-toggle{background:var(--bg-elev-2);border:1px solid var(--border);color:var(--muted);border-radius:6px;width:26px;height:26px;font-size:12px;cursor:pointer;display:inline-flex;align-items:center;justify-content:center}.stats-toggle:hover{color:var(--text)}.stats-toggle.open{color:var(--accent);border-color:#5b8def66}.dot{width:8px;height:8px;border-radius:50%;background:#4b5263;flex-shrink:0}.dot.off{background:#4b5263}.dot.connecting,.dot.preparing{background:#f59e0b;animation:blink 1s infinite ease-in-out}.dot.listening{background:var(--accent);box-shadow:0 0 #5b8def99;animation:ring 2s infinite}.dot.active{background:var(--accent-2);box-shadow:0 0 #34d399a6;animation:ring 1.1s infinite}@keyframes blink{0%,to{opacity:.4}50%{opacity:1}}@keyframes ring{0%{box-shadow:0 0 0 0 currentColor}70%{box-shadow:0 0 0 8px #0000}to{box-shadow:0 0 #0000}}.mic{position:relative;width:72px;height:72px;border-radius:50%;border:1px solid var(--border);background:radial-gradient(circle at 30% 30%,#1c2333,#0f131c);color:var(--text);cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:transform 80ms ease,box-shadow .2s ease,border-color .2s ease,background .2s ease;box-shadow:0 6px 18px #00000059,inset 0 1px #ffffff0d;flex-shrink:0;-webkit-tap-highlight-color:transparent;touch-action:manipulation}.mic:active{transform:scale(.95)}.mic.on{background:radial-gradient(circle at 30% 30%,#1f2c45,#0b1322);border-color:#5b8def73;color:var(--accent);box-shadow:0 0 0 3px #5b8def1f,0 6px 18px #0006}.mic.on.speaking{border-color:#34d3998c;color:var(--accent-2);box-shadow:0 0 0 3px #34d3992e,0 6px 18px #0006}.mic .pulse{position:absolute;top:-4px;right:-4px;bottom:-4px;left:-4px;border-radius:50%;pointer-events:none}.mic.on .pulse{animation:pulse 2.2s infinite ease-out;border:2px solid rgba(91,141,239,.55)}.mic.on.speaking .pulse{animation-duration:1s;border-color:#34d399a6}@keyframes pulse{0%{transform:scale(.92);opacity:.7}80%{transform:scale(1.2);opacity:0}to{transform:scale(1.2);opacity:0}}.stream-section{margin-top:10px}.spectrum{width:100%;height:64px;display:block}.stream-preview{position:relative;height:140px;background:var(--bg-elev-2);border:1px solid var(--border);border-radius:8px;padding:4px 8px;overflow:hidden;display:flex;flex-direction:column;transition:border-color .12s ease}.stream-preview-text{flex:1 1 auto;font-size:12px;line-height:1.35;color:var(--text);overflow-y:auto;overflow-x:hidden;scrollbar-width:thin;word-break:break-word;display:flex;flex-direction:column;gap:1px}.stream-preview-text::-webkit-scrollbar{width:4px}.stream-preview-text::-webkit-scrollbar-thumb{background:#ffffff14;border-radius:2px}.stream-preview-placeholder{color:var(--muted);opacity:.5}.stream-line{display:flex;align-items:baseline;gap:6px;padding:1px 0}.stream-line-marker{flex:0 0 auto;width:10px;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:11px;color:var(--muted);opacity:.7;line-height:1.35}.stream-line-text{flex:1 1 auto;min-width:0;white-space:pre-wrap}.stream-line-text.mono{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:11px}.stream-line.llm-pending+.stream-line.llm-pending,.stream-line.llm-done+.stream-line.llm-pending,.stream-line.asr-live+.stream-line.llm-pending,.stream-line.asr-final+.stream-line.llm-pending,.stream-line.asr-live+.stream-line.llm-done,.stream-line.asr-final+.stream-line.llm-done{border-top:1px solid rgba(52,211,153,.18);margin-top:4px;padding-top:4px}.stream-line.asr-live+.stream-line.llm-error,.stream-line.asr-final+.stream-line.llm-error{border-top:1px solid rgba(239,68,68,.25);margin-top:4px;padding-top:4px}.stream-line.asr-live .stream-line-text,.stream-line.asr-final .stream-line-text{color:#cfd9ef}.stream-line.asr-live .stream-line-marker,.stream-line.asr-final .stream-line-marker{color:#5b8defcc}.stream-line.processing .stream-line-text{color:#b9f0d3}.stream-line.processing .stream-line-marker{color:#34d399cc}.stream-line.llm-pending .stream-line-text{color:#b9f0d3}.stream-line.llm-pending .stream-line-marker{color:#34d399cc}.stream-line.llm-done .stream-line-text{color:#b9f0d3}.stream-line.llm-done .stream-line-marker{color:#34d3998c}.stream-line.llm-error .stream-line-text{color:#f5b5b5}.stream-line.llm-error .stream-line-marker{color:var(--danger)}.stream-preview.asr-live{border-color:#5b8def8c}.stream-preview.llm-pending{border-color:#34d3998c}.stream-preview.llm-done{border-color:#34d3994d}.stream-preview.llm-error{border-color:#ef44448c}.stream-preview.processing{border-color:#ffffff26}.transcript-wrap{flex:1 1 auto;min-height:0;background:var(--bg-elev);border:1px solid var(--border);border-radius:12px;padding:10px 12px;display:flex;flex-direction:column}.transcript{flex:1 1 auto;min-height:0;overflow-y:auto;display:flex;flex-direction:column;gap:12px;scroll-behavior:smooth;-webkit-overflow-scrolling:touch;padding-bottom:env(safe-area-inset-bottom,4px)}.transcript .empty{color:var(--muted);font-style:italic;margin:auto;text-align:center;max-width:360px;line-height:1.5;font-size:14px;padding:0 16px}.block{background:var(--bg-elev-2);border:1px solid var(--border);border-radius:10px;padding:8px 12px 10px;display:flex;flex-direction:column;gap:4px;transition:border-color .2s ease}.block.active{border-color:#5b8def59;box-shadow:inset 0 0 0 1px #5b8def1a}.block.sealed{opacity:.92}.block-head{display:flex;align-items:baseline;justify-content:space-between;gap:8px;font-size:10px;color:var(--muted);font-variant-numeric:tabular-nums;letter-spacing:.4px}.block-time{text-transform:uppercase}.block-dur{font-size:10px;opacity:.8}.block-body{display:flex;flex-direction:column;gap:2px}.block-summary{margin-top:6px;padding:6px 10px;border-radius:6px;background:#5b8def14;border-left:2px solid var(--accent);font-size:12px;line-height:1.4;color:#cbd2e0;display:flex;flex-direction:column;gap:2px}.block-summary.pending{opacity:.7}.block-summary.error{background:#ef44440f;border-left-color:#ef444499;color:#fca5a5}.block-summary-label{font-size:9px;text-transform:uppercase;letter-spacing:.6px;color:var(--muted)}.block-summary-ms{opacity:.8}.block-summary-text{font-style:italic}.block-corrected{margin-top:8px;padding:10px 14px;border-radius:8px;background:#22c55e38;border-left:3px solid rgba(34,197,94,.85);color:#fff;display:flex;flex-direction:column;gap:4px}.block-corrected.pending{background:#22c55e24}.block-corrected.error{background:#ef44442e;border-left-color:#ef4444cc;color:#ffe4e4}.block-corrected-head{display:flex;align-items:baseline;gap:8px;font-size:10px;text-transform:uppercase;letter-spacing:.5px;color:#ffffffbf}.block-corrected.error .block-corrected-head{color:#fca5a5}.block-corrected-label{font-weight:600}.block-corrected-ms{opacity:.7}.block-corrected-text{margin:0;font-size:16px;line-height:1.5;color:#fff;white-space:pre-wrap;word-wrap:break-word}.block-corrected-text.dim{color:#fff9}.block-corrected-text .cursor{display:inline-block;width:.55ch;height:1em;margin-left:2px;vertical-align:text-bottom;background:#fff;animation:blink 1s steps(2,start) infinite}.block-corrected-text .dots{display:inline-block;animation:pulse 1.4s ease-in-out infinite}.transcript .line{margin:0;padding:1px 0;font-size:16px;line-height:1.5;word-wrap:break-word;white-space:pre-wrap;color:var(--text)}.transcript .partial{color:#6b7180;font-style:italic}.transcript .cursor{display:inline-block;width:2px;height:1em;background:var(--accent-2);margin-left:3px;vertical-align:text-bottom;animation:caret 1s steps(2) infinite}@keyframes caret{0%,to{opacity:1}50%{opacity:0}}.error{background:#ef444414;border:1px solid rgba(239,68,68,.35);color:#fca5a5;padding:6px 10px;border-radius:8px;font-size:12px}.error-pill{background:#ef44441f;border:1px solid rgba(239,68,68,.45);color:#fca5a5;border-radius:6px;padding:3px 8px;font-size:11px;cursor:pointer;display:inline-flex;align-items:center;gap:4px;max-width:60vw;min-width:0}.error-pill:hover{background:#ef44442e}.error-pill-text{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:22ch}.stats{display:grid;grid-template-columns:repeat(auto-fill,minmax(110px,1fr));gap:6px;max-height:30vh;overflow-y:auto}.stat{background:var(--bg-elev-2);border:1px solid var(--border);border-radius:6px;padding:6px 8px;display:flex;flex-direction:column;gap:1px;min-width:0}.stat-label{font-size:9px;text-transform:uppercase;letter-spacing:.6px;color:var(--muted)}.stat-value{font-size:12px;font-variant-numeric:tabular-nums;font-family:ui-monospace,SF Mono,Menlo,monospace;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.stat.ok .stat-value,.stat.speak .stat-value{color:var(--accent-2)}.stat.warn .stat-value{color:#fca5a5}.stat.info .stat-value{color:var(--accent)}.transcript::-webkit-scrollbar,.stats::-webkit-scrollbar{width:6px}.transcript::-webkit-scrollbar-thumb,.stats::-webkit-scrollbar-thumb{background:#232836;border-radius:3px}.transcript::-webkit-scrollbar-track,.stats::-webkit-scrollbar-track{background:transparent}@media (min-width: 720px){.app{padding:14px 16px 10px;gap:10px}.topbar{padding:12px 14px}.mic{width:84px;height:84px}.spectrum{height:72px}.stream-preview{height:160px}.stream-preview-text{font-size:13px}.transcript .line{font-size:17px}}.content-tabs{padding:8px 14px 0;flex:0 0 auto}.tabs{display:flex;gap:4px;border-bottom:1px solid var(--border)}.tab{-webkit-appearance:none;-moz-appearance:none;appearance:none;background:transparent;border:0;color:var(--muted);padding:8px 14px 10px;display:flex;flex-direction:column;align-items:flex-start;gap:2px;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px;transition:color .15s ease,border-color .15s ease}.tab:hover{color:var(--text)}.tab.active{color:var(--text);border-bottom-color:var(--accent)}.tab-label{font-size:13px;font-weight:600}.tab-sub{font-size:10px;color:var(--muted);text-transform:lowercase;letter-spacing:.3px}.form-wrap{flex:1 1 auto;overflow:auto;padding:14px}.form-fill{max-width:760px;margin:0 auto;display:flex;flex-direction:column;gap:14px}.form-fill-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;flex-wrap:wrap}.form-fill-head h2{margin:0;font-size:18px;font-weight:600}.form-fill-sub{margin:4px 0 0;color:var(--muted);font-size:12px}.form-fill-meta{display:flex;align-items:center;gap:8px;font-size:11px;color:var(--muted)}.form-fill-status{padding:3px 8px;border-radius:6px;background:var(--bg-elev-2);border:1px solid var(--border)}.form-fill-status-running{color:#f59e0b}.form-fill-status-ok{color:var(--accent-2)}.form-fill-status-error{color:var(--danger)}.form-fill-count{padding:3px 8px;border-radius:6px;background:var(--bg-elev-2);border:1px solid var(--border)}.ghost-btn{-webkit-appearance:none;-moz-appearance:none;appearance:none;background:transparent;color:var(--muted);border:1px solid var(--border);border-radius:6px;padding:4px 10px;font-size:11px;cursor:pointer}.ghost-btn:hover{color:var(--text);border-color:#3a3f4f}.form-fill-grid{display:grid;grid-template-columns:1fr;gap:10px}@media (min-width: 640px){.form-fill-grid{grid-template-columns:1fr 1fr}.form-fill-grid .form-field-checkbox,.form-fill-grid .form-field-multiselect,.form-fill-grid .form-field-range,.form-fill-grid .form-field-radio,.form-fill-grid .form-field-text.span-2{grid-column:span 2}}.form-field{display:flex;flex-direction:column;gap:6px;background:var(--bg-elev);border:1px solid var(--border);border-radius:8px;padding:10px 12px;transition:border-color .3s ease,background .3s ease,box-shadow .3s ease}.form-field-label{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.4px;font-weight:600}.form-field-help{text-transform:none;letter-spacing:0;font-weight:400;opacity:.7}.form-field input[type=text],.form-field input[type=date],.form-field input[type=number],.form-field select{background:var(--bg);color:var(--text);border:1px solid var(--border);border-radius:6px;padding:6px 10px;font-size:14px;font-family:inherit;width:100%}.form-field input:focus,.form-field select:focus{outline:1px solid var(--accent);outline-offset:0;border-color:var(--accent)}.form-field-radio-group,.form-field-checkbox-group{display:flex;flex-wrap:wrap;gap:6px 12px}.form-field-radio{display:inline-flex;align-items:center;gap:6px;font-size:13px;cursor:pointer}.form-field-checkbox{display:inline-flex;align-items:center;gap:6px;padding:3px 8px;border:1px solid var(--border);border-radius:6px;font-size:13px;cursor:pointer}.form-field-checkbox.on{background:#5b8def2e;border-color:var(--accent)}.form-field-checkbox input,.form-field-radio input{accent-color:var(--accent)}.form-field-multiselect{display:flex;flex-wrap:wrap;gap:6px}.pill{-webkit-appearance:none;-moz-appearance:none;appearance:none;background:var(--bg);color:var(--text);border:1px solid var(--border);border-radius:999px;padding:4px 12px;font-size:12px;cursor:pointer}.pill:hover{border-color:#3a3f4f}.pill.on{background:var(--accent);border-color:var(--accent);color:#fff}.form-field-range input[type=range]{width:100%;accent-color:var(--accent)}.form-field-range-meta{display:flex;align-items:baseline;justify-content:space-between;gap:8px;font-size:11px;color:var(--muted)}.form-field-range-meta strong{font-size:16px;color:var(--text);font-weight:600}.form-field-range-meta strong.dim{color:var(--muted);font-weight:400}.range-end{opacity:.7}.form-field.just-changed{border-color:var(--accent-2);background:#34d3991a;box-shadow:0 0 0 2px #34d39940;animation:form-field-pop .45s ease}@keyframes form-field-pop{0%{transform:scale(1)}35%{transform:scale(1.02)}to{transform:scale(1)}}.form-fill-debug{background:var(--bg-elev-2);border:1px solid var(--border);border-radius:8px;padding:6px 12px;font-size:11px;color:var(--muted)}.form-fill-debug summary{cursor:pointer;padding:4px 0}.form-fill-debug pre{margin:6px 0 0;padding:8px;background:var(--bg);border-radius:6px;overflow:auto;max-height:200px;font-size:11px;white-space:pre-wrap;word-break:break-all}
