:root{font-family:Inter,Microsoft YaHei,system-ui,sans-serif;color:#172033;background:#eef2f6}*{box-sizing:border-box}html,body,#root{width:100%;height:100%}body{margin:0}button,input,textarea,select{font:inherit}button{border:1px solid #cbd5e1;background:#fff;color:#172033;border-radius:6px;min-height:34px;padding:0 12px;display:inline-flex;align-items:center;justify-content:center;gap:7px;cursor:pointer}button:hover{border-color:#64748b}button:disabled{opacity:.55;cursor:not-allowed}input,textarea,select{width:100%;border:1px solid #ccd5e1;border-radius:6px;padding:9px 10px;color:#0f172a;background:#fff}textarea{resize:vertical;line-height:1.6}label{display:grid;gap:7px;margin-bottom:12px;color:#475569;font-size:13px}h1,h2,p{margin:0}h1{font-size:22px}h2{font-size:17px}.app-shell{position:relative;height:100vh;display:grid;grid-template-rows:auto minmax(0,1fr);overflow:hidden}.topbar{height:76px;padding:14px 22px;border-bottom:1px solid #d8dee8;background:#fff;display:flex;justify-content:space-between;align-items:center;gap:18px}.topbar p,.panel-head p,.hint{color:#64748b;font-size:13px;line-height:1.55}.topbar-actions{display:flex;gap:9px;align-items:center}.primary{background:#0f766e;border-color:#0f766e;color:#fff}.compact{width:auto}.full{width:100%;margin:4px 0 14px}.dashboard{min-height:0;display:grid;grid-template-columns:300px minmax(580px,1fr) 320px}.timeline-panel,.tactics-panel{min-height:0;overflow:auto;background:#fff}.timeline-panel{border-right:1px solid #d8dee8;padding:18px}.tactics-panel{border-left:1px solid #d8dee8;padding:16px}.result-panel{min-width:0;min-height:0;overflow:hidden;scrollbar-width:none;padding:16px;background:#f8fafc}.result-panel *{scrollbar-width:none}.result-panel::-webkit-scrollbar,.result-panel *::-webkit-scrollbar{width:0;height:0}.timeline h2{margin-bottom:16px}.timeline-step{position:relative;width:100%;min-height:86px;padding:0 0 16px;border:0;border-radius:0;background:transparent;display:grid;grid-template-columns:34px minmax(0,1fr);align-items:start;text-align:left}.timeline-step:hover{border-color:transparent}.timeline-step.active .timeline-content{border-color:#0f766e;background:#ecfdf5}.timeline-line{position:absolute;left:16px;top:28px;bottom:-4px;width:1px;background:#d8dee8}.timeline-step:last-child .timeline-line{display:none}.timeline-dot{position:relative;z-index:1;width:32px;height:32px;border-radius:50%;display:grid;place-items:center;background:#f1f5f9;color:#475569;font-size:12px;font-weight:700;border:1px solid #d8dee8}.timeline-step.success .timeline-dot{background:#0f766e;border-color:#0f766e;color:#fff}.timeline-step.running .timeline-dot{background:#2563eb;border-color:#2563eb;color:#fff}.timeline-step.waiting .timeline-dot{background:#b45309;border-color:#b45309;color:#fff}.timeline-step.failed .timeline-dot{background:#b91c1c;border-color:#b91c1c;color:#fff}.timeline-content{min-width:0;border:1px solid #e2e8f0;border-radius:8px;padding:10px;display:grid;gap:5px;background:#fff}.timeline-content strong{font-size:14px}.timeline-content small{color:#64748b}.timeline-content em{color:#475569;font-size:12px;font-style:normal;line-height:1.45}.timeline-preview{display:grid;gap:4px}.timeline-preview i{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:#0f766e;font-size:12px;font-style:normal}.run-log{margin-top:16px;border:1px solid #d8dee8;border-radius:8px;padding:12px;display:grid;gap:10px}.run-log div{display:grid;gap:7px;max-height:160px;overflow:auto;color:#475569;font-size:12px}.article-showcase{height:100%;min-height:0;display:grid;grid-template-columns:minmax(220px,.92fr) minmax(0,1.08fr);gap:14px;align-items:stretch;overflow:hidden;max-height:100%}.article-copy,.image-carousel,.showcase-empty{background:#fff;border:1px solid #d8dee8;border-radius:8px}.article-copy{min-width:0;min-height:0;padding:clamp(14px,2vw,22px);overflow:hidden;max-height:100%;display:grid;grid-template-rows:auto auto auto minmax(0,1fr)}.article-meta{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:10px}.article-meta span{border-radius:999px;padding:5px 9px;background:#ecfdf5;color:#0f766e;font-size:12px}.article-copy h2{font-size:clamp(20px,2.2vw,26px);line-height:1.25;margin-bottom:10px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.digest{color:#64748b;font-size:13px;line-height:1.55;margin-bottom:12px;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.paragraphs{display:grid;gap:9px;min-height:0;overflow:auto;max-height:100%;align-content:start}.paragraphs p{color:#243247;font-size:clamp(12px,1.15vw,15px);line-height:1.65}.image-carousel{position:relative;min-width:0;min-height:0;height:100%;overflow:hidden;display:grid;place-items:center;background:radial-gradient(circle at 20% 20%,rgba(20,184,166,.15),transparent 28%),linear-gradient(135deg,#f8fafc,#eef7f5)}.image-carousel img{width:100%;height:100%;object-fit:contain}.carousel-btn{position:absolute;top:50%;transform:translateY(-50%);width:38px;height:38px;border-radius:50%;padding:0;background:#ffffffeb}.carousel-btn.prev{left:12px}.carousel-btn.next{right:12px}.carousel-dots{position:absolute;left:0;right:0;bottom:14px;display:flex;justify-content:center;gap:7px}.carousel-dots button{width:8px;height:8px;min-height:8px;padding:0;border-radius:50%;border:0;background:#ffffff8c}.carousel-dots button.active{background:#fff}.showcase-empty{min-height:100%;grid-column:1 / -1;display:grid;place-items:center;text-align:center;padding:32px}.showcase-empty div{max-width:480px;display:grid;justify-items:center;gap:12px;color:#64748b}.image-waiting{width:min(72%,360px);display:grid;justify-items:center;gap:12px;color:#334155;text-align:center}.image-waiting strong{font-size:16px;color:#0f766e}.image-waiting p{color:#64748b;font-size:13px}.waiting-art{position:relative;width:100%;aspect-ratio:3 / 4;max-height:420px;border:1px solid rgba(15,118,110,.16);border-radius:8px;background:linear-gradient(90deg,transparent,rgba(255,255,255,.82),transparent) -120% 0 / 60% 100% no-repeat,linear-gradient(#dbeafe 0 0) 18% 16% / 64% 8% no-repeat,linear-gradient(#ccfbf1 0 0) 18% 31% / 42% 5% no-repeat,linear-gradient(#e2e8f0 0 0) 18% 45% / 70% 5% no-repeat,linear-gradient(#e2e8f0 0 0) 18% 55% / 58% 5% no-repeat,linear-gradient(#bae6fd 0 0) 18% 72% / 22% 12% no-repeat,linear-gradient(#99f6e4 0 0) 56% 72% / 22% 12% no-repeat,#fff;box-shadow:0 20px 55px #0f766e21;animation:shimmer 1.6s ease-in-out infinite}.waiting-art span{position:absolute;width:10px;height:10px;border-radius:50%;background:#0f766e;opacity:.22;animation:pulse-dot 1.3s ease-in-out infinite}.waiting-art span:nth-child(1){left:24%;top:64%}.waiting-art span:nth-child(2){left:48%;top:64%;animation-delay:.15s}.waiting-art span:nth-child(3){left:72%;top:64%;animation-delay:.3s}.article-switcher{margin-bottom:14px;border-bottom:1px solid #e2e8f0;padding-bottom:14px}.panel-block{min-height:0;display:grid;grid-template-rows:auto minmax(0,1fr);gap:14px}.panel-head{display:flex;justify-content:space-between;gap:12px;align-items:start;padding-bottom:14px;border-bottom:1px solid #e2e8f0}.panel-body{min-height:0;display:grid;gap:10px;overflow:auto;padding-right:2px}.status-pill{border-radius:999px;padding:5px 9px;font-size:12px;color:#475569;background:#f1f5f9;white-space:nowrap}.status-pill.success{color:#0f766e;background:#ecfdf5}.status-pill.running{color:#1d4ed8;background:#eff6ff}.status-pill.waiting{color:#92400e;background:#fffbeb}.status-pill.failed{color:#b91c1c;background:#fef2f2}.grid-two{display:grid;grid-template-columns:1fr 1fr;gap:10px}.strategy-box{min-height:66px;border:1px solid #ccd5e1;border-radius:6px;padding:9px 10px;display:grid;gap:3px;align-content:center;background:#f8fafc}.strategy-box span{color:#475569;font-size:13px}.strategy-box strong{color:#0f766e}.strategy-box small{color:#64748b}.candidate-actions,.preview-actions,.image-action-list{display:flex;gap:8px;flex-wrap:wrap}.candidate-list,.image-action-list{display:grid;gap:9px}.candidate-list{max-height:44vh;overflow:auto;padding-right:2px}.candidate{display:grid;grid-template-columns:20px 1fr 34px;gap:8px;align-items:center}.candidate input[type=checkbox]{width:17px;height:17px}.icon{width:34px;padding:0}.kv{display:flex;justify-content:space-between;gap:12px;padding:10px 0;border-bottom:1px solid #eef2f7;font-size:13px}.kv span,small{color:#64748b}.kv strong{text-align:right;font-weight:600}.title-preview-list{display:grid;gap:7px;padding-top:10px}.title-preview-list p{padding:8px;border-radius:6px;background:#f1f5f9;color:#334155;font-size:13px}.editor{display:grid;gap:10px}.editor textarea{min-height:96px}.editor .summary-textarea{min-height:180px;max-height:320px}.error-banner,.inline-error{border:1px solid #fecaca;background:#fef2f2;color:#991b1b;padding:9px 12px;display:flex;gap:8px;align-items:center}.error-banner{position:absolute;top:84px;left:320px;right:440px;z-index:10;border-radius:8px;box-shadow:0 12px 30px #0f172a1f}.inline-error{border-radius:7px;font-size:13px}.empty-state{color:#64748b}.spin{animation:spin .9s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@keyframes shimmer{to{background-position:180% 0,18% 16%,18% 31%,18% 45%,18% 55%,18% 72%,56% 72%,0 0}}@keyframes pulse-dot{0%,to{transform:translateY(0);opacity:.22}50%{transform:translateY(-8px);opacity:.72}}@media(max-width:1180px){.dashboard{grid-template-columns:1fr;grid-template-rows:auto minmax(520px,1fr) auto;overflow:auto}.app-shell{overflow:auto}.timeline-panel,.tactics-panel{border:0}.article-showcase{grid-template-columns:1fr}.image-carousel{min-height:360px}.topbar{height:auto;align-items:flex-start;flex-direction:column}}
