:root{--bg: #0f1117;--bg-card: #1a1d27;--bg-hover: #252833;--border: #2d3041;--text: #e4e6eb;--text-dim: #8b8fa3;--accent: #6366f1;--accent-hover: #818cf8;--success: #22c55e;--warning: #f59e0b;--danger: #ef4444;--radius: 8px;--shadow: 0 2px 8px rgba(0,0,0,.3)}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,system-ui,sans-serif;background:var(--bg);color:var(--text);line-height:1.6}.app{display:flex;flex-direction:column;height:100vh}.app-header{display:flex;align-items:center;padding:0 20px;height:52px;background:var(--bg-card);border-bottom:1px solid var(--border);gap:16px}.app-title{font-size:16px;font-weight:600;white-space:nowrap;color:var(--accent)}.tab-bar{display:flex;gap:4px;flex:1}.tab-btn{padding:6px 16px;border:none;background:transparent;color:var(--text-dim);border-radius:var(--radius);cursor:pointer;font-size:14px;transition:all .15s}.tab-btn:hover{background:var(--bg-hover);color:var(--text)}.tab-btn.active{background:var(--accent);color:#fff}.ws-indicator{width:28px;height:28px;border-radius:50%;background:var(--danger);display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:600;color:#fff;flex-shrink:0}.ws-indicator.connected{background:var(--success)}.app-main{flex:1;overflow:auto;padding:20px}.panel{max-width:1200px;margin:0 auto}.panel-title{font-size:20px;font-weight:600;margin-bottom:16px}.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:16px;margin-bottom:12px}.card:hover{border-color:var(--accent)}.btn{padding:8px 16px;border:none;border-radius:var(--radius);cursor:pointer;font-size:14px;font-weight:500;transition:all .15s}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover{background:var(--accent-hover)}.btn-success{background:var(--success);color:#fff}.btn-success:hover{opacity:.9}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover{opacity:.9}.btn-outline{background:transparent;border:1px solid var(--border);color:var(--text)}.btn-outline:hover{border-color:var(--accent);color:var(--accent)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-group{display:flex;gap:8px;margin-top:12px}.input,.select,.textarea{width:100%;padding:8px 12px;border:1px solid var(--border);border-radius:var(--radius);background:var(--bg);color:var(--text);font-size:14px;outline:none;transition:border-color .15s}.input:focus,.select:focus,.textarea:focus{border-color:var(--accent)}.textarea{min-height:80px;resize:vertical;font-family:inherit}.label{display:block;font-size:13px;color:var(--text-dim);margin-bottom:4px}.field{margin-bottom:12px}.badge{display:inline-block;padding:2px 8px;border-radius:12px;font-size:12px;font-weight:500}.badge-info{background:#6366f133;color:var(--accent)}.badge-success{background:#22c55e33;color:var(--success)}.badge-warning{background:#f59e0b33;color:var(--warning)}.badge-danger{background:#ef444433;color:var(--danger)}.menu-item{display:block;width:100%;text-align:left;background:none;border:none;padding:8px 14px;font-size:13px;color:var(--text);cursor:pointer;white-space:nowrap}.menu-item:hover{background:var(--bg-hover, rgba(255,255,255,.06))}.grid{display:grid;gap:16px}.grid-2{grid-template-columns:1fr 1fr}.grid-3{grid-template-columns:1fr 1fr 1fr}.empty-state{text-align:center;padding:60px 20px;color:var(--text-dim)}.empty-state h3{font-size:18px;margin-bottom:8px;color:var(--text)}.stepper{display:flex;gap:4px;padding:12px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:16px;overflow-x:auto}.step-item{padding:6px 12px;border-radius:var(--radius);font-size:12px;white-space:nowrap;color:var(--text-dim);border:1px solid transparent}.step-item.current{background:var(--accent);color:#fff;border-color:var(--accent)}.step-item.completed{color:var(--success);border-color:#22c55e4d}.step-item.awaiting{color:var(--warning);border-color:#f59e0b4d}.step-item.failed{color:var(--danger);border-color:#ef44444d}.step-item.running{background:#6366f126;border-color:var(--accent);color:var(--accent-hover);display:flex;align-items:center;gap:6px;animation:step-pulse 1.4s ease-in-out infinite}@keyframes step-pulse{0%,to{opacity:1}50%{opacity:.65}}@keyframes spin{to{transform:rotate(360deg)}}.spinner{display:inline-block;width:14px;height:14px;border:2px solid rgba(99,102,241,.25);border-top-color:var(--accent);border-radius:50%;animation:spin .7s linear infinite;flex-shrink:0;vertical-align:middle}.step-spinner{display:inline-block;width:10px;height:10px;border:1.5px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite;flex-shrink:0}.progress-panel{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:12px}.progress-header{display:flex;align-items:center;gap:8px;padding:8px 14px;background:var(--bg-card);border-bottom:1px solid var(--border);cursor:pointer;-webkit-user-select:none;user-select:none}.progress-header:hover{background:var(--bg-hover)}.progress-header-title{flex:1;font-size:13px;font-weight:500;color:var(--text)}.progress-logs{height:140px;overflow-y:auto;padding:10px 14px;font-family:SF Mono,Fira Code,Cascadia Code,monospace;font-size:12px;line-height:1.65}.log-line{display:flex;gap:6px;padding:2px 0;align-items:baseline}.log-line.err .log-text{color:#f87171}.log-line.out .log-text{color:#94a3b8}.log-line.log-error .log-text{color:#f87171}.log-line.log-warn .log-text{color:#fbbf24}.log-line.log-info .log-text{color:#94a3b8}.log-line.log-debug .log-text{color:#475569}.log-line.sep{margin:4px 0 2px}.log-sep-text{color:#334155;font-style:italic;font-size:11px;letter-spacing:.04em}.log-ts{color:#3d4a5c;flex-shrink:0;font-size:11px;padding-top:1px;min-width:58px}.log-badge{flex-shrink:0;font-size:10px;font-weight:600;padding:0 5px;border-radius:3px;background:#1e293b;color:#60a5fa;white-space:nowrap;letter-spacing:.02em;line-height:1.7}.log-line.log-error .log-badge{color:#f87171;background:#2d1818}.log-line.log-warn .log-badge{color:#fbbf24;background:#2a2208}.log-text{word-break:break-all;white-space:pre-wrap}.route-card{background:var(--bg-card);border:2px solid var(--border);border-radius:var(--radius);padding:16px;cursor:pointer;transition:all .15s}.route-card:hover{border-color:var(--accent);transform:translateY(-2px)}.route-card.selected{border-color:var(--success);background:#22c55e0d}.route-card h4{font-size:15px;margin-bottom:8px}.route-card .score{font-size:24px;font-weight:700;color:var(--accent)}.route-card ul{list-style:none;padding:0;margin:8px 0}.route-card li{font-size:13px;color:var(--text-dim);padding:2px 0}.route-card li:before{content:"- ";color:var(--accent)}.chat-container{display:flex;flex-direction:column;height:calc(100vh - 120px)}.chat-messages{flex:1;overflow-y:auto;padding:16px 20px;display:flex;flex-direction:column;gap:16px}.chat-group{display:flex;gap:10px;max-width:85%}.chat-group.user{align-self:flex-end;flex-direction:row-reverse}.chat-group.bot{align-self:flex-start}.chat-avatar{width:32px;height:32px;border-radius:50%;background:var(--bg-hover);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:600;color:var(--text-dim);flex-shrink:0}.chat-group.bot .chat-avatar{background:#6366f126;color:var(--accent)}.chat-group-body{display:flex;flex-direction:column;gap:4px;min-width:0}.chat-ts{font-size:11px;color:var(--text-dim);padding:0 4px}.user-bubble{background:var(--accent);color:#fff;padding:10px 14px;border-radius:16px 16px 4px;font-size:14px;line-height:1.5;white-space:pre-wrap}.bot-bubble{background:var(--bg-card);border:1px solid var(--border);padding:10px 14px;border-radius:16px 16px 16px 4px;font-size:14px;line-height:1.6}.chat-md-content h1,.chat-md-content h2,.chat-md-content h3{margin:12px 0 6px;font-size:15px}.chat-md-content p{margin:4px 0}.chat-md-content ul,.chat-md-content ol{padding-left:20px;margin:6px 0}.chat-md-content code{background:#6366f11f;padding:1px 5px;border-radius:4px;font-size:13px;font-family:SF Mono,Fira Code,monospace}.chat-md-content pre{background:var(--bg);border:1px solid var(--border);border-radius:6px;padding:10px 12px;overflow-x:auto;font-size:13px;margin:8px 0}.chat-md-content pre code{background:none;padding:0}.chat-md-content blockquote{border-left:3px solid var(--accent);padding-left:12px;margin:8px 0;color:var(--text-dim)}.chat-md-content table{border-collapse:collapse;margin:8px 0}.chat-md-content th,.chat-md-content td{border:1px solid var(--border);padding:6px 10px;font-size:13px}.chat-md-content th{background:var(--bg-hover)}.chat-thinking-block{margin-bottom:6px;border-radius:10px;border:1px dashed rgba(255,255,255,.12);background:#ffffff08;overflow:hidden}.chat-thinking-toggle{display:flex;align-items:center;gap:6px;padding:6px 10px;border:none;background:none;color:var(--text-dim);font-size:12px;cursor:pointer;width:100%;text-align:left}.chat-thinking-toggle:hover{color:var(--text)}.chat-thinking-icon{font-size:10px}.chat-thinking-content{padding:8px 12px;font-size:12px;line-height:1.5;color:var(--text-dim);white-space:pre-wrap;border-top:1px dashed rgba(255,255,255,.08);max-height:200px;overflow-y:auto}.chat-reading-indicator{padding:12px 18px!important}.reading-dots{display:flex;gap:4px}.reading-dots span{width:6px;height:6px;border-radius:50%;background:var(--text-dim);animation:reading-bounce 1.2s infinite}.reading-dots span:nth-child(2){animation-delay:.2s}.reading-dots span:nth-child(3){animation-delay:.4s}@keyframes reading-bounce{0%,60%,to{transform:translateY(0);opacity:.4}30%{transform:translateY(-5px);opacity:1}}.chat-input-bar{display:flex;gap:8px;padding:12px 16px;background:var(--bg-card);border-top:1px solid var(--border)}.chat-input-bar input{flex:1}.json-view{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);padding:12px;font-family:SF Mono,Fira Code,monospace;font-size:13px;overflow:auto;max-height:400px;white-space:pre-wrap;word-break:break-word}.artifact-view{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);padding:16px 20px;max-height:500px;overflow:auto;font-size:14px;line-height:1.7;margin-bottom:12px}.artifact-view h1,.artifact-view h2,.artifact-view h3{margin:16px 0 8px}.artifact-view p{margin:6px 0}.artifact-view ul,.artifact-view ol{padding-left:24px;margin:8px 0}.artifact-view code{background:#6366f11a;padding:1px 4px;border-radius:3px;font-size:13px}.artifact-view pre{background:var(--bg-card);border:1px solid var(--border);border-radius:6px;padding:12px;overflow-x:auto}.artifact-view blockquote{border-left:3px solid var(--accent);padding-left:12px;color:var(--text-dim)}.chapter-content{max-width:700px;margin:0 auto;font-size:16px;line-height:1.8;white-space:pre-wrap}.chapter-nav{display:flex;justify-content:space-between;padding:12px 0;border-top:1px solid var(--border);margin-top:20px}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-dim)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:100}.modal{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;padding:24px;min-width:400px;max-width:600px;max-height:80vh;overflow-y:auto;box-shadow:0 20px 60px #00000080}.modal h2{font-size:18px;margin-bottom:16px}.workshop-header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:16px}.workshop-header-left{display:flex;align-items:center;gap:14px}.workshop-progress-ring{width:48px;height:48px;border-radius:50%;background:conic-gradient(var(--accent) var(--pct, 0%),var(--bg) var(--pct, 0%));display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;color:var(--accent);position:relative;flex-shrink:0}.workshop-progress-ring:before{content:"";position:absolute;top:4px;right:4px;bottom:4px;left:4px;border-radius:50%;background:var(--bg-card)}.workshop-progress-ring span{position:relative;z-index:1}.workshop-status-title{font-size:15px;font-weight:600}.workshop-status-sub{font-size:12px;color:var(--text-dim);margin-top:2px;display:flex;align-items:center;gap:10px}.workshop-auto-label{font-size:13px;color:var(--text-dim);display:flex;align-items:center;gap:6px;cursor:pointer}.miro-badge{padding:2px 8px;border-radius:10px;font-size:11px;font-weight:500}.miro-badge.online{background:#22c55e26;color:var(--success)}.miro-badge.offline{background:#ef444426;color:var(--danger)}.pipeline{display:flex;align-items:flex-start;gap:0;padding:16px 12px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:16px;overflow-x:auto}.pipeline-group-wrap{display:flex;align-items:center}.pipeline-connector{width:24px;height:2px;background:var(--border);flex-shrink:0}.pipeline-connector.active{background:var(--accent)}.pipeline-group{border:1px solid var(--border);border-radius:10px;padding:8px 10px;min-width:80px;transition:all .2s}.pipeline-group.active{border-color:var(--group-color, var(--accent));box-shadow:0 0 12px #6366f126}.pipeline-group.done{border-color:#22c55e66}.pipeline-group-header{display:flex;align-items:center;gap:5px;padding-bottom:6px;margin-bottom:4px;border-bottom:1px solid var(--border)}.pipeline-group-icon{font-size:13px}.pipeline-group-name{font-size:11px;font-weight:600;color:var(--text-dim);white-space:nowrap}.pipeline-group.active .pipeline-group-name{color:var(--group-color, var(--accent))}.pipeline-group-steps{display:flex;flex-direction:column;gap:3px}.pipeline-step{display:flex;align-items:center;gap:6px;padding:2px 4px;border-radius:4px;font-size:11px;color:var(--text-dim);white-space:nowrap}.pipeline-step.current{color:var(--accent);font-weight:600}.pipeline-step.running{color:var(--accent);animation:step-pulse 1.4s ease-in-out infinite}.pipeline-step.done{color:var(--success)}.pipeline-step.awaiting{color:var(--warning)}.pipeline-step.failed{color:var(--danger)}.pipeline-step.review{font-style:italic}.pipeline-step-dot{font-size:10px;width:14px;text-align:center;flex-shrink:0}.log-panel-content{margin-top:8px}.log-viewer{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);padding:12px 14px;font-family:SF Mono,Fira Code,Cascadia Code,monospace;font-size:12px;line-height:1.6;max-height:calc(100vh - 220px);overflow:auto;margin:0;white-space:pre-wrap;word-break:break-all}.log-viewer-line{padding:1px 0}.log-viewer-line.err{color:#f87171}.log-viewer-line.warn{color:#fbbf24}.creative-modes{display:flex;gap:8px;margin-bottom:12px;flex-wrap:wrap}.creative-desc{font-size:13px;color:var(--text-dim);margin-bottom:14px}.creative-presets{display:flex;gap:6px;margin-bottom:14px;flex-wrap:wrap}.creative-preset-btn{font-size:12px;padding:4px 12px}.creative-hint{font-size:12px;color:var(--text-dim)}.creative-results{margin-top:16px;display:flex;flex-direction:column;gap:12px}.creative-result-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px;padding-bottom:8px;border-bottom:1px solid var(--border)}.creative-result-query{font-size:13px;font-weight:500;color:var(--accent)}.creative-result-content{font-size:14px;line-height:1.7}.creative-result-content h1,.creative-result-content h2,.creative-result-content h3{margin:12px 0 6px;font-size:15px}.creative-result-content p{margin:6px 0}.creative-result-content ul,.creative-result-content ol{padding-left:24px;margin:8px 0}.creative-result-content code{background:#6366f11a;padding:1px 4px;border-radius:3px;font-size:13px}.creative-result-content pre{background:var(--bg);border:1px solid var(--border);border-radius:6px;padding:10px;overflow-x:auto}.creative-result-content blockquote{border-left:3px solid var(--accent);padding-left:12px;color:var(--text-dim)}.workshop-layout{display:flex;gap:0;height:calc(100vh - 92px);max-width:100%}.workshop-error{position:absolute;top:60px;left:50%;transform:translate(-50%);z-index:10}.workshop-sidebar{width:220px;flex-shrink:0;padding:12px;overflow-y:auto;border-right:1px solid var(--border);background:var(--bg-card);display:flex;flex-direction:column}.workshop-main{flex:1;display:flex;flex-direction:column;overflow:hidden}.workshop-log-pane{flex-shrink:0;padding:12px 16px 0}.workshop-content-pane{flex:1;overflow-y:auto;padding:0 16px 16px;display:flex;flex-direction:column;gap:12px}.workshop-progress-header{display:flex;align-items:center;gap:10px;padding-bottom:12px;border-bottom:1px solid var(--border);margin-bottom:8px}.workshop-running-bar{display:flex;align-items:center;gap:8px;padding:10px 14px;background:#6366f114;border:1px solid rgba(99,102,241,.2);border-radius:var(--radius);color:var(--accent);font-size:13px}.workshop-guidance-card{padding:12px}.pipeline-sidebar{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:2px}.pipeline-sg{margin-bottom:6px}.pipeline-sg-header{font-size:11px;font-weight:600;color:var(--text-dim);padding:4px 6px}.pipeline-s{display:flex;align-items:center;gap:6px;padding:4px 8px;border-radius:5px;font-size:12px;color:var(--text-dim);cursor:pointer;position:relative}.pipeline-s:hover{background:var(--bg-hover)}.pipeline-s.selected{background:#6366f11f;color:var(--accent)}.pipeline-s.current{color:var(--accent);font-weight:600}.pipeline-s.running{color:var(--accent);animation:step-pulse 1.4s ease-in-out infinite}.pipeline-s.done{color:var(--success)}.pipeline-s.awaiting{color:var(--warning)}.pipeline-s.failed{color:var(--danger)}.pipeline-s-dot{width:14px;text-align:center;font-size:10px;flex-shrink:0}.pipeline-s-label{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.pipeline-rollback{position:absolute;right:4px;opacity:0;background:none;border:none;color:var(--text-dim);cursor:pointer;font-size:12px;padding:2px 4px;border-radius:3px}.pipeline-s:hover .pipeline-rollback{opacity:1}.pipeline-rollback:hover{background:#ef444426;color:var(--danger)}.miro-sidebar-badge{font-size:11px;text-align:center;padding:4px 8px;border-radius:8px;margin-top:8px;display:flex;flex-direction:column;align-items:center;gap:2px}.miro-sidebar-badge.online{background:#22c55e1a;color:var(--success)}.miro-sidebar-badge.offline{background:#ef44441a;color:var(--danger)}.miro-mode-tag{display:block;font-size:10px;margin-top:3px;padding:1px 6px;border-radius:4px;font-weight:600}.miro-mode-tag.zep{background:#6366f133;color:#a5b4fc}.miro-mode-tag.fallback{background:#f59e0b33;color:#fbbf24}.miro-mode-banner{display:flex;align-items:flex-start;gap:10px;padding:12px 16px;border-radius:8px;font-size:13px;line-height:1.6;margin-bottom:4px}.miro-mode-banner.zep{background:#6366f114;border:1px solid rgba(99,102,241,.3);color:var(--text)}.miro-mode-banner.fallback{background:#f59e0b14;border:1px solid rgba(245,158,11,.3);color:var(--text)}.miro-mode-icon{font-size:18px;flex-shrink:0;margin-top:1px}.review-actions-card{border:1px solid var(--accent);background:#6366f10d}.review-actions-title{font-size:14px;font-weight:700;color:var(--accent);margin-bottom:4px}.review-actions-hint{font-size:12px;color:var(--text-dim);line-height:1.6}.rich-view-title{font-size:13px;font-weight:600;color:var(--text-dim);margin-bottom:12px;text-transform:uppercase;letter-spacing:.05em}.rich-view{display:flex;flex-direction:column;gap:16px}.rich-overview{background:var(--bg);border-radius:8px;padding:12px 16px;font-size:14px;line-height:1.7}.rich-overview p{margin:4px 0}.rich-label{display:inline-block;font-size:11px;font-weight:700;color:var(--accent);background:#6366f11f;padding:1px 6px;border-radius:4px;margin-right:8px}.rich-section{display:flex;flex-direction:column;gap:8px}.rich-section-title{font-size:13px;font-weight:600;color:var(--text-dim);border-bottom:1px solid var(--border);padding-bottom:6px}.rich-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:10px}.rich-card{background:var(--bg);border-radius:8px;padding:12px;border:1px solid var(--border);display:flex;flex-direction:column;gap:4px}.rich-card-name{font-size:14px;font-weight:600;color:var(--text)}.rich-card-desc{font-size:12px;color:var(--text-dim);line-height:1.6}.rich-card-meta{font-size:11px;color:var(--accent)}.rich-card-tags{display:flex;flex-wrap:wrap;gap:4px;margin-top:4px}.rich-card-rels{display:flex;flex-wrap:wrap;gap:4px;margin-top:6px}.rich-card-row{display:flex;align-items:baseline;gap:4px;font-size:13px}.char-card-full{grid-column:span 1}.rich-list{display:flex;flex-direction:column;gap:6px}.rich-list-item{display:flex;gap:8px;font-size:13px;align-items:baseline;background:var(--bg);padding:8px 12px;border-radius:6px}.rich-list-title{font-weight:600;color:var(--accent);white-space:nowrap;min-width:80px}.rich-list-body{color:var(--text-dim);line-height:1.5}.rich-tags{display:flex;flex-wrap:wrap;gap:6px}.rich-ol{padding-left:20px;margin:0;display:flex;flex-direction:column;gap:6px;font-size:13px;color:var(--text-dim);line-height:1.6}.rich-logline{font-size:16px;font-style:italic;color:var(--text-dim);text-align:center;padding:12px 16px;border-left:3px solid var(--accent);background:var(--bg);border-radius:0 8px 8px 0}.rich-chapter-list{display:flex;flex-direction:column;gap:4px}.rich-chapter-item{display:grid;grid-template-columns:56px 140px 1fr auto;align-items:baseline;gap:8px;padding:7px 10px;background:var(--bg);border-radius:6px;font-size:13px}.rich-ch-id{font-size:11px;color:var(--accent);font-weight:700;white-space:nowrap}.rich-ch-title{font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.rich-ch-sum{color:var(--text-dim);font-size:12px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.rich-ch-fs{font-size:11px;color:var(--warning);white-space:nowrap}.foreshadow-grid{display:flex;flex-direction:column;gap:6px}.foreshadow-item{display:flex;align-items:center;gap:8px;padding:6px 10px;border-radius:6px;font-size:13px;background:var(--bg)}.foreshadow-item.unresolved{border-left:3px solid var(--warning)}.foreshadow-item.resolved{border-left:3px solid var(--success);opacity:.7}.foreshadow-badge{font-size:10px;padding:1px 6px;border-radius:8px;background:#f59e0b26;color:var(--warning);flex-shrink:0}.foreshadow-badge.done{background:#22c55e26;color:var(--success)}.quality-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:10px}.quality-card{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);padding:10px}.quality-card-low{border-color:#ef444459;background:#ef44440a}.quality-card-header{font-size:13px;font-weight:600;margin-bottom:6px}.quality-bars{display:flex;flex-direction:column;gap:3px}.qbar{display:flex;align-items:center;gap:6px}.qbar-label{font-size:11px;color:var(--text-dim);width:36px;text-align:right}.qbar-track{flex:1;height:6px;background:var(--bg-card);border-radius:3px;overflow:hidden}.qbar-fill{height:100%;border-radius:3px;transition:width .3s}.qbar-val{font-size:11px;width:24px;font-weight:500}.qbar-val.highlight{color:var(--accent);font-weight:700}.quality-feedback{font-size:11px;color:var(--text-dim);margin-top:4px;line-height:1.4}.char-arc-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:8px}.char-arc-card{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);padding:8px 10px}.char-arc-name{font-size:13px;font-weight:600;margin-bottom:4px}.char-arc-row{display:flex;justify-content:space-between;font-size:11px;color:var(--text-dim);padding:1px 0}.char-arc-row span:last-child{color:var(--text)}.char-arc-knowledge{margin-top:4px;padding-top:4px;border-top:1px solid var(--border)}.drama-chart{display:flex;align-items:flex-end;gap:3px;height:80px;padding:4px 0}.drama-bar-wrap{flex:1;display:flex;flex-direction:column;align-items:center;height:100%}.drama-bar{width:100%;border-radius:3px 3px 0 0;min-height:2px;transition:height .3s}.drama-label{font-size:9px;color:var(--text-dim);margin-top:2px}.materials-drawer{width:260px;flex-shrink:0;border-left:1px solid var(--border);background:var(--bg-card);padding:12px;overflow-y:auto}.materials-drawer-header{display:flex;justify-content:space-between;align-items:center;padding-bottom:8px;border-bottom:1px solid var(--border);margin-bottom:8px;font-size:14px;font-weight:600}.materials-section{margin-bottom:12px}.material-card{background:var(--bg);border:1px solid var(--border);border-radius:6px;padding:6px 8px;margin-bottom:4px}.material-title{font-size:12px;font-weight:500;margin-bottom:2px}.material-preview{font-size:11px;color:var(--text-dim);line-height:1.3;margin-bottom:4px}.mode-toggle-row{display:flex;align-items:center;justify-content:space-between;padding:8px 10px;margin:8px 0 4px;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius)}.mode-toggle-label{font-size:12px;font-weight:600;color:var(--text)}.mode-toggle-btn{font-size:11px;padding:3px 10px;border-radius:4px;border:1px solid var(--border);cursor:pointer;transition:background .15s,color .15s}.mode-toggle-btn.auto{background:#2a4a2a;color:#7fda7f;border-color:#4a8a4a}.mode-toggle-btn.auto:hover{background:#1e3a1e}.mode-toggle-btn.manual{background:#3a3a1e;color:#dacc6a;border-color:#8a7a2a}.mode-toggle-btn.manual:hover{background:#2a2a10}.reader-md h1,.reader-md h2,.reader-md h3{margin:20px 0 10px}.reader-md p{margin:8px 0;text-indent:2em}.reader-md blockquote{border-left:3px solid var(--accent);padding-left:16px;color:var(--text-dim);margin:12px 0}@media(max-width:768px){.grid-2,.grid-3{grid-template-columns:1fr}.stepper{flex-wrap:wrap}.modal{min-width:90vw}.pipeline{flex-wrap:wrap}.pipeline-connector{width:12px}.workshop-layout{flex-direction:column;height:auto}.workshop-sidebar{width:100%;border-right:none;border-bottom:1px solid var(--border)}.materials-drawer{width:100%;border-left:none;border-top:1px solid var(--border)}}
