:root{--bg: #ffffff;--bg-alt: #fafafa;--bg-soft: #f4f4f5;--border: #e5e5e5;--border-strong: #d4d4d8;--text: #0a0a0a;--text-2: #404040;--muted: #737373;--accent: #0a0a0a;--accent-hover: #262626;--blue: #2563eb;--green: #10b981;--red: #ef4444;--amber: #f59e0b;--radius: 12px;--radius-sm: 8px;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .04);--shadow-md: 0 4px 16px rgba(0, 0, 0, .05);--mono: ui-monospace, SFMono-Regular, "JetBrains Mono", Menlo, monospace;--spk-0-from: #6366f1;--spk-0-to: #8b5cf6;--spk-0-ring: rgba(99, 102, 241, .4);--spk-1-from: #0ea5e9;--spk-1-to: #22d3ee;--spk-1-ring: rgba(14, 165, 233, .4);--spk-2-from: #f59e0b;--spk-2-to: #f97316;--spk-2-ring: rgba(245, 158, 11, .45);--spk-3-from: #10b981;--spk-3-to: #14b8a6;--spk-3-ring: rgba(16, 185, 129, .4);--spk-4-from: #f43f5e;--spk-4-to: #ec4899;--spk-4-ring: rgba(244, 63, 94, .4);--spk-5-from: #64748b;--spk-5-to: #475569;--spk-5-ring: rgba(100, 116, 139, .4)}*{box-sizing:border-box}html,body,#root{height:100%}body{margin:0;font-family:-apple-system,BlinkMacSystemFont,Inter,PingFang SC,Microsoft YaHei,Segoe UI,Roboto,sans-serif;background:var(--bg);color:var(--text);font-size:14px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.app-shell{display:flex;flex-direction:column;min-height:100vh}.brandbar{position:sticky;top:0;z-index:10;display:flex;align-items:center;gap:14px;padding:12px 28px;background:#ffffffd9;backdrop-filter:saturate(180%) blur(8px);-webkit-backdrop-filter:saturate(180%) blur(8px);border-bottom:1px solid var(--border)}.brand-logo{height:28px;width:auto;display:block;object-fit:contain}.brand-title{font-weight:600;font-size:15px;letter-spacing:.2px}.brand-sep{color:var(--border-strong)}.brand-sub{color:var(--muted);font-size:13px}.brand-spacer{flex:1}.brand-status{display:inline-flex;align-items:center;gap:8px;font-size:12px;color:var(--muted)}.prov-select{position:relative}.prov-trigger{display:inline-flex;align-items:center;gap:8px;padding:6px 10px 6px 12px;border-radius:999px;background:var(--bg-soft);border:1px solid var(--border);font-family:inherit;font-size:12.5px;cursor:pointer;color:var(--text);transition:all .15s}.prov-trigger:hover:not(:disabled){background:#ececef;border-color:var(--border-strong)}.prov-trigger:disabled{cursor:not-allowed;opacity:.55}.prov-label-prefix{color:var(--muted);font-size:11px}.prov-label{font-weight:600}.prov-caret{color:var(--muted);font-size:10px;transition:transform .15s}.prov-select.open .prov-caret{transform:rotate(180deg)}.prov-menu{position:absolute;right:0;top:calc(100% + 6px);min-width:280px;max-width:360px;background:#fff;border:1px solid var(--border);border-radius:10px;box-shadow:var(--shadow-md);padding:6px;z-index:20;display:flex;flex-direction:column;gap:2px;animation:pill-in .15s ease-out}.prov-item{display:flex;flex-direction:column;gap:2px;text-align:left;background:transparent;border:none;cursor:pointer;padding:9px 10px;border-radius:7px;font-family:inherit}.prov-item:hover{background:var(--bg-soft)}.prov-item.active{background:#f0f9ff}.prov-item-title{font-size:13px;font-weight:600;color:var(--text);display:inline-flex;align-items:center;gap:8px}.prov-item-desc{font-size:11.5px;color:var(--muted)}.prov-badge{font-size:10px;font-weight:500;background:#e0f2fe;color:#0369a1;padding:1px 6px;border-radius:999px}.prov-empty{padding:12px;color:var(--muted);font-size:12px;text-align:center}.brand-dot-wrap{position:relative;width:10px;height:10px}.brand-dot{width:10px;height:10px;border-radius:999px;background:#d4d4d8;position:absolute;top:0;right:0;bottom:0;left:0}.brand-dot.online{background:var(--green)}.brand-dot.busy{background:var(--amber)}.brand-dot.rec{background:var(--red)}.brand-dot.rec:before,.brand-dot.rec:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:999px;border:2px solid var(--red);opacity:0;animation:rip 1.8s ease-out infinite}.brand-dot.rec:after{animation-delay:.9s}@keyframes rip{0%{transform:scale(1);opacity:.55}to{transform:scale(2.6);opacity:0}}.layout{display:grid;grid-template-columns:1fr 320px;gap:24px;padding:24px 28px 64px;max-width:1400px;width:100%;margin:0 auto;align-items:start}@media (max-width: 1024px){.layout{grid-template-columns:1fr}}.tabs{display:inline-flex;background:var(--bg-soft);border:1px solid var(--border);padding:3px;border-radius:999px;gap:2px}.tab{border:none;background:transparent;padding:6px 14px;font-size:13px;cursor:pointer;color:var(--text-2);border-radius:999px;transition:all .15s;font-family:inherit}.tab:hover{color:var(--text)}.tab.active{background:#fff;color:var(--text);font-weight:600;box-shadow:0 1px 3px #00000014}.tab:disabled{cursor:not-allowed;opacity:.55}.btn{border:1px solid transparent;border-radius:var(--radius-sm);padding:8px 14px;font-size:13px;font-weight:500;cursor:pointer;transition:all .15s;display:inline-flex;align-items:center;gap:6px;font-family:inherit}.btn.primary{background:var(--accent);color:#fff}.btn.primary:hover{background:var(--accent-hover)}.btn.secondary{background:#fff;color:var(--text);border-color:var(--border-strong)}.btn.secondary:hover{background:var(--bg-soft)}.btn.danger{background:#fff;color:var(--red);border-color:#fecaca}.btn.danger:hover{background:#fef2f2}.btn.ghost{background:transparent;color:var(--text-2);padding:6px 10px}.btn.ghost:hover{background:var(--bg-soft);color:var(--text)}.btn:disabled{opacity:.45;cursor:not-allowed}.btn-row{display:flex;gap:8px;flex-wrap:wrap}.card{background:#fff;border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm)}.card-pad{padding:16px 18px}.card-head{padding:14px 18px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;gap:12px}.card-title{font-size:13px;font-weight:600;letter-spacing:.2px}.card-sub{font-size:12px;color:var(--muted)}.kpi-bar{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin:14px 0 0}@media (max-width: 720px){.kpi-bar{grid-template-columns:repeat(2,1fr)}}.kpi{background:#fff;border:1px solid var(--border);border-radius:var(--radius-sm);padding:12px 14px;display:flex;flex-direction:column;gap:4px}.kpi-label{font-size:11px;color:var(--muted);letter-spacing:.4px;text-transform:uppercase}.kpi-value{font-size:22px;font-weight:600;font-family:var(--mono);letter-spacing:-.5px}.kpi-unit{font-size:12px;color:var(--muted);margin-left:4px;font-weight:400;font-family:inherit}.transcript-wrap{position:relative}.transcript-status{display:flex;align-items:center;gap:8px;padding:9px 18px;border-bottom:1px solid var(--border);background:#fafafa;color:var(--muted);font-size:12.5px}.transcript-status .status-dot{width:7px;height:7px;border-radius:999px;background:var(--muted);box-shadow:0 0 0 3px #71717a1f}.transcript-status.recording .status-dot,.transcript-status.finalizing .status-dot,.transcript-status.connecting .status-dot{animation:live-blink 1.1s ease-in-out infinite}.transcript-status.done .status-dot{background:#52525b;box-shadow:none}.transcript-status.error{color:#b91c1c;background:#fef2f2}.transcript-status.error .status-dot{background:#ef4444;box-shadow:0 0 0 3px #ef44441f}.transcript{display:flex;flex-direction:column;height:clamp(280px,42vh,420px);overflow-y:auto;padding:8px 18px 24px;scroll-behavior:smooth}.jump-pill{position:absolute;right:18px;bottom:16px;background:#0a0a0ae0;color:#fff;border:none;padding:7px 14px;border-radius:999px;font-size:12px;font-weight:500;cursor:pointer;box-shadow:0 8px 24px #0000002e;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);animation:pill-in .2s ease-out;font-family:inherit}.jump-pill:hover{background:#000}@keyframes pill-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.transcript-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;color:var(--muted);gap:8px;padding:40px 20px;text-align:center}.transcript-empty .empty-title{color:var(--text);font-size:16px;font-weight:600}.transcript-empty .empty-hint{font-size:13px}.transcript-empty svg{color:#e4e4e7;margin-bottom:6px}.big-wb{animation:bar-flow 1.8s ease-in-out infinite;transform-origin:center;transform-box:fill-box}.big-wb.b1{animation-delay:0s}.big-wb.b2{animation-delay:.1s}.big-wb.b3{animation-delay:.2s}.big-wb.b4{animation-delay:.3s}.big-wb.b5{animation-delay:.4s}.big-wb.b6{animation-delay:.5s}.big-wb.b7{animation-delay:.6s}@keyframes bar-flow{0%,to{transform:scaleY(.7);opacity:.6}50%{transform:scaleY(1.15);opacity:1}}.bubble-row{position:relative;display:grid;grid-template-columns:3px 1fr;gap:12px;padding:14px 12px 14px 10px;border-radius:10px;animation:bubble-in .22s ease-out}@keyframes bubble-in{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.bubble-row:hover{background:#fafafa}.bubble-row+.bubble-row{margin-top:2px}.bubble-row.latest{animation:bubble-in .22s ease-out,latest-glow 1.4s ease-out}@keyframes latest-glow{0%{background:#6366f112}to{background:transparent}}.bubble-row[data-spk="0"] .spk-strip{background:linear-gradient(180deg,var(--spk-0-from),var(--spk-0-to))}.bubble-row[data-spk="1"] .spk-strip{background:linear-gradient(180deg,var(--spk-1-from),var(--spk-1-to))}.bubble-row[data-spk="2"] .spk-strip{background:linear-gradient(180deg,var(--spk-2-from),var(--spk-2-to))}.bubble-row[data-spk="3"] .spk-strip{background:linear-gradient(180deg,var(--spk-3-from),var(--spk-3-to))}.bubble-row[data-spk="4"] .spk-strip{background:linear-gradient(180deg,var(--spk-4-from),var(--spk-4-to))}.bubble-row[data-spk="5"] .spk-strip{background:linear-gradient(180deg,var(--spk-5-from),var(--spk-5-to))}.spk-strip{width:3px;border-radius:3px;align-self:stretch;background:#e4e4e7;opacity:.85}.bubble-body{min-width:0}.bubble-meta{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--muted);margin-bottom:6px;flex-wrap:wrap}.spk-name{font-weight:600;font-size:13px}.spk-name[data-spk="0"]{color:var(--spk-0-from)}.spk-name[data-spk="1"]{color:var(--spk-1-from)}.spk-name[data-spk="2"]{color:var(--spk-2-from)}.spk-name[data-spk="3"]{color:var(--spk-3-from)}.spk-name[data-spk="4"]{color:var(--spk-4-from)}.spk-name[data-spk="5"]{color:var(--spk-5-from)}.bubble-row.draft .spk-strip{background:linear-gradient(180deg,#d4d4d8,#a1a1aa)}.bubble-row.draft .spk-name,.bubble-row.draft .spk-name[data-spk]{color:var(--muted)}.bubble-row.draft .bubble-text{color:var(--text-2)}.bubble-row.draft.latest{animation:bubble-in .22s ease-out}.time-pill{background:var(--bg-soft);padding:1px 8px;border-radius:999px;font-family:var(--mono);font-size:11px;color:var(--text-2);border:1px solid var(--border)}.time-pill.subtle{color:var(--muted)}.bubble-text{font-size:15px;line-height:1.75;color:var(--text);word-break:break-word}.partial-row{display:grid;grid-template-columns:3px 1fr;gap:12px;padding:10px 12px 10px 10px;margin-top:4px}.partial-strip{background:linear-gradient(180deg,#d4d4d8,#a1a1aa)}.live-dot{width:8px;height:8px;border-radius:999px;background:var(--muted);box-shadow:0 0 0 3px #71717a24;animation:live-blink 1.1s ease-in-out infinite}.live-label{color:var(--muted);font-weight:600}@keyframes live-blink{50%{opacity:.45}}.loading-dots{display:inline-flex;align-items:center;gap:3px;margin-left:-4px}.loading-dots span{width:4px;height:4px;border-radius:999px;background:var(--muted);opacity:.45;animation:loading-dot 1.1s ease-in-out infinite}.loading-dots span:nth-child(2){animation-delay:.15s}.loading-dots span:nth-child(3){animation-delay:.3s}@keyframes loading-dot{0%,80%,to{opacity:.35;transform:translateY(0)}40%{opacity:.9;transform:translateY(-2px)}}.partial-text{color:var(--text-2);letter-spacing:.3px}.dropzone{border:1.5px dashed var(--border-strong);border-radius:var(--radius);padding:28px 20px;text-align:center;background:var(--bg-alt);cursor:pointer;transition:all .15s}.dropzone:hover,.dropzone.drag-over{background:#f0f9ff;border-color:var(--blue)}.dropzone .big{font-size:30px;opacity:.45}.dropzone .hint{color:var(--muted);margin-top:6px;font-size:13px}.dropzone .hint2{color:var(--muted);margin-top:2px;font-size:11px}.dropzone input[type=file]{display:none}.uploaded-audio{padding:12px;border:1px solid var(--border);border-radius:var(--radius-sm);background:#fff}.uploaded-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:10px}.uploaded-title{font-size:13px;font-weight:600;color:var(--text);word-break:break-all}.uploaded-meta{font-size:12px;color:var(--muted);margin-top:3px}.uploaded-audio audio{width:100%;display:block}.sidebar{display:flex;flex-direction:column;gap:16px;position:sticky;top:76px}.kv-list{display:flex;flex-direction:column;gap:8px;padding:14px 18px 16px}.kv{display:flex;justify-content:space-between;gap:12px;font-size:12.5px}.kv .k{color:var(--muted)}.kv .v{color:var(--text);font-family:var(--mono);text-align:right;word-break:break-all}.sidebar audio{width:100%;margin-top:10px}.error-banner{display:flex;gap:10px;align-items:flex-start;background:#fef2f2;border:1px solid #fecaca;color:#b91c1c;padding:10px 12px;border-radius:var(--radius-sm);font-size:13px;margin-top:12px;white-space:pre-wrap}.error-banner .err-msg{flex:1}.error-banner .err-close{background:transparent;border:none;color:#b91c1c;cursor:pointer;padding:0 4px;font-size:16px;line-height:1}.divider{height:1px;background:var(--border);margin:14px 0}.muted{color:var(--muted)}.hidden{display:none!important}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-thumb{background:#e4e4e7;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#d4d4d8}
