:root{color-scheme:dark;--bg: #000000;--bg-elevated: #0e0e0f;--bg-modal: #18181a;--text: #ffffff;--text-muted: rgba(255, 255, 255, .6);--text-faint: rgba(255, 255, 255, .4);--border: rgba(255, 255, 255, .1);--border-strong: rgba(255, 255, 255, .2);--accent: #22c55e;--amber: #f59e0b;--red: #ef4444;--hud-bg: rgba(20, 20, 22, .85);--shadow-lg: 0 20px 60px -15px rgba(0, 0, 0, .7);--radius-sm: 8px;--radius-md: 12px;--radius-lg: 18px;--transition: .2s ease}*,*:before,*:after{box-sizing:border-box}[hidden]{display:none!important}html,body{margin:0;padding:0;height:100%;background:var(--caption-bg, var(--bg));color:var(--text);font-family:Inter,ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow:hidden;overscroll-behavior:none}#app{height:100%}button{font:inherit}.brand{display:inline-flex;align-items:center;gap:.55rem}.brand-mark{width:1.2em;height:1.2em;border-radius:.28em;background:#0a0a0a;position:relative;flex-shrink:0;box-shadow:inset 0 0 0 1px var(--border)}.brand-mark:before{content:"";position:absolute;left:30%;top:22%;width:12%;height:50%;background:#fff;border-radius:1.5px 1.5px 0 0}.brand-mark:after{content:"";position:absolute;left:30%;top:65%;width:40%;height:12%;background:#fff;border-radius:0 0 1.5px 1.5px}.brand-text{font-weight:700;letter-spacing:-.02em;font-size:1.05em}.brand-large{font-size:2.4rem}.brand-large .brand-mark:before,.brand-large .brand-mark:after{background:#fff}.brand-large .brand-mark{box-shadow:inset 0 0 0 1.5px var(--border-strong)}.live{position:relative;width:100%;height:100%}.captions{position:absolute;inset:0;display:flex;flex-direction:column;justify-content:flex-end;align-items:center;padding-top:6vh;padding-left:5vw;padding-right:5vw;padding-bottom:calc((100 - var(--caption-vert-pos, 80)) * .74vh + 6vh);text-align:center;gap:1.4vh;pointer-events:none;overflow:hidden;transition:padding-bottom .25s ease}.caption-block{display:flex;flex-direction:column;align-items:center;gap:.4em;max-width:92vw;width:100%;animation:caption-enter .45s cubic-bezier(.22,1,.36,1);transform-origin:bottom center;will-change:transform,opacity}.caption-block.caption-block-exit{animation:caption-exit .18s ease-in forwards;pointer-events:none}@keyframes caption-enter{0%{opacity:0;transform:translateY(28px)}to{opacity:1;transform:translateY(0)}}@keyframes caption-exit{to{opacity:0;transform:translateY(-24px);max-height:0;margin-top:-1.4vh}}.caption-source{font-size:calc(clamp(1.2rem,3vw,3.2rem) * var(--font-scale, 1));font-weight:400;color:var(--text-faint);line-height:var(--line-height, 1.2);font-style:italic;letter-spacing:var(--letter-spacing, -.005em);font-family:var(--caption-font, inherit);text-shadow:var(--caption-shadow, none)}.caption-target{font-size:calc(clamp(2.6rem,7vw,9rem) * var(--font-scale, 1));font-weight:600;line-height:var(--line-height, 1.15);letter-spacing:var(--letter-spacing, -.005em);color:var(--font-color, var(--text));font-family:var(--caption-font, inherit);word-wrap:break-word;text-shadow:var(--caption-shadow, none)}.hint{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1.5rem;text-align:center;padding:2rem;pointer-events:none;transition:opacity var(--transition)}.hint p{margin:0;font-size:1.05rem;color:var(--text-muted);max-width:32ch}.hint p strong{color:var(--text);font-weight:600}.hud{position:fixed;left:0;right:0;bottom:0;padding:1.25rem 1.5rem calc(1.25rem + env(safe-area-inset-bottom));display:flex;align-items:center;justify-content:space-between;gap:1rem;z-index:10;pointer-events:none;transition:opacity .4s ease,transform .4s ease}.hud>*{pointer-events:auto}body[data-hud-visible=false] .hud{opacity:0;transform:translateY(8px)}.hud-left,.hud-right{display:flex;align-items:center;gap:.6rem}.status{display:inline-flex;align-items:center;gap:.5rem;padding:.45rem .85rem;border-radius:999px;background:var(--hud-bg);border:1px solid var(--border);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);font-size:.78rem;font-weight:500;letter-spacing:.01em;white-space:nowrap;max-width:50vw;overflow:hidden;text-overflow:ellipsis}.status-dot{width:7px;height:7px;border-radius:50%;background:#888;flex-shrink:0}.status[data-state=connecting] .status-dot,.status[data-state=reconnecting] .status-dot{background:var(--amber);animation:pulse 1.1s ease-in-out infinite}.status[data-state=live] .status-dot{background:var(--accent);box-shadow:0 0 0 3px #22c55e2e}.status[data-state=error] .status-dot{background:var(--red)}@keyframes pulse{0%,to{opacity:1}50%{opacity:.35}}.timer{font-variant-numeric:tabular-nums;font-size:.78rem;font-weight:500;color:var(--text-muted);padding:.45rem .7rem;border-radius:999px;background:var(--hud-bg);border:1px solid var(--border);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}.waveform-host{width:140px;height:36px;border-radius:999px;background:transparent;overflow:hidden}.btn-primary,.btn-secondary,.icon-btn{cursor:pointer;font-weight:600;border-radius:999px;transition:background var(--transition),color var(--transition),transform .05s ease,border-color var(--transition);font-size:.9rem}.btn-primary{background:#fff;color:#000;border:none;padding:.65rem 1.4rem}.btn-primary:hover{background:#e8e8e8}.btn-primary:active{transform:scale(.97)}.btn-primary:disabled{background:#fff3;color:#ffffff80;cursor:wait}.btn-secondary{background:#ffffff14;color:var(--text);border:1px solid var(--border);padding:.6rem 1.2rem}.btn-secondary:hover{background:#ffffff24;border-color:var(--border-strong)}.btn-secondary:active{transform:scale(.97)}.icon-btn{background:var(--hud-bg);border:1px solid var(--border);color:var(--text-muted);width:40px;height:40px;display:inline-flex;align-items:center;justify-content:center;padding:0;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}.icon-btn:hover{color:var(--text);border-color:var(--border-strong)}.icon-btn:active{transform:scale(.94)}.error-banner{position:fixed;bottom:calc(1.25rem + env(safe-area-inset-bottom));left:1.5rem;max-width:min(90vw,480px);background:#ef44441f;border:1px solid rgba(239,68,68,.4);color:#fecaca;padding:.7rem 1rem;border-radius:var(--radius-md);display:flex;align-items:center;gap:.75rem;font-size:.85rem;z-index:20;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}.error-banner span{flex:1}.error-banner .btn-secondary{padding:.4rem .9rem;font-size:.8rem;background:#ffffff1a;color:#fff;border-color:#ffffff26}body[data-viewer=true]{cursor:none}body[data-viewer=true]:hover{cursor:default}.viewer{position:relative;width:100%;height:100%}.viewer-hint{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;margin:0;text-align:center;color:var(--text-faint);font-size:1.1rem;line-height:1.6;padding:2rem;pointer-events:none}.viewer-hint strong{color:var(--text);font-weight:600}.settings-panel{--panel-width: 420px;position:fixed;top:0;right:0;height:100dvh;width:var(--panel-width);max-width:100vw;background:var(--bg-modal);border-left:1px solid var(--border);box-shadow:var(--shadow-lg);display:grid;grid-template-rows:auto 1fr auto;overflow:hidden;z-index:100;transform:translate(100%);transition:transform .25s ease}.settings-panel[data-open]{transform:translate(0)}body[data-settings-open=true] .live .captions{padding-right:calc(var(--panel-width, 420px) + 4vw);transition:padding-right .25s ease}@media(max-width:800px){.settings-panel{--panel-width: 100vw;border-left:none}body[data-settings-open=true] .live .captions{padding-right:4vw}}.settings-panel-header{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;padding:1.5rem 1.5rem .75rem;border-bottom:1px solid var(--border)}.settings-panel-header h2{margin:0;font-size:1.3rem;font-weight:600;letter-spacing:-.02em}.modal-subtitle{margin:.4rem 0 0;color:var(--text-muted);font-size:.92rem;line-height:1.45}.modal-close{background:transparent;color:var(--text-muted);border:none;font-size:1.6rem;width:32px;height:32px;border-radius:var(--radius-sm);cursor:pointer;line-height:1;display:flex;align-items:center;justify-content:center;flex-shrink:0}.modal-close:hover{background:#ffffff14;color:var(--text)}.settings-scroll{min-height:0;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;overscroll-behavior:contain}.settings-form{padding:1.25rem 1.5rem 1.5rem;display:flex;flex-direction:column;gap:.85rem}details.form-section{border:1px solid var(--border);border-radius:var(--radius-md);overflow:hidden;background:#ffffff05}details.form-section>summary{list-style:none;cursor:pointer;padding:.85rem 1rem;font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);display:flex;align-items:center;justify-content:space-between;user-select:none;transition:background var(--transition)}details.form-section>summary::-webkit-details-marker{display:none}details.form-section>summary:after{content:"";width:9px;height:9px;border-right:2px solid currentColor;border-bottom:2px solid currentColor;transform:rotate(45deg) translate(-2px,-2px);transition:transform .2s ease;margin-left:.5rem}details.form-section[open]>summary:after{transform:rotate(-135deg) translate(-2px,-2px)}details.form-section>summary:hover{background:#ffffff0a;color:var(--text)}details.form-section .section-content{padding:.5rem 1rem 1.1rem;display:flex;flex-direction:column;gap:.95rem;border-top:1px solid var(--border)}.color-row{display:flex;gap:.6rem;align-items:center}.color-row input[type=color]{width:44px;height:38px;padding:0;border:1px solid var(--border);border-radius:var(--radius-sm);background:transparent;cursor:pointer}.color-row input[type=color]::-webkit-color-swatch-wrapper{padding:4px}.color-row input[type=color]::-webkit-color-swatch{border-radius:4px;border:1px solid var(--border)}.color-row input[type=text]{flex:1;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;text-transform:uppercase}.checkbox-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.4rem .8rem;padding:.4rem 0}.checkbox-grid .field-checkbox{font-size:.85rem;margin:0}.checkbox-grid .field-checkbox input[type=checkbox]:disabled+span{color:var(--text-faint)}.viewer-buttons{display:flex;flex-direction:column;gap:.4rem}.viewer-buttons .btn-secondary{width:100%;text-align:center;justify-content:center}.field{display:flex;flex-direction:column;gap:.4rem}.field-label{font-size:.78rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted)}.field-hint{font-size:.78rem;color:var(--text-faint);line-height:1.4}.field-hint code{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:.85em;background:#ffffff0f;padding:.05rem .35rem;border-radius:4px}.field input[type=password],.field input[type=text],.field select{background:#ffffff0a;border:1px solid var(--border);color:var(--text);padding:.65rem .85rem;border-radius:var(--radius-sm);font:inherit;outline:none;transition:border-color var(--transition),background var(--transition)}.field input[type=password]:focus,.field input[type=text]:focus,.field select:focus{border-color:var(--accent);background:#ffffff0f}.field select{appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'><path fill='%23999' d='M6 8L0 0h12z'/></svg>");background-repeat:no-repeat;background-position:right .85rem center;padding-right:2rem}.field input[type=range]{-webkit-appearance:none;appearance:none;background:transparent;height:24px;cursor:pointer}.field input[type=range]::-webkit-slider-runnable-track{height:4px;background:#ffffff1a;border-radius:999px}.field input[type=range]::-moz-range-track{height:4px;background:#ffffff1a;border-radius:999px}.field input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:18px;height:18px;border-radius:50%;background:var(--text);margin-top:-7px;cursor:grab;border:none}.field input[type=range]::-moz-range-thumb{width:18px;height:18px;border-radius:50%;background:var(--text);cursor:grab;border:none}.field-checkbox{display:flex;align-items:center;gap:.7rem;cursor:pointer;font-size:.92rem;user-select:none}.field-checkbox input[type=checkbox]{width:18px;height:18px;accent-color:var(--accent);cursor:pointer}.mic-meter{width:100%;height:8px;background:#ffffff0f;border-radius:999px;overflow:hidden}.mic-meter-bar{height:100%;width:0%;background:linear-gradient(90deg,var(--accent),#4ade80);transition:width .05s linear;border-radius:inherit}.download-transcript{width:100%;justify-content:center}.modal-actions{display:flex;gap:.6rem;justify-content:space-between;align-items:center;padding:.85rem 1.5rem calc(.85rem + env(safe-area-inset-bottom));border-top:1px solid var(--border);background:var(--bg-modal);flex-shrink:0}.modal-actions-right{display:flex;gap:.6rem;margin-left:auto}.modal-actions .btn-primary,.modal-actions .btn-secondary{padding:.65rem 1.3rem}.btn-text{background:transparent;border:none;color:var(--text-muted);padding:.5rem .6rem;font-size:.85rem;font-weight:500;cursor:pointer;border-radius:var(--radius-sm);transition:color var(--transition),background var(--transition)}.btn-text:hover{color:var(--text);background:#ffffff0d}.modal-subtitle-quiet{font-size:.8rem!important;color:var(--text-faint)!important;margin-top:.5rem!important}.modal-subtitle-quiet strong{color:var(--text-muted);font-weight:600}.login{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;padding:1rem}.login-card{width:100%;max-width:400px;display:flex;flex-direction:column;gap:1.1rem;padding:2.2rem 2rem;background:var(--bg-modal);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg)}.login-card .brand-large{align-self:center;margin-bottom:.2rem}.login-subtitle{margin:0 0 .6rem;text-align:center;color:var(--text-muted);font-size:.95rem;line-height:1.4}.login-error{background:#ef44441f;border:1px solid rgba(239,68,68,.4);color:#fecaca;padding:.6rem .85rem;border-radius:var(--radius-sm);font-size:.85rem;line-height:1.4}.login-submit{margin-top:.4rem;width:100%;padding:.75rem 1.3rem}.login-submit:disabled{opacity:.7;cursor:wait}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}
