:root{--live-transcript-font-scale: 1}:root,[data-theme=dark]{--bg: #0f1115;--text: #e8eaed;--text-muted: #9aa0a6;--link: #8ab4f8;--panel-bg: #1a1d23;--border: #3c4043;--border-subtle: #2d3139;--error: #f28b82;--warning-bg: rgba(253, 214, 99, .15);--warning-border: rgba(253, 214, 99, .45);--warning-text: #fdd663;--accent: #8ab4f8;--fab-bg: #1f2a40;--fab-hover: #2a3a56;--live-trans-word-from: #6b7280;--live-trans-word-to: #e8eaed;--input-bg: #1a1d23;--shadow-fab: 0 2px 8px rgba(0, 0, 0, .35)}[data-theme=light]{--bg: #f4f6f8;--text: #1c1c1c;--text-muted: #5f6368;--link: #1a73e8;--panel-bg: #ffffff;--border: #dadce0;--border-subtle: #e8eaed;--error: #c5221f;--warning-bg: rgba(251, 188, 4, .18);--warning-border: rgba(251, 188, 4, .55);--warning-text: #b06000;--accent: #1a73e8;--fab-bg: #e8f0fe;--fab-hover: #d2e3fc;--live-trans-word-from: #9ca3af;--live-trans-word-to: #111827;--input-bg: #ffffff;--shadow-fab: 0 2px 8px rgba(60, 64, 67, .2)}:root{font-family:system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,Cantarell,Noto Sans,sans-serif;line-height:1.5;font-weight:400;color:var(--text);background-color:var(--bg)}*{box-sizing:border-box}html{height:100%}body{margin:0;min-height:100%;min-height:100dvh;height:100%;background-color:var(--bg);color:var(--text)}#root{height:100%;min-height:100dvh;display:flex;flex-direction:column}a{color:var(--link)}button,input,select,textarea{font:inherit}button{cursor:pointer}.app-shell{flex:1;min-height:0;display:flex;flex-direction:column;height:100%;min-height:100dvh;max-height:100dvh;background:var(--bg);color:var(--text);overflow:hidden}.app-header{flex-shrink:0;display:flex;align-items:center;gap:.75rem;padding:.5rem 1rem;border-bottom:1px solid var(--border);background:var(--bg)}.app-brand{display:inline-flex;align-items:center;gap:.5rem;color:inherit;margin-right:auto}.app-brand-name{font-weight:700;font-size:1.1rem;letter-spacing:-.02em}.app-logo{display:block;height:32px;width:auto;max-width:7.5rem}.app-theme-toggle{display:inline-flex;align-items:center;justify-content:center;width:2.25rem;height:2.25rem;padding:0;border-radius:8px;border:1px solid var(--border);background:var(--panel-bg);color:var(--text)}.app-theme-toggle:hover{background:var(--border-subtle)}.app-main{flex:1;min-height:0;display:flex;flex-direction:column;overflow:auto}.app-main--root-placeholder{align-items:center;justify-content:center;padding:2rem}.app-root-placeholder-message{margin:0;font-size:1rem;color:var(--text);opacity:.85;text-align:center}.app-main:has(>.live-layout),.app-main:has(>.live-text-tv-layout){overflow:hidden}.app-main>.live-layout,.app-main>.live-text-tv-layout{flex:1;min-height:0;max-height:100%;overflow:hidden}.live-layout{display:grid;grid-template-columns:1fr 1fr;gap:1rem;min-height:0;height:100%;max-height:100%;padding:1rem;box-sizing:border-box;align-items:stretch}.live-layout>*{min-height:0}.live-col-stream{display:flex;flex-direction:column;min-width:0;min-height:0}.live-stream-header{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin-bottom:.5rem}.live-stream-header .live-heading{margin-bottom:0}.live-network-health{display:inline-flex;align-items:center;gap:6px;font-size:.8rem;line-height:1.2;padding:4px 10px;border-radius:999px;border:1px solid var(--border);background:var(--panel-bg);color:var(--text)}.live-network-health-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.live-network-health--good .live-network-health-dot{background:#34a853;box-shadow:0 0 6px #34a85373}.live-network-health--degraded .live-network-health-dot{background:#f9ab00}.live-network-health--poor .live-network-health-dot{background:#ea4335}.live-network-health-hint{opacity:.75;font-weight:400}.live-video{max-height:min(42vh,400px);flex:0 1 auto}.live-video-frame{position:relative;width:100%;display:block;border-radius:8px;overflow:hidden}.live-video-subtitles{--live-subtitle-line-ch: 38;position:absolute;left:0;right:0;bottom:0;padding:12px 10px 16px;pointer-events:none;background:linear-gradient(transparent,#0000008c)}.live-video-subtitles-inner{display:flex;flex-direction:column;justify-content:flex-start;align-items:stretch;max-width:min(100%,calc(var(--live-subtitle-line-ch, 38) * 1ch + 2.5rem));margin:0 auto;padding:.5rem .85rem .65rem;text-align:center;border-radius:10px;background:#00000094;border:1px solid rgba(255,255,255,.12);box-shadow:0 4px 20px #00000073;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);box-sizing:border-box}.live-subtitle-fade-chunk{animation:live-subtitle-fade-chunk .32s ease-out both}@media(prefers-reduced-motion:reduce){.live-subtitle-fade-chunk{animation:none}}@keyframes live-subtitle-fade-chunk{0%{opacity:.35;filter:blur(1px)}to{opacity:1;filter:blur(0)}}.live-video-subtitles-placeholder{color:transparent;text-shadow:none}.live-video-subtitles-line{flex:0 0 auto;width:100%;font-size:clamp(.92rem,2.1vw,1.12rem);font-weight:600;line-height:1.48;min-height:1.48em;color:#fafafa;text-shadow:0 0 1px #000,0 1px 2px rgba(0,0,0,.95),0 2px 12px rgba(0,0,0,.75),0 0 3px rgba(0,0,0,1);letter-spacing:.02em;word-break:break-word;text-align:center;align-self:stretch}.live-stream-controls .live-cc-btn{padding:.25rem .5rem;border-radius:6px;border:1px solid var(--border);background:var(--panel-bg);color:var(--text);font-size:12px}.live-stream-controls .live-cc-btn[aria-pressed=true]{border-color:var(--accent);font-weight:600}.live-cc-source{display:inline-flex;align-items:center;gap:6px;font-size:12px;color:var(--text-muted)}.live-cc-source-label{-webkit-user-select:none;user-select:none}.live-cc-source select{padding:.2rem .35rem;border-radius:6px;border:1px solid var(--border);background:var(--input-bg);color:var(--text);font-size:12px;max-width:11rem}.live-col-text{display:flex;flex-direction:column;min-width:0;min-height:0}.live-transcript-wrap{position:relative;flex:1;min-height:0;display:flex;flex-direction:column;margin-top:8px}.live-transcript-scroll{flex:1;min-height:0;overflow-y:auto;padding:.75rem;background:var(--panel-bg);border-radius:8px;line-height:1.2;outline:none;border:1px solid var(--border-subtle);font-size:calc(1rem * var(--live-transcript-font-scale, 1));overscroll-behavior:contain}@media(prefers-reduced-motion:no-preference){.live-transcript-scroll,.live-transcript-scroll--tv{scroll-behavior:smooth}}.live-heading{margin-top:0;font-size:1rem;flex-shrink:0}.live-heading-inline{margin:0;font-size:1rem}.live-text-tv-layout{display:flex;flex-direction:column;flex:1;min-height:0;width:100%;padding:1rem;box-sizing:border-box}.live-transcript-wrap--tv:fullscreen,.live-transcript-wrap--tv:-webkit-full-screen{display:flex;flex-direction:column;flex:1;min-height:100%;width:100%;margin:0;padding:0;box-sizing:border-box;background:var(--bg)}.live-tv-fullscreen-btn{font-weight:500;padding:.35rem .65rem;border-radius:8px;border:1px solid var(--border);background:var(--panel-bg);color:var(--text);font-size:.85rem;white-space:nowrap}.live-tv-fullscreen-btn:hover{background:var(--border-subtle)}.live-tv-fullscreen-btn[aria-pressed=true]{border-color:var(--accent);font-weight:600}.live-toolbar--tv{margin-bottom:4px}.live-heading-tv{flex:1;min-width:8rem}.live-view-switch-group{display:inline-flex;align-items:stretch;border:1px solid var(--border);border-radius:8px;overflow:hidden;background:var(--panel-bg)}a.live-view-switch{display:inline-flex;align-items:center;justify-content:center;padding:.35rem .65rem;font-size:.85rem;font-weight:500;color:var(--text-muted);text-decoration:none;border-right:1px solid var(--border-subtle)}a.live-view-switch:last-child{border-right:none}a.live-view-switch:hover{background:var(--border-subtle);color:var(--text)}a.live-view-switch.live-view-switch--active{background:var(--border-subtle);color:var(--text);font-weight:700}.live-error--tv{flex-shrink:0;margin:0 0 8px}.live-transcript-wrap--tv{flex:1;min-height:0;margin-top:0}.live-transcript-scroll--tv{flex:1;min-height:0;align-self:stretch;width:100%;padding:1rem 1.35rem;box-sizing:border-box;background:var(--bg);border:none;border-radius:8px;font-size:calc(9vh * var(--live-transcript-font-scale, 1));line-height:1.2;white-space:normal;word-break:normal;overflow-wrap:break-word;overscroll-behavior:contain}.live-transcript-scroll--tv-fs{overflow:hidden!important;touch-action:none;overscroll-behavior:none}br.live-tv-br{margin:0;line-height:0}.live-toolbar{display:flex;align-items:center;gap:12px;flex-wrap:wrap;flex-shrink:0}.live-font-scale{display:inline-flex;align-items:center;margin-left:auto;border:1px solid var(--border);border-radius:8px;overflow:hidden;background:var(--panel-bg)}.live-font-scale button{display:inline-flex;align-items:center;justify-content:center;min-width:2rem;height:2.25rem;padding:0 .35rem;border:none;background:transparent;color:var(--text);font-size:.85rem;font-weight:600;line-height:1}.live-font-scale button:hover:not(:disabled){background:var(--border-subtle)}.live-font-scale button:disabled{opacity:.35;cursor:not-allowed}.live-font-scale-sep{width:1px;align-self:stretch;background:var(--border)}.live-tab-group{display:flex;gap:6px}.live-tab-btn{font-weight:400;padding:.35rem .6rem;border-radius:6px;border:1px solid var(--border);background:var(--panel-bg);color:var(--text)}.live-tab-btn[aria-pressed=true]{font-weight:700;border-color:var(--accent)}.live-error{color:var(--error)}.live-hint{font-size:12px;opacity:.75;flex-shrink:0}.live-muted{opacity:.6}.live-speaker{display:block;margin-top:0;margin-bottom:4px;font-size:.75em;font-weight:600}.live-spk-label-none{color:var(--text-muted)}.live-speaker-spaced{margin-top:10px}.live-spk-line-none.live-text-final{color:var(--text)}.live-spk-line-none.live-text-partial,.live-text-trans-partial.live-spk-line-none{color:var(--text-muted)}[data-theme=dark] .live-transcript-scroll .live-spk-line-0{color:#b5c9e0;--live-trans-word-from: #5a6a7a;--live-trans-word-to: #b5c9e0}[data-theme=dark] .live-transcript-scroll .live-spk-label-0{color:#9eb4cc}[data-theme=dark] .live-transcript-scroll .live-spk-line-1{color:#d2c4e8;--live-trans-word-from: #6a5c78;--live-trans-word-to: #d2c4e8}[data-theme=dark] .live-transcript-scroll .live-spk-label-1{color:#b8a8d4}[data-theme=dark] .live-transcript-scroll .live-spk-line-2{color:#b8e4d4;--live-trans-word-from: #4c6a62;--live-trans-word-to: #b8e4d4}[data-theme=dark] .live-transcript-scroll .live-spk-label-2{color:#9ecaba}[data-theme=dark] .live-transcript-scroll .live-spk-line-3{color:#edd4b8;--live-trans-word-from: #7a6a52;--live-trans-word-to: #edd4b8}[data-theme=dark] .live-transcript-scroll .live-spk-label-3{color:#d4baa0}[data-theme=dark] .live-transcript-scroll .live-spk-line-4{color:#e4c8dc;--live-trans-word-from: #6e5a68;--live-trans-word-to: #e4c8dc}[data-theme=dark] .live-transcript-scroll .live-spk-label-4{color:#c8a8bc}[data-theme=dark] .live-transcript-scroll .live-spk-line-5{color:#d0e8b8;--live-trans-word-from: #5c6e4a;--live-trans-word-to: #d0e8b8}[data-theme=dark] .live-transcript-scroll .live-spk-label-5{color:#b4d49a}[data-theme=dark] .live-transcript-scroll .live-spk-line-6{color:#b8dcf4;--live-trans-word-from: #4a5c6e;--live-trans-word-to: #b8dcf4}[data-theme=dark] .live-transcript-scroll .live-spk-label-6{color:#9ec4dc}[data-theme=dark] .live-transcript-scroll .live-spk-line-7{color:#e8e0c8;--live-trans-word-from: #6e6858;--live-trans-word-to: #e8e0c8}[data-theme=dark] .live-transcript-scroll .live-spk-label-7{color:#d0c8a8}[data-theme=light] .live-transcript-scroll .live-spk-line-0{color:#2d4a6a;--live-trans-word-from: #9aa8b8;--live-trans-word-to: #2d4a6a}[data-theme=light] .live-transcript-scroll .live-spk-label-0{color:#4a6282}[data-theme=light] .live-transcript-scroll .live-spk-line-1{color:#5a3d6e;--live-trans-word-from: #a898b8;--live-trans-word-to: #5a3d6e}[data-theme=light] .live-transcript-scroll .live-spk-label-1{color:#6e5088}[data-theme=light] .live-transcript-scroll .live-spk-line-2{color:#2d6a52;--live-trans-word-from: #8ab8a4;--live-trans-word-to: #2d6a52}[data-theme=light] .live-transcript-scroll .live-spk-label-2{color:#3d8268}[data-theme=light] .live-transcript-scroll .live-spk-line-3{color:#8a5a2a;--live-trans-word-from: #c4a888;--live-trans-word-to: #8a5a2a}[data-theme=light] .live-transcript-scroll .live-spk-label-3{color:#a06e3a}[data-theme=light] .live-transcript-scroll .live-spk-line-4{color:#6a3d58;--live-trans-word-from: #b898a8;--live-trans-word-to: #6a3d58}[data-theme=light] .live-transcript-scroll .live-spk-label-4{color:#825470}[data-theme=light] .live-transcript-scroll .live-spk-line-5{color:#4a6228;--live-trans-word-from: #a8b888;--live-trans-word-to: #4a6228}[data-theme=light] .live-transcript-scroll .live-spk-label-5{color:#5c7838}[data-theme=light] .live-transcript-scroll .live-spk-line-6{color:#2a5880;--live-trans-word-from: #88a8c8;--live-trans-word-to: #2a5880}[data-theme=light] .live-transcript-scroll .live-spk-label-6{color:#3d6a98}[data-theme=light] .live-transcript-scroll .live-spk-line-7{color:#6a5a38;--live-trans-word-from: #b8a888;--live-trans-word-to: #6a5a38}[data-theme=light] .live-transcript-scroll .live-spk-label-7{color:#827048}.live-transcript-scroll [class*=live-spk-line-]:not(.live-spk-line-none).live-text-partial,.live-transcript-scroll [class*=live-spk-line-]:not(.live-spk-line-none).live-text-trans-partial{opacity:.78}@keyframes live-trans-word-reveal{0%{color:var(--live-trans-word-from)}to{color:var(--live-trans-word-to)}}.live-trans-reveal-seg{display:inline;animation:live-trans-word-reveal .35s ease-out forwards}@media(prefers-reduced-motion:reduce){.live-trans-reveal-seg{animation:none;color:var(--live-trans-word-to)}}.live-jump-fab{position:absolute;right:12px;bottom:12px;z-index:2;padding:.5rem .85rem;border-radius:999px;border:1px solid var(--accent);background:var(--fab-bg);color:var(--text);font-size:.85rem;font-weight:600;box-shadow:var(--shadow-fab)}.live-jump-fab:hover{background:var(--fab-hover)}@media(max-width:900px){.live-layout{grid-template-columns:1fr}}@media(orientation:portrait){.live-layout{display:flex;flex-direction:column;flex:1;min-height:0;max-height:100%;padding:.75rem}.live-col-stream{flex:0 0 auto}.live-col-text{flex:1 1 0;min-height:0;min-width:0}.live-transcript-wrap{flex:1;min-height:0}}.app-field-input{padding:.5rem .6rem;border-radius:6px;border:1px solid var(--border);background:var(--input-bg);color:var(--text)}.app-table-wrap{overflow-x:auto;border:1px solid var(--border);border-radius:8px}.app-table{width:100%;border-collapse:collapse;font-size:13px}.app-table thead tr{text-align:left;border-bottom:1px solid var(--border)}.app-table tbody tr{border-bottom:1px solid var(--border-subtle)}.app-table th,.app-table td{padding:.45rem .6rem}.admin-export-btn{padding:0;border:none;background:none;color:var(--link);text-decoration:underline;cursor:pointer;font:inherit;font-size:inherit}.admin-export-btn:hover{opacity:.85}
