:root{--bg-primary: #0b0f14;--bg-card: #0f1620;--bg-input: #0b1220;--border: #1f2a37;--border-active: #60a5fa;--text-primary: #e6edf3;--text-muted: #9fb3c8;--text-link: #93c5fd;--accent: #2563eb;--accent-hover: #1d4ed8;--danger: #b91c1c;--success: #16a34a;--warning: #d97706;--purple: #a78bfa;--radius: 10px;--radius-sm: 8px}*{box-sizing:border-box;margin:0;padding:0}body{font-family:ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;background:var(--bg-primary);color:var(--text-primary);line-height:1.5;min-height:100vh}.app-layout{display:flex;flex-direction:column;min-height:100vh}header.app-header{display:flex;justify-content:space-between;align-items:center;padding:14px 20px;border-bottom:1px solid var(--border);gap:16px}.app-header .logo{font-weight:700;font-size:16px;letter-spacing:.2px}.app-header .nav{display:flex;gap:8px;align-items:center}main.app-main{flex:1;padding:20px;max-width:1400px;margin:0 auto;width:100%}.card{border:1px solid var(--border);border-radius:var(--radius);background:var(--bg-card);overflow:hidden}.card-header{padding:10px 14px;border-bottom:1px solid var(--border);font-size:13px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em}.card-body{padding:14px}button,.btn{display:inline-flex;align-items:center;gap:6px;background:var(--accent);color:#fff;border:0;border-radius:var(--radius-sm);padding:8px 14px;cursor:pointer;font-size:13px;font-weight:500;transition:background .15s}button:hover{background:var(--accent-hover)}button:disabled{opacity:.5;cursor:not-allowed}button:focus-visible{outline:2px solid var(--border-active);outline-offset:2px}.btn-secondary{background:#374151}.btn-secondary:hover{background:#4b5563}.btn-danger{background:var(--danger)}.btn-danger:hover{background:#991b1b}.btn-success{background:var(--success)}.btn-success:hover{background:#15803d}.btn-sm{padding:5px 10px;font-size:12px}.btn-ghost{background:transparent;color:var(--text-muted);padding:5px 10px}.btn-ghost:hover{background:#1f2a37;color:var(--text-primary)}input,textarea,select{width:100%;background:var(--bg-input);border:1px solid var(--border);color:var(--text-primary);border-radius:var(--radius-sm);padding:9px 12px;font-size:13px;font-family:inherit;transition:border-color .15s}input:focus,textarea:focus,select:focus{outline:none;border-color:var(--border-active)}input:focus-visible,textarea:focus-visible,select:focus-visible{outline:2px solid var(--border-active);outline-offset:-2px}textarea{min-height:70px;resize:vertical}.grid-2{display:grid;grid-template-columns:minmax(420px,420px) minmax(0,1fr);gap:16px;align-items:start}@media(max-width:980px){.grid-2{grid-template-columns:1fr}}.row{display:flex;gap:10px;align-items:center}.stack{display:flex;flex-direction:column;gap:8px}.text-muted{color:var(--text-muted);font-size:12px}.text-sm{font-size:13px}a{color:var(--text-link);text-decoration:none}a:hover{text-decoration:underline}a:focus-visible{outline:2px solid var(--border-active);outline-offset:2px;border-radius:2px}.pill{display:inline-flex;align-items:center;padding:2px 10px;border-radius:999px;font-size:12px;font-weight:500;border:1px solid var(--border)}.pill-success{border-color:var(--success);color:var(--success)}.pill-danger{border-color:var(--danger);color:var(--danger)}.pill-warning{border-color:var(--warning);color:var(--warning)}.pill-active{border-color:var(--border-active);color:var(--border-active)}.badge{display:inline-flex;align-items:center;gap:5px;padding:3px 10px;border-radius:999px;font-size:11px;font-weight:600;letter-spacing:.03em;text-transform:uppercase}.badge-queued{background:#374151;color:#9ca3af}.badge-executing,.badge-running{background:#1e3a5f;color:#60a5fa}.badge-completed,.badge-success{background:#14532d;color:#4ade80}.badge-failed,.badge-failure{background:#450a0a;color:#fca5a5}.badge-cancelled{background:#374151;color:#6b7280}.badge-awaiting_approval{background:#451a03;color:#fbbf24}.badge-awaiting_delegation{background:#2e1065;color:#c4b5fd}.list-item{padding:10px 12px;border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;background:var(--bg-input);transition:border-color .15s}.list-item:hover{border-color:#374151}.list-item.active{border-color:var(--border-active);box-shadow:0 0 0 1px var(--border-active) inset}pre,.log-output{white-space:pre-wrap;word-break:break-word;background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);padding:12px;max-height:400px;overflow:auto;font-size:12px;font-family:Cascadia Code,Fira Code,JetBrains Mono,monospace;line-height:1.6}.log-viewer{position:relative}.log-viewer pre{max-height:500px;scroll-behavior:smooth}.log-viewer .log-toolbar{display:flex;justify-content:flex-end;gap:6px;padding:4px 0}.log-viewer .scroll-bottom-btn{position:absolute;bottom:12px;right:16px;background:var(--accent);color:#fff;border:none;border-radius:999px;width:32px;height:32px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:14px;opacity:.85;transition:opacity .15s;box-shadow:0 2px 8px #0006}.log-viewer .scroll-bottom-btn:hover{opacity:1}.status-queued{color:var(--text-muted)}.status-running,.status-executing{color:#60a5fa}.status-success,.status-completed{color:var(--success)}.status-failure,.status-failed{color:var(--danger)}.status-gated,.status-awaiting_approval{color:var(--warning)}.status-awaiting_delegation{color:#a78bfa}.status-cancelled{color:var(--text-muted);text-decoration:line-through}.divider{border:0;border-top:1px solid var(--border);margin:14px 0}.timeline{display:flex;flex-direction:column;gap:2px}.timeline-step{display:flex;align-items:flex-start;gap:12px;padding:10px 12px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-input);transition:border-color .2s}.timeline-step.active-step{border-color:var(--border-active);background:#0d1a2d}.timeline-step-idx{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;flex-shrink:0;border:2px solid var(--border)}.timeline-step-content{flex:1;min-width:0}.timeline-step-header{display:flex;justify-content:space-between;align-items:center;gap:8px}.step-type-icon{display:inline-flex;align-items:center;gap:4px;font-size:13px}.step-duration{font-size:11px;color:var(--text-muted);font-variant-numeric:tabular-nums}@keyframes pulse-ring{0%{box-shadow:0 0 #60a5fa80}70%{box-shadow:0 0 0 6px #60a5fa00}to{box-shadow:0 0 #60a5fa00}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.pulse{animation:pulse-ring 1.5s cubic-bezier(.4,0,.6,1) infinite}.spinner{display:inline-block;width:14px;height:14px;border:2px solid transparent;border-top-color:currentColor;border-radius:50%;animation:spin .8s linear infinite}@keyframes skeleton-shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.skeleton{background:linear-gradient(90deg,#1f2a37 25%,#2d3a4a,#1f2a37 75%);background-size:200% 100%;animation:skeleton-shimmer 1.5s ease-in-out infinite;border-radius:var(--radius-sm)}.skeleton-text{height:14px;margin-bottom:8px;border-radius:4px}.skeleton-text:last-child{width:60%}.skeleton-card{height:60px;margin-bottom:8px}.welcome-banner{border:1px solid var(--border);border-radius:var(--radius);background:linear-gradient(135deg,#0f1620,#0d1a2d);padding:28px 24px;text-align:center}.welcome-banner h3{font-size:18px;font-weight:600;margin-bottom:8px}.welcome-banner p{color:var(--text-muted);font-size:14px;margin-bottom:4px;line-height:1.6}.cta-card{border:1px solid var(--border-active);border-radius:var(--radius);background:#0d1a2d;padding:14px 16px;display:flex;align-items:center;gap:12px}.cta-card .cta-icon{width:36px;height:36px;border-radius:50%;background:var(--accent);display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0}.cta-card .cta-text{flex:1}.cta-card .cta-text .cta-title{font-weight:600;font-size:14px;margin-bottom:2px}.cta-card .cta-text .cta-description{font-size:12px;color:var(--text-muted)}.breadcrumbs{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--text-muted);margin-bottom:4px}.breadcrumbs a{color:var(--text-muted);font-size:13px}.breadcrumbs a:hover{color:var(--text-link)}.breadcrumbs .sep{color:#4b5563;font-size:11px}.toast-container{position:fixed;bottom:16px;right:16px;display:flex;flex-direction:column-reverse;gap:8px;z-index:9999;pointer-events:none}.toast{display:flex;align-items:center;gap:8px;padding:10px 16px;border-radius:var(--radius-sm);font-size:13px;font-weight:500;background:#1f2a37;color:var(--text-primary);border:1px solid var(--border);box-shadow:0 4px 16px #0006;cursor:pointer;pointer-events:auto;animation:toast-slide-in .25s ease-out;max-width:380px}@keyframes toast-slide-in{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.toast-icon{font-size:15px;flex-shrink:0}.toast-message{flex:1;line-height:1.4}.toast-success{border-color:var(--success)}.toast-success .toast-icon{color:var(--success)}.toast-error{border-color:var(--danger)}.toast-error .toast-icon{color:var(--danger)}.toast-warning{border-color:var(--warning)}.toast-warning .toast-icon{color:var(--warning)}.toast-info{border-color:var(--border-active)}.toast-info .toast-icon{color:var(--border-active)}.worker-stats-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:10px}.stat-card{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);padding:10px 12px;text-align:center}.stat-card .stat-value{font-size:22px;font-weight:700;line-height:1;margin-bottom:4px}.stat-card .stat-label{font-size:11px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.approval-card{border:1px solid var(--warning);border-radius:var(--radius-sm);background:#1a1505;padding:12px}.approval-card .approval-header{display:flex;justify-content:space-between;align-items:center;gap:8px;margin-bottom:8px}.empty-state{padding:30px 20px;text-align:center;color:var(--text-muted);font-size:13px}.empty-state p{margin-top:6px}.info-tip{position:relative;display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;border-radius:50%;background:transparent;border:1px solid var(--border);color:var(--text-muted);font-size:11px;font-weight:600;cursor:help;flex-shrink:0}.info-tip .info-tip-text{display:none;position:absolute;bottom:100%;left:50%;transform:translate(-50%);margin-bottom:6px;background:#1f2a37;color:var(--text-primary);padding:8px 12px;border-radius:var(--radius-sm);font-size:12px;font-weight:400;line-height:1.5;white-space:normal;width:220px;text-align:left;box-shadow:0 4px 16px #0006;z-index:100;pointer-events:none}.info-tip:hover .info-tip-text,.info-tip:focus .info-tip-text{display:block}.checklist{display:flex;flex-direction:column;gap:6px;padding:12px 0}.checklist-item{display:flex;align-items:center;gap:10px;font-size:13px;color:var(--text-muted)}.checklist-item.done{color:var(--success)}.checklist-check{width:20px;height:20px;border-radius:50%;border:2px solid var(--border);display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:11px}.checklist-item.done .checklist-check{border-color:var(--success);background:var(--success);color:#fff}.theme-toggle{display:flex;align-items:center;gap:8px;cursor:pointer;font-size:12px;color:var(--text-muted);-webkit-user-select:none;user-select:none}.theme-toggle-track{width:32px;height:18px;border-radius:9px;background:var(--border);position:relative;transition:background .2s}.theme-toggle-track .theme-toggle-thumb{width:14px;height:14px;border-radius:50%;background:var(--text-primary);position:absolute;top:2px;left:2px;transition:left .2s}.theme-toggle-track.on{background:var(--accent)}.theme-toggle-track.on .theme-toggle-thumb{left:16px}[data-theme=light]{--bg-primary: #f8fafc;--bg-card: #ffffff;--bg-input: #f1f5f9;--border: #e2e8f0;--border-active: #3b82f6;--text-primary: #1e293b;--text-muted: #64748b;--text-link: #2563eb;--accent: #2563eb;--accent-hover: #1d4ed8;--danger: #dc2626;--success: #16a34a;--warning: #d97706;--purple: #7c3aed}[data-theme=light] .badge-queued{background:#e2e8f0;color:#64748b}[data-theme=light] .badge-executing,[data-theme=light] .badge-running{background:#dbeafe;color:#2563eb}[data-theme=light] .badge-completed,[data-theme=light] .badge-success{background:#dcfce7;color:#16a34a}[data-theme=light] .badge-failed,[data-theme=light] .badge-failure{background:#fee2e2;color:#dc2626}[data-theme=light] .badge-cancelled{background:#e2e8f0;color:#94a3b8}[data-theme=light] .badge-awaiting_approval{background:#fef3c7;color:#d97706}[data-theme=light] .badge-awaiting_delegation{background:#ede9fe;color:#7c3aed}[data-theme=light] .toast{background:#fff;border:1px solid #e2e8f0}[data-theme=light] .info-tip .info-tip-text{background:#fff;box-shadow:0 4px 16px #0000001a}[data-theme=light] .skeleton{background:linear-gradient(90deg,#e2e8f0 25%,#f1f5f9,#e2e8f0 75%);background-size:200% 100%}[data-theme=light] .cta-card{background:#eff6ff;border-color:#3b82f6}[data-theme=light] .welcome-banner{background:linear-gradient(135deg,#f8fafc,#eff6ff)}[data-theme=light] .approval-card{background:#fffbeb}[data-theme=light] .stat-card{background:#f1f5f9}[data-theme=light] .timeline-step.active-step{background:#eff6ff}@media(max-width:768px){main.app-main{padding:12px}header.app-header{padding:10px 12px}.grid-2{grid-template-columns:1fr}.row{flex-wrap:wrap}.worker-stats-grid{grid-template-columns:repeat(2,1fr)}.welcome-banner{padding:20px 16px}.welcome-banner h3{font-size:16px}h2{font-size:18px!important}}@media(max-width:480px){.worker-stats-grid{grid-template-columns:1fr 1fr}.timeline-step{padding:8px;gap:8px}.timeline-step-idx{width:24px;height:24px;font-size:10px}.breadcrumbs{font-size:12px}.wizard-steps{flex-direction:column}.wizard-step-line{display:none}.wizard-options-grid{grid-template-columns:1fr}}.wizard-steps{display:flex;align-items:center;gap:0;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:12px 16px}.wizard-step-btn{display:flex;align-items:center;gap:8px;background:none;border:none;color:var(--text-muted);font-size:13px;cursor:pointer;padding:6px 10px;border-radius:var(--radius-sm);transition:all .15s;position:relative;white-space:nowrap}.wizard-step-btn:hover{background:#60a5fa0f}.wizard-step-btn.active{color:var(--text-primary);background:#60a5fa1a}.wizard-step-btn.done{color:var(--success)}.wizard-step-num{width:24px;height:24px;border-radius:50%;border:2px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:600;flex-shrink:0;transition:all .15s}.wizard-step-btn.active .wizard-step-num{border-color:var(--border-active);color:var(--border-active)}.wizard-step-btn.done .wizard-step-num{border-color:var(--success);background:var(--success);color:#fff}.wizard-step-line{width:24px;height:1px;background:var(--border);flex-shrink:0;margin:0 2px}.wizard-step-label{font-weight:500}.wizard-panel{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:24px;display:flex;flex-direction:column;gap:20px}.wizard-panel-header{display:flex;align-items:center;justify-content:space-between;gap:12px}.wizard-panel-header h3{font-size:16px;font-weight:600;display:flex;align-items:center;gap:8px}.wizard-instructions{background:var(--bg-input);border-radius:var(--radius-sm);padding:16px 20px;font-size:13px;line-height:1.7}.wizard-instructions h4{font-size:13px;font-weight:600;margin-bottom:8px;color:var(--text-primary)}.wizard-instructions ol{padding-left:20px;color:var(--text-muted)}.wizard-instructions ol li{margin-bottom:6px}.wizard-instructions a{color:var(--text-link);text-decoration:underline;text-underline-offset:2px}.wizard-external-links{display:flex;gap:8px;margin-top:12px;flex-wrap:wrap}.wizard-external-links a{text-decoration:none}.wizard-label{display:flex;flex-direction:column;gap:4px;font-size:12px;font-weight:500;color:var(--text-muted)}.wizard-label input,.wizard-label select,.wizard-label textarea{font-size:13px}.wizard-config-table{margin-top:8px;border-collapse:collapse;font-size:12px;width:100%}.wizard-config-table td{padding:4px 8px;border:1px solid var(--border);vertical-align:top}.wizard-config-table td:first-child{font-weight:500;white-space:nowrap;width:140px;color:var(--text-primary)}.wizard-config-table code{font-size:11px;background:var(--bg-primary);padding:1px 4px;border-radius:3px;word-break:break-all}.wizard-result{display:flex;align-items:flex-start;gap:10px;padding:12px 16px;border-radius:var(--radius-sm);font-size:13px;line-height:1.5}.wizard-result-ok{background:#16a34a14;border:1px solid rgba(22,163,74,.3);color:var(--success)}.wizard-result-warn{background:#d9770614;border:1px solid rgba(217,119,6,.3);color:var(--warning)}.wizard-result-icon{font-size:16px;line-height:1;flex-shrink:0;margin-top:1px}.wizard-options-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:12px}.wizard-option-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);padding:14px}.wizard-verify-results{display:flex;flex-direction:column;gap:6px;margin-top:12px}.wizard-verify-row{display:flex;align-items:center;gap:10px;padding:8px 14px;border-radius:var(--radius-sm);font-size:13px}.wizard-verify-row.ok{background:#16a34a0f}.wizard-verify-row.fail{background:#b91c1c0f}.wizard-verify-icon{font-size:14px;width:20px;text-align:center;flex-shrink:0}.wizard-verify-row.ok .wizard-verify-icon{color:var(--success)}.wizard-verify-row.fail .wizard-verify-icon{color:var(--danger)}.wizard-verify-label{font-weight:600;text-transform:capitalize;min-width:80px}.wizard-verify-msg{color:var(--text-muted)}[data-theme=light] .wizard-instructions{background:#f8fafc}[data-theme=light] .wizard-option-card{background:#fff}[data-theme=light] .wizard-config-table code{background:#f1f5f9}[data-theme=light] .wizard-result-ok{background:#16a34a0d}[data-theme=light] .wizard-result-warn{background:#d977060d}[data-theme=light] .wizard-verify-row.ok{background:#16a34a0a}[data-theme=light] .wizard-verify-row.fail{background:#b91c1c0a}
