:root{--bg: #0f1117;--surface: #1a1d27;--surface2: #232734;--border: #2e3346;--text: #e4e4e7;--text-muted: #9ca3af;--accent: #3b82f6;--success: #22c55e;--danger: #ef4444;--warning: #eab308;--radius: 8px}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--bg);color:var(--text);line-height:1.5}.mono{font-family:SF Mono,Fira Code,monospace;font-size:.85em}.token-screen{display:flex;align-items:center;justify-content:center;min-height:100vh}.token-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:2rem;width:100%;max-width:360px;text-align:center}.token-card h1{font-size:1.5rem;margin-bottom:.25rem}.token-card input{width:100%;padding:.6rem .8rem;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);font-size:.95rem;margin-bottom:.75rem}.token-card input:focus{outline:none;border-color:var(--accent)}.token-card button{width:100%;padding:.6rem;background:var(--accent);color:#fff;border:none;border-radius:var(--radius);cursor:pointer;font-size:.95rem;font-weight:500}.token-card button:disabled{opacity:.5;cursor:not-allowed}.subtitle{color:var(--text-muted);font-size:.9rem;margin-bottom:1.5rem}.otp-input{font-family:SF Mono,Fira Code,monospace;font-size:1.5rem!important;letter-spacing:.5em;text-align:center}.back-link{display:block;width:100%;background:transparent;border:none;color:var(--text-muted);font-size:.8rem;cursor:pointer;margin-top:.5rem;padding:.4rem}.back-link:hover{color:var(--text);text-decoration:underline}.error{color:var(--danger);margin-top:.5rem;font-size:.85rem}.dashboard{display:flex;flex-direction:column;min-height:100vh}header{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1.5rem;background:var(--surface);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:10}.header-left{display:flex;align-items:center;gap:.75rem}.header-left h1{font-size:1.1rem;white-space:nowrap}.badge{background:var(--success);color:#000;font-size:.65rem;font-weight:700;padding:.15rem .5rem;border-radius:99px;text-transform:uppercase;letter-spacing:.05em}nav{display:flex;gap:.25rem}nav button{padding:.4rem .9rem;background:transparent;color:var(--text-muted);border:1px solid transparent;border-radius:var(--radius);cursor:pointer;font-size:.85rem}nav button:hover{color:var(--text);background:var(--surface2)}nav button.active{background:var(--surface2);color:var(--text);border-color:var(--border)}.user-info{display:flex;align-items:center;gap:.5rem}.user-role{font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;padding:.15rem .5rem;border-radius:99px;background:var(--surface2);border:1px solid var(--border);color:var(--text-muted)}.user-email{font-size:.8rem;color:var(--text-muted)}.logout-btn{padding:.25rem .5rem;background:transparent;color:var(--text-muted);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;font-size:.7rem}.logout-btn:hover{color:var(--danger);border-color:var(--danger)}main{padding:1.5rem;max-width:1200px;margin:0 auto;width:100%}.filters{display:flex;gap:.5rem;margin-bottom:1rem;align-items:center;flex-wrap:wrap}.filters select,.filters input{padding:.4rem .6rem;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);font-size:.85rem}.filters input{flex:1;min-width:150px}.filters input:focus,.filters select:focus{outline:none;border-color:var(--accent)}.refresh-indicator{margin-left:auto;font-size:.75rem;color:var(--text-muted)}table{width:100%;border-collapse:collapse}th,td{padding:.6rem .75rem;text-align:left;border-bottom:1px solid var(--border);font-size:.85rem}th{color:var(--text-muted);font-weight:500;font-size:.75rem;text-transform:uppercase;letter-spacing:.04em}tr.clickable{cursor:pointer}tr.clickable:hover{background:var(--surface2)}.empty{text-align:center;color:var(--text-muted);padding:2rem!important}.status-badge{display:inline-block;padding:.15rem .5rem;border-radius:99px;font-size:.7rem;font-weight:600;color:#fff;text-transform:uppercase;letter-spacing:.03em;white-space:nowrap}.back-btn{padding:.35rem .7rem;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);cursor:pointer;font-size:.85rem;margin-bottom:1rem}.back-btn:hover{background:var(--surface2)}.run-header h2{display:flex;align-items:center;gap:.75rem;font-size:1.1rem}.pipeline-name{font-weight:400;color:var(--text-muted)}.run-meta{display:flex;gap:1.5rem;margin:.75rem 0 1.5rem;font-size:.8rem;color:var(--text-muted)}.cost-summary-bar{display:flex;align-items:center;gap:.75rem;padding:.6rem 1rem;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);font-size:.85rem;margin-top:.75rem}.cost-separator{color:var(--border)}.cost-green{color:var(--success);font-weight:600}.cost-yellow{color:var(--warning);font-weight:600}.cost-red{color:var(--danger);font-weight:600}.cost-cell{text-align:right;font-family:SF Mono,Fira Code,monospace;font-size:.85em}.node-usage{display:flex;flex-wrap:wrap;gap:.75rem;font-size:.7rem;color:var(--text-muted);margin-top:.4rem;padding-top:.4rem;border-top:1px solid var(--border)}.nodes-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:.75rem;margin-top:.75rem}.node-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:.75rem;border-left:3px solid var(--border)}.node-card.status-success{border-left-color:var(--success)}.node-card.status-failed{border-left-color:var(--danger)}.node-card.status-running{border-left-color:var(--accent)}.node-card.status-waiting_approval{border-left-color:var(--warning)}.node-card.status-blocked{border-left-color:#f97316}.node-card.status-queued{border-left-color:#8b5cf6}.node-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.4rem}.node-name{font-weight:500;font-size:.85rem}.node-meta{display:flex;flex-wrap:wrap;gap:.75rem;font-size:.75rem;color:var(--text-muted)}.reason{color:var(--warning);font-style:italic}.approval-actions{display:flex;gap:.5rem;margin-top:.5rem}.approve-btn,.reject-btn{flex:1;padding:.4rem;border:none;border-radius:var(--radius);cursor:pointer;font-size:.8rem;font-weight:600}.approve-btn{background:var(--success);color:#000}.approve-btn:hover{opacity:.9}.reject-btn{background:var(--danger);color:#fff}.reject-btn:hover{opacity:.9}.approve-btn:disabled,.reject-btn:disabled{opacity:.4;cursor:not-allowed}.locks-list h2{margin-bottom:1rem}.empty-state{text-align:center;color:var(--text-muted);padding:3rem;background:var(--surface);border-radius:var(--radius);border:1px dashed var(--border)}.projects-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:.75rem;margin-top:1rem}.project-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1rem}.project-card h3{font-size:1rem;margin-bottom:.25rem}.project-card .meta{display:block;font-size:.8rem;color:var(--text-muted)}.active-run-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1rem;margin-bottom:1.5rem}.active-run-card h3{display:flex;align-items:center;gap:.75rem;margin-bottom:.75rem}.queue-badge{font-size:.75rem;background:var(--accent);color:#fff;padding:.15rem .5rem;border-radius:99px;font-weight:500}.run-info{display:flex;align-items:center;gap:.75rem;margin-bottom:.75rem;font-size:.85rem}.progress-bar{display:flex;height:8px;border-radius:4px;overflow:hidden;background:var(--surface2);margin-bottom:.75rem}.progress-segment{flex:1}.progress-segment.status-success{background:var(--success)}.progress-segment.status-failed{background:var(--danger)}.progress-segment.status-running{background:var(--accent)}.progress-segment.status-pending{background:var(--surface2)}.progress-segment.status-queued{background:#8b5cf6}.progress-segment.status-blocked{background:#f97316}.progress-segment.status-waiting_approval{background:var(--warning)}.progress-segment.status-skipped{background:#6b7280}.node-list-compact{display:flex;flex-wrap:wrap;gap:.4rem}.node-compact{display:flex;align-items:center;gap:.35rem;font-size:.8rem}.loading{text-align:center;padding:3rem;color:var(--text-muted)}.error-banner{background:#ef44441a;border:1px solid var(--danger);color:var(--danger);padding:.6rem 1rem;border-radius:var(--radius);margin-bottom:1rem;font-size:.85rem}@media(max-width:768px){header{flex-wrap:wrap;gap:.5rem;padding:.5rem 1rem}.header-left h1{font-size:.95rem}nav button{padding:.3rem .6rem;font-size:.8rem}main{padding:1rem}.nodes-grid{grid-template-columns:1fr}.filters{flex-direction:column}.filters input{min-width:100%}.run-meta{flex-wrap:wrap;gap:.75rem}th,td{padding:.4rem .5rem;font-size:.8rem}}@media(max-width:480px){.projects-grid{grid-template-columns:1fr}.run-header h2{flex-wrap:wrap;font-size:.95rem}}
