:root{color:#1d2433;background:#f6f7f2;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-synthesis:none;text-rendering:optimizeLegibility}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100dvh;background:#f6f7f2}button,input,textarea{font:inherit}button{cursor:pointer}button:disabled{cursor:not-allowed;opacity:.55}.app-shell{display:grid;grid-template-columns:280px minmax(0,1fr);min-height:100dvh}.sidebar{display:flex;flex-direction:column;gap:28px;padding:24px;color:#f8fafc;background:#1f2a37}.brand-block{display:flex;gap:14px;align-items:center}.brand-mark{display:grid;width:46px;height:46px;place-items:center;border-radius:8px;color:#10201b;background:#8fd6b3;font-weight:800}.brand-block h1,.panel-heading h2,.stage-header h2{margin:0;font-size:20px;line-height:1.2}.brand-block p,.panel-heading p,.stage-header p{margin:4px 0 0;color:#9ca3af;font-size:14px}.nav-list{display:grid;gap:8px}.nav-item,.primary-button,.secondary-button,.icon-button{min-height:44px;border:0;border-radius:8px;display:inline-flex;align-items:center;justify-content:center;gap:8px;font-weight:700}.nav-item{justify-content:flex-start;width:100%;padding:0 14px;color:#cbd5e1;background:transparent}.nav-item.active,.nav-item:hover{color:#111827;background:#f9fafb}.main-panel{min-width:0;padding:22px}.topbar{display:flex;justify-content:space-between;gap:16px;align-items:center;margin-bottom:18px}.summary-row,.button-row,.teleprompter-controls{display:flex;gap:10px;flex-wrap:wrap;align-items:center}.metric,.notice{min-height:44px;padding:8px 14px;border-radius:8px;background:#fff;border:1px solid #d7dce2}.metric span{display:block;color:#64748b;font-size:12px}.metric strong{display:block;font-size:18px}.notice{color:#0f5132;border-color:#b7e1c2;background:#edf8f0}.project-switcher{display:grid;grid-template-columns:auto minmax(0,1fr);gap:12px;align-items:center;margin:-6px 0 18px;padding:10px 12px;border:1px solid #d7dce2;border-radius:8px;background:#fff}.project-switcher-heading{display:grid;min-width:160px;gap:2px}.project-switcher-heading span,.project-pill span,.project-empty{color:#64748b;font-size:12px;font-weight:800}.project-switcher-heading strong{max-width:260px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.project-switcher-list{display:flex;min-width:0;gap:8px;overflow-x:auto;padding-bottom:2px}.project-pill{display:inline-flex;flex:0 0 auto;min-height:40px;max-width:280px;align-items:center;gap:8px;padding:0 12px;border:1px solid #d7dce2;border-radius:8px;color:#1d2433;background:#f8fafc;text-align:left}.project-pill.active{border-color:#8fd6b3;background:#edf8f0}.project-pill strong{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.project-empty{display:inline-flex;min-height:40px;align-items:center}.muted{color:#667085;font-size:.9rem;overflow-wrap:anywhere}.workspace-grid{display:grid;gap:18px}.setup-grid,.video-grid{grid-template-columns:minmax(320px,.9fr) minmax(340px,1.1fr)}.panel,.line-row{border:1px solid #d7dce2;border-radius:8px;background:#fff}.panel{padding:20px}.panel-heading{display:flex;justify-content:space-between;gap:16px;align-items:center;margin-bottom:18px}.field{display:grid;gap:8px;margin-bottom:14px}.field span{color:#465366;font-size:14px;font-weight:700}input,textarea,select{width:100%;border:1px solid #cbd5e1;border-radius:8px;color:#1d2433;background:#fff;padding:12px 13px}textarea{min-height:150px;resize:vertical;line-height:1.5}.script-field textarea{min-height:360px}.primary-button{padding:0 16px;color:#082018;background:#8fd6b3}.secondary-button{padding:0 16px;color:#1d2433;background:#e6ebf0}.icon-button{width:48px;color:#1d2433;background:#e6ebf0}.line-list{display:grid;gap:10px;align-content:start}.line-row{padding:14px}.project-row{display:grid;width:100%;text-align:left}.project-row.selected{border-color:#b7e1c2;background:#edf8f0}.line-row span{color:#2563eb;font-size:13px;font-weight:800}.line-row p{margin:6px 0 0;line-height:1.45}.teleprompter-layout{display:grid;grid-template-columns:minmax(0,1.35fr) 360px;gap:18px}.teleprompter-stage{min-width:0;min-height:calc(100dvh - 150px);border-radius:8px;padding:26px;color:#f8fafc;background:#111827;overflow:hidden}.stage-header{display:flex;justify-content:space-between;gap:16px;align-items:center}.stage-actions{display:inline-flex;flex-wrap:wrap;justify-content:flex-end;gap:10px;align-items:center}.recording-dot{display:inline-flex;align-items:center;gap:8px;min-height:36px;padding:0 12px;border-radius:999px;color:#cbd5e1;background:#263244}.recording-dot.active{color:#082018;background:#8fd6b3}.script-display{display:flex;flex-direction:column;min-height:520px;align-items:center;justify-content:center;gap:18px;padding:18px 0;text-align:center}.stage-meta{display:inline-flex;min-height:34px;align-items:center;padding:0 12px;border-radius:999px;color:#cbd5e1;background:#263244;font-weight:800}.stage-score{display:inline-flex;flex-wrap:wrap;justify-content:center;gap:10px;max-width:min(860px,92%);padding:10px 14px;border-radius:8px;color:#cbd5e1;background:#263244}.stage-score.good{color:#082018;background:#8fd6b3}.stage-score span{font-weight:700}.rolling-script{width:min(1120px,100%);height:min(58dvh,620px);min-height:380px;overflow-y:auto;padding:22vh 18px;border-radius:8px;outline:1px solid rgb(148 163 184 / 14%);background:#0f172a3d;cursor:pointer;scroll-behavior:smooth;scrollbar-width:thin;scrollbar-color:#475569 transparent;font-size:var(--prompt-font-size, 52px)}.rolling-script:focus-visible{outline:3px solid #8fd6b3;outline-offset:3px}.rolling-script::-webkit-scrollbar{width:8px}.rolling-script::-webkit-scrollbar-thumb{border-radius:999px;background:#475569}.rolling-line{display:grid;max-width:1060px;gap:8px;margin:12px auto;padding:22px 20px;border-radius:8px;color:#94a3b8;opacity:.42;transition:background .18s ease,color .18s ease,opacity .18s ease,transform .18s ease}.rolling-line span{color:#94a3b8;font-size:14px;font-weight:800;text-transform:uppercase}.rolling-line p,.rolling-empty{max-width:1040px;margin:0 auto;color:#cbd5e1;font-size:1em;font-weight:800;line-height:1.18}.rolling-line.active{color:#f8fafc;background:#1f2937;box-shadow:inset 0 0 0 1px #8fd6b338;opacity:1;transform:scale(1.015)}.rolling-line.active span{color:#8fd6b3}.rolling-line.active p,.rolling-empty{color:#f8fafc}.prompt-settings{display:flex;flex-wrap:wrap;justify-content:center;gap:10px;margin-bottom:14px}.reader-hint{display:inline-flex;min-height:44px;align-items:center;padding:8px 12px;border-radius:8px;color:#cbd5e1;background:#263244;font-size:13px;font-weight:800}.range-control{display:inline-flex;min-height:44px;align-items:center;gap:10px;padding:8px 12px;border-radius:8px;color:#cbd5e1;background:#263244;font-weight:800}.range-control span,.range-control strong{font-size:13px}.range-control input{width:150px;padding:0}.select-control select{min-height:30px;width:136px;padding:0 8px;border:0;border-radius:6px;background:#f8fafc;color:#111827;font-weight:800}.dark-control{color:#f8fafc;background:#263244}.transcript-panel,.capture-panel{position:relative;align-self:start;min-width:320px;max-height:calc(100dvh - 150px);overflow:auto}.resize-handle{position:absolute;top:12px;left:-14px;display:grid;width:24px;height:46px;place-items:center;border:1px solid #d7dce2;border-radius:8px;color:#64748b;background:#fff;cursor:ew-resize}.checkbox-control{display:inline-flex;align-items:center;gap:8px;margin-top:6px;color:#334155;font-size:13px;font-weight:800}.checkbox-control input{width:auto;padding:0}.live-transcript{min-height:82px;padding:14px;margin-bottom:14px;border-radius:8px;color:#334155;background:#f1f5f9;line-height:1.5}.live-transcript p{margin:0 0 8px}.live-transcript p:last-child{margin-bottom:0}.interim-transcript{color:#64748b;font-style:italic}.score-summary,.live-take{display:grid;gap:4px;margin-bottom:12px;padding:12px;border-radius:8px;color:#334155;background:#f1f5f9}.score-summary.good,.live-take.good{color:#0f5132;border:1px solid #b7e1c2;background:#edf8f0}.score-summary span,.live-take span,.score-summary small{color:#64748b;font-size:13px}.score-summary strong{font-size:22px}.live-take-list{display:grid;max-height:230px;gap:8px;margin-bottom:14px;overflow:auto}.current-line-records,.recent-take-list{display:grid;gap:10px;margin-bottom:14px}.current-line-records{padding:12px;border-radius:8px;background:#f1f5f9}.recent-take-list{max-height:310px;overflow:auto}.recent-take-list h3{margin:0;font-size:15px}.line-take-card,.line-record-take{display:grid;min-width:0;gap:8px;padding:12px;border-radius:8px;color:#334155;background:#fff}.line-take-card.good,.line-record-take.good{color:#0f5132;border:1px solid #b7e1c2;background:#edf8f0}.take-card-header,.take-card-meta{display:flex;flex-wrap:wrap;gap:6px 10px;align-items:center;justify-content:space-between}.take-card-header span,.take-card-meta span,.line-record-take span{color:#64748b;font-size:13px}.take-transcript,.line-record-take p{margin:0;color:inherit;line-height:1.45;overflow-wrap:anywhere}.line-record-take{width:100%;border:0;text-align:left;white-space:normal}.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 12px}.video-review-box{display:grid;gap:10px;margin-bottom:14px;padding:12px;border-radius:8px;color:#334155;background:#f1f5f9}.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:4px}.video-review-box span{color:#64748b;font-size:13px}.review-video{display:block;width:100%;max-height:220px;border-radius:8px;background:#111827;aspect-ratio:16 / 9;object-fit:cover}.live-preview{border:2px solid #8fd6b3}.hidden-preview{display:none}.line-summary-list{display:grid;gap:10px;margin-bottom:18px}.line-summary-list h2{margin:0}.line-summary-card{display:grid;grid-template-columns:minmax(220px,1.4fr) minmax(180px,.8fr) minmax(80px,.35fr) minmax(180px,.8fr) auto;gap:12px;align-items:center;padding:14px;border-radius:8px;background:#f8fafc}.line-summary-card.good{border:1px solid #b7e1c2;background:#edf8f0}.line-summary-card div{display:grid;min-width:0;gap:4px}.line-summary-card span,.take-chip{color:#64748b;font-size:13px}.line-summary-card strong{overflow-wrap:anywhere}.take-chip-row{grid-column:1 / -1;display:flex;flex-wrap:wrap;gap:8px}.take-chip{min-height:34px;padding:0 10px;border:0;border-radius:8px;background:#e6ebf0;font-weight:800}.take-chip.good{color:#0f5132;background:#d9f2e3}.review-ranges{margin-bottom:18px}.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:#111827}.teleprompter-layout.is-fullscreen .teleprompter-stage{display:grid;grid-template-rows:auto minmax(0,1fr) auto;min-height:100dvh;border-radius:0;padding:34px}.teleprompter-layout.is-fullscreen .script-display{min-height:0;padding:14px 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,.teleprompter-controls{justify-content:center}.review-panel{overflow-x:auto}.take-table{display:grid;min-width:780px;gap:8px}.take-row{display:grid;grid-template-columns:120px 130px 250px 80px 90px minmax(220px,1fr);gap:12px;align-items:center;min-height:54px;padding:10px 12px;border-radius:8px;background:#f8fafc}.take-row.selected{background:#edf8f0;border:1px solid #b7e1c2}.table-head{color:#64748b;font-size:12px;font-weight:800;text-transform:uppercase}.attempt-label{display:inline-flex;align-items:center;gap:8px}.upload-zone{display:grid;min-height:150px;margin-bottom:14px;place-items:center;gap:8px;border:1px dashed #64748b;border-radius:8px;color:#334155;background:#f8fafc;font-weight:800}.upload-zone input{max-width:280px}.floating-action{position:fixed;right:22px;bottom:22px;display:grid;width:54px;height:54px;place-items:center;border:0;border-radius:50%;color:#082018;background:#f5c85b;box-shadow:0 16px 32px #1d24332e}.auth-page{display:grid;min-height:100dvh;place-items:center;padding:22px;background:#1f2a37}.auth-panel{width:min(520px,100%);padding:24px;border-radius:8px;background:#fff}.brand-block.dark{color:#1d2433;margin-bottom:22px}.auth-panel h2{margin:0 0 18px;font-size:26px}.setup-status,.status-pill{display:grid;gap:4px;margin-top:16px;padding:12px;border-radius:8px;color:#334155;background:#f1f5f9}.status-pill{display:inline-flex;margin:12px 0;font-weight:800}@media(max-width:980px){.app-shell,.setup-grid,.video-grid,.teleprompter-layout,.project-switcher{grid-template-columns:1fr}.sidebar{position:sticky;top:0;z-index:10;padding:14px}.nav-list{grid-template-columns:repeat(5,minmax(0,1fr))}.nav-item{justify-content:center;padding:0 8px}.nav-item span{display:none}.rolling-script{min-height:340px;font-size:min(var(--prompt-font-size, 52px),34px)}.rolling-line{padding:18px 12px}}@media(max-width:640px){.main-panel{padding:14px}.topbar{align-items:stretch;flex-direction:column}.script-display{min-height:320px}.video-review-box.wide,.line-summary-card,.review-ranges .take-row{grid-template-columns:1fr}.rolling-script{height:440px;min-height:300px;padding-right:10px;padding-left:10px;font-size:min(var(--prompt-font-size, 52px),28px)}.range-control{width:100%;justify-content:space-between}.range-control input{width:min(170px,42vw)}}
