*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--sidebar-bg:#0d0e12;--sidebar-text:#a0a4ab;--sidebar-active-bg:#1c1e26;--sidebar-hover-bg:#161820;--sidebar-active-text:#fff;--sidebar-width:220px;--content-bg:#fff;--content-secondary-bg:#f7f7f8;--green:#04aa51;--green-dark:#038a41;--blue:#1a73e8;--red:#f44336;--amber:#d4a017;--purple:#9c27b0;--gray:#757575;--text-primary:#24292f;--text-secondary:#656d76;--border:#d1d5da;--link:#0969da;--font:"Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--mono:"JetBrains Mono", "Fira Code", "Courier New", monospace}body{font-family:var(--font);color:var(--text-primary);background:var(--content-bg);-webkit-font-smoothing:antialiased;font-size:13px;line-height:1.5}a{color:var(--link);text-decoration:none}a:hover{text-decoration:underline}button{cursor:pointer;font-family:var(--font)}button:disabled{cursor:not-allowed;opacity:.55}input,select,textarea{font-family:var(--font)}.app-shell{height:100vh;display:flex;overflow:hidden}.sidebar{width:var(--sidebar-width);min-width:var(--sidebar-width);background:var(--sidebar-bg);z-index:100;flex-direction:column;height:100vh;display:flex;position:relative;overflow:hidden}.sidebar-org{cursor:pointer;border-bottom:1px solid #ffffff14;align-items:center;gap:10px;padding:16px;transition:background .15s;display:flex;position:relative}.sidebar-org:hover{background:var(--sidebar-hover-bg)}.org-dropdown{z-index:220;background:#1e2029;border:1px solid #ffffff26;border-radius:8px;padding:10px;position:absolute;top:calc(100% - 6px);left:12px;right:12px;box-shadow:0 10px 28px #00000073}.org-dropdown-title{color:#fff;margin-bottom:2px;font-size:13px;font-weight:600}.org-dropdown-meta{color:var(--sidebar-text);text-transform:capitalize;margin-bottom:8px;font-size:12px}.org-dropdown button{color:#e0e0e0;text-align:left;background:0 0;border:0;border-radius:6px;width:100%;padding:8px;font-size:13px}.org-dropdown button:hover{background:#ffffff14}.org-avatar{background:var(--green);color:#fff;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:14px;font-weight:700;display:flex}.org-name{color:var(--sidebar-active-text);white-space:nowrap;text-overflow:ellipsis;flex:1;font-size:14px;font-weight:600;overflow:hidden}.org-chevron{color:var(--sidebar-text);flex-shrink:0;font-size:10px}.sidebar-search{border-bottom:1px solid #ffffff0f;padding:10px 12px;position:relative}.sidebar-search input{color:#fff;background:#ffffff12;border:1px solid #ffffff1a;border-radius:6px;outline:none;width:100%;padding:6px 10px 6px 30px;font-size:13px;transition:border-color .15s}.sidebar-search input::placeholder{color:var(--sidebar-text)}.sidebar-search input:focus{border-color:var(--green)}.sidebar-search-icon{color:var(--sidebar-text);pointer-events:none;font-size:12px;position:absolute;top:50%;left:22px;transform:translateY(-50%)}.search-dropdown{z-index:200;background:#1e2029;border:1px solid #ffffff26;border-radius:6px;max-height:300px;position:absolute;top:calc(100% - 4px);left:12px;right:12px;overflow-y:auto;box-shadow:0 8px 24px #00000080}.search-group-label{color:var(--sidebar-text);text-transform:uppercase;letter-spacing:.5px;padding:8px 12px 4px;font-size:11px;font-weight:600}.search-result-item{cursor:pointer;color:#e0e0e0;align-items:center;gap:8px;padding:8px 12px;font-size:13px;transition:background .1s;display:flex}.search-result-item:hover{background:#ffffff14}.sidebar-nav{flex:1;padding:8px 0;overflow-y:auto}.nav-item{color:var(--sidebar-text);cursor:pointer;-webkit-user-select:none;user-select:none;border-left:3px solid #0000;align-items:center;gap:10px;padding:8px 16px;font-size:14px;text-decoration:none;transition:background .12s,color .12s;display:flex}.nav-item:hover{background:var(--sidebar-hover-bg);color:#d0d4db;text-decoration:none}.nav-item.active{background:var(--sidebar-active-bg);color:var(--sidebar-active-text);border-left-color:var(--green)}.nav-item svg{flex-shrink:0;width:18px;height:18px}.sidebar-user{border-top:1px solid #ffffff14;align-items:center;gap:10px;padding:12px 16px;display:flex}.user-avatar{color:#fff;background:#4a90e2;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:12px;font-weight:600;display:flex}.user-name{color:var(--sidebar-text);white-space:nowrap;text-overflow:ellipsis;font-size:13px;overflow:hidden}.main-content{background:var(--content-bg);flex-direction:column;flex:1;display:flex;overflow-y:auto}.page-header{border-bottom:1px solid var(--border);background:var(--content-bg);justify-content:space-between;align-items:center;padding:20px 24px 16px;display:flex}.page-title{color:var(--text-primary);align-items:center;gap:8px;font-size:20px;font-weight:600;display:flex}.btn{border:1px solid var(--border);background:var(--content-bg);color:var(--text-primary);cursor:pointer;white-space:nowrap;border-radius:6px;align-items:center;gap:6px;padding:6px 14px;font-size:13px;font-weight:500;transition:background .15s,border-color .15s,opacity .15s;display:inline-flex}.btn:hover{background:var(--content-secondary-bg)}.btn-primary{background:var(--green);color:#fff;border-color:var(--green)}.btn-primary:hover{background:var(--green-dark);border-color:var(--green-dark)}.btn-danger{background:var(--red);color:#fff;border-color:var(--red)}.btn-danger:hover{opacity:.9}.btn-ghost{color:var(--text-secondary);background:0 0;border-color:#0000;padding:4px 8px}.btn-ghost:hover{background:var(--content-secondary-bg);color:var(--text-primary)}.btn-icon{border:1px solid var(--border);background:var(--content-bg);width:30px;height:30px;color:var(--text-secondary);cursor:pointer;border-radius:6px;justify-content:center;align-items:center;padding:0;transition:background .15s;display:inline-flex}.btn-icon:hover{background:var(--content-secondary-bg);color:var(--text-primary)}.badge{white-space:nowrap;border-radius:12px;align-items:center;gap:4px;padding:3px 10px;font-size:12px;font-weight:600;display:inline-flex}.badge-success{color:#15803d;background:#dcfce7}.badge-failed{color:#b91c1c;background:#fee2e2}.badge-running{color:#1d4ed8;background:#dbeafe}.badge-queued,.badge-on_hold{color:#92400e;background:#fef9c3}.badge-canceled,.badge-blocked{color:#4b5563;background:#f3f4f6}.badge-not_run{color:#9ca3af;background:#f3f4f6}.badge-needs_approval{color:#7e22ce;background:#f3e8ff}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.spin{animation:1s linear infinite spin}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.pulse{animation:2s ease-in-out infinite pulse}.filter-bar{background:var(--content-bg);border-bottom:1px solid var(--border);flex-wrap:wrap;align-items:center;gap:10px;padding:12px 24px;display:flex}.filter-select{border:1px solid var(--border);background:var(--content-bg);color:var(--text-primary);cursor:pointer;white-space:nowrap;border-radius:6px;align-items:center;gap:6px;padding:6px 10px;font-size:13px;display:inline-flex}.filter-select:hover{background:var(--content-secondary-bg)}.filter-select select{color:inherit;font-size:inherit;cursor:pointer;background:0 0;border:none;outline:none}.pipeline-list{padding:0}.pipeline-row{border-bottom:1px solid var(--border);cursor:pointer;grid-template-columns:220px 200px 180px 1fr 140px;align-items:center;gap:8px;padding:12px 24px;transition:background .12s;display:grid}.pipeline-row:hover{background:var(--content-secondary-bg)}.pipeline-header-row{background:var(--content-secondary-bg);border-bottom:1px solid var(--border);color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;grid-template-columns:220px 200px 180px 1fr 140px;gap:8px;padding:8px 24px;font-size:12px;font-weight:600;display:grid}.pipeline-project-name{color:var(--link);font-size:13px;font-weight:600}.pipeline-number{color:var(--text-secondary);font-size:12px}.workflow-name{color:var(--link);font-size:13px}.trigger-info{flex-direction:column;gap:2px;display:flex}.branch-label{background:var(--content-secondary-bg);border:1px solid var(--border);color:var(--text-secondary);text-overflow:ellipsis;white-space:nowrap;border-radius:12px;align-items:center;gap:4px;max-width:160px;padding:1px 8px;font-size:11px;display:inline-flex;overflow:hidden}.commit-msg{color:var(--text-secondary);text-overflow:ellipsis;white-space:nowrap;max-width:280px;font-size:12px;overflow:hidden}.trigger-user{color:var(--text-secondary);align-items:center;gap:6px;font-size:12px;display:flex}.user-avatar-sm{color:#fff;background:#4a90e2;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:20px;height:20px;font-size:9px;font-weight:700;display:flex}.pipeline-actions{justify-content:flex-end;align-items:center;gap:4px;display:flex}.breadcrumb{color:var(--text-secondary);border-bottom:1px solid var(--border);background:var(--content-bg);flex-wrap:wrap;align-items:center;gap:6px;padding:12px 24px;font-size:13px;display:flex}.breadcrumb a{color:var(--link)}.breadcrumb a:hover{text-decoration:underline}.breadcrumb-sep{color:var(--border);font-size:12px}.breadcrumb-current{color:var(--text-primary);font-weight:500}.pipeline-meta{border-bottom:1px solid var(--border);background:var(--content-secondary-bg);padding:16px 24px}.pipeline-meta-row{flex-wrap:wrap;align-items:center;gap:20px;display:flex}.meta-item{color:var(--text-secondary);align-items:center;gap:6px;font-size:13px;display:flex}.commit-hash{font-family:var(--mono);background:var(--content-secondary-bg);border:1px solid var(--border);border-radius:4px;padding:2px 6px;font-size:12px}.workflow-map{background:var(--content-secondary-bg);border-bottom:1px solid var(--border);padding:24px;overflow-x:auto}.dag-container{align-items:flex-start;gap:48px;min-width:max-content;display:flex}.dag-column{flex-direction:column;align-items:center;gap:12px;display:flex}.dag-node{border:2px solid var(--border);background:var(--content-bg);cursor:pointer;border-radius:8px;flex-direction:column;gap:4px;width:130px;min-height:52px;padding:8px 10px;transition:border-color .15s,box-shadow .15s;display:flex;position:relative}.dag-node:hover{box-shadow:0 2px 8px #0000001f}.dag-node.success{border-color:#04aa51}.dag-node.failed{border-color:var(--red)}.dag-node.running{border-color:var(--blue)}.dag-node.on_hold{border-color:var(--amber)}.dag-node.blocked{border-color:var(--border);opacity:.7}.dag-node.not_run{border-color:var(--border);opacity:.5}.dag-node.canceled{border-color:var(--gray);opacity:.6}.dag-node.approval{border-color:var(--purple);border-style:dashed}.dag-node-name{color:var(--text-primary);text-overflow:ellipsis;white-space:nowrap;font-size:12px;font-weight:600;overflow:hidden}.dag-node-status{align-items:center;gap:4px;font-size:11px;display:flex}.dag-node-duration{color:var(--text-secondary);font-size:11px}.dag-connector{color:var(--border);align-self:center;align-items:center;padding:0 4px;font-size:18px;display:flex}.jobs-table{border-collapse:collapse;width:100%}.jobs-table th{text-align:left;background:var(--content-secondary-bg);color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid var(--border);padding:10px 24px;font-size:12px;font-weight:600}.jobs-table td{border-bottom:1px solid var(--border);vertical-align:middle;padding:10px 24px;font-size:13px}.jobs-table tr:hover td{background:var(--content-secondary-bg)}.tab-bar{border-bottom:1px solid var(--border);background:var(--content-bg);align-items:center;padding:0 24px;display:flex}.tab{color:var(--text-secondary);cursor:pointer;white-space:nowrap;border-bottom:2px solid #0000;margin-bottom:-1px;padding:12px 16px;font-size:14px;transition:color .15s,border-color .15s}.tab:hover{color:var(--text-primary)}.tab.active{color:var(--green);border-bottom-color:var(--green);font-weight:500}.terminal{font-family:var(--mono);color:#d4d4d4;background:#1e1e1e;border-radius:6px;padding:12px;font-size:12px;line-height:1.6;overflow-x:auto}.terminal-line{gap:12px;padding:1px 0;display:flex}.terminal-line:hover{background:#ffffff0a}.terminal-line-number{color:#555;text-align:right;-webkit-user-select:none;user-select:none;flex-shrink:0;min-width:32px}.terminal-line-text{white-space:pre-wrap;word-break:break-all;flex:1}.terminal-line-text.error{color:#f48771}.terminal-line-text.success{color:#6a9955}.step-list{flex-direction:column;gap:8px;padding:16px 24px;display:flex}.step-item{border:1px solid var(--border);border-radius:6px;overflow:hidden}.step-header{background:var(--content-secondary-bg);cursor:pointer;align-items:center;gap:10px;padding:10px 14px;transition:background .12s;display:flex}.step-header:hover{background:#eff0f2}.step-item.failed .step-header{border-left:3px solid var(--red)}.step-item.success .step-header{border-left:3px solid var(--green)}.step-name{color:var(--text-primary);flex:1;font-size:13px;font-weight:500}.step-duration{color:var(--text-secondary);font-size:12px}.terminal-search{background:#2d2d2d;border-top:1px solid #444;align-items:center;gap:8px;padding:8px 12px;display:flex}.terminal-search input{color:#d4d4d4;font-family:var(--mono);background:#1e1e1e;border:1px solid #555;border-radius:4px;outline:none;flex:1;padding:4px 8px;font-size:12px}.terminal-search input:focus{border-color:#888}.projects-list{flex-direction:column;gap:8px;padding:16px 24px;display:flex}.project-card{border:1px solid var(--border);background:var(--content-bg);border-radius:8px;align-items:center;gap:16px;padding:14px 18px;transition:box-shadow .15s;display:flex}.project-card:hover{box-shadow:0 2px 8px #00000014}.project-vcs-icon{background:var(--content-secondary-bg);border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;display:flex}.project-info{flex:1;min-width:0}.project-name{color:var(--link);cursor:pointer;font-size:15px;font-weight:600}.project-name:hover{text-decoration:underline}.project-url{color:var(--text-secondary);text-overflow:ellipsis;white-space:nowrap;font-size:12px;overflow:hidden}.insights-time-range{border-bottom:1px solid var(--border);align-items:center;gap:4px;padding:12px 24px;display:flex}.time-range-btn{border:1px solid var(--border);background:var(--content-bg);color:var(--text-secondary);cursor:pointer;border-radius:6px;padding:5px 12px;font-size:13px;transition:all .15s}.time-range-btn:hover{background:var(--content-secondary-bg)}.time-range-btn.active{background:var(--text-primary);color:#fff;border-color:var(--text-primary)}.insight-cards{grid-template-columns:repeat(4,1fr);gap:16px;padding:20px 24px;display:grid}.insight-card{background:var(--content-bg);border:1px solid var(--border);border-radius:8px;padding:18px}.insight-card-label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px;font-size:12px;font-weight:500}.insight-card-value{color:var(--text-primary);margin-bottom:6px;font-size:28px;font-weight:700;line-height:1}.insight-trend{align-items:center;gap:4px;font-size:12px;display:flex}.insight-trend.up{color:var(--green)}.insight-trend.down{color:var(--red)}.data-table{border-collapse:collapse;width:100%}.data-table th{text-align:left;background:var(--content-secondary-bg);color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid var(--border);cursor:pointer;-webkit-user-select:none;user-select:none;white-space:nowrap;padding:10px 24px;font-size:12px;font-weight:600}.data-table th:hover{color:var(--text-primary)}.data-table td{border-bottom:1px solid var(--border);vertical-align:middle;padding:10px 24px;font-size:13px}.data-table tr:hover td{background:var(--content-secondary-bg)}.rate-bar{align-items:center;gap:8px;display:flex}.rate-bar-track{background:#e0e0e0;border-radius:2px;flex:1;min-width:60px;height:4px;overflow:hidden}.rate-bar-fill{border-radius:2px;height:100%}.settings-layout{height:100%;display:flex}.settings-sidebar{border-right:1px solid var(--border);flex-shrink:0;width:200px;padding:16px 0}.settings-tab{color:var(--text-secondary);cursor:pointer;border-radius:6px;margin:0 8px 2px;padding:8px 16px;font-size:14px;text-decoration:none;transition:background .12s,color .12s;display:block}.settings-tab:hover{background:var(--content-secondary-bg);color:var(--text-primary);text-decoration:none}.settings-tab.active{background:var(--content-secondary-bg);color:var(--text-primary);font-weight:500}.settings-content{flex:1;padding:24px;overflow-y:auto}.modal-overlay{z-index:1000;background:#00000080;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal{background:var(--content-bg);border-radius:10px;width:420px;max-width:90vw;padding:24px;box-shadow:0 20px 60px #0003}.modal-title{margin-bottom:16px;font-size:18px;font-weight:600}.confirm-modal{width:440px}.confirm-message{color:var(--text-secondary);margin-bottom:4px;font-size:14px;line-height:1.5}.notice-card{border:1px solid var(--border);background:var(--content-secondary-bg);color:var(--text-secondary);border-radius:6px;margin-top:12px;padding:10px 12px;font-size:13px}.form-field{margin-bottom:14px}.form-field label{color:var(--text-primary);margin-bottom:5px;font-size:13px;font-weight:500;display:block}.form-field input,.form-field select{border:1px solid var(--border);border-radius:6px;outline:none;width:100%;padding:8px 10px;font-size:13px;transition:border-color .15s}.form-field input:focus,.form-field select:focus{border-color:var(--blue)}.modal-actions{justify-content:flex-end;gap:8px;margin-top:20px;display:flex}.env-table{border-collapse:collapse;width:100%}.env-table th{text-align:left;background:var(--content-secondary-bg);color:var(--text-secondary);border-bottom:1px solid var(--border);padding:8px 12px;font-size:12px;font-weight:600}.env-table td{border-bottom:1px solid var(--border);padding:10px 12px;font-size:13px}.env-table tr:hover td{background:var(--content-secondary-bg)}.toggle-row{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:14px 0;display:flex}.toggle-row:last-child{border-bottom:none}.toggle-label{color:var(--text-primary);font-size:14px}.toggle-desc{color:var(--text-secondary);margin-top:2px;font-size:12px}.toggle{flex-shrink:0;width:40px;height:22px;position:relative}.toggle input{opacity:0;width:0;height:0}.toggle-slider{cursor:pointer;background:#ccc;border-radius:22px;transition:background .2s;position:absolute;inset:0}.toggle-slider:before{content:"";background:#fff;border-radius:50%;width:16px;height:16px;transition:transform .2s;position:absolute;top:3px;left:3px}.toggle input:checked+.toggle-slider{background:var(--green)}.toggle input:checked+.toggle-slider:before{transform:translate(18px)}.toggle-switch{background:#ccc;border:0;border-radius:22px;flex-shrink:0;justify-content:flex-start;align-items:center;width:40px;height:22px;padding:3px;transition:background .2s;display:inline-flex}.toggle-switch.checked{background:var(--green);justify-content:flex-end}.toggle-switch:focus-visible{outline:2px solid var(--blue);outline-offset:2px}.toggle-switch-thumb{background:#fff;border-radius:50%;width:16px;height:16px;box-shadow:0 1px 2px #00000026}.timing-chart{padding:20px 24px}.timing-bar-row{align-items:center;gap:12px;margin-bottom:8px;display:flex}.timing-bar-label{width:200px;color:var(--text-secondary);text-align:right;text-overflow:ellipsis;white-space:nowrap;font-size:12px;overflow:hidden}.timing-bar-track{background:var(--content-secondary-bg);border-radius:4px;flex:1;height:24px;position:relative;overflow:hidden}.timing-bar-fill{background:var(--green);border-radius:4px;min-width:4px;height:100%;transition:width .3s}.timing-bar-fill.running{background:var(--blue)}.timing-bar-fill.failed{background:var(--red)}.timing-bar-duration{width:60px;color:var(--text-secondary);font-size:12px}.runners-section{padding:20px 24px}.runners-section h3{margin-bottom:12px;font-size:16px;font-weight:600}.deploy-env-grid{grid-template-columns:repeat(3,1fr);gap:16px;padding:20px 24px;display:grid}.deploy-env-card{border:1px solid var(--border);border-radius:8px;padding:18px}.deploy-env-name{margin-bottom:12px;font-size:16px;font-weight:600}.plan-header{color:#fff;background:linear-gradient(135deg,#0d0e12,#1c1e26);padding:24px}.plan-name{font-size:24px;font-weight:700}.credit-bar{background:var(--border);border-radius:4px;height:8px;margin:8px 0;overflow:hidden}.credit-bar-fill{background:var(--green);border-radius:4px;height:100%}.empty-state{color:var(--text-secondary);text-align:center;flex-direction:column;justify-content:center;align-items:center;padding:48px 24px;display:flex}.empty-state-title{color:var(--text-primary);margin-bottom:6px;font-size:16px;font-weight:600}.empty-state-desc{font-size:13px}.text-link{color:var(--link);cursor:pointer}.text-link:hover{text-decoration:underline}.link-button{color:var(--link);cursor:pointer;font:inherit;background:0 0;border:0}.link-button:hover{text-decoration:underline}.text-muted{color:var(--text-secondary)}.text-mono{font-family:var(--mono);font-size:12px}.flex{display:flex}.flex-1{flex:1}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-8{gap:8px}.gap-4{gap:4px}.mt-4{margin-top:4px}.mt-8{margin-top:8px}.mt-16{margin-top:16px}.section-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:16px 24px;display:flex}.section-title{font-size:15px;font-weight:600}.vcs-github{color:#24292f}.vcs-gitlab{color:#fc6d26}.vcs-bitbucket{color:#0052cc}.duration{color:var(--text-secondary);font-variant-numeric:tabular-nums;font-size:12px}.content-body{padding:20px 24px}
