:root{--bg-primary:#fafafa;--bg-secondary:#f5f5f5;--card-bg:#fff;--text-primary:#111;--text-secondary:#777;--border-color:#ebebeb;--accent:#6366f1;--success:#22c55e;--warning:#f59e0b;--danger:#ef4444;--muted:#6b7280}.dark-mode{--bg-primary:#0a0a0a;--bg-secondary:#141414;--card-bg:#1a1a1a;--text-primary:#e5e5e5;--text-secondary:#888;--border-color:#2a2a2a}*{box-sizing:border-box;margin:0;padding:0}html,body,#root{width:100%;height:100%;overflow:hidden}body{background:var(--bg-primary);color:var(--text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,SF Pro Display,Segoe UI,Roboto,sans-serif}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-secondary)}::selection{background:#6366f133}.shell{background:var(--bg-primary);flex-direction:column;height:100vh;display:flex;overflow:hidden}.topbar{border-bottom:1px solid var(--border-color);background:var(--card-bg);flex-shrink:0;justify-content:space-between;align-items:center;padding:12px 24px;display:flex}.row{align-items:center;gap:12px;display:flex}.row-sm{align-items:center;gap:8px;display:flex}.row-lg{align-items:center;gap:16px;display:flex}.title{color:var(--text-primary);margin:0;font-size:18px;font-weight:600}.pill{color:#fff;border-radius:9999px;padding:2px 10px;font-size:11px;font-weight:600;display:inline-block}.meta{color:var(--text-secondary);white-space:nowrap;font-size:11px}.branch{background:var(--bg-secondary);color:var(--text-secondary);border-radius:9999px;padding:2px 8px;font-size:10px;font-weight:600}.btn{cursor:pointer;background:var(--bg-secondary);color:var(--text-primary);border:none;border-radius:8px;padding:6px 12px;font-size:12px;font-weight:600}.btn-accent{color:#fff;background:#6366f1}.btn-dark{color:#fff;background:#111}.btn-success{color:#fff;background:#22c55e}.btn-warn{color:#fff;background:#f59e0b}.btn-muted{color:#fff;background:#6b7280}.statsbar{border-bottom:1px solid var(--border-color);background:var(--card-bg);flex-shrink:0;gap:10px;padding:10px 24px;display:flex;overflow-x:auto}.stat{background:var(--bg-secondary);white-space:nowrap;border-radius:10px;align-items:center;gap:6px;padding:6px 14px;font-size:12px;font-weight:500;display:flex}.stat-val{font-size:16px;font-weight:700}.main{flex:1;grid-template-columns:420px 1fr;display:grid;overflow:hidden}@media (width<=1100px){.main{grid-template-columns:1fr}}.pipecol{border-right:1px solid var(--border-color);overflow-y:auto}@media (width<=1100px){.pipecol{border-right:none}.pipecol.hide{display:none}}.repo-block{border-bottom:1px solid var(--border-color)}.repo-head{cursor:pointer;background:var(--card-bg);justify-content:space-between;align-items:center;padding:10px 20px;display:flex}.repo-head:hover{background:var(--bg-secondary)}.repo-label{align-items:center;gap:8px;font-size:13px;font-weight:600;display:flex}.dot{border-radius:50%;flex-shrink:0;width:10px;height:10px}.dot.pulse{animation:1.5s infinite dot-pulse}@keyframes dot-pulse{0%{box-shadow:0 0 #f59e0b66}70%{box-shadow:0 0 0 6px #0000}to{box-shadow:0 0 #0000}}.run-row{cursor:pointer;border-bottom:1px solid var(--border-color);grid-template-columns:24px 1fr auto auto auto auto;align-items:center;gap:10px;padding:8px 20px 8px 36px;display:grid}.run-row:hover,.run-row.sel{background:var(--bg-secondary)}.run-name{text-overflow:ellipsis;white-space:nowrap;font-size:12px;font-weight:500;overflow:hidden}.detailcol{background:var(--bg-primary);flex-direction:column;display:flex;overflow:hidden}@media (width<=1100px){.detailcol.hide{display:none}}.detail-head{background:var(--card-bg);border-bottom:1px solid var(--border-color);flex-shrink:0;justify-content:space-between;align-items:flex-start;padding:16px 24px;display:flex}.detail-title{font-size:15px;font-weight:600}.detail-meta{color:var(--text-secondary);gap:14px;margin-top:4px;font-size:11px;display:flex}.tabs{border-bottom:1px solid var(--border-color);background:var(--card-bg);flex-shrink:0;display:flex}.tab{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;padding:9px 18px;font-size:12px;font-weight:500}.tab.on{color:var(--text-primary);border-bottom-color:var(--text-primary);font-weight:600}.job-card{background:var(--card-bg);border-radius:12px;margin-bottom:10px;overflow:hidden;box-shadow:0 1px 3px #00000014}.job-head{cursor:pointer;justify-content:space-between;align-items:center;padding:10px 14px;display:flex}.job-head:hover{background:var(--bg-secondary)}.job-name{align-items:center;gap:6px;font-size:12px;font-weight:600;display:flex}.step-row{border-top:1px solid var(--border-color);align-items:center;gap:6px;padding:5px 14px 5px 34px;font-size:11px;display:flex}.step-icon{text-align:center;flex-shrink:0;width:14px;font-size:10px;font-weight:700}.log-pre{color:#c9d1d9;white-space:pre-wrap;word-break:break-all;background:#0d1117;flex:1;margin:0;padding:16px 24px;font-family:SF Mono,Menlo,Monaco,monospace;font-size:11px;line-height:1.6;overflow:auto}.ai-wrap{flex:1;padding:20px 24px;overflow-y:auto}.ai-card{background:var(--card-bg);border-radius:14px;margin-bottom:12px;padding:20px;box-shadow:0 1px 3px #00000014}.ai-title{margin-bottom:10px;font-size:14px;font-weight:600}.code-block{color:#c9d1d9;white-space:pre-wrap;background:#0d1117;border-radius:10px;margin:6px 0;padding:14px;font-family:SF Mono,Menlo,monospace;font-size:11px;line-height:1.5;overflow-x:auto}.ai-error{color:#991b1b;background:#fef2f2;border-radius:12px;margin-bottom:12px;padding:12px;font-size:12px}.empty{height:100%;color:var(--text-secondary);text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:10px;padding:40px;font-size:13px;display:flex}.modal-overlay{z-index:1000;background:#00000080;justify-content:center;align-items:center;padding:24px;display:flex;position:fixed;inset:0}.modal-box{background:var(--card-bg);border-radius:20px;width:100%;max-width:440px;overflow:hidden;box-shadow:0 20px 60px #00000026}.modal-head{border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:center;padding:14px 20px;font-size:15px;font-weight:600;display:flex}.modal-body{padding:20px}.input{border:1px solid var(--border-color);background:var(--bg-primary);width:100%;color:var(--text-primary);box-sizing:border-box;border-radius:10px;outline:none;padding:10px 14px;font-size:13px}.input:focus{border-color:var(--accent);box-shadow:0 0 0 3px #6366f11a}.field-label{color:var(--text-primary);margin-bottom:3px;font-size:12px;font-weight:600}.field-text{color:var(--text-primary);font-size:13px;line-height:1.6}.small-text{color:var(--text-secondary);font-size:11px}.usage-row{border-bottom:1px solid var(--border-color);justify-content:space-between;padding:5px 0;font-size:11px;display:flex}.errlog-wrap{flex-direction:column;height:100%;display:flex}.errlog-bar{border-bottom:1px solid var(--border-color);background:var(--card-bg);flex-shrink:0;align-items:center;gap:10px;padding:10px 24px;display:flex;overflow-x:auto}.errlog-counts{flex-shrink:0;gap:8px;display:flex}.errlog-count{border-radius:9999px;padding:3px 10px;font-size:11px;font-weight:700}.errlog-count.err{color:#991b1b;background:#fef2f2}.errlog-count.warn{color:#92400e;background:#fef3c7}.errlog-chips{flex-wrap:nowrap;gap:4px;display:flex;overflow-x:auto}.errlog-chip{cursor:pointer;border:none;border-radius:6px;padding:2px 8px;font-family:SF Mono,Menlo,monospace;font-size:10px;font-weight:600}.errlog-chip.error{color:#dc2626;background:#ef44441f}.errlog-chip.warning{color:#d97706;background:#f59e0b1f}.errlog-chip:hover{opacity:.8}.errlog-blocks{background:#0d1117;flex:1;padding:16px 24px;overflow-y:auto}.errlog-block{border:1px solid #21262d;border-radius:10px;margin-bottom:12px;overflow:hidden}.errlog-block-head{color:#c9d1d9;align-items:center;gap:8px;padding:8px 12px;font-size:11px;display:flex}.errlog-block-head.error{background:#ef44441a}.errlog-block-head.warning{background:#f59e0b14}.errlog-sev-dot{border-radius:50%;flex-shrink:0;width:7px;height:7px}.errlog-block-head.error .errlog-sev-dot{background:#ef4444}.errlog-block-head.warning .errlog-sev-dot{background:#f59e0b}.errlog-ctx{font-family:SF Mono,Menlo,Monaco,monospace;font-size:11px;line-height:1.6}.errlog-line{color:#8b949e;padding:0 12px;display:flex}.errlog-line.err{color:#f87171;background:#ef44441f}.errlog-line.warn{color:#fbbf24;background:#f59e0b14}.errlog-linenum{text-align:right;color:#484f58;-webkit-user-select:none;user-select:none;flex-shrink:0;width:48px;padding-right:12px}.errlog-linetext{white-space:pre-wrap;word-break:break-all;flex:1}.region-panel{align-items:center;gap:6px;display:flex}.region-chip{background:var(--bg-secondary);border:1px solid;border-radius:9999px;align-items:center;gap:5px;padding:4px 10px;font-size:11px;display:flex}.region-chip-label{font-size:10px;font-weight:600}.region-health-dot{border-radius:50%;flex-shrink:0;width:7px;height:7px}.region-row{background:var(--bg-secondary);border-radius:10px;align-items:center;gap:12px;margin-bottom:8px;padding:12px;display:flex}.region-row-info{color:var(--text-secondary);gap:12px;font-size:11px;display:flex}.deploy-btn{transition:opacity .15s}.deploy-btn-locked{cursor:not-allowed;opacity:.6;background:var(--bg-secondary)!important;color:var(--text-secondary)!important}.deploy-lock-banner{color:#92400e;background:#f59e0b14;border:1px solid #f59e0b33;border-radius:10px;align-items:center;gap:8px;margin-bottom:12px;padding:10px 12px;font-size:11px;line-height:1.4;display:flex}.stage-wrap{padding:20px 24px}.stage-summary{grid-template-columns:repeat(4,1fr);gap:10px;margin-bottom:20px;display:grid}.stage-summary-item{background:var(--card-bg);border-radius:12px;padding:14px;box-shadow:0 1px 3px #00000014}.stage-summary-label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px;font-size:10px;font-weight:500;display:block}.stage-summary-val{color:var(--text-primary);font-size:16px;font-weight:700}.stage-grid-wrap{background:var(--card-bg);border-radius:12px;margin-bottom:24px;overflow-x:auto;box-shadow:0 1px 3px #00000014}.stage-header-row{border-bottom:2px solid var(--border-color);display:flex}.stage-job-header{color:var(--text-primary);text-align:center;border-right:1px solid var(--border-color);white-space:nowrap;padding:10px 12px;font-size:11px;font-weight:700}.stage-job-header:last-child{border-right:none}.stage-name-row{border-bottom:1px solid var(--border-color);background:var(--bg-secondary);display:flex}.stage-run-label{border-right:1px solid var(--border-color);flex-shrink:0;align-items:center;gap:6px;width:90px;min-width:90px;padding:8px 10px;display:flex}.stage-run-num{color:var(--text-primary);font-family:SF Mono,Menlo,monospace;font-size:11px;font-weight:600}.stage-run-badge{text-transform:uppercase;border-radius:4px;padding:1px 6px;font-size:9px;font-weight:700}.stage-run-badge.ok{color:#16a34a;background:#22c55e26}.stage-run-badge.fail{color:#dc2626;background:#ef444426}.stage-run-badge.other{color:#6b7280;background:#6b72801f}.stage-col-head{text-align:center;border-right:1px solid var(--border-color);min-width:100px;padding:8px 10px}.stage-col-head:last-child{border-right:none}.stage-col-name{color:var(--text-secondary);white-space:nowrap;text-overflow:ellipsis;max-width:120px;font-size:10px;font-weight:500;overflow:hidden}.stage-col-avg{margin-top:2px;font-size:12px;font-weight:700}.stage-run-row{border-bottom:1px solid var(--border-color);display:flex}.stage-run-row:last-child{border-bottom:none}.stage-cell{text-align:center;border-right:1px solid var(--border-color);min-width:100px;padding:8px 10px;position:relative;overflow:hidden}.stage-cell:last-child{border-right:none}.stage-cell.empty-cell{background:#6b72800a}.stage-cell-bar{border-radius:0 2px 0 0;height:3px;transition:width .5s;position:absolute;bottom:0;left:0}.stage-cell-dur{z-index:1;font-size:11px;font-weight:600;position:relative}.stage-slow-badge{color:#ef4444;vertical-align:middle;background:#ef444426;border-radius:3px;margin-left:4px;padding:0 4px;font-size:8px;font-weight:700;display:inline-block}.stage-bars-section{background:var(--card-bg);border-radius:12px;padding:16px 20px;box-shadow:0 1px 3px #00000014}.stage-bars-title{color:var(--text-primary);margin-bottom:14px;font-size:13px;font-weight:600}.stage-bar-row{align-items:center;gap:10px;margin-bottom:8px;display:flex}.stage-bar-name{width:160px;min-width:160px;color:var(--text-secondary);white-space:nowrap;text-overflow:ellipsis;font-size:11px;font-weight:500;overflow:hidden}.stage-bar-track{background:var(--bg-secondary);border-radius:7px;flex:1;height:14px;overflow:hidden}.stage-bar-fill{border-radius:7px;min-width:4px;height:100%}.stage-bar-stats{text-align:right;flex-direction:column;align-items:flex-end;width:120px;min-width:120px;font-size:11px;display:flex}.stat-val-pop{animation:.35s stat-pop}@keyframes stat-pop{0%{transform:scale(1)}40%{transform:scale(1.25)}to{transform:scale(1)}}.stat-val{transition:color .3s;display:inline-block}.pill-sync{animation:.8s infinite pill-sync-pulse}@keyframes pill-sync-pulse{0%,to{opacity:1}50%{opacity:.5}}.countdown-ring{flex-shrink:0;justify-content:center;align-items:center;width:24px;height:24px;display:flex;position:relative}.countdown-num{color:var(--text-secondary);font-family:SF Mono,Menlo,monospace;font-size:8px;font-weight:700;position:absolute}
