:root{--bg: #0e0f12;--panel: #181a1f;--panel-2: #22252c;--border: #2e333c;--text: #f2f3f5;--muted: #8b91a0;--accent: #4c8cf5;--accent-press: #3d77d6;--danger: #e15454;--warn: #e8a33b;--ok: #52c57a;--mono: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace}*{box-sizing:border-box}html,body,#root{margin:0;padding:0;height:100%;background:var(--bg);color:var(--text);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;font-size:15px}.app{display:flex;flex-direction:column;min-height:100vh}header.top{display:flex;align-items:center;gap:16px;padding:12px 20px;background:var(--panel);border-bottom:1px solid var(--border)}header.top h1{font-size:16px;margin:0;font-weight:600;letter-spacing:.02em}header.top .show-meta{display:flex;gap:14px;margin-left:auto;color:var(--muted);font-family:var(--mono);font-size:13px}nav.tabs{display:flex;gap:2px;padding:0 20px;background:var(--panel);border-bottom:1px solid var(--border)}nav.tabs button{background:transparent;color:var(--muted);border:none;border-bottom:2px solid transparent;padding:10px 14px;font-size:14px;cursor:pointer;font-family:inherit}nav.tabs button.active{color:var(--text);border-bottom-color:var(--accent)}nav.tabs button:disabled{color:#4a4f5a;cursor:not-allowed}main{flex:1;padding:24px;max-width:1100px;width:100%;margin:0 auto}h2{font-size:20px;margin:0 0 16px}h3{font-size:15px;margin:24px 0 10px;color:var(--muted);text-transform:uppercase;letter-spacing:.08em}.panel{background:var(--panel);border:1px solid var(--border);border-radius:8px;padding:20px;margin-bottom:20px}.row{display:flex;gap:12px;margin-bottom:10px;align-items:center}.row label{width:140px;color:var(--muted);font-size:13px}input[type=text],input[type=number],select,textarea{background:var(--panel-2);color:var(--text);border:1px solid var(--border);border-radius:6px;padding:8px 10px;font-family:inherit;font-size:14px;flex:1;min-width:0}textarea{font-family:var(--mono);resize:vertical;min-height:80px}input[type=checkbox]{width:18px;height:18px}button{background:var(--accent);color:#fff;border:none;border-radius:6px;padding:10px 16px;font-size:14px;font-weight:500;cursor:pointer;font-family:inherit}button:hover{background:var(--accent-press)}button:disabled{background:#3a3e46;color:var(--muted);cursor:not-allowed}button.ghost{background:transparent;color:var(--text);border:1px solid var(--border)}button.ghost:hover{background:var(--panel-2)}button.danger{background:var(--danger)}button.big{padding:18px 28px;font-size:16px;width:100%}.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:12px}.list{list-style:none;padding:0;margin:0}.list li{background:var(--panel-2);border:1px solid var(--border);border-radius:6px;padding:10px 12px;margin-bottom:6px;display:flex;justify-content:space-between;align-items:center;gap:8px}.list li .meta{color:var(--muted);font-size:12px;font-family:var(--mono)}.phase-card{background:var(--panel-2);border:2px solid var(--accent);border-radius:8px;padding:20px;text-align:center;margin-bottom:20px}.phase-card .phase-label{font-size:11px;letter-spacing:.12em;color:var(--muted);text-transform:uppercase}.phase-card .phase-value{font-size:28px;font-weight:600;margin:8px 0;font-family:var(--mono)}.phase-card .cycle{font-size:16px;color:var(--muted);font-family:var(--mono)}.steps{display:grid;gap:10px}.step-row{display:grid;grid-template-columns:32px 1fr auto;align-items:center;gap:14px;padding:14px 16px;background:var(--panel-2);border:1px solid var(--border);border-radius:6px}.step-row .step-num{font-family:var(--mono);color:var(--muted);font-size:13px}.step-row .step-label{font-size:15px}.step-row.done .step-label{color:var(--muted);text-decoration:line-through}.brief{background:var(--panel-2);border:1px solid var(--border);border-radius:8px;padding:28px;font-size:18px;line-height:1.55}.brief h2{font-size:28px;margin:0 0 12px}.brief .section{margin:24px 0}.brief .section-label{color:var(--muted);text-transform:uppercase;font-size:12px;letter-spacing:.08em;margin-bottom:6px}.brief .character{border-left:3px solid var(--accent);padding-left:16px;margin:12px 0}.brief .character .name{font-weight:600;font-size:20px}.brief .character .objective{margin:6px 0}.brief .character .beats{list-style:disc;margin:8px 0 0 20px}.stats{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}.stat{background:var(--panel-2);border:1px solid var(--border);border-radius:6px;padding:16px;text-align:center}.stat .value{font-size:28px;font-weight:600;font-family:var(--mono)}.stat .label{font-size:12px;color:var(--muted);text-transform:uppercase;letter-spacing:.08em;margin-top:4px}.feed{max-height:340px;overflow-y:auto;background:var(--panel-2);border:1px solid var(--border);border-radius:6px;padding:8px}.feed-item{padding:8px 10px;border-bottom:1px solid var(--border);font-size:14px}.feed-item:last-child{border-bottom:none}.feed-item .meta{color:var(--muted);font-size:11px;font-family:var(--mono);margin-top:2px}.error{color:var(--danger);background:#e154541a;border:1px solid rgba(225,84,84,.3);padding:10px 12px;border-radius:6px;margin-bottom:14px;font-family:var(--mono);font-size:13px}.muted{color:var(--muted)}.mono{font-family:var(--mono)}.pill{display:inline-block;font-size:11px;padding:2px 8px;border-radius:10px;background:var(--panel);color:var(--muted);border:1px solid var(--border);font-family:var(--mono);text-transform:uppercase;letter-spacing:.06em}.pill.ok{color:var(--ok);border-color:#52c57a66}.pill.warn{color:var(--warn);border-color:#e8a33b66}.vote-options{display:grid;gap:8px}.vote-row{display:grid;grid-template-columns:1fr 60px 80px;gap:10px;padding:10px 12px;background:var(--panel-2);border:1px solid var(--border);border-radius:6px;align-items:center}.vote-row.winner{border-color:var(--ok);background:#52c57a14}.winner-banner{background:#52c57a1f;border:1px solid rgba(82,197,122,.4);padding:14px 16px;border-radius:6px;margin-bottom:20px}.winner-banner .label{font-size:11px;color:var(--ok);text-transform:uppercase;letter-spacing:.1em}.winner-banner .text{font-size:18px;margin-top:4px}.qr-view{display:grid;grid-template-columns:minmax(0,1fr) 260px;gap:24px;align-items:stretch}.qr-card{background:#000;border:1px solid var(--border);border-radius:10px;padding:28px;display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:520px}.qr-headline{font-size:18px;color:var(--muted);text-transform:uppercase;letter-spacing:.1em;margin-bottom:18px}.qr-image-wrap{background:#fff;border-radius:12px;padding:24px;display:flex;align-items:center;justify-content:center;width:min(520px,70vmin);aspect-ratio:1 / 1}.qr-image{width:100%;height:100%;image-rendering:pixelated;display:block}.qr-placeholder{color:#333;font-family:var(--mono)}.qr-url-label{color:var(--muted);margin-top:22px;font-size:14px;letter-spacing:.06em;text-transform:uppercase}.qr-url{font-family:var(--mono);font-size:clamp(20px,2.8vw,34px);color:#fff;margin-top:8px;word-break:break-all;text-align:center}.qr-sidebar{display:flex;flex-direction:column;gap:14px;justify-content:flex-start}.qr-count{background:var(--panel-2);border:1px solid var(--border);border-radius:8px;padding:24px;text-align:center}.qr-count-value{font-family:var(--mono);font-size:56px;font-weight:600;color:var(--ok);line-height:1}.qr-count-label{font-size:12px;color:var(--muted);text-transform:uppercase;letter-spacing:.1em;margin-top:6px}.qr-actions{display:flex;flex-direction:column;gap:8px}.qr-view.fullscreen{display:flex;flex-direction:column;align-items:center;justify-content:center;background:#000;width:100vw;height:100vh;padding:4vh 4vw;grid-template-columns:unset;gap:0}.qr-view.fullscreen .qr-card{border:none;padding:0;min-height:0}.qr-view.fullscreen .qr-image-wrap{width:min(78vh,78vw);padding:3vmin}.qr-view.fullscreen .qr-url{margin-top:4vh;font-size:clamp(28px,5vw,64px)}.qr-view.fullscreen .qr-url-label{margin-top:4vh}.qr-exit-fullscreen{position:fixed;top:16px;right:16px;background:#ffffff14;color:#fff;border:1px solid rgba(255,255,255,.2);font-size:12px;padding:6px 10px;border-radius:6px;font-family:var(--mono)}.qr-exit-fullscreen:hover{background:#ffffff26}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b8;z-index:100;display:flex;align-items:center;justify-content:center;padding:24px}.modal{background:var(--panel);border:1px solid var(--border);border-radius:10px;padding:20px;max-width:1100px;width:100%;max-height:92vh;overflow-y:auto;position:relative}.modal-close{position:absolute;top:12px;right:12px;background:transparent;border:1px solid var(--border);color:var(--text);padding:6px 12px;font-size:14px}.modal-close:hover{background:var(--panel-2)}@media (max-width: 900px){.qr-view{grid-template-columns:1fr}}.record-card{border-left:3px solid var(--danger)}.record-card-head{display:flex;align-items:center;gap:10px;margin-bottom:2px}.record-indicator{font-family:var(--mono);color:var(--danger);display:inline-flex;align-items:center;gap:8px;font-weight:600;margin-left:auto}.record-dot{width:12px;height:12px;border-radius:50%;background:var(--danger);animation:blink 1s infinite}@keyframes blink{50%{opacity:.2}}.record-mode-toggle{display:inline-flex;align-items:center;gap:8px;background:var(--panel-2);border:1px solid var(--border);border-radius:8px;padding:4px;margin:10px 0}.record-mode-toggle .mode-btn{background:transparent;color:var(--muted);border:none;padding:6px 12px;font-size:13px;border-radius:6px;font-family:inherit}.record-mode-toggle .mode-btn.active{background:var(--accent);color:#fff}.record-mode-toggle .mode-btn:disabled{color:#4a4f5a;background:transparent;cursor:not-allowed}.record-mode-toggle .muted{padding:0 8px}.live-preview{position:fixed;bottom:16px;right:16px;width:220px;aspect-ratio:16 / 9;background:#000;border-radius:8px;overflow:hidden;border:2px solid var(--danger);box-shadow:0 6px 18px #0006;z-index:90}.live-preview video{width:100%;height:100%;object-fit:cover;display:block}.record-playback{margin-top:14px;padding-top:14px;border-top:1px solid var(--border)}.upload-progress{margin-top:10px;background:var(--panel-2);border:1px solid var(--border);border-radius:6px;overflow:hidden}.upload-progress .bar{height:8px;background:var(--accent);transition:width .2s ease}.upload-progress .label{display:flex;justify-content:space-between;padding:6px 10px;font-family:var(--mono);font-size:12px;color:var(--muted)}.summary-section{margin-top:14px;border-top:1px solid var(--border);padding-top:10px}.summary-section details{margin:6px 0}.summary-section summary{cursor:pointer;padding:6px 0;font-size:13px;color:var(--muted);-webkit-user-select:none;user-select:none}.summary-section summary:hover{color:var(--text)}.summary-section details[open] summary{color:var(--text);margin-bottom:4px}.character-involvement{display:grid;grid-template-columns:120px 1fr;gap:6px 14px;font-size:13px;padding:6px 0}.character-involvement .name{color:var(--accent);font-weight:500}.notable-list{list-style:none;padding:0;margin:8px 0 0}.notable-list li{background:#4c8cf514;border-left:3px solid var(--accent);padding:8px 12px;margin-bottom:6px;border-radius:0 4px 4px 0;font-style:italic;font-size:14px}.confidence-badge{display:inline-flex;align-items:center;gap:8px;padding:6px 12px;border-radius:6px;font-family:var(--mono);font-size:13px;font-weight:600}.confidence-badge.high{background:#52c57a1f;color:var(--ok);border:1px solid rgba(82,197,122,.4)}.confidence-badge.medium{background:#e8a33b1f;color:var(--warn);border:1px solid rgba(232,163,59,.4)}.confidence-badge.low{background:#e154541f;color:var(--danger);border:1px solid rgba(225,84,84,.4)}.auth-gate{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:40px 20px;background:var(--bg)}.auth-card{background:var(--panel);border:1px solid var(--border);border-radius:12px;padding:40px 36px;max-width:420px;width:100%;box-shadow:0 16px 48px #00000059}.auth-brand{font-size:22px;font-weight:600;letter-spacing:.02em;text-align:center;margin-bottom:24px;color:var(--text)}.auth-title{font-size:20px;font-weight:600;text-align:center;margin-bottom:8px}.auth-subtitle{color:var(--muted);text-align:center;margin-bottom:22px;font-size:14px}.auth-form{display:flex;flex-direction:column;gap:14px}.auth-field{display:flex;flex-direction:column;gap:4px}.auth-field>span{color:var(--muted);font-size:12px;text-transform:uppercase;letter-spacing:.08em}.auth-field input{width:100%;padding:10px 12px}.auth-error{color:var(--danger);background:#e1545414;border:1px solid rgba(225,84,84,.3);padding:10px 12px;border-radius:6px;font-size:13px;text-align:center}.auth-loading{min-height:100vh;display:flex;align-items:center;justify-content:center;color:var(--muted);font-family:var(--mono)}.user-menu{position:relative;display:inline-flex;align-items:center}.user-menu-btn{background:var(--panel-2);border:1px solid var(--border);color:var(--text);display:inline-flex;align-items:center;gap:8px;padding:6px 12px;border-radius:6px;font-size:13px;font-family:inherit;cursor:pointer}.user-menu-btn:hover{background:var(--panel)}.user-menu-btn .role{color:var(--muted);font-size:11px;text-transform:uppercase;letter-spacing:.08em}.user-menu-dropdown{position:absolute;top:100%;right:0;margin-top:6px;min-width:180px;background:var(--panel);border:1px solid var(--border);border-radius:6px;box-shadow:0 8px 24px #0000004d;z-index:50;overflow:hidden}.user-menu-dropdown button{width:100%;text-align:left;background:transparent;color:var(--text);padding:10px 14px;border:none;border-radius:0;font-size:13px;font-family:inherit}.user-menu-dropdown button:hover{background:var(--panel-2)}.user-menu-dropdown .divider{height:1px;background:var(--border)}.user-menu-dropdown .who{padding:10px 14px;color:var(--muted);font-size:11px;text-transform:uppercase;letter-spacing:.08em}.operator-row{display:grid;grid-template-columns:1fr 110px 1fr auto;gap:12px;align-items:center;padding:10px 12px;background:var(--panel-2);border:1px solid var(--border);border-radius:6px;margin-bottom:8px}.operator-row .role-pill{font-family:var(--mono);font-size:11px;text-transform:uppercase;padding:3px 10px;border-radius:10px;text-align:center}.operator-row .role-pill.admin{color:var(--accent);background:#4c8cf51f}.operator-row .role-pill.operator{color:var(--muted);background:var(--panel)}.summary-review .metadata{display:grid;grid-template-columns:140px 1fr;gap:6px 14px;font-size:13px;margin-top:8px}.summary-review .metadata .key{color:var(--muted);text-transform:uppercase;letter-spacing:.08em;font-size:11px;padding-top:2px}.summary-review .quotes{margin-top:12px;border-left:2px solid var(--border);padding-left:12px}.summary-review .quotes blockquote{margin:8px 0;font-style:italic;color:var(--text)}.confidence-warn{background:#e8a33b1a;border:1px solid rgba(232,163,59,.4);color:var(--warn);padding:10px 12px;border-radius:6px;margin-bottom:12px;font-size:13px}.manual-toggle{background:none;border:none;color:var(--accent);padding:0;font-size:13px;cursor:pointer;text-decoration:underline}.manual-toggle:hover{background:none;color:var(--accent-press)}.stepper{display:flex;flex-direction:column;margin:14px 0}.stepper-item{display:grid;grid-template-columns:48px 1fr;gap:14px;padding-bottom:6px}.stepper-rail{display:flex;flex-direction:column;align-items:center;width:48px}.stepper-icon{width:32px;height:32px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;font-size:14px;font-weight:600;font-family:var(--mono);border:2px solid var(--border);background:var(--panel);color:var(--muted);flex-shrink:0}.stepper-icon.ready{background:var(--accent);color:#fff;border-color:var(--accent);box-shadow:0 0 0 3px #4c8cf533}.stepper-icon.in-progress{background:transparent;border-color:var(--accent);color:var(--accent)}.stepper-icon.done{background:var(--ok);border-color:var(--ok);color:#fff}.stepper-icon.error{background:var(--danger);border-color:var(--danger);color:#fff}.stepper-icon.locked{opacity:.6}.stepper-line{flex:1;width:2px;background:var(--border);min-height:20px;margin:4px 0}.stepper-line.completed{background:var(--ok)}.stepper-content{background:var(--panel);border:1px solid var(--border);border-radius:8px;padding:14px 16px;margin-bottom:8px;transition:border-color .15s ease}.stepper-item.ready .stepper-content{border-color:var(--accent);box-shadow:0 0 0 1px #4c8cf54d}.stepper-item.error .stepper-content{border-color:var(--danger)}.stepper-item.locked .stepper-content{opacity:.65}.stepper-head{display:flex;justify-content:space-between;align-items:flex-start;gap:10px}.stepper-label{font-size:15px;font-weight:500;color:var(--text)}.stepper-item.completed .stepper-label{color:var(--muted)}.stepper-sub{font-size:12px;color:var(--muted);margin-top:2px}.step-error{margin-top:8px;padding:8px 10px;background:#e154541f;border:1px solid rgba(225,84,84,.35);color:var(--danger);border-radius:5px;font-size:13px;font-family:var(--mono)}.step-expansion{margin-top:12px;padding-top:12px;border-top:1px solid var(--border)}.spinner{display:inline-block;width:14px;height:14px;border-radius:50%;border:2px solid rgba(255,255,255,.15);border-top-color:var(--accent);animation:spin .8s linear infinite}.spinner-inline{display:inline-flex;align-items:center;gap:8px;color:var(--muted);font-size:13px}@keyframes spin{to{transform:rotate(360deg)}}.cycle-transition{display:flex;align-items:center;justify-content:center;min-height:50vh}.cycle-transition-inner{text-align:center;padding:36px 48px;background:var(--panel);border:1px solid var(--border);border-radius:12px;animation:fade-in .3s ease}.cycle-transition-main{font-size:40px;font-weight:600;font-family:var(--mono);margin:14px 0 8px;letter-spacing:-.02em}@keyframes fade-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}.status-indicator{display:inline-flex;align-items:center;gap:8px;padding:8px 12px;background:var(--panel-2);border:1px solid var(--border);border-radius:6px;cursor:pointer;font-family:inherit;font-size:13px;color:var(--text)}.status-indicator:hover{background:var(--panel)}.status-indicator .dot{width:10px;height:10px;border-radius:50%;display:inline-block}.status-indicator.healthy .dot{background:var(--ok);box-shadow:0 0 0 3px #52c57a2e}.status-indicator.warning .dot{background:var(--warn);box-shadow:0 0 0 3px #e8a33b2e}.status-indicator.critical .dot{background:var(--danger);box-shadow:0 0 0 3px #e1545433;animation:blink 1.4s infinite}.status-indicator .meta{color:var(--muted);font-size:12px}.settings{display:flex;flex-direction:column;gap:20px}.settings h2{margin:0 0 6px}.settings .section{background:var(--panel);border:1px solid var(--border);border-radius:8px;padding:20px}.settings .section.danger{border-color:#e1545480;background:#e154540a}.settings .section h3{margin:0 0 12px;color:var(--text);letter-spacing:0;text-transform:none;font-size:16px}.settings .section .help{color:var(--muted);font-size:13px;margin:0 0 14px}.service-list{display:grid;grid-template-columns:1fr;gap:8px}.service-row{display:grid;grid-template-columns:1fr 110px 140px;gap:12px;padding:10px 12px;background:var(--panel-2);border:1px solid var(--border);border-radius:6px;align-items:center}.service-row .name{font-weight:500}.service-row .meta{color:var(--muted);font-family:var(--mono);font-size:12px}.service-row .status-pill{padding:3px 10px;border-radius:10px;font-family:var(--mono);font-size:11px;text-align:center;letter-spacing:.06em;text-transform:uppercase}.service-row .status-pill.healthy{background:#52c57a26;color:var(--ok)}.service-row .status-pill.unreachable{background:#e1545426;color:var(--danger)}.service-row .key-state{font-family:var(--mono);font-size:12px;color:var(--muted)}.service-row .key-state.ok{color:var(--ok)}.service-row .key-state.missing{color:var(--warn)}.secret-input{display:grid;grid-template-columns:1fr auto auto auto;gap:8px;align-items:center}.test-result.ok{color:var(--ok);font-family:var(--mono);font-size:13px}.test-result.bad{color:var(--danger);font-family:var(--mono);font-size:13px}
