:root{--bg: #f4f5f9;--surface: #ffffff;--surface-2: #f8f9fc;--border: #e3e6ef;--border-2: #cdd1e0;--text-primary: #1a1d2e;--text-secondary: #5a6075;--text-muted: #8b91a8;--accent: #5b55e7;--accent-hover: #4a44d4;--accent-light: #ededfc;--accent-2: #e84393;--green: #22c55e;--green-light: #dcfce7;--amber: #f59e0b;--amber-light: #fef3c7;--red: #ef4444;--red-light: #fee2e2;--radius-sm: 6px;--radius: 10px;--radius-lg: 16px;--shadow-sm: 0 1px 3px rgba(0,0,0,.06);--shadow: 0 4px 12px rgba(0,0,0,.08);--shadow-lg: 0 8px 32px rgba(0,0,0,.12);font-family:PingFang SC,Microsoft YaHei,Inter,system-ui,sans-serif;color:var(--text-primary);background:var(--bg);font-size:14px;line-height:1.6}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{min-height:100vh}button{cursor:pointer;font:inherit;border:none;outline:none}input,textarea,select{font:inherit}.app{min-height:100vh;display:flex;flex-direction:column}.app-topbar{position:sticky;top:0;z-index:100;background:var(--surface);border-bottom:1px solid var(--border);box-shadow:var(--shadow-sm)}.app-topbar-inner{max-width:1440px;margin:0 auto;padding:0 24px;height:52px;display:flex;align-items:center;gap:16px}.app-logo{display:flex;align-items:center;gap:10px;background:none;color:var(--text-primary);text-decoration:none;flex-shrink:0}.app-logo-mark{width:30px;height:30px;background:linear-gradient(135deg,var(--accent),var(--accent-2));border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:14px}.app-logo-text{font-weight:600;font-size:15px;color:var(--text-primary)}.back-btn{background:none;color:var(--text-secondary);font-size:13px;padding:5px 10px;border-radius:var(--radius-sm);transition:background .15s}.back-btn:hover{background:var(--bg);color:var(--text-primary)}.app-topbar-right{margin-left:auto}.project-badge{font-size:12px;color:var(--text-muted);background:var(--bg);padding:4px 10px;border-radius:20px;border:1px solid var(--border)}.app-body{flex:1}.center-page{max-width:1200px;margin:0 auto;padding:48px 24px 80px}.center-header{margin-bottom:56px;text-align:center}.center-header-inner{max-width:680px;margin:0 auto}.center-badge{display:inline-block;margin-bottom:16px;font-size:11px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--accent);background:var(--accent-light);padding:4px 12px;border-radius:20px}.center-title{font-size:clamp(28px,4vw,42px);font-weight:700;line-height:1.2;color:var(--text-primary);margin-bottom:16px}.center-desc{font-size:15px;color:var(--text-secondary);line-height:1.8;margin-bottom:20px}.center-stats{display:flex;align-items:center;justify-content:center;gap:10px}.center-stat{font-size:13px;color:var(--text-muted)}.center-divider{color:var(--border-2)}.agents-section{margin-bottom:56px}.flow-label{font-size:11px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--text-muted);margin-bottom:16px}.flow-arrow-row{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:40px;align-items:stretch}.flow-arrow-item{position:relative;display:flex;min-width:0}.flow-arrow-item .agent-card{width:100%}.flow-arrow{position:absolute;right:-28px;top:50%;transform:translateY(-50%);color:var(--border-2);font-size:20px;pointer-events:none}.agent-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:24px 20px;display:flex;flex-direction:column;gap:8px;transition:box-shadow .15s,transform .15s,border-color .15s;cursor:default}.agent-card:not(.disabled):hover{box-shadow:var(--shadow);border-color:var(--accent);transform:translateY(-2px)}.agent-card.disabled{opacity:.6}.agent-card-top{display:flex;align-items:center;justify-content:space-between}.agent-step-badge{font-size:10px;font-weight:700;letter-spacing:.06em;color:var(--text-muted)}.agent-status{font-size:11px;font-weight:500;padding:2px 8px;border-radius:20px}.status-active{background:var(--green-light);color:#16a34a}.status-placeholder{background:var(--amber-light);color:#b45309}.status-planned{background:var(--bg);color:var(--text-muted);border:1px solid var(--border)}.agent-icon{font-size:28px;margin:4px 0}.agent-card-name{font-size:16px;font-weight:600}.agent-card-desc{font-size:13px;color:var(--text-secondary);line-height:1.5;flex:1}.agent-card-btn{margin-top:8px;width:100%;background:var(--accent);color:#fff;padding:8px 0;border-radius:var(--radius-sm);font-size:13px;font-weight:500;transition:background .15s}.agent-card-btn:hover{background:var(--accent-hover)}.agent-card-btn--disabled{background:var(--bg);color:var(--text-muted);border:1px solid var(--border)}.agent-card-btn--disabled:hover{background:var(--bg)}.quick-start-section{margin-top:40px}.section-heading{font-size:18px;font-weight:600;margin-bottom:20px}.quick-start-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px}.quick-item{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:24px 20px;cursor:pointer;transition:box-shadow .15s,border-color .15s;display:flex;flex-direction:column;gap:6px}.quick-item:hover{box-shadow:var(--shadow);border-color:var(--accent)}.quick-icon{font-size:24px}.quick-item strong{font-size:15px;font-weight:600}.quick-item p{font-size:13px;color:var(--text-secondary)}.workspace{display:flex;flex-direction:column;min-height:calc(100vh - 52px)}.step-nav{display:flex;align-items:center;padding:0 24px;background:var(--surface);border-bottom:1px solid var(--border);overflow-x:auto;scrollbar-width:none}.step-nav::-webkit-scrollbar{display:none}.step-nav-item-wrap{display:flex;align-items:center;flex-shrink:0}.step-nav-item{display:flex;align-items:center;gap:6px;padding:14px 12px;background:none;color:var(--text-muted);font-size:13px;font-weight:500;border-bottom:2px solid transparent;transition:color .15s,border-color .15s;white-space:nowrap}.step-nav-item:hover{color:var(--text-primary)}.step-nav-item.current{color:var(--accent);border-bottom-color:var(--accent)}.step-nav-item.inactive{opacity:.5}.step-num{width:18px;height:18px;border-radius:50%;background:var(--bg);font-size:10px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}.step-nav-item.current .step-num{background:var(--accent);color:#fff}.step-icon{font-size:14px}.step-connector{color:var(--border-2);padding:0 4px;font-size:16px}.workspace-content{display:flex;flex:1;max-width:1440px;width:100%;margin:0 auto;padding:24px;gap:24px;align-items:flex-start}.workspace-sidebar{width:340px;flex-shrink:0;display:flex;flex-direction:column;gap:16px;position:sticky;top:76px;max-height:calc(100vh - 100px);overflow-y:auto}.workspace-main{flex:1;min-width:0}.agent-info{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px}.agent-info-step{font-size:11px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--text-muted);margin-bottom:4px}.agent-info-name{font-size:20px;font-weight:700;margin-bottom:6px}.agent-info-desc{font-size:13px;color:var(--text-secondary)}.placeholder-notice{background:var(--amber-light);border:1px solid #fcd34d;border-radius:var(--radius);padding:16px;display:flex;gap:10px;align-items:flex-start}.placeholder-icon{font-size:20px;flex-shrink:0}.placeholder-notice p{font-size:13px;color:#92400e;line-height:1.6}.upstream-notice{background:var(--accent-light);border:1px solid #c7c3f7;border-radius:var(--radius);padding:10px 14px;font-size:12px;color:var(--accent);display:flex;gap:8px;align-items:center}.input-panel{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px;display:flex;flex-direction:column;gap:16px}.input-panel h2{font-size:14px;font-weight:600;color:var(--text-secondary);margin-bottom:4px}.field-label span{font-size:13px;font-weight:500;color:var(--text-secondary)}input[type=text],input[type=number],textarea,select{width:100%;padding:9px 12px;border:1px solid var(--border-2);border-radius:var(--radius-sm);background:var(--surface);color:var(--text-primary);transition:border-color .15s,box-shadow .15s}input:focus,textarea:focus,select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px #5b55e71a}input:disabled,textarea:disabled,select:disabled{background:var(--bg);color:var(--text-muted);cursor:not-allowed}textarea{min-height:140px;resize:vertical}.action-bar{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:16px;display:flex;flex-direction:column;gap:10px}.btn-primary{width:100%;background:var(--accent);color:#fff;padding:10px 20px;border-radius:var(--radius-sm);font-size:14px;font-weight:600;display:flex;align-items:center;justify-content:center;gap:8px;transition:background .15s}.btn-primary:hover:not(:disabled){background:var(--accent-hover)}.btn-primary:disabled{background:var(--text-muted);cursor:not-allowed}.btn-spinner{width:14px;height:14px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .6s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.action-secondary{display:flex;gap:8px}.btn-secondary{flex:1;padding:8px 0;background:var(--bg);color:var(--text-secondary);border:1px solid var(--border-2);border-radius:var(--radius-sm);font-size:13px;transition:background .15s}.btn-secondary:hover{background:var(--border)}.btn-ghost{width:100%;padding:8px;background:none;color:var(--text-muted);font-size:12px;text-align:center}.btn-ghost:hover{color:var(--red)}.btn-next{width:100%;padding:10px;background:linear-gradient(135deg,var(--accent),var(--accent-2));color:#fff;border-radius:var(--radius-sm);font-size:13px;font-weight:600;transition:opacity .15s}.btn-next:hover{opacity:.9}.result-section{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:0;min-height:300px;overflow:hidden}.result-title{font-size:15px;font-weight:600;padding:16px 20px 0}.running-state,.empty-state,.error-state{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:300px;padding:40px;text-align:center;color:var(--text-muted)}.spinner{width:36px;height:36px;border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite;margin-bottom:16px}.empty-icon{font-size:40px;margin-bottom:12px}.running-state p,.empty-state p{font-size:14px}.error-state{flex-direction:row;gap:12px;background:var(--red-light);color:var(--red);min-height:auto;text-align:left;padding:20px 24px}.error-icon{font-size:20px;flex-shrink:0}.error-state strong{display:block;font-weight:600;margin-bottom:4px}.error-state p{font-size:13px}.renderer{padding:0}.renderer-header{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px;padding:16px 20px;border-bottom:1px solid var(--border);background:var(--surface-2)}.renderer-meta{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.renderer-title{font-size:15px;font-weight:600}.renderer-stat{font-size:12px;color:var(--text-muted);background:var(--bg);padding:3px 10px;border-radius:20px;border:1px solid var(--border)}.renderer-toolbar{display:flex;align-items:center;gap:8px}.view-toggle{display:flex;border:1px solid var(--border-2);border-radius:var(--radius-sm);overflow:hidden}.view-toggle button{padding:5px 12px;font-size:12px;background:var(--surface);color:var(--text-muted);border:none;transition:background .1s}.view-toggle button.active{background:var(--accent);color:#fff}.btn-export{padding:5px 12px;font-size:12px;background:var(--bg);color:var(--text-secondary);border:1px solid var(--border-2);border-radius:var(--radius-sm)}.btn-export:hover{background:var(--border)}.tag{display:inline-block;font-size:11px;font-weight:500;background:var(--accent-light);color:var(--accent);padding:2px 8px;border-radius:4px}.tag-subtle{display:inline-block;font-size:11px;background:var(--bg);color:var(--text-secondary);padding:2px 8px;border-radius:4px;border:1px solid var(--border)}.icon-btn{padding:4px 8px;font-size:12px;background:var(--bg);color:var(--text-secondary);border-radius:var(--radius-sm);border:1px solid var(--border)}.icon-btn:hover{background:var(--border)}.row-actions{display:flex;gap:4px}.empty-hint{color:var(--text-muted);padding:32px;text-align:center}.sb-table-wrap{overflow-x:auto}.sb-table{width:100%;border-collapse:collapse;font-size:13px}.sb-table th{text-align:left;padding:10px 12px;background:var(--surface-2);font-size:11px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;border-bottom:1px solid var(--border);white-space:nowrap}.sb-table td{padding:11px 12px;border-bottom:1px solid var(--border);vertical-align:top}.sb-table tr:hover td{background:var(--surface-2)}.sb-table tr.expanded td{background:var(--accent-light)}.shot-num{font-weight:700;color:var(--accent);white-space:nowrap}.cell-desc{max-width:240px;line-height:1.5}.cell-dialogue{max-width:180px}.dialogue-text{color:var(--accent);font-style:italic}.narration-text{color:var(--text-muted);font-size:12px}.detail-row td{background:var(--accent-light)!important}.shot-detail{padding:8px 0;display:flex;flex-direction:column;gap:6px;font-size:13px}.shot-detail strong{color:var(--text-secondary)}.sb-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:16px;padding:20px}.sb-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:16px;display:flex;flex-direction:column;gap:10px}.sb-card-header{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.shot-badge{font-size:12px;font-weight:700;background:var(--accent);color:#fff;padding:2px 8px;border-radius:var(--radius-sm)}.scene-label{font-size:12px;color:var(--text-muted)}.duration-label{font-size:12px;color:var(--text-muted);margin-left:auto;margin-right:4px}.sb-card-desc{font-size:13px;line-height:1.6}.sb-card-row{display:flex;gap:8px;font-size:12px}.sb-label{color:var(--text-muted);flex-shrink:0}.sb-card-footer{display:flex;gap:6px;flex-wrap:wrap}.sb-card-notes{font-size:12px;color:var(--text-muted);border-top:1px solid var(--border);padding-top:8px}.va-tabs{display:flex;gap:0;border-bottom:1px solid var(--border);padding:0 20px;background:var(--surface)}.va-tab{display:flex;align-items:center;gap:6px;padding:12px 16px;font-size:13px;font-weight:500;background:none;color:var(--text-muted);border-bottom:2px solid transparent;transition:color .15s,border-color .15s;white-space:nowrap}.va-tab:hover{color:var(--text-primary)}.va-tab.active{color:var(--accent);border-bottom-color:var(--accent)}.tab-count{font-size:11px;background:var(--bg);border:1px solid var(--border);padding:1px 6px;border-radius:10px}.va-tab.active .tab-count{background:var(--accent-light);border-color:var(--accent);color:var(--accent)}.va-content{padding:20px}.asset-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px}.asset-card{border:1px solid var(--border);border-radius:var(--radius);padding:16px;display:flex;gap:14px;background:var(--surface)}.asset-avatar{width:48px;height:48px;flex-shrink:0;background:linear-gradient(135deg,var(--accent),var(--accent-2));border-radius:var(--radius);color:#fff;display:flex;align-items:center;justify-content:center;font-size:20px;font-weight:700}.scene-icon{font-size:32px;flex-shrink:0}.asset-body{flex:1;min-width:0;display:flex;flex-direction:column;gap:6px}.asset-name{font-size:15px;font-weight:600}.asset-desc{font-size:13px;color:var(--text-secondary);line-height:1.5}.asset-row{display:flex;gap:8px;font-size:12px}.asset-label{color:var(--text-muted);flex-shrink:0}.asset-tags{display:flex;gap:6px;flex-wrap:wrap}.asset-shots{font-size:11px;color:var(--text-muted)}.asset-list{display:flex;flex-direction:column;gap:12px}.prop-row{display:flex;gap:12px;align-items:flex-start;padding:14px;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface)}.prop-icon{font-size:20px;flex-shrink:0}.prop-body{flex:1}.prop-body strong{font-size:14px;font-weight:600;display:block;margin-bottom:4px}.prop-body p{font-size:13px;color:var(--text-secondary)}.style-panel{display:flex;flex-direction:column;gap:20px}.style-summary{font-size:14px;line-height:1.7;color:var(--text-secondary)}.style-section{display:flex;flex-direction:column;gap:8px}.style-section h4{font-size:13px;font-weight:600;color:var(--text-muted)}.style-section p{font-size:13px;color:var(--text-secondary)}.color-palette{display:flex;gap:10px;flex-wrap:wrap}.color-chip{display:flex;flex-direction:column;align-items:center;gap:4px}.color-swatch{width:36px;height:36px;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--border)}.color-chip span{font-size:11px;color:var(--text-muted)}.pm-layout{display:flex;min-height:480px}.pm-shot-list{width:180px;flex-shrink:0;border-right:1px solid var(--border);display:flex;flex-direction:column;overflow-y:auto;max-height:600px}.pm-shot-list-header{padding:12px 14px;font-size:11px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--border);background:var(--surface-2)}.pm-shot-item{display:flex;flex-direction:column;align-items:flex-start;text-align:left;padding:10px 14px;gap:2px;background:none;color:var(--text-secondary);border-bottom:1px solid var(--border);font-size:12px;transition:background .1s}.pm-shot-item:hover{background:var(--bg)}.pm-shot-item.active{background:var(--accent-light);color:var(--accent)}.pm-shot-num{font-weight:700}.pm-shot-desc{font-size:11px;color:var(--text-muted);overflow:hidden;white-space:nowrap;text-overflow:ellipsis;max-width:140px}.pm-shot-item.active .pm-shot-desc{color:var(--accent);opacity:.7}.pm-detail{flex:1;padding:20px;display:flex;flex-direction:column;gap:16px;overflow-y:auto}.pm-detail-header{display:flex;align-items:center;gap:12px;flex-wrap:wrap;padding-bottom:16px;border-bottom:1px solid var(--border)}.pm-detail-num{font-size:16px;font-weight:700}.pm-detail-desc{font-size:13px;color:var(--text-muted);flex:1}.pm-fields{display:flex;flex-direction:column;gap:12px}.pm-field{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.pm-field-header{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;border-bottom:1px solid var(--border);background:var(--surface)}.pm-field-label{font-size:12px;font-weight:600;color:var(--text-secondary)}.pm-field-body{padding:12px 14px;font-size:13px;line-height:1.7;color:var(--text-primary);white-space:pre-wrap}.pm-field-body.negative{color:var(--red);background:var(--red-light)}.copy-btn{padding:4px 10px;font-size:11px;background:var(--bg);color:var(--text-secondary);border:1px solid var(--border-2);border-radius:var(--radius-sm);white-space:nowrap;transition:background .1s}.copy-btn:hover{background:var(--border)}.pm-params{display:flex;flex-direction:column;gap:4px;padding:12px 14px}.pm-param-row{display:flex;gap:12px;font-size:12px}.pm-param-key{color:var(--text-muted);width:100px;flex-shrink:0}.pm-param-val{color:var(--text-primary);font-weight:500}.json-dump{overflow:auto;padding:20px;background:#171927;color:#e9ecff;font-size:12px;line-height:1.6;border-radius:0 0 var(--radius-lg) var(--radius-lg)}.input-panel{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px;display:flex;flex-direction:column;gap:14px}.field-label{display:grid;gap:6px}.field-label>span{font-size:12px;font-weight:600;color:var(--text-secondary)}@media(max-width:1024px){.workspace-content{padding:16px;gap:16px}.workspace-sidebar{width:300px;position:static;max-height:none}}@media(max-width:768px){.center-page{padding:32px 16px 60px}.flow-arrow-row{grid-template-columns:1fr;gap:12px}.flow-arrow{display:none}.flow-arrow-item{min-width:140px}.workspace-content{flex-direction:column}.workspace-sidebar{width:100%}.pm-layout{flex-direction:column}.pm-shot-list{width:100%;max-height:120px;flex-direction:row;overflow-x:auto;overflow-y:hidden;border-right:none;border-bottom:1px solid var(--border)}.pm-shot-item{flex-direction:row;border-bottom:none;border-right:1px solid var(--border)}}@media(prefers-reduced-motion:reduce){.spinner,.btn-spinner{animation:none}*{transition:none!important}}.topbar-nav{display:flex;gap:4px;margin-left:8px}.topbar-nav-item{padding:6px 14px;font-size:13px;font-weight:500;background:none;color:var(--text-muted);border-radius:var(--radius-sm);transition:background .15s,color .15s}.topbar-nav-item:hover{background:var(--bg);color:var(--text-primary)}.topbar-nav-item.active{background:var(--accent-light);color:var(--accent)}.topbar-user-btn{width:32px;height:32px;border-radius:50%;background:var(--bg);border:1px solid var(--border);font-size:14px;display:flex;align-items:center;justify-content:center;cursor:not-allowed;opacity:.5}.page-container{max-width:960px;margin:0 auto;padding:40px 24px 80px}.page-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:32px;flex-wrap:wrap}.page-title{font-size:24px;font-weight:700;margin-bottom:4px}.page-subtitle{font-size:14px;color:var(--text-muted)}.breadcrumb-btn{background:none;color:var(--text-muted);font-size:13px;padding:0;margin-bottom:6px;display:block}.breadcrumb-btn:hover{color:var(--accent)}.btn-md{padding:9px 20px;font-size:14px;border-radius:var(--radius-sm);white-space:nowrap}.project-grid{display:flex;flex-direction:column;gap:10px}.project-card{display:flex;align-items:center;gap:16px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:16px 20px;text-align:left;width:100%;transition:box-shadow .15s,border-color .15s}.project-card:hover{box-shadow:var(--shadow);border-color:var(--accent)}.project-card-icon{font-size:24px;flex-shrink:0}.project-card-body{flex:1;min-width:0}.project-card-name{font-size:15px;font-weight:600}.project-card-meta{font-size:12px;color:var(--text-muted);margin-top:2px}.project-card-arrow{font-size:20px;color:var(--border-2)}.loading-state{display:flex;flex-direction:column;align-items:center;padding:60px 20px;gap:12px;color:var(--text-muted)}.loading-inline{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--text-muted);padding:12px 0}.spinner-sm{width:14px;height:14px;border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .7s linear infinite;flex-shrink:0}.empty-state-page{display:flex;flex-direction:column;align-items:center;padding:80px 20px;gap:12px;text-align:center}.empty-state-page h2{font-size:18px;font-weight:600}.empty-state-page p{color:var(--text-muted);max-width:300px}.empty-state-sm{padding:24px;text-align:center;color:var(--text-muted);font-size:13px}.modal-overlay{position:fixed;inset:0;background:#0006;z-index:200;display:flex;align-items:center;justify-content:center;padding:24px}.modal{background:var(--surface);border-radius:var(--radius-lg);padding:28px;width:100%;max-width:440px;display:flex;flex-direction:column;gap:16px;box-shadow:var(--shadow-lg)}.modal-title{font-size:18px;font-weight:700}.modal-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:4px}.inline-error{font-size:13px;color:var(--red)}.overview-section{margin-bottom:36px}.section-heading{font-size:16px;font-weight:600;margin-bottom:14px}.progress-section{margin-bottom:32px}.progress-header{display:flex;justify-content:space-between;font-size:13px;margin-bottom:8px}.progress-label{font-weight:500}.progress-count{color:var(--text-muted)}.progress-bar-track{height:6px;background:var(--border);border-radius:3px;overflow:hidden}.progress-bar-fill{height:100%;background:linear-gradient(90deg,var(--accent),var(--accent-2));border-radius:3px;transition:width .4s ease}.artifact-status-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:12px}.artifact-card{display:flex;align-items:center;gap:12px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:16px;text-align:left;transition:box-shadow .15s,border-color .15s;width:100%}.artifact-card:hover{box-shadow:var(--shadow);border-color:var(--accent)}.artifact-card.exists{border-color:var(--green);background:var(--green-light)}.artifact-card-icon{font-size:24px;flex-shrink:0}.artifact-card-body{flex:1;min-width:0}.artifact-card-label{display:block;font-size:14px;font-weight:600}.artifact-exists-badge{display:block;font-size:11px;color:#16a34a;margin-top:2px}.artifact-missing-badge{display:block;font-size:11px;color:var(--text-muted);margin-top:2px}.artifact-card-arrow{font-size:18px;color:var(--border-2)}.agent-entry-list{display:flex;flex-direction:column;gap:8px}.agent-entry-item{display:flex;align-items:center;gap:14px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:14px 16px;text-align:left;transition:box-shadow .15s,border-color .15s;width:100%}.agent-entry-item:hover{box-shadow:var(--shadow);border-color:var(--accent)}.agent-entry-item.inactive{opacity:.6}.agent-entry-step{width:28px;height:28px;border-radius:50%;background:var(--accent-light);color:var(--accent);font-size:12px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}.agent-entry-body{flex:1;min-width:0}.agent-entry-name{display:block;font-size:14px;font-weight:600}.agent-entry-desc{display:block;font-size:12px;color:var(--text-muted);margin-top:1px}.agent-entry-status{font-size:11px;padding:2px 8px;border-radius:20px;white-space:nowrap}.run-history-list{display:flex;flex-direction:column;gap:8px}.run-history-item{display:flex;align-items:center;gap:12px;padding:10px 14px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);font-size:13px}.run-agent-name{flex:1;font-weight:500}.run-time{font-size:12px;color:var(--text-muted)}.run-status-badge{font-size:11px;padding:2px 8px;border-radius:20px;font-weight:500;white-space:nowrap}.status-failed{background:var(--red-light);color:var(--red)}.status-running{background:var(--amber-light);color:var(--amber)}.status-pending{background:var(--bg);color:var(--text-muted);border:1px solid var(--border)}.drawer-overlay{position:fixed;inset:0;background:#00000040;z-index:150}.run-drawer{position:fixed;right:0;top:52px;bottom:0;width:320px;background:var(--surface);border-left:1px solid var(--border);box-shadow:var(--shadow-lg);z-index:160;transform:translate(100%);transition:transform .25s ease;display:flex;flex-direction:column}.run-drawer.open{transform:translate(0)}.drawer-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border);flex-shrink:0}.drawer-title{font-size:15px;font-weight:600}.drawer-close{background:none;color:var(--text-muted);font-size:16px;padding:4px 8px;border-radius:var(--radius-sm)}.drawer-close:hover{background:var(--bg);color:var(--text-primary)}.drawer-body{flex:1;overflow-y:auto;padding:16px}.run-list{display:flex;flex-direction:column;gap:8px}.run-item{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-sm);padding:12px 14px}.run-item-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:4px}.run-item-id{font-size:11px;color:var(--text-muted);font-family:monospace}.upstream-banner{display:flex;gap:12px;align-items:flex-start;border-radius:var(--radius);padding:14px 16px;font-size:13px}.upstream-banner strong{display:block;font-weight:600;margin-bottom:6px}.upstream-banner p{color:inherit;opacity:.85;font-size:12px;margin-bottom:8px}.upstream-ok{background:var(--green-light);border:1px solid #86efac;color:#15803d}.upstream-warn{background:var(--amber-light);border:1px solid #fcd34d;color:#92400e}.upstream-banner>span{font-size:18px;flex-shrink:0;margin-top:1px}.upstream-banner-body{flex:1}.upstream-hint{font-size:12px;margin-top:6px;opacity:.8}.upstream-items{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:4px}.upstream-item-tag{font-size:11px;background:#fff9;padding:3px 10px;border-radius:20px;border:1px solid currentColor;opacity:.9}.upstream-missing-btn{font-size:12px;font-weight:600;background:#ffffffb3;color:#92400e;border:1px solid #fcd34d;border-radius:var(--radius-sm);padding:5px 12px}.upstream-missing-btn:hover{background:#fffffff2}.workflow-pipeline{display:flex;align-items:stretch;gap:0;flex-wrap:wrap;margin-top:8px}.workflow-step-wrap{display:flex;align-items:center;flex:1;min-width:160px}.workflow-step{flex:1;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:24px 20px;text-align:left;display:flex;flex-direction:column;gap:6px;transition:box-shadow .15s,border-color .15s}.workflow-step:hover{box-shadow:var(--shadow);border-color:var(--accent)}.workflow-step.done{border-color:var(--green);background:var(--green-light)}.workflow-step.inactive{opacity:.55}.workflow-step-header{display:flex;align-items:center;justify-content:space-between}.workflow-step-num{width:24px;height:24px;border-radius:50%;background:var(--accent-light);color:var(--accent);font-size:12px;font-weight:700;display:flex;align-items:center;justify-content:center}.workflow-step.done .workflow-step-num{background:var(--green);color:#fff}.workflow-done-check{font-size:16px;color:#16a34a}.workflow-step-name{font-size:15px;font-weight:600}.workflow-step-desc{font-size:12px;color:var(--text-secondary);line-height:1.5}.workflow-step-time{font-size:11px;color:var(--text-muted);margin-top:4px}.workflow-step-status{font-size:11px;color:var(--text-muted)}.workflow-connector{font-size:22px;color:var(--border-2);padding:0 8px;flex-shrink:0}.workflow-connector.done{color:var(--green)}:focus-visible{outline:2px solid var(--accent);outline-offset:2px}button:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg);padding:24px}.auth-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:40px 36px;width:100%;max-width:420px;box-shadow:var(--shadow-lg);display:flex;flex-direction:column;gap:16px}.auth-logo{display:flex;justify-content:center;margin-bottom:4px}.auth-logo .app-logo-mark{width:44px;height:44px;font-size:20px;background:linear-gradient(135deg,var(--accent),var(--accent-2));border-radius:var(--radius);color:#fff;font-weight:700;display:flex;align-items:center;justify-content:center}.auth-title{font-size:22px;font-weight:700;text-align:center}.auth-subtitle{font-size:14px;color:var(--text-muted);text-align:center;line-height:1.6}.auth-form{display:flex;flex-direction:column;gap:14px}.auth-submit-btn{width:100%;padding:11px;font-size:15px;border-radius:var(--radius-sm)}.auth-links{display:flex;justify-content:center;align-items:center;gap:8px;font-size:13px;color:var(--text-muted)}.auth-links-divider{color:var(--border-2)}.auth-link{color:var(--accent);text-decoration:none}.auth-link:hover{text-decoration:underline}.auth-dev-notice{font-size:12px;color:var(--amber);text-align:center;background:var(--amber-light);padding:8px 12px;border-radius:var(--radius-sm)}.error-page{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;padding:40px;text-align:center;gap:12px}.error-page-code{font-size:64px;font-weight:700;color:var(--border-2);line-height:1}.error-page-title{font-size:22px;font-weight:700}.error-page-desc{font-size:14px;color:var(--text-muted);max-width:320px}.user-menu-wrap{position:relative}.user-menu-trigger{display:flex;align-items:center;gap:8px;padding:5px 10px;border-radius:var(--radius-sm);background:var(--bg);border:1px solid var(--border);font-size:13px;color:var(--text-primary);transition:background .15s}.user-menu-trigger:hover{background:var(--border)}.user-avatar{width:24px;height:24px;border-radius:50%;background:linear-gradient(135deg,var(--accent),var(--accent-2));color:#fff;font-size:11px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}.user-name{max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-menu-dropdown{position:absolute;right:0;top:calc(100% + 6px);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-lg);min-width:220px;z-index:300;overflow:hidden}.user-menu-header{padding:14px 16px;border-bottom:1px solid var(--border);background:var(--surface-2)}.user-menu-email{font-size:13px;font-weight:500}.user-menu-org{font-size:12px;color:var(--text-muted);margin-top:2px;display:flex;align-items:center;gap:6px}.user-menu-role{font-size:10px;background:var(--accent-light);color:var(--accent);padding:1px 6px;border-radius:20px}.user-menu-section{padding:6px;border-bottom:1px solid var(--border)}.user-menu-section:last-child{border-bottom:none}.user-menu-section-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);padding:4px 10px}.user-menu-org-item{display:flex;align-items:center;justify-content:space-between;width:100%;padding:8px 10px;border-radius:var(--radius-sm);background:none;text-align:left;font-size:13px;color:var(--text-primary);transition:background .1s}.user-menu-org-item:hover{background:var(--bg)}.user-menu-org-item.active{color:var(--accent);font-weight:500}.user-menu-item{display:block;width:100%;padding:9px 10px;border-radius:var(--radius-sm);background:none;text-align:left;font-size:13px;color:var(--text-primary);transition:background .1s}.user-menu-item:hover{background:var(--bg)}.user-menu-item.danger{color:var(--red)}.user-menu-item.danger:hover{background:var(--red-light)}.settings-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:24px;margin-bottom:24px}.platform-api-notice{display:flex;gap:14px;align-items:flex-start;background:var(--green-light);border:1px solid #86efac;border-radius:var(--radius);padding:16px;font-size:13px;color:#15803d}.platform-api-notice strong{display:block;font-weight:600;margin-bottom:4px}.platform-api-notice p{color:#166534;font-size:13px;line-height:1.6}.viewer-notice{font-size:13px;color:var(--text-muted);text-align:center;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);padding:12px 16px}.credential-form{display:flex;flex-direction:column;gap:16px}.form-section-title{font-size:16px;font-weight:600}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}.form-grid .full-width{grid-column:1 / -1}.form-grid .checkbox-label{display:flex;align-items:center;gap:8px;flex-direction:row}.form-grid .checkbox-label span{font-size:13px;font-weight:500;color:var(--text-secondary)}.field-hint{font-size:11px;color:var(--text-muted);margin-top:3px}.required-mark{color:var(--red)}.form-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:4px}.credential-list{display:flex;flex-direction:column;gap:10px}.credential-item{display:flex;align-items:center;gap:16px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:16px;transition:border-color .15s}.credential-item.disabled{opacity:.55}.credential-item-main{flex:1;min-width:0}.credential-item-header{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-bottom:6px}.credential-name{font-size:14px;font-weight:600}.credential-scope-badge{font-size:11px;background:var(--bg);color:var(--text-muted);border:1px solid var(--border);padding:1px 8px;border-radius:20px}.credential-default-badge{font-size:11px;background:var(--accent-light);color:var(--accent);padding:1px 8px;border-radius:20px}.credential-status-dot{width:8px;height:8px;border-radius:50%;margin-left:auto;flex-shrink:0}.credential-status-dot.active{background:var(--green)}.credential-status-dot.inactive{background:var(--border-2)}.credential-item-meta{display:flex;gap:16px;flex-wrap:wrap}.credential-meta-field{font-size:12px;color:var(--text-muted)}.credential-url{font-family:monospace;font-size:11px}.credential-item-actions{display:flex;gap:6px;flex-shrink:0}.btn-sm{padding:5px 12px;font-size:12px;border-radius:var(--radius-sm)}.btn-danger{background:var(--red-light);color:var(--red);border:1px solid #fca5a5}.btn-danger:hover{background:#fecaca}.btn-danger:disabled{opacity:.5;cursor:not-allowed}.model-source-selector{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:14px;display:flex;flex-direction:column;gap:10px}.model-source-label{font-size:12px;font-weight:600;color:var(--text-secondary)}.model-source-options{display:flex;flex-direction:column;gap:8px}.model-source-option{display:flex;align-items:flex-start;gap:10px;padding:10px 12px;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--surface);cursor:pointer;transition:border-color .15s}.model-source-option:has(input:checked){border-color:var(--accent);background:var(--accent-light)}.model-source-option.disabled-option{opacity:.5;cursor:not-allowed}.model-source-option input[type=radio]{margin-top:2px;flex-shrink:0;accent-color:var(--accent)}.model-source-option-label{display:flex;flex-direction:column;gap:2px}.model-source-option-label strong{font-size:13px}.model-source-option-label span{font-size:11px;color:var(--text-muted)}.model-credential-select{padding-top:4px}.test-warning{font-size:13px;line-height:1.7;color:var(--text-secondary)}.test-warning strong{color:var(--text-primary)}.test-result-msg{font-size:13px;color:var(--text-muted);margin-top:4px}.modal-body-center{display:flex;flex-direction:column;align-items:center;gap:16px;padding:24px 0;color:var(--text-muted)}@media(max-width:600px){.form-grid{grid-template-columns:1fr}.credential-item{flex-direction:column;align-items:flex-start}.credential-item-actions{flex-wrap:wrap}}.credential-status-dot.invalid{background:var(--amber)}.credential-invalid-hint{color:var(--amber)!important;font-size:11px!important}.project-picker-list{display:flex;flex-direction:column;gap:8px;max-height:280px;overflow-y:auto;margin-bottom:4px}.project-picker-item{display:flex;align-items:center;gap:12px;padding:12px 14px;text-align:left;width:100%;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);font-size:14px;transition:border-color .15s,background .15s}.project-picker-item:hover{border-color:var(--accent);background:var(--accent-light)}.running-state{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:360px;padding:48px 32px;gap:24px;text-align:center}.running-spinner-wrap{position:relative}.running-spinner-wrap .spinner{width:48px;height:48px;border-width:3px}.running-text{display:flex;flex-direction:column;align-items:center;gap:10px}.running-title{font-size:16px;font-weight:600;color:var(--text-primary)}.running-hints{display:flex;flex-direction:column;align-items:center;gap:4px;min-height:56px}.running-hint{font-size:13px;color:var(--text-muted);opacity:0;animation:fade-in-hint .4s forwards}.running-hint-0{animation-delay:.1s}.running-hint-1{animation-delay:1.8s}.running-hint-2{animation-delay:4s}@keyframes fade-in-hint{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.running-notice{font-size:12px;color:var(--text-muted);opacity:.7;margin-top:4px}.error-state-full{padding:24px;display:flex;flex-direction:column;gap:16px}.error-state-header{display:flex;gap:14px;align-items:flex-start;background:var(--red-light);border:1px solid #fca5a5;border-radius:var(--radius);padding:16px}.error-state-icon{font-size:20px;flex-shrink:0;margin-top:2px}.error-state-title{display:block;font-weight:600;color:var(--red);margin-bottom:4px}.error-state-msg{font-size:13px;color:#7f1d1d;line-height:1.6;word-break:break-word}.error-toggle-btn{margin-top:6px;background:none;border:none;color:var(--red);font-size:12px;padding:0;cursor:pointer;text-decoration:underline}.error-state-tips{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-sm);padding:12px 16px;font-size:13px;color:var(--text-secondary)}.error-state-tips p{font-weight:500;margin-bottom:6px}.error-state-tips ul{margin:0;padding-left:18px;display:flex;flex-direction:column;gap:3px}.copy-btn-compact{padding:3px 7px;font-size:12px;min-width:unset}.icon-btn.copied{color:var(--green);border-color:var(--green)}.cell-scene{max-width:90px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.cell-mood{max-width:72px;font-size:12px;color:var(--text-muted)}.cell-dur{white-space:nowrap;font-size:12px;color:var(--text-muted)}.cell-cam{max-width:80px;font-size:12px}.cell-trans{max-width:72px;font-size:12px}.asset-name-row{display:flex;align-items:center;gap:8px;margin-bottom:4px}.asset-name-row .asset-name{margin-bottom:0}.asset-identity{font-size:12px;color:var(--text-muted);margin-bottom:6px}.asset-consistency{margin-top:8px;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-sm);overflow:hidden}.asset-consistency-header{display:flex;align-items:center;justify-content:space-between;padding:6px 10px;border-bottom:1px solid var(--border)}.asset-consistency-text{font-size:12px;line-height:1.6;color:var(--text-secondary);padding:8px 10px;margin:0}.prop-function{font-size:12px;color:var(--text-muted);font-style:italic;margin:2px 0 4px}.style-panel-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:16px}.style-consistency{font-size:13px}.pm-shot-num{font-size:13px;font-weight:600}.pm-shot-platform{font-size:10px;color:var(--text-muted);background:var(--bg);padding:1px 5px;border-radius:4px;border:1px solid var(--border);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}.pm-detail-actions{display:flex;align-items:center;gap:6px}.pm-detail-label{font-size:12px;color:var(--text-muted)}.pm-field-meta{background:var(--surface)}.upstream-icon{font-size:16px;flex-shrink:0;margin-top:2px}.upstream-version{font-size:10px;opacity:.8}.upstream-date{font-size:10px;opacity:.7}.upstream-item-ok{background:#fffc;border-color:#16a34a66}@media(prefers-reduced-motion:reduce){.running-hint{animation:none;opacity:1}}.running-spinner-wrap{position:relative;display:flex;flex-direction:column;align-items:center;gap:6px}.running-elapsed{font-size:11px;color:var(--text-muted);font-variant-numeric:tabular-nums}.running-step{font-size:14px;color:var(--accent);font-weight:500;min-height:22px;transition:opacity .3s}.error-state-content{flex:1}.empty-title{font-size:15px;font-weight:600;color:var(--text-secondary);margin-bottom:6px}.empty-hint-text{font-size:13px;color:var(--text-muted);max-width:300px;line-height:1.6}.pm-shot-count{font-size:11px;color:var(--text-muted);font-weight:400;margin-left:auto}.pm-detail-nav{display:flex;align-items:center;gap:8px}.pm-nav-btn{width:28px;height:28px;border-radius:var(--radius-sm);background:var(--bg);border:1px solid var(--border-2);font-size:18px;line-height:1;display:flex;align-items:center;justify-content:center;color:var(--text-secondary);transition:background .1s;flex-shrink:0}.pm-nav-btn:hover:not(:disabled){background:var(--border)}.pm-nav-btn:disabled{opacity:.3;cursor:not-allowed}.pm-detail-progress{font-size:11px;color:var(--text-muted);margin-left:6px;font-variant-numeric:tabular-nums}.pm-field-negative{border-left:3px solid var(--red)}.copy-ok{color:var(--green)!important;border-color:var(--green)!important}.copy-err{color:var(--red)!important;border-color:var(--red)!important}.artifact-summary{display:block;font-size:11px;color:#16a34a;margin-top:2px}.artifact-desc{display:block;font-size:11px;color:var(--text-muted);margin-top:2px}.run-agent-icon{font-size:16px;flex-shrink:0}.run-view-btn{margin-left:auto;font-size:11px;padding:3px 10px;background:var(--accent-light);color:var(--accent);border:1px solid #c7c3f7;border-radius:var(--radius-sm);white-space:nowrap;transition:background .1s}.run-view-btn:hover{background:#dddafb}.pm-detail:focus-visible{outline:2px solid var(--accent);outline-offset:-2px;border-radius:var(--radius-sm)}.director-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:14px;margin-top:16px}.director-shot-card{border:1px solid var(--border);border-radius:var(--radius-md);background:#fff;padding:14px;box-shadow:var(--shadow-sm)}.director-shot-head,.director-shot-meta{display:flex;align-items:center;justify-content:space-between;gap:10px}.director-shot-head{margin-bottom:8px;color:var(--text-primary)}.director-shot-meta{margin-bottom:10px;font-size:12px;color:var(--text-muted)}.director-shot-card p{margin:8px 0;color:var(--text-secondary);line-height:1.55;font-size:13px}.director-priority{padding:3px 8px;border-radius:999px;font-size:11px;font-weight:600}.priority-high{color:#b91c1c;background:#fee2e2}.priority-medium{color:#92400e;background:#fef3c7}.priority-low{color:#166534;background:#dcfce7}.director-section{margin-top:18px;padding:16px;border:1px solid var(--border);border-radius:var(--radius-md);background:var(--bg)}.director-section h3{margin:0 0 10px;font-size:15px;color:var(--text-primary)}.director-section p,.director-section li{color:var(--text-secondary);line-height:1.6;font-size:13px}.director-section ul{margin:0;padding-left:18px}
