:root{--slate-0: #ffffff;--slate-25: #fbfcfe;--slate-50: #f7f8fa;--slate-100: #eef1f5;--slate-150: #e6eaf0;--slate-200: #dce1e9;--slate-300: #c5cdd9;--slate-400: #8b96a8;--slate-500: #5f6b7e;--slate-600: #475160;--slate-700: #333c4a;--slate-800: #232b38;--slate-900: #131925;--slate-950: #0c111b;--brand-50: #ecfaf2;--brand-100: #d2f2e0;--brand-200: #a7e6c5;--brand-300: #6fd3a3;--brand-400: #2fb87c;--brand-500: #109a64;--brand-600: #0c7f53;--brand-700: #0a6644;--brand-strong: #07301f;--brand-glow: #109a64;--brand-glow-bright: #0c7f53;--band-good: #109a64;--band-good-soft: #eef9f2;--band-good-border: #bce3cf;--band-good-ink: #0a6644;--band-usable: #0d9488;--band-usable-soft: #ecf7f5;--band-usable-ink: #0a6b62;--band-weak: #b27d12;--band-weak-soft: #fbf3e0;--band-weak-ink: #855a09;--band-ng: #c9483f;--band-ng-soft: #fbeeed;--band-ng-ink: #9a342c;--status-info: #2563eb;--status-warn: #b27d12;--page-bg: #fafbfc;--surface: var(--slate-0);--surface-soft: var(--slate-50);--surface-inset: var(--slate-50);--border-subtle: var(--slate-150);--border-default: var(--slate-200);--border-strong: var(--slate-300);--side-bg: #ffffff;--side-border: var(--slate-150);--side-text: var(--slate-600);--side-text-strong: var(--slate-900);--side-text-soft: var(--slate-500);--stage-bg: #ffffff;--stage-panel: var(--slate-50);--stage-panel-soft: var(--slate-50);--stage-border: var(--slate-150);--stage-text: var(--slate-800);--stage-text-soft: var(--slate-500);--stage-text-dim: var(--slate-400);--font-sans: "Inter", ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;--font-mono: ui-monospace, "SF Mono", "JetBrains Mono", "Fira Code", "Cascadia Code", Menlo, Consolas, monospace;--text-xs: 12px;--text-sm: 13px;--text-base: 14px;--text-md: 15px;--text-lg: 17px;--text-xl: 20px;--text-2xl: 24px;--text-3xl: 30px;--text-4xl: 38px;--weight-regular: 400;--weight-medium: 500;--weight-semibold: 600;--weight-bold: 700;--weight-heavy: 800;--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 20px;--space-6: 24px;--space-7: 32px;--space-8: 40px;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 20px;--radius-pill: 999px;--shadow-xs: 0 1px 1px rgb(19 25 37 / 3%);--shadow-sm: 0 1px 2px rgb(19 25 37 / 4%);--shadow-md: 0 1px 2px rgb(19 25 37 / 4%), 0 6px 16px rgb(19 25 37 / 6%);--shadow-lg: 0 4px 12px rgb(19 25 37 / 6%), 0 18px 40px rgb(19 25 37 / 8%);--shadow-stage: 0 1px 2px rgb(19 25 37 / 4%), 0 8px 24px rgb(19 25 37 / 6%);--shadow-focus: 0 0 0 3px rgb(16 154 100 / 22%);--ease: cubic-bezier(.4, 0, .2, 1);--transition-fast: .12s var(--ease);--transition: .18s var(--ease);color:var(--slate-800);background:var(--page-bg);font-family:var(--font-sans);font-size:var(--text-base);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100dvh;color:var(--slate-800);background:var(--page-bg);line-height:1.55}h1,h2,h3{letter-spacing:-.012em}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.skip-link{position:absolute;top:var(--space-2);left:var(--space-2);z-index:2000;display:inline-flex;align-items:center;min-height:44px;padding:0 var(--space-4);border-radius:var(--radius-sm);color:#fff;background:var(--brand-600);font-weight:var(--weight-semibold);text-decoration:none;box-shadow:var(--shadow-md);transform:translateY(-150%);transition:transform var(--transition)}.skip-link:focus,.skip-link:focus-visible{transform:translateY(0);outline:3px solid var(--brand-600);outline-offset:2px}:focus-visible{outline:2px solid var(--brand-500);outline-offset:2px;border-radius:var(--radius-sm)}#main-content:focus{outline:none}button,input,textarea,select{font:inherit}button{cursor:pointer}button:disabled{cursor:not-allowed;opacity:.5}.app-shell{display:grid;grid-template-columns:288px minmax(0,1fr);min-height:100dvh}.sidebar{display:flex;flex-direction:column;gap:var(--space-6);padding:var(--space-7) var(--space-5);color:var(--side-text);background:var(--side-bg);border-right:1px solid var(--side-border)}.brand-block{display:flex;gap:var(--space-3);align-items:center;min-width:0;padding-bottom:var(--space-6);border-bottom:1px solid var(--border-subtle)}.brand-mark{display:grid;flex:0 0 auto;width:42px;height:42px;place-items:center;border-radius:var(--radius-md);color:#fff;background:var(--brand-600);box-shadow:inset 0 1px #ffffff2e;font-weight:var(--weight-bold);font-size:var(--text-md);letter-spacing:.02em}.brand-block h1,.panel-heading h2,.stage-header h2{margin:0;font-size:var(--text-lg);font-weight:var(--weight-semibold);line-height:1.2}.brand-block h1{color:var(--side-text-strong)}.brand-block h1,.brand-block p{overflow-wrap:anywhere}.brand-block p,.panel-heading p,.stage-header p{margin:var(--space-1) 0 0;color:var(--slate-500);font-size:var(--text-base)}.brand-block p{color:var(--side-text-soft)}.nav-list{display:grid;gap:2px}.nav-item,.primary-button,.secondary-button,.icon-button{min-height:44px;border:0;border-radius:var(--radius-md);display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);font-weight:var(--weight-semibold);transition:background var(--transition-fast),color var(--transition-fast),border-color var(--transition-fast),box-shadow var(--transition-fast),transform var(--transition-fast)}.nav-item{position:relative;justify-content:flex-start;width:100%;padding:0 var(--space-3) 0 var(--space-4);color:var(--side-text);background:transparent;font-size:var(--text-base);font-weight:var(--weight-medium)}.nav-item svg{flex:0 0 auto;color:var(--slate-400);transition:color var(--transition-fast)}.nav-item:hover{color:var(--side-text-strong);background:var(--slate-50)}.nav-item:hover svg{color:var(--slate-500)}.nav-item.active{color:var(--brand-700);background:var(--brand-50);font-weight:var(--weight-semibold)}.nav-item.active svg{color:var(--brand-600)}.nav-item.active:before{content:"";position:absolute;top:50%;left:0;width:3px;height:20px;border-radius:var(--radius-pill);background:var(--brand-500);transform:translateY(-50%)}.sidebar>button.nav-item{margin-top:auto;color:var(--slate-500);background:transparent}.sidebar>button.nav-item:hover{color:var(--band-ng-ink);background:var(--band-ng-soft)}.sidebar>button.nav-item:hover svg{color:var(--band-ng)}.main-panel{min-width:0;padding:var(--space-8) var(--space-8) var(--space-8)}.topbar{display:flex;justify-content:space-between;gap:var(--space-4);align-items:center;margin-bottom:var(--space-7)}.summary-row,.button-row,.teleprompter-controls{display:flex;gap:var(--space-3);flex-wrap:wrap;align-items:center}.summary-row{gap:var(--space-3)}.metric{display:grid;gap:var(--space-2);min-height:44px;min-width:132px;padding:var(--space-4) var(--space-5);border-radius:var(--radius-md);background:var(--surface);border:1px solid var(--border-subtle);box-shadow:var(--shadow-xs);transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.metric:hover{border-color:var(--border-default);box-shadow:var(--shadow-sm)}.metric span{display:block;color:var(--slate-500);font-size:var(--text-xs);font-weight:var(--weight-semibold);text-transform:uppercase;letter-spacing:.06em}.metric strong{display:block;color:var(--slate-900);font-size:var(--text-2xl);font-weight:var(--weight-semibold);line-height:1.1;letter-spacing:-.02em;overflow:hidden;text-overflow:ellipsis}.notice{display:inline-flex;align-items:center;min-height:44px;max-width:460px;padding:var(--space-2) var(--space-4);border-radius:var(--radius-md);color:var(--band-good-ink);border:1px solid var(--band-good-border);background:var(--band-good-soft);font-size:var(--text-base);font-weight:var(--weight-medium);box-shadow:var(--shadow-xs)}.project-switcher{display:grid;grid-template-columns:auto minmax(0,1fr);gap:var(--space-5);align-items:center;margin:0 0 var(--space-7);padding:var(--space-4) var(--space-5);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);background:var(--surface);box-shadow:var(--shadow-xs)}.project-switcher-heading{display:grid;min-width:160px;gap:var(--space-1);padding-right:var(--space-4);border-right:1px solid var(--border-subtle)}.project-switcher-heading span,.project-pill span,.project-empty{color:var(--slate-500);font-size:var(--text-xs);font-weight:var(--weight-bold);text-transform:uppercase;letter-spacing:.05em}.project-switcher-heading strong{max-width:260px;color:var(--slate-900);font-size:var(--text-md);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.project-switcher-list{display:flex;min-width:0;gap:var(--space-2);overflow-x:auto;padding-bottom:var(--space-1);scrollbar-width:thin}.project-pill{display:inline-flex;flex:0 0 auto;flex-direction:column;justify-content:center;min-height:46px;max-width:280px;gap:2px;padding:var(--space-2) var(--space-4);border:1px solid var(--border-default);border-radius:var(--radius-md);color:var(--slate-800);background:var(--surface-soft);text-align:left;transition:border-color var(--transition-fast),background var(--transition-fast),box-shadow var(--transition-fast),transform var(--transition-fast)}.project-pill:hover{border-color:var(--border-strong);background:var(--surface);box-shadow:var(--shadow-sm)}.project-pill.active{border-color:var(--brand-300);background:var(--brand-50)}.project-pill.active strong{color:var(--brand-700)}.project-pill span{font-size:10px}.project-pill.active span{color:var(--brand-600)}.project-pill strong{font-size:var(--text-base);font-weight:var(--weight-semibold);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.project-empty{display:inline-flex;min-height:40px;align-items:center;gap:var(--space-2);text-transform:none;letter-spacing:0;font-weight:var(--weight-medium)}.project-empty svg{flex:0 0 auto;color:var(--slate-400)}.muted{color:var(--slate-500);font-size:.92rem;overflow-wrap:anywhere}.workspace-grid{display:grid;gap:var(--space-6)}.setup-grid,.video-grid{grid-template-columns:minmax(320px,.9fr) minmax(340px,1.1fr);align-items:start}.panel{border:1px solid var(--border-subtle);border-radius:var(--radius-lg);background:var(--surface);box-shadow:var(--shadow-xs)}.panel{padding:var(--space-7)}.line-row{border:1px solid var(--border-subtle);border-radius:var(--radius-md);background:var(--surface)}.panel-heading{display:flex;justify-content:space-between;gap:var(--space-4);align-items:center;margin-bottom:var(--space-6)}.panel-heading h2{color:var(--slate-900);font-size:var(--text-2xl);font-weight:var(--weight-semibold)}.panel-heading p{color:var(--slate-500);font-size:var(--text-md)}.field{display:grid;gap:var(--space-2);margin-bottom:var(--space-5)}.field span{color:var(--slate-700);font-size:var(--text-base);font-weight:var(--weight-medium)}input,textarea,select{width:100%;border:1px solid var(--border-default);border-radius:var(--radius-md);color:var(--slate-900);background:var(--surface);padding:var(--space-3) var(--space-4);transition:border-color var(--transition-fast),box-shadow var(--transition-fast),background var(--transition-fast)}input::placeholder,textarea::placeholder{color:var(--slate-400)}input:hover,textarea:hover,select:hover{border-color:var(--slate-300)}input:focus,textarea:focus,select:focus{outline:none;border-color:var(--brand-400);box-shadow:var(--shadow-focus)}textarea{min-height:150px;resize:vertical;line-height:1.55}.script-field textarea{min-height:360px}select{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%235f6b7e' stroke-width='2.25' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right var(--space-3) center;padding-right:var(--space-7)}.primary-button{padding:0 var(--space-5);color:#fff;background:var(--brand-600);box-shadow:var(--shadow-xs)}.primary-button:hover:not(:disabled){background:var(--brand-700)}.primary-button:active:not(:disabled){background:var(--brand-700);box-shadow:none}.secondary-button{padding:0 var(--space-5);color:var(--slate-700);background:var(--surface);border:1px solid var(--border-default);box-shadow:var(--shadow-xs)}.secondary-button:hover:not(:disabled){border-color:var(--slate-300);background:var(--surface-soft);color:var(--slate-900)}.secondary-button:active:not(:disabled){background:var(--slate-100)}.icon-button{width:48px;color:var(--slate-700);background:var(--surface);border:1px solid var(--border-default)}.icon-button:hover:not(:disabled){background:var(--surface-soft)}.line-list{display:grid;gap:var(--space-3);align-content:start}.line-row{padding:var(--space-4);box-shadow:var(--shadow-xs);transition:border-color var(--transition-fast),box-shadow var(--transition-fast),transform var(--transition-fast)}.project-row{display:grid;width:100%;gap:var(--space-1);text-align:left}.project-row:hover{border-color:var(--border-strong);box-shadow:var(--shadow-sm)}.project-row.selected{border-color:var(--brand-300);background:var(--brand-50)}.line-row span{color:var(--brand-600);font-size:var(--text-xs);font-weight:var(--weight-semibold);text-transform:uppercase;letter-spacing:.05em}.line-row p{margin:var(--space-2) 0 0;color:var(--slate-800);font-size:var(--text-md);line-height:1.5}.teleprompter-layout{display:grid;grid-template-columns:minmax(0,1fr) 560px;gap:var(--space-5)}.teleprompter-stage{display:flex;flex-direction:column;gap:var(--space-6);min-width:0;min-height:calc(100dvh - 150px);border-radius:var(--radius-lg);padding:var(--space-7);color:var(--stage-text);background:var(--stage-bg);border:1px solid var(--border-subtle);box-shadow:var(--shadow-xs);overflow:hidden}.stage-header{display:flex;justify-content:space-between;gap:var(--space-4);align-items:center}.stage-header h2{font-size:var(--text-2xl);color:var(--slate-900);font-weight:var(--weight-semibold)}.stage-header p{color:var(--stage-text-soft)}.stage-actions{display:inline-flex;flex-wrap:wrap;justify-content:flex-end;gap:var(--space-3);align-items:center}.recording-dot{display:inline-flex;align-items:center;gap:var(--space-2);min-height:36px;padding:0 var(--space-4);border-radius:var(--radius-pill);color:var(--slate-500);background:var(--slate-50);border:1px solid var(--border-default);font-size:var(--text-sm);font-weight:var(--weight-semibold);letter-spacing:.01em}.recording-dot:before{content:"";width:8px;height:8px;border-radius:50%;background:var(--slate-400);box-shadow:0 0 #109a6400}.recording-dot.active{color:var(--band-good-ink);background:var(--band-good-soft);border-color:var(--band-good-border)}.recording-dot.active:before{background:var(--brand-500);animation:recording-pulse 1.6s var(--ease) infinite}@keyframes recording-pulse{0%{box-shadow:0 0 #109a6473}70%{box-shadow:0 0 0 8px #109a6400}to{box-shadow:0 0 #109a6400}}.script-display{display:flex;flex-direction:column;flex:1;min-height:520px;align-items:center;justify-content:center;gap:var(--space-5);padding:var(--space-4) 0;text-align:center}.stage-meta{display:inline-flex;min-height:34px;align-items:center;padding:0 var(--space-4);border-radius:var(--radius-pill);color:var(--slate-500);background:var(--slate-50);border:1px solid var(--border-default);font-size:var(--text-sm);font-weight:var(--weight-semibold);letter-spacing:.04em;text-transform:uppercase}.stage-score{display:inline-flex;flex-wrap:wrap;justify-content:center;align-items:center;gap:var(--space-3);max-width:min(860px,92%);padding:var(--space-3) var(--space-5);border-radius:var(--radius-md);color:var(--slate-600);background:var(--slate-50);border:1px solid var(--border-default)}.stage-score.good{color:var(--band-good-ink);background:var(--band-good-soft);border-color:var(--band-good-border)}.stage-score strong{font-size:var(--text-lg);font-weight:var(--weight-bold)}.stage-score span{font-weight:var(--weight-medium)}.rolling-script{width:min(1120px,100%);height:min(58dvh,620px);min-height:380px;overflow-y:auto;padding:22vh var(--space-4);border-radius:var(--radius-lg);outline:1px solid var(--border-subtle);background:var(--slate-50);cursor:pointer;scroll-behavior:smooth;scrollbar-width:thin;scrollbar-color:var(--slate-300) transparent;font-size:var(--prompt-font-size, 64px)}.rolling-script.mirrored{transform:scaleX(-1)}.rolling-script:focus-visible{outline:2px solid var(--brand-500);outline-offset:3px}.rolling-script::-webkit-scrollbar{width:8px}.rolling-script::-webkit-scrollbar-thumb{border-radius:var(--radius-pill);background:var(--slate-300)}.rolling-line{display:grid;max-width:1060px;gap:var(--space-2);margin:var(--space-4) auto;padding:var(--space-7) var(--space-6);border-radius:var(--radius-lg);color:var(--slate-400);opacity:.5;transition:background var(--transition),box-shadow var(--transition),color var(--transition),opacity var(--transition),transform var(--transition)}.rolling-line span{color:var(--slate-400);font-weight:var(--weight-bold);letter-spacing:.04em;text-transform:uppercase}.rolling-line>span{font-size:var(--text-base);letter-spacing:.08em}.rolling-line p,.rolling-empty{max-width:1040px;margin:0 auto;color:var(--slate-400);font-size:1em;font-weight:var(--weight-bold);line-height:1.2;letter-spacing:-.01em;overflow-wrap:anywhere}.script-line-text{position:relative}.script-word-layer{white-space:pre-wrap}.script-word,.script-punctuation{transition:color var(--transition-fast),background var(--transition-fast),box-shadow var(--transition-fast)}.script-word.pending{color:currentColor}.script-word.spoken,.rolling-line.active .script-word.spoken{color:var(--brand-600)}.script-word.next{border-radius:6px;background:var(--band-weak-soft);box-shadow:0 0 0 .06em var(--band-weak-soft)}.rolling-line.active{color:var(--slate-900);background:#fff;box-shadow:inset 0 0 0 1px var(--brand-200),var(--shadow-md);opacity:1;transform:scale(1.025)}.rolling-line.active span{color:var(--brand-600)}.rolling-line.active p{color:var(--slate-900)}.rolling-empty{color:var(--slate-500)}.prompt-settings{display:flex;flex-wrap:wrap;justify-content:center;gap:var(--space-3)}.reader-hint{display:inline-flex;min-height:44px;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);border-radius:var(--radius-md);color:var(--slate-500);background:var(--slate-50);border:1px solid var(--border-default);font-size:var(--text-sm);font-weight:var(--weight-medium)}.range-control{display:inline-flex;min-height:44px;align-items:center;gap:var(--space-3);padding:var(--space-2) var(--space-4);border-radius:var(--radius-md);color:var(--slate-500);background:var(--slate-50);border:1px solid var(--border-default);font-weight:var(--weight-semibold)}.range-control span,.range-control strong{font-size:var(--text-sm)}.range-control strong{color:var(--slate-800)}.range-control input[type=range]{width:150px;height:6px;padding:0;border:0;border-radius:var(--radius-pill);background:linear-gradient(90deg,var(--brand-500),var(--brand-300));-webkit-appearance:none;-moz-appearance:none;appearance:none;cursor:pointer}.range-control input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:18px;height:18px;border-radius:50%;background:#fff;border:3px solid var(--brand-500);box-shadow:var(--shadow-sm);cursor:pointer}.range-control input[type=range]::-moz-range-thumb{width:18px;height:18px;border-radius:50%;background:#fff;border:3px solid var(--brand-500);box-shadow:var(--shadow-sm);cursor:pointer}.range-control input[type=range]:focus-visible{outline:2px solid var(--brand-500);outline-offset:4px}.select-control select{min-height:32px;width:142px;padding:0 var(--space-6) 0 var(--space-3);border:1px solid var(--border-default);border-radius:var(--radius-sm);background-color:var(--surface);color:var(--slate-900);font-weight:var(--weight-semibold);background-position:right var(--space-2) center}.dark-control{color:var(--slate-700);background:var(--surface);border:1px solid var(--border-default);box-shadow:var(--shadow-xs)}.dark-control:hover:not(:disabled){color:var(--slate-900);background:var(--surface-soft);border-color:var(--slate-300)}.teleprompter-controls{justify-content:center}.teleprompter-stage{background:#0e1117;border-color:#212935;color:#c3ccd6}.teleprompter-stage .stage-header h2{color:#f4f7fb}.teleprompter-stage .stage-header p,.teleprompter-stage .reader-hint,.teleprompter-stage .range-control>span,.teleprompter-stage .range-control strong{color:#9aa6b3}.teleprompter-stage .recording-dot,.teleprompter-stage .stage-meta{color:#c3ccd6;background:#ffffff0f;border-color:#ffffff24}.teleprompter-stage .recording-dot:before{background:#5b6470}.teleprompter-stage .rolling-script{background:#090c11;outline-color:#ffffff14;scrollbar-color:rgb(255 255 255 / 22%) transparent}.teleprompter-stage .rolling-script::-webkit-scrollbar-thumb{background:#ffffff38}.teleprompter-stage .rolling-line,.teleprompter-stage .rolling-line p,.teleprompter-stage .rolling-line>span{color:#7c8794}.teleprompter-stage .rolling-line.active{background:#1b2430;color:#fff;box-shadow:inset 0 0 0 1px #34d3998c,0 18px 44px #00000073}.teleprompter-stage .rolling-line .script-word,.teleprompter-stage .rolling-line .script-punctuation{color:#7c8794}.teleprompter-stage .rolling-line.active p,.teleprompter-stage .rolling-line.active .script-word,.teleprompter-stage .rolling-line.active .script-punctuation{color:#fff}.teleprompter-stage .rolling-line.active>span{color:#34d399}.teleprompter-stage .rolling-line.active .script-word.spoken,.teleprompter-stage .rolling-line .script-word.spoken{color:#34d399}.teleprompter-stage .script-word.next{background:#f5c85033;box-shadow:0 0 0 .06em #f5c85033}.teleprompter-stage .rolling-empty{color:#9aa6b3}.teleprompter-stage .dark-control,.teleprompter-stage .select-control select{color:#e6edf3;background:#ffffff0f;border-color:#ffffff29;box-shadow:none}.teleprompter-stage .dark-control:hover:not(:disabled){color:#fff;background:#ffffff1f;border-color:#ffffff3d}.teleprompter-stage .dark-control.is-active{color:#34d399;background:#34d39924;border-color:#34d39973}.teleprompter-stage .range-control input[type=range]{background:#ffffff1f}.teleprompter-stage .stage-score{color:#c3ccd6}.teleprompter-stage .stage-score strong{color:#fff}.transcript-panel,.capture-panel{position:relative;align-self:start;min-width:460px;max-height:calc(100dvh - 150px);overflow:auto;scrollbar-width:thin}.resize-handle{position:absolute;top:var(--space-3);left:-14px;display:grid;width:26px;height:48px;place-items:center;border:1px solid var(--border-default);border-radius:var(--radius-md);color:var(--slate-500);background:var(--surface);box-shadow:var(--shadow-sm);cursor:ew-resize;transition:color var(--transition-fast),border-color var(--transition-fast)}.resize-handle:hover{color:var(--brand-600);border-color:var(--brand-300)}.checkbox-control{display:inline-flex;align-items:center;gap:var(--space-2);margin-top:var(--space-2);color:var(--slate-700);font-size:var(--text-sm);font-weight:var(--weight-semibold);cursor:pointer}.checkbox-control input{width:auto;padding:0;accent-color:var(--brand-500)}.live-transcript{min-height:82px;padding:var(--space-4);margin-bottom:var(--space-4);border-radius:var(--radius-md);color:var(--slate-700);background:var(--surface-inset);line-height:1.55}.live-transcript p{margin:0 0 var(--space-2)}.live-transcript p:last-child{margin-bottom:0}.interim-transcript{color:var(--slate-500);font-style:italic}.score-summary,.live-take,.live-match-summary{display:grid;gap:var(--space-1);margin-bottom:var(--space-3);padding:var(--space-4);border-radius:var(--radius-md);color:var(--slate-700);background:var(--surface-inset);border:1px solid var(--border-subtle)}.score-summary.good,.live-take.good,.live-match-summary{color:var(--band-good-ink);border:1px solid var(--band-good-border);background:var(--band-good-soft)}.score-summary span,.live-take span,.score-summary small{color:var(--slate-500);font-size:var(--text-sm)}.score-summary.good span,.score-summary.good small{color:var(--band-good-ink)}.score-summary span{font-weight:var(--weight-semibold);text-transform:uppercase;letter-spacing:.04em;font-size:var(--text-xs)}.score-summary strong{color:var(--slate-900);font-size:var(--text-3xl);font-weight:var(--weight-bold);line-height:1.05;letter-spacing:-.02em}.score-summary.good strong{color:var(--band-good-ink)}.live-take-list{display:grid;max-height:230px;gap:var(--space-2);margin-bottom:var(--space-4);overflow:auto}.current-line-records,.recent-take-list{display:grid;gap:var(--space-3);margin-bottom:var(--space-4)}.current-line-records{padding:var(--space-3);border-radius:var(--radius-md);background:var(--surface-inset);border:1px solid var(--border-subtle)}.recent-take-list{max-height:320px;overflow:auto}.recent-take-list h3{margin:0;color:var(--slate-700);font-size:var(--text-xs);font-weight:var(--weight-bold);text-transform:uppercase;letter-spacing:.06em}.line-take-card,.line-record-take{display:grid;min-width:0;gap:var(--space-2);padding:var(--space-3) var(--space-4);border-radius:var(--radius-md);color:var(--slate-700);background:var(--surface);border:1px solid var(--border-subtle);box-shadow:var(--shadow-xs)}.line-record-take{transition:border-color var(--transition-fast),box-shadow var(--transition-fast),transform var(--transition-fast)}.line-record-take:hover:not(:disabled){border-color:var(--border-strong);box-shadow:var(--shadow-sm);transform:translateY(-1px)}.line-take-card.good,.line-record-take.good{color:var(--band-good-ink);border:1px solid var(--band-good-border);background:var(--band-good-soft)}.take-card-header,.take-card-meta{display:flex;flex-wrap:wrap;gap:var(--space-1) var(--space-3);align-items:center;justify-content:space-between}.take-card-header strong{font-size:var(--text-md);font-weight:var(--weight-bold)}.take-card-header span,.take-card-meta span,.line-record-take span{color:var(--slate-500);font-size:var(--text-sm)}.take-card-meta span{display:inline-flex;align-items:center;padding:2px var(--space-2);border-radius:var(--radius-pill);background:var(--surface-soft);font-weight:var(--weight-semibold)}.line-take-card.good .take-card-meta span{background:#109a641f;color:var(--band-good-ink)}.take-transcript,.line-record-take p{margin:0;color:inherit;line-height:1.5;overflow-wrap:anywhere}.line-record-take{width:100%;text-align:left;white-space:normal}.line-record-take strong{font-size:var(--text-base);font-weight:var(--weight-bold)}.live-take{grid-template-columns:minmax(0,1.25fr) minmax(80px,.85fr) minmax(90px,.8fr) auto;align-items:center;margin-bottom:0}.live-take div{display:grid;min-width:0;gap:2px}.live-take strong,.live-take span{overflow-wrap:anywhere}.compact-button{min-height:38px;padding:0 var(--space-4)}.video-review-box{display:grid;gap:var(--space-3);margin-bottom:var(--space-4);padding:var(--space-4);border-radius:var(--radius-md);color:var(--slate-700);background:var(--surface-inset);border:1px solid var(--border-subtle)}.video-review-box.wide{grid-template-columns:minmax(220px,.9fr) minmax(320px,1.2fr) auto;align-items:center}.video-review-box div{display:grid;gap:var(--space-1)}.video-review-box span{color:var(--slate-500);font-size:var(--text-sm)}.video-review-box strong{color:var(--slate-800);font-size:var(--text-md);font-weight:var(--weight-semibold)}.video-review-box h2{margin:0;color:var(--slate-900);font-size:var(--text-xl)}.download-link{display:inline-flex;min-height:36px;align-items:center;justify-content:center;gap:var(--space-2);padding:0 var(--space-4);border-radius:var(--radius-md);color:var(--slate-900);font-size:var(--text-base);font-weight:var(--weight-semibold);text-decoration:none;background:var(--surface);border:1px solid var(--border-strong);box-shadow:var(--shadow-xs);transition:background var(--transition-fast),border-color var(--transition-fast)}.download-link:hover{background:var(--surface-soft);border-color:var(--slate-400)}.download-link:focus-visible{outline:3px solid var(--brand-500);outline-offset:2px}.review-video{display:block;width:100%;max-height:220px;border-radius:var(--radius-md);background:var(--slate-900);border:1px solid var(--border-default);aspect-ratio:16 / 9;object-fit:cover}.review-audio{display:block;width:100%}.review-audio:not([controls]){display:none}.video-review-box.wide .review-audio{grid-column:2 / -1}.live-preview{border:2px solid var(--brand-400);box-shadow:0 0 0 4px #109a6424}.hidden-preview{display:none}.line-summary-list{display:grid;gap:var(--space-3);margin-bottom:var(--space-5)}.line-summary-list h2{margin:0;color:var(--slate-900);font-size:var(--text-xl)}.line-summary-card{display:grid;grid-template-columns:minmax(220px,1.4fr) minmax(180px,.8fr) minmax(80px,.35fr) minmax(180px,.8fr) auto;gap:var(--space-3);align-items:center;padding:var(--space-4);border-radius:var(--radius-md);background:var(--surface);border:1px solid var(--border-subtle);box-shadow:var(--shadow-xs)}.line-summary-card.good{border:1px solid var(--band-good-border);background:var(--band-good-soft)}.line-summary-card div{display:grid;min-width:0;gap:var(--space-1)}.line-summary-card span,.take-chip{color:var(--slate-500);font-size:var(--text-sm)}.line-summary-card span{font-size:var(--text-xs);font-weight:var(--weight-semibold);text-transform:uppercase;letter-spacing:.05em}.line-summary-card strong{color:var(--slate-900);font-weight:var(--weight-semibold);overflow-wrap:anywhere}.take-chip-row{grid-column:1 / -1;display:flex;flex-wrap:wrap;gap:var(--space-2)}.take-chip{min-height:34px;padding:0 var(--space-3);border:1px solid var(--border-default);border-radius:var(--radius-pill);background:var(--surface-soft);font-weight:var(--weight-semibold);transition:background var(--transition-fast),border-color var(--transition-fast)}.take-chip:hover:not(:disabled){border-color:var(--slate-400);background:var(--surface)}.take-chip.good{color:var(--band-good-ink);background:var(--band-good-soft);border-color:var(--band-good-border)}.review-section{display:grid;gap:var(--space-3);margin-bottom:var(--space-5)}.review-section h2,.review-section h3{margin:0;color:var(--slate-900);font-size:var(--text-xl)}.review-section h3{font-size:var(--text-md)}.current-session{padding:var(--space-4);border-radius:var(--radius-md);background:var(--surface-inset);border:1px solid var(--border-subtle)}.current-session-title{color:var(--slate-900);font-size:var(--text-lg);font-weight:var(--weight-semibold)}.session-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:var(--space-3)}.session-stats div{display:grid;gap:var(--space-1)}.session-stats span{color:var(--slate-500);font-size:var(--text-xs);font-weight:var(--weight-semibold);text-transform:uppercase;letter-spacing:.05em}.session-stats strong{color:var(--slate-900);font-size:var(--text-lg);font-weight:var(--weight-semibold)}.review-section-head{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:var(--space-3)}.combined-download{display:flex;flex-wrap:wrap;align-items:center;gap:var(--space-3)}.combined-hint{color:var(--slate-500);font-size:var(--text-sm)}.all-takes-list{display:grid;gap:var(--space-3)}.all-takes-line{display:grid;gap:var(--space-2);padding:var(--space-4);border-radius:var(--radius-md);background:var(--surface);border:1px solid var(--border-subtle);box-shadow:var(--shadow-xs)}.all-takes-line-head{display:grid;gap:var(--space-1)}.all-takes-line-head span{color:var(--slate-500);font-size:var(--text-xs);font-weight:var(--weight-semibold);text-transform:uppercase;letter-spacing:.05em}.all-takes-line-head strong{color:var(--slate-900);font-weight:var(--weight-semibold);overflow-wrap:anywhere}.all-takes-empty{margin:0;color:var(--slate-500);font-size:var(--text-sm)}.take-option-row{display:grid;gap:var(--space-2);margin:0;padding:0;list-style:none}.take-option{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:var(--space-3);padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);background:var(--surface-soft);border:1px solid var(--border-subtle)}.take-option.chosen{background:var(--band-good-soft);border-color:var(--band-good-border)}.take-option-label{color:var(--slate-700);font-size:var(--text-sm);font-weight:var(--weight-semibold)}.take-option-actions{display:inline-flex;align-items:center;gap:var(--space-2)}.take-option .icon-button{min-height:36px;min-width:36px;border:1px solid var(--border-default);background:var(--surface);font-size:var(--text-sm)}.take-option .icon-button:hover:not(:disabled){border-color:var(--slate-400)}.take-option .secondary-button{min-height:36px;padding:0 var(--space-3)}.take-summary-text{display:grid;gap:var(--space-3);margin-top:var(--space-5)}.take-summary-text h2{margin:0;color:var(--slate-900);font-size:var(--text-xl)}.take-summary-text pre{min-height:140px;max-height:360px;margin:0;overflow:auto;white-space:pre-wrap;overflow-wrap:anywhere;padding:var(--space-4);border-radius:var(--radius-md);color:var(--slate-700);background:var(--surface-inset);border:1px solid var(--border-subtle);font-family:var(--font-mono);font-size:var(--text-sm);line-height:1.6}.review-ranges{margin-bottom:var(--space-5)}.review-ranges .take-row{grid-template-columns:minmax(180px,1fr) 220px 80px auto}.teleprompter-layout.is-fullscreen{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;display:grid;grid-template-columns:1fr;gap:0;padding:0;background:var(--stage-bg)}.teleprompter-layout.is-fullscreen .teleprompter-stage{display:grid;grid-template-rows:auto minmax(0,1fr) auto;min-height:100dvh;border-radius:0;border:0;padding:var(--space-8)}.teleprompter-layout.is-fullscreen .script-display{min-height:0;padding:var(--space-4) 0}.teleprompter-layout.is-fullscreen .rolling-script{width:min(1500px,96vw);height:min(72dvh,calc(100dvh - 240px));padding-top:30dvh;padding-bottom:30dvh}.teleprompter-layout.is-fullscreen .rolling-line{max-width:min(1400px,92vw)}.teleprompter-layout.is-fullscreen .panel{display:none}.teleprompter-layout.is-fullscreen .teleprompter-controls{justify-content:center}.review-panel{overflow-x:auto}.take-table{display:grid;min-width:780px;gap:var(--space-2)}.take-row{display:grid;grid-template-columns:120px 130px 250px 80px 90px minmax(220px,1fr);gap:var(--space-3);align-items:center;min-height:54px;padding:var(--space-3) var(--space-4);border-radius:var(--radius-md);background:var(--surface);border:1px solid var(--border-subtle);font-size:var(--text-base)}.take-row span{color:var(--slate-600)}.take-row strong{color:var(--slate-900);font-weight:var(--weight-bold)}.take-row.selected{background:var(--brand-50);border:1px solid var(--band-good-border)}.table-head{background:transparent;border:0;min-height:0;padding-bottom:var(--space-1)}.table-head span{color:var(--slate-500);font-size:var(--text-xs);font-weight:var(--weight-bold);text-transform:uppercase;letter-spacing:.06em}.attempt-label{display:inline-flex;align-items:center;gap:var(--space-2)}.upload-zone{display:grid;min-height:150px;margin-bottom:var(--space-4);place-items:center;gap:var(--space-2);border:1.5px dashed var(--border-strong);border-radius:var(--radius-lg);color:var(--slate-600);background:var(--surface-soft);font-weight:var(--weight-semibold);transition:border-color var(--transition-fast),background var(--transition-fast)}.upload-zone:hover{border-color:var(--brand-300);background:var(--brand-50)}.upload-zone input{max-width:280px}.floating-action{position:fixed;right:var(--space-6);bottom:var(--space-6);display:grid;width:56px;height:56px;place-items:center;border:0;border-radius:50%;color:#fff;background:var(--brand-600);box-shadow:var(--shadow-lg);transition:transform var(--transition-fast),box-shadow var(--transition-fast)}.floating-action:hover{transform:translateY(-2px) scale(1.04)}.auth-page{display:grid;min-height:100dvh;place-items:center;padding:var(--space-6);background:radial-gradient(720px 480px at 50% -10%,rgb(16 154 100 / 6%),transparent 60%),var(--page-bg)}.auth-panel{width:min(440px,100%);padding:var(--space-8) var(--space-7);border-radius:var(--radius-lg);background:var(--surface);border:1px solid var(--border-subtle);box-shadow:var(--shadow-md)}.brand-block.dark{color:var(--slate-900);margin-bottom:var(--space-6);padding-bottom:var(--space-6);border-bottom:1px solid var(--border-subtle)}.brand-block.dark h1{color:var(--slate-900)}.brand-block.dark p{color:var(--slate-500)}.auth-panel h2{margin:0 0 var(--space-5);color:var(--slate-900);font-size:var(--text-2xl);font-weight:var(--weight-semibold)}.auth-panel .primary-button{width:100%;margin-top:var(--space-2)}.setup-status,.status-pill{display:grid;gap:var(--space-1);margin-top:var(--space-4);padding:var(--space-4);border-radius:var(--radius-md);color:var(--slate-600);background:var(--surface-inset);border:1px solid var(--border-subtle)}.setup-status strong{color:var(--slate-800);font-size:var(--text-base)}.setup-status span{font-size:var(--text-sm);line-height:1.5}.status-pill{display:inline-flex;margin:var(--space-3) 0;color:var(--band-usable-ink);background:var(--band-usable-soft);border-color:#0d948842;font-weight:var(--weight-bold)}.empty-state{display:grid;justify-items:center;gap:var(--space-2);padding:var(--space-5) var(--space-4);text-align:center;color:var(--slate-500)}.empty-state svg{color:var(--slate-400)}.empty-state strong{color:var(--slate-700);font-size:var(--text-md);font-weight:var(--weight-semibold)}.empty-state span{font-size:var(--text-sm);line-height:1.5;max-width:32ch}.empty-state.on-stage{color:var(--stage-text-soft)}.empty-state.on-stage svg{color:var(--stage-text-dim)}.empty-state.on-stage strong{color:var(--stage-text)}@media(max-width:980px){.app-shell,.setup-grid,.video-grid,.teleprompter-layout{grid-template-columns:1fr}.app-shell{display:block}.project-switcher{grid-template-columns:1fr}.project-switcher-heading{padding-right:0;border-right:0;padding-bottom:var(--space-2);border-bottom:1px solid var(--border-subtle)}.sidebar{position:sticky;top:0;z-index:10;display:grid;grid-template-columns:minmax(0,1fr) 48px;grid-template-areas:"brand signout" "nav nav";gap:var(--space-3);padding:var(--space-3)}.sidebar>.brand-block{grid-area:brand;padding-bottom:0;border-bottom:0}.sidebar>.nav-list{grid-area:nav}.sidebar>button.nav-item{grid-area:signout;width:48px;margin-top:0;align-self:start}.nav-list{display:flex;min-width:0;gap:var(--space-2);overflow-x:auto;padding-bottom:var(--space-1)}.nav-item{flex:0 0 52px;justify-content:center;padding:0}.nav-item.active:before{display:none}.nav-item span{display:none}.main-panel{padding:var(--space-4)}.teleprompter-layout{gap:var(--space-3)}.teleprompter-stage{min-height:auto;padding:var(--space-5)}.transcript-panel,.capture-panel{width:100%;min-width:0;max-height:none}.resize-handle{display:none}.rolling-script{min-height:340px;font-size:min(var(--prompt-font-size, 52px),34px)}.rolling-line{padding:var(--space-5) var(--space-3)}}@media(max-width:640px){.main-panel{padding:var(--space-3)}.topbar{align-items:stretch;flex-direction:column}.summary-row{display:grid;grid-template-columns:repeat(2,minmax(0,1fr))}.metric{min-width:0}.metric strong{overflow-wrap:anywhere}.notice{max-width:none}.brand-mark{width:40px;height:40px}.brand-block{gap:var(--space-3)}.brand-block h1{font-size:var(--text-lg)}.brand-block p{font-size:var(--text-xs)}.panel{padding:var(--space-4)}.panel-heading,.stage-header{align-items:flex-start;flex-direction:column}.stage-actions{width:100%;justify-content:space-between}.teleprompter-stage{padding:var(--space-4) var(--space-3)}.script-display{min-height:320px}.video-review-box.wide,.line-summary-card,.review-ranges .take-row{grid-template-columns:1fr}.review-section-head,.take-option{flex-direction:column;align-items:stretch}.take-option-actions{justify-content:space-between}.rolling-script{height:440px;min-height:300px;padding-right:var(--space-3);padding-left:var(--space-3);font-size:min(var(--prompt-font-size, 52px),28px)}.range-control{width:100%;justify-content:space-between}.range-control input[type=range]{width:min(170px,42vw)}.teleprompter-controls .primary-button,.teleprompter-controls .secondary-button{flex:1 1 96px}.live-take{grid-template-columns:1fr}.download-link{width:100%}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important;scroll-behavior:auto!important}.rolling-script{scroll-behavior:auto}.skip-link{transition:none}.recording-dot.active:before{animation:none}.metric:hover,.project-pill:hover,.project-row:hover,.line-record-take:hover,.primary-button:hover:not(:disabled),.secondary-button:hover:not(:disabled),.floating-action:hover{transform:none}}
