:root{--fg:#0f172a;--muted:#64748b;--bg:#fff;--surface:#f8fafc;--border:#e2e8f0;--accent:#2563eb}*{box-sizing:border-box}html,body{min-height:100vh;color:var(--fg);background:var(--bg);margin:0;padding:0;font-family:ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,sans-serif}main{max-width:960px;margin:0 auto;padding:3rem 1.5rem}h1{margin:0 0 .5rem;font-size:1.75rem}p{color:var(--muted);line-height:1.5}a{color:var(--accent)}.dashboard-header{justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:2rem;display:flex}.dashboard-header-actions{align-items:center;gap:.5rem;display:flex}.button{cursor:pointer;color:inherit;background:0 0;border:1px solid #0000;border-radius:6px;padding:.5rem .9rem;font-family:inherit;font-size:.875rem;font-weight:500;text-decoration:none;display:inline-block}.button-primary{background:var(--accent);color:#fff;border-color:var(--accent)}.button-primary:hover{background:#1d4ed8}.button-ghost{border-color:var(--border);color:var(--fg);background:0 0}.button-ghost:hover{background:var(--surface)}.empty-state{border:1px dashed var(--border);text-align:center;background:var(--surface);border-radius:12px;padding:3rem 2rem}.empty-state h2{color:var(--fg);margin:0 0 .5rem}.empty-state p{max-width:32rem;margin:0 auto 1.5rem}.course-list{flex-direction:column;gap:.75rem;margin:0;padding:0;list-style:none;display:flex}.course-card{border:1px solid var(--border);background:#fff;border-radius:10px;transition:border-color .15s}.course-card:hover{border-color:var(--accent)}.course-card-link{color:inherit;justify-content:space-between;align-items:center;gap:1rem;padding:1rem 1.25rem;text-decoration:none;display:flex}.course-card-main h3{color:var(--fg);margin:0 0 .25rem;font-size:1rem}.course-card-subject{margin:0;font-size:.875rem}.course-card-meta{flex-direction:column;flex-shrink:0;align-items:flex-end;gap:.375rem;display:flex}.course-card-time{color:var(--muted);font-size:.75rem}.status-badge{text-transform:lowercase;letter-spacing:.02em;background:var(--surface);color:var(--fg);border:1px solid var(--border);border-radius:999px;padding:.2rem .6rem;font-size:.75rem;font-weight:500;display:inline-block}.status-drafting{color:#854d0e;background:#fef3c7;border-color:#fde68a}.status-generating{color:#1e40af;background:#dbeafe;border-color:#bfdbfe}.status-review{color:#5b21b6;background:#ede9fe;border-color:#ddd6fe}.status-published{color:#166534;background:#dcfce7;border-color:#bbf7d0}.status-archived{color:#475569;background:#f1f5f9;border-color:#e2e8f0}.wizard-header{margin-bottom:2rem}.wizard-back{color:var(--muted);margin-bottom:1rem;font-size:.875rem;text-decoration:none;display:inline-block}.wizard-back:hover{color:var(--accent)}.wizard-form{flex-direction:column;gap:1.25rem;max-width:36rem;display:flex}.wizard-field{flex-direction:column;gap:.375rem;display:flex}.wizard-field label{color:var(--fg);font-size:.875rem;font-weight:500}.wizard-field input,.wizard-field select{border:1px solid var(--border);color:var(--fg);background:#fff;border-radius:6px;padding:.5rem .75rem;font-family:inherit;font-size:.875rem}.wizard-field input:focus,.wizard-field select:focus{outline:2px solid var(--accent);outline-offset:-1px;border-color:var(--accent)}.wizard-field-hint{color:var(--muted);margin:0;font-size:.75rem}.wizard-field-error{color:#b91c1c;margin:0;font-size:.75rem}.wizard-form-error{color:#991b1b;background:#fef2f2;border:1px solid #fecaca;border-radius:6px;margin:0;padding:.75rem 1rem;font-size:.875rem}.wizard-form-ok{color:#166534;background:#f0fdf4;border:1px solid #bbf7d0;border-radius:6px;margin:0;padding:.75rem 1rem;font-size:.875rem}.wizard-field-link{color:var(--accent);align-self:flex-start;font-size:.75rem;text-decoration:none}.wizard-field-link:hover{text-decoration:underline}.wizard-section{flex-direction:column;gap:.75rem;margin-top:2rem;display:flex}.wizard-section h2{margin:0;font-size:1.125rem}.wizard-form-actions{gap:.5rem;margin-top:.5rem;display:flex}.button:disabled{opacity:.6;cursor:not-allowed}.outline-field{flex-direction:column;gap:.375rem;display:flex}.outline-field span{color:var(--fg);font-size:.8125rem;font-weight:500}.outline-field input,.outline-field textarea{border:1px solid var(--border);width:100%;min-width:0;color:var(--fg);resize:vertical;background:#fff;border-radius:6px;padding:.5rem .75rem;font-family:inherit;font-size:.875rem}.outline-field input:focus,.outline-field textarea:focus{outline:2px solid var(--accent);outline-offset:-1px;border-color:var(--accent)}.auth-page{justify-content:center;align-items:center;min-height:100vh;padding:2rem 1rem;display:flex}.auth-card{border:1px solid var(--border);background:#fff;border-radius:12px;flex-direction:column;gap:1rem;width:100%;max-width:26rem;padding:2rem;display:flex}.auth-card h1{text-align:center;margin:0;font-size:1.375rem}.auth-divider{color:var(--muted);text-transform:uppercase;letter-spacing:.08em;align-items:center;gap:.5rem;font-size:.75rem;display:flex}.auth-divider:before,.auth-divider:after{content:"";background:var(--border);flex:1;height:1px}.auth-form{flex-direction:column;gap:.75rem;display:flex}.auth-alt{text-align:center;margin:0;font-size:.875rem}.button-full{text-align:center;width:100%}.workbench{grid-template-columns:280px 1fr 320px;gap:0;min-height:calc(100vh - 64px);display:grid}.workbench__toc{border-right:1px solid var(--border);padding:1rem;overflow-y:auto}.workbench__toc .toc__header h1{margin:.25rem 0;font-size:1.1rem}.workbench__toc .toc__phase{text-transform:uppercase;letter-spacing:.05em;color:var(--muted);font-size:.75rem;display:inline-block}.workbench__toc .toc__list{margin:1rem 0 0;padding:0;list-style:none}.workbench__toc .toc__item{text-align:left;width:100%;color:var(--fg);cursor:pointer;background:0 0;border:0;border-radius:.5rem;align-items:center;gap:.5rem;padding:.5rem .75rem;display:flex}.workbench__toc .toc__item:hover{background:var(--surface)}.workbench__toc .toc__item--active{background:var(--surface);font-weight:500}.workbench__toc .toc__order{color:var(--muted);font-variant-numeric:tabular-nums;text-align:right;width:1.5rem}.workbench__toc .toc__title{text-overflow:ellipsis;white-space:nowrap;flex:1;overflow:hidden}.workbench__toc .toc__status[data-status=failed],.workbench__toc .toc__status[data-status=cancelled]{color:#dc2626}.workbench__toc .toc__status[data-status=claimed]{color:#2563eb}.workbench__toc .toc__status[data-status=done]{color:#16a34a}.workbench__main{padding:1.25rem 1.5rem;overflow-y:auto}.workbench__empty{color:var(--muted);padding:2rem}.workbench__status{border-left:1px solid var(--border);background:var(--surface);position:relative;overflow-y:auto}.workbench__status--collapsed{width:40px}.workbench__status-toggle{cursor:pointer;color:var(--muted);background:0 0;border:0;font-size:1rem;position:absolute;top:.5rem;left:.25rem}.status-panel{padding:2rem 1rem 1rem}.status-panel header h2{margin:0;font-size:1rem}.status-panel__cost{color:var(--muted);margin:.25rem 0 1rem;font-size:.85rem}.status-panel__counts{gap:.75rem;margin:0;padding:0;list-style:none;display:grid}.status-panel__counts header{justify-content:space-between;margin-bottom:.25rem;font-size:.85rem;display:flex}.status-panel__bar{background:var(--border);border-radius:.25rem;height:.5rem;display:flex;overflow:hidden}.bar{height:100%;display:inline-block}.bar--done{background:#16a34a}.bar--running{background:#2563eb}.bar--pending{background:#94a3b8}.bar--failed{background:#dc2626}.status-panel__errors{margin-top:1.5rem}.status-panel__errors h3{text-transform:uppercase;letter-spacing:.05em;color:var(--muted);margin:0 0 .5rem;font-size:.85rem}.status-panel__errors ul{gap:.75rem;margin:0;padding:0;list-style:none;display:grid}.status-panel__errors li{background:var(--bg);border:1px solid var(--border);border-radius:.5rem;padding:.75rem;font-size:.85rem}.status-panel__error-msg{color:#b91c1c;margin:.25rem 0 .5rem;font-size:.8rem}.gate-bar{border:1px solid var(--border);border-radius:.5rem;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:1.25rem;padding:1rem 1.25rem;display:flex}.gate-bar[data-tone=ready]{background:#ecfeff;border-color:#67e8f9}.gate-bar[data-tone=running]{background:#eff6ff;border-color:#93c5fd}.gate-bar[data-tone=done]{background:#f0fdf4;border-color:#86efac}.gate-bar[data-tone=error]{background:#fef2f2;border-color:#fca5a5}.gate-bar__actions{gap:.5rem;display:flex}.gate-bar.gate-bar--style{display:block}.gate-bar.gate-bar--style>p{margin:0 0 .75rem}.gate-bar.gate-bar--style .gate-bar__actions{justify-content:flex-end;margin-top:.75rem}.style-editor{gap:.75rem;padding:.75rem 0;display:grid}.style-editor__field{gap:.25rem;display:grid}.style-editor__field>span,.style-editor__field-label{color:var(--muted);font-size:.85rem}.style-editor__palette ul,.style-editor__characters ul{gap:.4rem;margin:0 0 .5rem;padding:0;list-style:none;display:grid}.style-editor__palette li,.style-editor__characters li{align-items:center;gap:.4rem;display:flex}.style-editor__palette input[type=text]{width:6rem;font-family:ui-monospace,monospace}.style-editor__characters input[type=text],.style-editor__characters input[type=url]{flex:1;min-width:6rem}.style-editor__voice select{width:100%;padding:.4rem}.style-editor__clone form{flex-wrap:wrap;gap:.4rem;margin-top:.5rem;display:flex}.style-editor__save{align-items:center;gap:.5rem;display:flex}.style-editor__error{color:#b91c1c}.scene-detail{gap:1.25rem;display:grid}.scene-detail__title{background:0 0;border:0;width:100%;padding:.25rem 0;font-size:1.5rem;font-weight:600}.scene-detail__summary{resize:vertical;width:100%;font:inherit;color:var(--muted);background:0 0;border:0;padding:.25rem 0}.scene-detail__save-row{min-height:1.5rem}.scene-detail__pills{flex-wrap:wrap;gap:.5rem;margin:0;padding:0;list-style:none;display:flex}.pill{background:var(--surface);border:1px solid var(--border);border-radius:999px;align-items:center;gap:.5rem;padding:.25rem .75rem;font-size:.8rem;display:inline-flex}.pill--done{background:#f0fdf4;border-color:#bbf7d0}.pill--claimed{background:#eff6ff;border-color:#bfdbfe}.pill--failed,.pill--cancelled{background:#fef2f2;border-color:#fecaca}.pill__retry{cursor:pointer;background:0 0;border:0;padding:0;font-size:1rem}.scene-detail__items{gap:1rem;display:grid}.scene-detail__items-save{gap:.5rem;display:flex}.item{border:1px solid var(--border);border-radius:.5rem;gap:.5rem;padding:1rem;display:grid}.item h3{margin:0 0 .5rem;font-size:.95rem}.item label{gap:.25rem;font-size:.85rem;display:grid}.item label span{color:var(--muted)}.item__options{gap:.25rem;margin:0;padding:0;list-style:none;display:grid}.item__options li{align-items:center;gap:.5rem;display:flex}.item__options input[type=text]{flex:1;padding:.25rem .5rem}.scene-detail__media{gap:.5rem;display:grid}.scene-detail__media img{border-radius:.5rem;max-width:100%}.muted{color:var(--muted)}button.ghost{border:1px solid var(--border);background:0 0}button.danger{color:#fff;background:#dc2626;border:1px solid #dc2626}button.danger:hover:not(:disabled){background:#b91c1c;border-color:#b91c1c}button.ghost.danger{color:#dc2626;background:0 0;border-color:#dc2626}button.ghost.danger:hover:not(:disabled){background:#dc262614}.workbench__toc .toc__actions{gap:.5rem;margin-top:.75rem;display:flex}.modal-overlay{z-index:50;background:#00000073;justify-content:center;align-items:center;padding:1rem;display:flex;position:fixed;inset:0}.modal{background:var(--bg,white);color:var(--fg);border:1px solid var(--border);border-radius:.75rem;gap:.75rem;width:100%;max-width:420px;padding:1.25rem 1.5rem;display:grid;box-shadow:0 12px 40px #00000040}.modal h2{margin:0;font-size:1.1rem}.modal label{gap:.35rem;font-size:.9rem;display:grid}.modal label input{border:1px solid var(--border);font:inherit;background:var(--surface,white);color:inherit;border-radius:.4rem;padding:.5rem .6rem}.modal__error{color:#dc2626;margin:0;font-size:.85rem}.modal__actions{justify-content:flex-end;gap:.5rem;margin-top:.25rem;display:flex}.workbench__mobile-topbar,.workbench__mobile-backdrop{display:none}@media (width<=768px){.workbench{grid-template-columns:minmax(0,1fr);min-height:auto}.workbench__mobile-topbar{border-bottom:1px solid var(--border);background:var(--bg);z-index:30;gap:.5rem;padding:.5rem .75rem;display:flex;position:sticky;top:0}.workbench__mobile-toggle{border:1px solid var(--border);background:var(--surface);min-height:44px;color:var(--fg);font:inherit;cursor:pointer;border-radius:.4rem;flex:1;padding:.5rem .75rem;font-size:.9rem}.workbench__mobile-toggle:active{background:var(--border)}.workbench__mobile-backdrop{z-index:40;background:#0006;display:block;position:fixed;inset:0}.workbench__status-toggle{display:none}.workbench__toc,.workbench__status{z-index:50;background:var(--bg);border:0;width:min(85vw,320px);transition:transform .18s ease-out;position:fixed;top:0;bottom:0;overflow-y:auto}.workbench__toc{border-right:1px solid var(--border);left:0;transform:translate(-100%)}.workbench__status{border-left:1px solid var(--border);width:min(90vw,360px);right:0;transform:translate(100%)}.workbench__toc--mobile-open,.workbench__status--mobile-open{transform:translate(0)}.workbench__status.workbench__status--collapsed.workbench__status--mobile-open{width:min(90vw,360px)}.workbench__main{padding:1rem}.gate-bar{flex-direction:column;align-items:stretch;padding:.875rem 1rem}.gate-bar__actions{flex-wrap:wrap}.gate-bar__actions button{min-height:44px}.style-editor__palette li,.style-editor__characters li{flex-wrap:wrap}.style-editor__palette input[type=text]{flex:1;width:auto;min-width:5rem}.style-editor__characters input[type=text],.style-editor__characters input[type=url]{flex:100%}.style-editor__palette li>button,.style-editor__characters li>button{min-width:44px;min-height:44px}.style-editor__clone form input[type=text],.style-editor__clone form input[type=file]{flex:100%}.dashboard-header,.dashboard-header-actions{flex-direction:column;align-items:stretch}.dashboard-header-actions>*{width:100%}main{padding:1.25rem 1rem}}
