.app-footer[data-v-ce759869]{text-align:center;background:linear-gradient(to right, var(--bg-primary) 0%, color-mix(in srgb, var(--accent-primary) 4%, var(--bg-primary)) 50%, var(--bg-primary) 100%);background-image:linear-gradient(var(--bg-primary), var(--bg-primary)), linear-gradient(to right, transparent, var(--accent-primary), transparent);background-origin:padding-box,border-box;background-clip:padding-box,border-box;border-top:1px solid #0000;padding:14px 24px;animation:.6s both footerFadeIn-ce759869;position:relative}.footer-copy[data-v-ce759869]{color:var(--text-tertiary);letter-spacing:.01em;font-size:.73rem}.footer-brand[data-v-ce759869]{color:var(--text-secondary);font-weight:500}@keyframes footerFadeIn-ce759869{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}@media (width<=480px){.app-footer[data-v-ce759869]{padding:12px 16px}.footer-copy[data-v-ce759869]{font-size:.7rem}}@font-face{font-family:Inter;font-style:normal;font-weight:300 800;font-display:swap;src:url(/fonts/inter-cyrillic-ext.woff2)format("woff2");unicode-range:U+460-52F,U+1C80-1C8A,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F}@font-face{font-family:Inter;font-style:normal;font-weight:300 800;font-display:swap;src:url(/fonts/inter-cyrillic.woff2)format("woff2");unicode-range:U+301,U+400-45F,U+490-491,U+4B0-4B1,U+2116}@font-face{font-family:Inter;font-style:normal;font-weight:300 800;font-display:swap;src:url(/fonts/inter-vietnamese.woff2)format("woff2");unicode-range:U+102-103,U+110-111,U+128-129,U+168-169,U+1A0-1A1,U+1AF-1B0,U+300-301,U+303-304,U+308-309,U+323,U+329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Inter;font-style:normal;font-weight:300 800;font-display:swap;src:url(/fonts/inter-latin-ext.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Inter;font-style:normal;font-weight:300 800;font-display:swap;src:url(/fonts/inter-latin.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:JetBrains Mono;font-style:normal;font-weight:400 600;font-display:swap;src:url(/fonts/jetbrains-mono-cyrillic-ext.woff2)format("woff2");unicode-range:U+460-52F,U+1C80-1C8A,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F}@font-face{font-family:JetBrains Mono;font-style:normal;font-weight:400 600;font-display:swap;src:url(/fonts/jetbrains-mono-cyrillic.woff2)format("woff2");unicode-range:U+301,U+400-45F,U+490-491,U+4B0-4B1,U+2116}@font-face{font-family:JetBrains Mono;font-style:normal;font-weight:400 600;font-display:swap;src:url(/fonts/jetbrains-mono-latin-ext.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:JetBrains Mono;font-style:normal;font-weight:400 600;font-display:swap;src:url(/fonts/jetbrains-mono-latin.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}:root{--bg-primary:#eef5fc;--bg-secondary:#fff;--bg-tertiary:#e5f0fb;--bg-elevated:#fff;--bg-glass:#fffc;--bg-glass-border:#3d9be91f;--bg-input:#fff;--bg-hover:#3d9be90d;--bg-active:#3d9be91a;--bg-code:#0d2137;--bg-transcript:#e8f3fb;--text-transcript:#0d2137;--border-transcript:#3d9be91f;--surface-hover:#3d9be90f;--primary-glow:#3d9be940;--text-primary:#0d2137;--text-secondary:#1e4976;--text-tertiary:#6a9bc8;--text-inverse:#f0f7ff;--text-code:#a8d4f5;--border-primary:#3d9be926;--border-secondary:#3d9be914;--border-focus:#3d9be98c;--accent-primary:#3d9be9;--accent-primary-hover:#2d8fd4;--accent-gradient:linear-gradient(135deg, #3d9be9 0%, #1e4976 100%);--accent-gradient-soft:linear-gradient(135deg, #3d9be91f 0%, #1e497614 100%);--accent-glow:0 0 20px #3d9be94d;--danger:#ef4444;--danger-soft:#ef44441a;--warning:#f59e0b;--warning-soft:#f59e0b1a;--info:#3d9be9;--info-soft:#3d9be91a;--success:#10b981;--success-soft:#10b9811a;--shadow-sm:0 1px 2px #0000000a;--shadow-md:0 4px 16px #0000000f;--shadow-lg:0 12px 40px #00000014;--shadow-xl:0 24px 64px #0000001a;--radius-sm:8px;--radius-md:12px;--radius-lg:16px;--radius-xl:20px;--radius-full:9999px;--speaker-1:#1e40af;--speaker-2:#164e63;--speaker-3:#1f2937;--speaker-4:#2d3748;--speaker-5:#3f3f46;--speaker-6:#1a365d;--speaker-7:#44546f;--speaker-8:#374151;--speaker-9:#1e293b;--speaker-10:#2c5282;--speaker-11:#2d5016;--speaker-12:#334155;--speaker-13:#3f5f5f;--speaker-14:#1e3a5f;--speaker-15:#2d4a2b;--speaker-16:#4a3728;--speaker-17:#1f4d6d;--speaker-18:#3d3d4d;--speaker-19:#2d5563;--speaker-20:#475569}[data-theme=dark]{--bg-primary:#08101e;--bg-secondary:#0d2137;--bg-tertiary:#132236;--bg-elevated:#162840;--bg-glass:#0d2137e0;--bg-glass-border:#3d9be91f;--bg-input:#132236;--bg-hover:#3d9be90f;--bg-active:#3d9be924;--bg-code:#060e1a;--bg-transcript:#091628;--text-transcript:#a8d4f5;--border-transcript:#3d9be91a;--surface-hover:#3d9be914;--primary-glow:#3d9be959;--text-primary:#deedf9;--text-secondary:#a8d4f5;--text-tertiary:#4a7aab;--text-inverse:#0d2137;--text-code:#a8d4f5;--border-primary:#3d9be924;--border-secondary:#3d9be912;--border-focus:#3d9be9a6;--shadow-sm:0 1px 2px #0000004d;--shadow-md:0 4px 16px #00000073;--shadow-lg:0 12px 40px #0000008c;--shadow-xl:0 24px 64px #000000a6}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;scroll-padding-top:72px;font-size:15px}html,body,#app{min-height:100vh}body{background:var(--bg-primary);color:var(--text-primary);font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;line-height:1.6;transition:background .3s,color .3s}h1,h2,h3,h4,h5,h6{color:var(--text-primary);font-weight:600;line-height:1.3}h1{letter-spacing:-.03em;font-size:2rem;font-weight:800}h2{letter-spacing:-.02em;font-size:1.5rem;font-weight:700}h3{letter-spacing:-.01em;font-size:1.15rem;font-weight:600}h4{text-transform:uppercase;letter-spacing:.04em;color:var(--text-secondary);font-size:.95rem;font-weight:600}a{color:var(--accent-primary);text-decoration:none}a:hover{text-decoration:underline}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border-primary);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-tertiary)}.mono{font-family:JetBrains Mono,monospace}.truncate{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.app-root{flex-direction:column;min-height:100vh;display:flex}.app-bg{z-index:0;pointer-events:none;background:radial-gradient(at 15% 5%,#3d9be912,#0000 50%),radial-gradient(at 85% 15%,#a8d4f50d,#0000 45%),radial-gradient(at 50% 90%,#1e49760a,#0000 40%);position:fixed;inset:0}[data-theme=dark] .app-bg{background:radial-gradient(at 15% 5%,#3d9be917,#0000 50%),radial-gradient(at 85% 15%,#1e497614,#0000 45%),radial-gradient(at 50% 90%,#0d21370f,#0000 40%)}.app-content{z-index:1;flex:1;width:100%;max-width:1600px;margin:0 auto;padding:0 24px;position:relative}.card{background:var(--bg-glass);-webkit-backdrop-filter:blur(16px);border:1px solid var(--bg-glass-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);will-change:transform, box-shadow;transition:box-shadow .2s,transform .2s}.card:hover{box-shadow:var(--shadow-lg);transform:translateY(-1px)}.card-padded{padding:40px}.btn{border-radius:var(--radius-md);cursor:pointer;border:none;justify-content:center;align-items:center;gap:8px;min-height:40px;padding:10px 20px;font-family:inherit;font-size:.9rem;font-weight:600;transition:all .18s;display:inline-flex;position:relative;overflow:hidden}.btn:active{transition-duration:80ms;transform:translateY(0)scale(.97)!important}.btn:focus-visible{outline:2px solid var(--border-focus);outline-offset:2px}.btn:after{content:"";pointer-events:none;background:linear-gradient(#ffffff1a,#fff0);position:absolute;inset:0}.btn-primary{background:var(--accent-gradient);color:#fff;box-shadow:0 2px 12px #3d9be959}.btn-primary:hover{transform:translateY(-1px);box-shadow:0 4px 20px #3d9be973}.btn-secondary{background:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border-primary)}.btn-secondary:hover{background:var(--bg-hover);transform:translateY(-1px)}.btn-danger{background:var(--danger);color:#fff;box-shadow:0 2px 12px #ef44444d}.btn-danger:hover{transform:translateY(-1px);box-shadow:0 4px 20px #ef444466}.btn-ghost{color:var(--text-secondary);border:1px solid var(--border-primary);background:0 0}.btn-ghost:hover{background:var(--bg-hover);color:var(--text-primary)}.btn-sm{border-radius:var(--radius-sm);padding:6px 12px;font-size:.82rem}.btn-icon{border-radius:var(--radius-full);width:36px;height:36px;padding:0}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.input,.select{background:var(--bg-input);width:100%;color:var(--text-primary);border:1px solid var(--border-primary);border-radius:var(--radius-md);font:inherit;outline:none;min-height:40px;padding:10px 14px;font-size:.9rem;transition:border-color .18s,box-shadow .18s}.input:hover,.select:hover{border-color:var(--text-tertiary)}.input:focus,.select:focus{border-color:var(--border-focus);box-shadow:0 0 0 3px #3d9be926}.input::placeholder{color:var(--text-tertiary)}.select{cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='%2394a3b8' viewBox='0 0 16 16'%3E%3Cpath d='M8 11L3 6h10l-5 5z'/%3E%3C/svg%3E");background-position:right 12px center;background-repeat:no-repeat;padding-right:36px}.field{flex-direction:column;gap:6px;display:flex}.field-label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.04em;font-size:.82rem;font-weight:600}.badge{border-radius:var(--radius-full);text-transform:uppercase;letter-spacing:.04em;align-items:center;gap:4px;padding:3px 10px;font-size:.72rem;font-weight:600;display:inline-flex}.badge-success{background:var(--success-soft);color:var(--success)}.badge-danger{background:var(--danger-soft);color:var(--danger)}.badge-warning{background:var(--warning-soft);color:var(--warning)}.badge-info{background:var(--info-soft);color:var(--info)}.badge-neutral{background:var(--bg-tertiary);color:var(--text-secondary)}.status-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px;display:inline-block}.status-dot.connected{background:var(--success);box-shadow:0 0 8px var(--success)}.status-dot.connecting{background:var(--warning);animation:1.2s infinite pulse-dot}.status-dot.disconnected{background:var(--text-tertiary)}.status-dot.error{background:var(--danger);box-shadow:0 0 8px var(--danger)}.app-header{z-index:100;background:var(--bg-secondary);border-bottom:1px solid var(--border-primary);padding:12px 24px;position:sticky;top:0}.header-inner{justify-content:space-between;align-items:center;gap:16px;max-width:1600px;margin:0 auto;display:flex}.header-brand{align-items:center;gap:12px;display:flex}.header-brand h2{background:var(--accent-gradient);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:1.2rem}.header-controls{align-items:center;gap:12px;display:flex}.header-meta{color:var(--text-secondary);align-items:center;gap:8px;font-family:JetBrains Mono,monospace;font-size:.82rem;display:flex}.login-view{justify-content:center;align-items:center;min-height:100vh;padding:24px;display:flex}.login-card{flex-direction:column;gap:24px;width:min(460px,100%);padding:40px;display:flex}.login-card h1{text-align:center;background:var(--accent-gradient);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.login-subtitle{text-align:center;color:var(--text-secondary);font-size:.95rem}.login-form{flex-direction:column;gap:16px;display:flex}.login-error{color:var(--danger);text-align:center;background:var(--danger-soft);border-radius:var(--radius-sm);padding:8px;font-size:.88rem}.sidebar{flex-direction:column;gap:12px;display:flex;overflow-y:auto}.sidebar-section{flex-direction:column;gap:8px;display:flex}.sidebar-section h4{padding:0 4px}.sidebar-list{flex-direction:column;gap:4px;max-height:60vh;padding-right:4px;display:flex;overflow-y:auto}.sidebar-item{border-radius:var(--radius-md);cursor:pointer;text-align:left;color:var(--text-primary);font:inherit;background:0 0;border:1px solid #0000;flex-direction:column;gap:2px;padding:8px 12px;transition:background .15s,border-color .15s;display:flex;position:relative}.sidebar-item:hover{background:var(--bg-hover);border-color:var(--border-primary)}.sidebar-item:active{transform:scale(.99)}.sidebar-item.active{background:var(--bg-active);border-color:var(--accent-primary);padding-left:14px}.sidebar-item.active:before{content:"";background:var(--accent-primary);border-radius:0 2px 2px 0;width:3px;position:absolute;top:20%;bottom:20%;left:0}.sidebar-item-title{font-size:.9rem;font-weight:600}.sidebar-item-meta{color:var(--text-tertiary);align-items:center;gap:6px;font-size:.78rem;display:flex}.center-panel{flex-direction:column;gap:16px;display:flex;overflow:hidden}.recording-panel{flex-direction:column;gap:16px;display:flex}.recording-controls{flex-wrap:wrap;align-items:center;gap:12px;display:flex}.recording-settings{grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:10px;display:grid}.checkbox-field{border-radius:var(--radius-md);background:var(--bg-tertiary);cursor:pointer;align-items:center;gap:8px;padding:10px 14px;font-size:.88rem;font-weight:500;display:flex}.checkbox-field input{width:auto;accent-color:var(--accent-primary)}.record-btn-wrap{display:inline-flex;position:relative}.record-btn{background:var(--accent-gradient);color:#fff;cursor:pointer;z-index:1;border:none;border-radius:50%;justify-content:center;align-items:center;width:56px;height:56px;transition:transform .2s,box-shadow .2s;display:flex;position:relative;box-shadow:0 4px 20px #3d9be966}.record-btn:hover{transform:scale(1.06)}.record-btn.recording{background:var(--danger);box-shadow:0 4px 24px #ef444466}.record-btn svg{width:24px;height:24px}.record-pulse{border:2px solid var(--accent-primary);opacity:0;pointer-events:none;border-radius:50%;animation:none;position:absolute;inset:-8px}.record-btn.recording+.record-pulse{animation:1.5s ease-out infinite record-pulse}.visualizer-wrap{border-radius:var(--radius-md);background:var(--bg-transcript);width:100%;height:48px;overflow:hidden}.visualizer-wrap canvas{width:100%;height:100%;display:block}.transcript-panel{flex-direction:column;gap:12px;display:flex}.transcript-content{border-radius:var(--radius-md);background:var(--bg-transcript);color:var(--text-transcript);border:1px solid var(--border-transcript);white-space:pre-wrap;word-break:break-word;min-height:80px;max-height:300px;padding:16px;font-family:JetBrains Mono,monospace;font-size:.85rem;line-height:1.7;overflow-y:auto}.transcript-empty{color:var(--text-tertiary);text-align:center;justify-content:center;align-items:center;padding:32px;font-style:italic;display:flex}.timeline{flex-direction:column;gap:4px;display:flex}.timeline-item{border-radius:var(--radius-sm);align-items:center;gap:10px;padding:8px 12px;font-size:.82rem;transition:background .15s;display:flex}.timeline-item:hover{background:var(--bg-hover)}.timeline-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.timeline-dot.started{background:var(--warning);animation:1s infinite pulse-dot}.timeline-dot.completed{background:var(--success)}.timeline-dot.failed{background:var(--danger)}.timeline-label{color:var(--text-primary);min-width:100px;font-weight:600}.timeline-meta{color:var(--text-tertiary);font-family:JetBrains Mono,monospace;font-size:.78rem}.diarization-list{flex-direction:column;gap:6px;display:flex}.diarization-segment{border-radius:var(--radius-md);background:var(--bg-secondary);border:1px solid var(--border-secondary);border-left:3px solid var(--speaker-accent,var(--border-primary));opacity:0;flex-direction:column;gap:8px;padding:12px 14px 12px 16px;transition:box-shadow .2s,border-color .2s;animation:.4s forwards segment-slide-in;display:flex}.diarization-segment:hover{box-shadow:0 4px 16px -8px var(--speaker-accent,#0f172a26);border-color:var(--border-primary)}.diarization-segment.speaker-1{--speaker-accent:var(--speaker-1);--speaker-soft:#1e40af1a}.diarization-segment.speaker-2{--speaker-accent:var(--speaker-2);--speaker-soft:#164e631a}.diarization-segment.speaker-3{--speaker-accent:var(--speaker-3);--speaker-soft:#1f29371a}.diarization-segment.speaker-4{--speaker-accent:var(--speaker-4);--speaker-soft:#3f3f461a}.diarization-segment.speaker-5{--speaker-accent:var(--speaker-5);--speaker-soft:#2d37481a}.diarization-segment.speaker-6{--speaker-accent:var(--speaker-6);--speaker-soft:#1a365d1a}.diarization-segment.speaker-7{--speaker-accent:var(--speaker-7);--speaker-soft:#44546f1a}.diarization-segment.speaker-8{--speaker-accent:var(--speaker-8);--speaker-soft:#3741511a}.diarization-segment.speaker-9{--speaker-accent:var(--speaker-9);--speaker-soft:#1e293b1a}.diarization-segment.speaker-10{--speaker-accent:var(--speaker-10);--speaker-soft:#2c52821a}.diarization-segment.speaker-11{--speaker-accent:var(--speaker-11);--speaker-soft:#2d37481a}.diarization-segment.speaker-12{--speaker-accent:var(--speaker-12);--speaker-soft:#1f29371a}.diarization-segment.speaker-13{--speaker-accent:var(--speaker-13);--speaker-soft:#2d50161a}.diarization-segment.speaker-14{--speaker-accent:var(--speaker-14);--speaker-soft:#1e3a5f1a}.diarization-segment.speaker-15{--speaker-accent:var(--speaker-15);--speaker-soft:#3341551a}.diarization-segment.speaker-16{--speaker-accent:var(--speaker-16);--speaker-soft:#27272a1a}.diarization-segment.speaker-17{--speaker-accent:var(--speaker-17);--speaker-soft:#1f29371a}.diarization-segment.speaker-18{--speaker-accent:var(--speaker-18);--speaker-soft:#1e293b1a}.diarization-segment.speaker-19{--speaker-accent:var(--speaker-19);--speaker-soft:#3741511a}.diarization-segment.speaker-20{--speaker-accent:var(--speaker-20);--speaker-soft:#4b55631a}.segment-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:8px;display:flex}.speaker-meta{align-items:center;gap:10px;min-width:0;display:inline-flex}.speaker-avatar{color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:30px;height:30px;display:inline-flex}.speaker-avatar svg{flex-shrink:0;width:16px;height:16px;overflow:visible}.speaker-avatar.speaker-1{background:var(--speaker-1);--speaker-accent:var(--speaker-1)}.speaker-avatar.speaker-2{background:var(--speaker-2);--speaker-accent:var(--speaker-2)}.speaker-avatar.speaker-3{background:var(--speaker-3);--speaker-accent:var(--speaker-3)}.speaker-avatar.speaker-4{background:var(--speaker-4);--speaker-accent:var(--speaker-4)}.speaker-avatar.speaker-5{background:var(--speaker-5);--speaker-accent:var(--speaker-5)}.speaker-avatar.speaker-6{background:var(--speaker-6);--speaker-accent:var(--speaker-6)}.speaker-avatar.speaker-7{background:var(--speaker-7);--speaker-accent:var(--speaker-7)}.speaker-avatar.speaker-8{background:var(--speaker-8);--speaker-accent:var(--speaker-8)}.speaker-avatar.speaker-9{background:var(--speaker-9);--speaker-accent:var(--speaker-9)}.speaker-avatar.speaker-10{background:var(--speaker-10);--speaker-accent:var(--speaker-10)}.speaker-avatar.speaker-11{background:var(--speaker-11);--speaker-accent:var(--speaker-11)}.speaker-avatar.speaker-12{background:var(--speaker-12);--speaker-accent:var(--speaker-12)}.speaker-avatar.speaker-13{background:var(--speaker-13);--speaker-accent:var(--speaker-13)}.speaker-avatar.speaker-14{background:var(--speaker-14);--speaker-accent:var(--speaker-14)}.speaker-avatar.speaker-15{background:var(--speaker-15);--speaker-accent:var(--speaker-15)}.speaker-avatar.speaker-16{background:var(--speaker-16);--speaker-accent:var(--speaker-16)}.speaker-avatar.speaker-17{background:var(--speaker-17);--speaker-accent:var(--speaker-17)}.speaker-avatar.speaker-18{background:var(--speaker-18);--speaker-accent:var(--speaker-18)}.speaker-avatar.speaker-19{background:var(--speaker-19);--speaker-accent:var(--speaker-19)}.speaker-avatar.speaker-20{background:var(--speaker-20);--speaker-accent:var(--speaker-20)}.speaker-chip{border-radius:var(--radius-full);color:#fff;align-items:center;gap:6px;padding:4px 12px;font-size:.78rem;font-weight:700;display:inline-flex}.speaker-chip.speaker-1{background:var(--speaker-1)}.speaker-chip.speaker-2{background:var(--speaker-2)}.speaker-chip.speaker-3{background:var(--speaker-3)}.speaker-chip.speaker-4{background:var(--speaker-4)}.speaker-chip.speaker-5{background:var(--speaker-5)}.speaker-chip.speaker-6{background:var(--speaker-6)}.speaker-chip.speaker-7{background:var(--speaker-7)}.speaker-chip.speaker-8{background:var(--speaker-8)}.speaker-chip.speaker-9{background:var(--speaker-9)}.speaker-chip.speaker-10{background:var(--speaker-10)}.speaker-chip.speaker-11{background:var(--speaker-11)}.speaker-chip.speaker-12{background:var(--speaker-12)}.speaker-chip.speaker-13{background:var(--speaker-13)}.speaker-chip.speaker-14{background:var(--speaker-14)}.speaker-chip.speaker-15{background:var(--speaker-15)}.speaker-chip.speaker-16{background:var(--speaker-16)}.speaker-chip.speaker-17{background:var(--speaker-17)}.speaker-chip.speaker-18{background:var(--speaker-18)}.speaker-chip.speaker-19{background:var(--speaker-19)}.speaker-chip.speaker-20{background:var(--speaker-20)}.segment-time{color:var(--text-tertiary);font-family:JetBrains Mono,monospace;font-size:.78rem}.segment-text{color:var(--text-primary);font-size:.9rem;line-height:1.6}.diarization-list.is-compact .segment-text{-webkit-line-clamp:2;-webkit-box-orient:vertical;min-height:2.88rem;display:-webkit-box;overflow:hidden}.diarization-list.is-fullscreen .segment-text{white-space:pre-wrap;word-break:break-word}.segment-text .typing-cursor{background:var(--accent-primary);vertical-align:text-bottom;width:2px;height:1em;margin-left:2px;animation:.8s infinite cursor-blink;display:inline-block}.segment-player{border-radius:var(--radius-sm);background:var(--speaker-soft,var(--bg-tertiary));border:1px solid color-mix(in srgb, var(--speaker-accent,var(--accent-primary)) 20%, transparent);cursor:pointer;align-items:center;gap:8px;padding:6px 10px;transition:background .15s,border-color .15s;display:flex}.segment-player:hover{background:color-mix(in srgb, var(--speaker-accent,var(--accent-primary)) 18%, transparent)}.segment-player .play-btn{background:var(--speaker-accent,var(--accent-primary));color:#fff;cursor:pointer;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;transition:opacity .15s,transform .15s;display:flex}.segment-player .play-btn:hover{opacity:.85;transform:scale(1.08)}.segment-player .play-btn svg{width:13px;height:13px}.segment-player .loading-text{color:var(--text-tertiary);font-size:.78rem}.player-progress-wrap{flex:1;align-items:center;gap:8px;min-width:0;display:flex}.player-progress-bar{background:var(--border-secondary);cursor:pointer;border-radius:2px;flex:1;height:3px;overflow:hidden}.player-progress-fill{background:var(--speaker-accent,var(--accent-primary));border-radius:2px;height:100%;transition:width .1s linear}.player-time{color:var(--text-tertiary);white-space:nowrap;min-width:70px;font-size:.72rem}.events-panel{flex-direction:column;gap:12px;display:flex;overflow:hidden}.events-section{flex-direction:column;gap:6px;display:flex}.events-list{flex-direction:column;gap:4px;max-height:30vh;padding-right:4px;display:flex;overflow-y:auto}.event-item{border-radius:var(--radius-sm);background:var(--bg-secondary);border:1px solid var(--border-secondary);flex-direction:column;gap:2px;padding:8px 10px;font-size:.8rem;animation:.2s fade-in;display:flex}.event-item-header{justify-content:space-between;align-items:center;gap:8px;display:flex}.event-item-title{color:var(--text-primary);font-weight:600}.event-item-meta{color:var(--text-tertiary);font-family:JetBrains Mono,monospace;font-size:.72rem}.event-item-body{color:var(--text-secondary);font-size:.78rem;line-height:1.4}.status-banner{border-radius:var(--radius-md);align-items:center;gap:10px;padding:10px 16px;font-size:.85rem;font-weight:500;transition:all .3s;display:flex}.status-banner.idle{background:var(--bg-tertiary);color:var(--text-secondary)}.status-banner.processing{background:var(--accent-gradient-soft);color:var(--accent-primary)}.status-banner.success{background:var(--success-soft);color:var(--success)}.status-banner.error{background:var(--danger-soft);color:var(--danger)}.network-badge{border-radius:20px;align-items:center;gap:6px;margin-bottom:10px;padding:5px 14px;font-size:.82rem;font-weight:600;display:inline-flex}.network-badge--online{background:var(--success-soft);color:var(--success)}.network-badge--offline{background:var(--danger-soft);color:var(--danger)}.status-banner .spinner{border:2px solid #0000;border-top-color:currentColor;border-radius:50%;flex-shrink:0;width:16px;height:16px;animation:.8s linear infinite spin}.toast-container{z-index:10000;flex-direction:column;gap:8px;display:flex;position:fixed;bottom:20px;right:20px}.toast{border-radius:var(--radius-md);-webkit-backdrop-filter:blur(12px);box-shadow:var(--shadow-lg);max-width:380px;padding:12px 20px;font-size:.88rem;font-weight:500;animation:.3s toast-in}.toast.success{color:#fff;background:#10b981eb}.toast.error{color:#fff;background:#ef4444e6}.toast.info{color:#fff;background:#3b82f6e6}.toast-exit{animation:.3s forwards toast-out}.theme-toggle{border:1px solid var(--border-primary);background:var(--bg-secondary);width:36px;height:36px;color:var(--text-secondary);cursor:pointer;border-radius:50%;justify-content:center;align-items:center;font-size:1.1rem;transition:all .2s;display:flex}.theme-toggle:hover{background:var(--bg-hover);color:var(--text-primary);transform:rotate(20deg)}.audio-detail{flex-direction:column;gap:16px;display:flex}.audio-detail-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:10px;display:flex}.audio-detail-meta{grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:8px;display:grid}.detail-stat{border-radius:var(--radius-sm);background:var(--bg-tertiary);border:1px solid var(--border-secondary);padding:12px 16px;transition:border-color .18s}.detail-stat:hover{border-color:var(--border-primary)}.detail-stats-row{border:1px solid var(--border-primary);border-radius:var(--radius-md);background:var(--bg-secondary);align-items:stretch;display:flex;overflow:hidden}.detail-stat-flat{flex:1;padding:12px 24px}.detail-stat-flat:last-child{border-right:none}.section-header{justify-content:space-between;align-items:center;gap:8px;display:flex}.btn-expand{border:1px solid var(--border-primary);border-radius:var(--radius-sm);width:32px;height:32px;color:var(--text-tertiary);cursor:pointer;background:0 0;flex-shrink:0;justify-content:center;align-items:center;padding:0;transition:background .15s,color .15s,border-color .15s;display:inline-flex}.btn-expand:hover{background:var(--bg-hover);color:var(--text-primary);border-color:var(--text-tertiary)}.btn-expand:active{transform:scale(.94)}.fullscreen-overlay{z-index:9000;background:var(--bg-primary);flex-direction:column;height:100vh;display:flex;position:fixed;inset:0}.fullscreen-header{border-bottom:1px solid var(--border-primary);background:var(--bg-glass);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);flex-shrink:0;justify-content:space-between;align-items:center;padding:16px 24px;display:flex}.fullscreen-body{box-sizing:border-box;flex:1;width:100%;min-height:0;padding:32px 40px;overflow-y:auto}.fs-enter-active,.fs-leave-active{transition:opacity .2s,transform .2s}.fs-enter-from,.fs-leave-to{opacity:0;transform:scale(.98)}.detail-stat-label{color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.04em;font-size:.72rem;font-weight:600}.detail-stat-value{color:var(--text-primary);font-family:JetBrains Mono,monospace;font-size:1.1rem;font-weight:700}.tab-bar{background:var(--bg-tertiary);border-radius:var(--radius-md);gap:2px;padding:3px;display:flex}.tab-btn{border-radius:var(--radius-sm);color:var(--text-secondary);font:inherit;cursor:pointer;background:0 0;border:none;padding:8px 16px;font-size:.85rem;font-weight:600;transition:all .15s}.tab-btn:hover{color:var(--text-primary)}.tab-btn.active{background:var(--bg-secondary);color:var(--text-primary);box-shadow:var(--shadow-sm)}@media (width<=900px){.app-header{padding:10px 16px}.app-content{padding:0 12px}.recording-settings{grid-template-columns:1fr}}@keyframes pulse-dot{0%,to{opacity:1}50%{opacity:.4}}@keyframes record-pulse{0%{opacity:.6;transform:scale(1)}to{opacity:0;transform:scale(1.6)}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes fade-in{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}@keyframes segment-slide-in{0%{opacity:0;transform:translate(-12px)}to{opacity:1;transform:translate(0)}}@keyframes cursor-blink{0%,to{opacity:1}50%{opacity:0}}@keyframes toast-in{0%{opacity:0;transform:translateY(12px)scale(.95)}to{opacity:1;transform:translateY(0)scale(1)}}@keyframes toast-out{to{opacity:0;transform:translateY(12px)scale(.95)}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.hidden-input{display:none}.session-idle{text-align:center;flex-direction:column;align-items:center;gap:28px;display:flex;padding:48px 32px!important}.idle-hero{flex-direction:column;align-items:center;gap:12px;display:flex}.idle-hero h2{font-size:1.5rem}.idle-hero p{color:var(--text-secondary);max-width:480px;font-size:.95rem;line-height:1.6}.idle-steps{flex-wrap:wrap;justify-content:center;align-items:center;gap:12px;display:flex}.step-item{border-radius:var(--radius-md);background:var(--bg-tertiary);align-items:center;gap:8px;padding:10px 16px;font-size:.88rem;font-weight:500;display:flex}.step-num{background:var(--accent-gradient);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:24px;height:24px;font-size:.78rem;font-weight:700;display:flex}.step-arrow{color:var(--text-tertiary);font-size:1.2rem}.session-recording{flex-direction:column;gap:12px;display:flex}.live-panel{overflow:hidden}.live-header{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.live-header h3{align-items:center;gap:8px;display:flex}.live-dot{background:var(--danger);border-radius:50%;width:10px;height:10px;animation:1s infinite pulse-dot;display:inline-block}.live-text-area{border-radius:var(--radius-md);background:var(--bg-transcript);color:var(--text-transcript);border:1px solid var(--border-transcript);white-space:pre-wrap;word-break:break-word;min-height:120px;max-height:400px;padding:16px 20px;font-family:JetBrains Mono,monospace;font-size:.88rem;line-height:1.8;overflow-y:auto}.live-text{word-break:break-word}.live-waiting{color:var(--text-tertiary);justify-content:center;align-items:center;font-style:italic;display:flex}.typing-cursor{background:var(--accent-primary);vertical-align:text-bottom;width:2px;height:1em;margin-left:2px;animation:.8s infinite cursor-blink;display:inline-block}.live-chunk-line{border-bottom:1px solid var(--border-transcript);align-items:flex-start;gap:10px;padding:4px 0;animation:.3s fade-in;display:flex}.live-chunk-line:last-child{border-bottom:none}.chunk-time{color:var(--accent-primary);opacity:.8;flex-shrink:0;min-width:40px;font-family:JetBrains Mono,monospace;font-size:.75rem}.chunk-seq{color:var(--text-tertiary);flex-shrink:0;min-width:24px;font-family:JetBrains Mono,monospace;font-size:.72rem}.chunk-transcript{color:var(--text-transcript);font-size:.88rem;line-height:1.5}.session-processing{flex-direction:column;gap:12px;display:flex}.process-steps{overflow:hidden}.process-steps h3{margin-bottom:12px}.pipeline-steps{flex-direction:column;gap:6px;display:flex}.pipeline-step{border-radius:var(--radius-sm);background:var(--bg-tertiary);align-items:center;gap:12px;padding:12px 16px;font-size:.9rem;animation:.3s fade-in;display:flex}.pipeline-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.pipeline-dot.started{background:var(--warning);animation:1s infinite pulse-dot}.pipeline-dot.completed{background:var(--success)}.pipeline-dot.failed{background:var(--danger)}.pipeline-label{flex:1;font-weight:600}.pipeline-time{color:var(--accent-primary);margin-left:auto;padding-left:20px;font-family:JetBrains Mono,monospace;font-size:1.1rem;font-weight:700}.pipeline-waiting{color:var(--text-tertiary);align-items:center;gap:8px;padding:16px;font-size:.85rem;display:flex}.session-results{flex-direction:column;gap:12px;display:flex}.results-actions{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.result-section{overflow:hidden}.result-section h3{margin-bottom:10px}.result-transcript{border-radius:var(--radius-md);background:var(--bg-transcript);color:var(--text-transcript);border:1px solid var(--border-transcript);white-space:pre-wrap;word-break:break-word;max-height:300px;padding:16px 20px;font-family:JetBrains Mono,monospace;font-size:.88rem;line-height:1.8;overflow-y:auto}.chunk-list{flex-direction:column;gap:6px;display:flex}.chunk-item{border-radius:var(--radius-sm);background:var(--bg-tertiary);border:1px solid var(--border-secondary);padding:10px 14px;animation:.2s fade-in}.chunk-header{align-items:center;gap:8px;margin-bottom:4px;display:flex}.chunk-text{color:var(--text-primary);font-size:.88rem;line-height:1.5}.dashboard-layout{grid-template-columns:280px 1fr;gap:24px;min-height:calc(100vh - 60px);padding:24px 0;display:grid}@media (width<=900px){.dashboard-layout{grid-template-columns:1fr}}.markdown-body{color:var(--text-primary);white-space:normal;font-family:Inter,-apple-system,sans-serif;font-size:.92rem;line-height:1.7}.markdown-body h1{color:var(--accent-primary);text-align:center;letter-spacing:.18em;margin:.6em 0 .3em;font-size:1.25rem;font-weight:700}.markdown-body h2{color:var(--accent-primary);text-align:center;text-transform:uppercase;margin:1em 0 .4em;font-size:1rem;font-weight:700}.markdown-body h3,.markdown-body h4,.markdown-body h5,.markdown-body h6{color:var(--text-primary);margin:1em 0 .4em}.markdown-body p{margin:.5em 0;line-height:1.75}.markdown-body ul,.markdown-body ol{margin:.6em 0;padding-left:1.4em}.markdown-body li{margin:.3em 0}.markdown-body li p{margin:0}.markdown-body strong{color:var(--accent-primary);font-weight:700}.markdown-body em{color:var(--text-secondary)}.markdown-body code{background:var(--bg-transcript);color:var(--text-transcript);border:1px solid var(--border-transcript);border-radius:4px;padding:2px 6px;font-family:JetBrains Mono,monospace;font-size:.85em}.markdown-body pre{background:var(--bg-transcript);border:1px solid var(--border-transcript);border-radius:var(--radius-sm);padding:12px 16px;overflow-x:auto}.markdown-body pre code{background:0 0;border:none;padding:0}.markdown-body blockquote{border-left:3px solid var(--accent-primary);background:var(--accent-gradient-soft);border-radius:0 var(--radius-sm) var(--radius-sm) 0;margin:.8em 0;padding:6px 12px}.markdown-body hr{border:none;border-top:1px solid var(--border-primary);margin:1em 0}.markdown-body table{border-collapse:collapse;width:100%;margin:.8em 0}.markdown-body th,.markdown-body td{border:1px solid var(--border-primary);text-align:left;padding:8px 12px;font-size:.88rem}.markdown-body th{background:var(--bg-tertiary);font-weight:600}.detail-breadcrumb{align-items:center;gap:8px;margin-bottom:20px;font-size:.85rem;display:flex}.breadcrumb-back{border-radius:var(--radius-sm);border:1px solid var(--border-primary);color:var(--text-secondary);font:inherit;cursor:pointer;background:0 0;align-items:center;gap:5px;padding:5px 10px;font-size:.82rem;transition:background .15s,color .15s;display:inline-flex}.breadcrumb-back:hover{background:var(--bg-hover);color:var(--text-primary)}.breadcrumb-sep{color:var(--text-tertiary)}.breadcrumb-current{color:var(--text-secondary);text-overflow:ellipsis;white-space:nowrap;max-width:300px;font-weight:500;overflow:hidden}.audio-detail-meta-row{flex-wrap:wrap;align-items:center;gap:6px;margin-top:4px;display:flex}.detail-meta-chip{color:var(--text-tertiary);background:var(--bg-tertiary);border:1px solid var(--border-primary);border-radius:var(--radius-full);padding:2px 8px;font-family:JetBrains Mono,monospace;font-size:.75rem}.mic-error-banner{border-radius:var(--radius-md);background:var(--danger-soft);border:1px solid #ef444440;align-items:flex-start;gap:16px;margin-bottom:24px;padding:18px 20px;animation:.3s fade-in;display:flex}.mic-error-icon{color:var(--danger);flex-shrink:0;margin-top:2px}.mic-error-body{flex-direction:column;flex:1;gap:6px;display:flex}.mic-error-title{color:var(--danger);font-size:.95rem;font-weight:700}.mic-error-message{color:var(--text-primary);font-size:.88rem;line-height:1.5}.mic-error-hint{color:var(--text-secondary);border-radius:var(--radius-sm);border-left:3px solid var(--danger);background:#ef44440f;padding:8px 12px;font-size:.82rem;line-height:1.5}.mic-error-hint strong{color:var(--danger)}.mic-error-close{color:var(--danger);border-color:#ef44444d;flex-shrink:0;align-self:flex-start;font-size:1rem;line-height:1}.mic-error-close:hover{background:#ef44441a}
