@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600&family=JetBrains+Mono:wght@400;500&display=swap";*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{background:#06060b;color:#e2e8f0;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;min-height:100vh}.mono{font-family:JetBrains Mono,monospace}.app-shell{min-height:100vh;position:relative;overflow:hidden;background:radial-gradient(ellipse 80% 50% at 50% -20%,rgba(167,139,250,.06) 0%,transparent 60%),radial-gradient(ellipse 60% 40% at 80% 110%,rgba(96,165,250,.04) 0%,transparent 50%),radial-gradient(ellipse 50% 30% at 10% 90%,rgba(74,222,128,.04) 0%,transparent 50%),#06060b}.app-shell:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;background-image:radial-gradient(rgba(255,255,255,.03) 1px,transparent 1px);background-size:24px 24px;pointer-events:none;z-index:0}.app-shell:after{content:"";position:fixed;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,#a78bfa,rgba(96,165,250,.6),transparent);z-index:100}.top-nav{position:sticky;top:0;z-index:50;display:flex;align-items:center;justify-content:space-between;padding:12px 40px;background:#06060bcc;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-bottom:1px solid rgba(30,30,46,.6)}.nav-brand{display:flex;align-items:center;gap:10px}.nav-logo{width:28px;height:28px;border-radius:8px;background:linear-gradient(135deg,#3730a3,#a78bfa);display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;color:#06060b}.nav-name{font-size:14px;font-weight:600;color:#e2e8f0;letter-spacing:-.01em}.nav-name span{color:#a78bfa}.nav-links{display:flex;align-items:center;gap:6px}.nav-link{font-size:11px;color:#64748b;padding:5px 12px;border-radius:6px;text-decoration:none;transition:all .2s;font-weight:500}.nav-link:hover{color:#e2e8f0;background:#ffffff0a}.nav-link.active{color:#a78bfa;background:#a78bfa14}.nav-env{font-size:10px;font-family:JetBrains Mono,monospace;color:#475569;padding:3px 8px;border-radius:4px;border:1px solid #1e1e2e;background:#0f0f1a99}.nav-env .env-dot{display:inline-block;width:5px;height:5px;border-radius:50%;background:#4ade80;margin-right:5px;animation:pulse 1.5s infinite}.dashboard-page{position:relative;z-index:1;max-width:1440px;width:100%;margin:0 auto;padding:28px 40px 40px;display:flex;flex-direction:column;gap:16px}.loading-state,.error-state{display:flex;align-items:center;justify-content:center;gap:10px;min-height:300px;font-size:14px;color:#64748b}.error-state button{background:#1e1e2e;color:#e2e8f0;border:1px solid #333;padding:6px 16px;border-radius:6px;cursor:pointer;font-size:12px}.error-state button:hover{background:#2a2a3e}.phase-header{border-radius:14px;padding:18px 22px;display:flex;align-items:center;justify-content:space-between;box-shadow:0 2px 12px #3730a31a}.phase-title{font-size:14px;font-weight:600}.phase-sub{font-size:11px;margin-top:3px}.header-badge{font-size:10px;padding:2px 8px;border-radius:10px;font-weight:500;background:#0a0a0f;border:1px solid #3730a3;white-space:nowrap}.panel{background:#0f0f1ab3;border:1px solid rgba(30,30,46,.8);border-radius:14px;padding:18px;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);box-shadow:0 2px 8px #0000004d,0 0 1px #ffffff08 inset;transition:border-color .3s,box-shadow .3s}.panel:hover{border-color:#323246e6;box-shadow:0 4px 16px #0006,0 0 1px #ffffff0d inset}.panel-title{font-size:11px;font-weight:500;color:#64748b;text-transform:uppercase;letter-spacing:.08em;margin-bottom:14px}.grid2{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.grid3{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}.grid4{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px}.right-col{display:flex;flex-direction:column;gap:12px}.live-dot{width:6px;height:6px;border-radius:50%;background:#4ade80;display:inline-block;margin-right:4px;animation:pulse 1.5s infinite;flex-shrink:0}@keyframes pulse{0%,to{opacity:1}50%{opacity:.3}}.metric-card{background:#13131fcc;border:1px solid rgba(30,30,46,.6);border-radius:10px;padding:14px;position:relative;overflow:hidden;transition:border-color .2s,transform .2s,box-shadow .2s}.metric-card:hover{border-color:#323246cc;transform:translateY(-1px);box-shadow:0 4px 12px #0000004d}.metric-card:before{content:"";position:absolute;top:0;left:0;right:0;height:2px}.metric-card.blue:before{background:linear-gradient(90deg,#3b82f6,#60a5fa)}.metric-card.purple:before{background:linear-gradient(90deg,#8b5cf6,#a78bfa)}.metric-card.green:before{background:linear-gradient(90deg,#10b981,#4ade80)}.metric-card.amber:before{background:linear-gradient(90deg,#f59e0b,#fbbf24)}.metric-card.red:before{background:linear-gradient(90deg,#ef4444,#f87171)}.metric-label{font-size:10px;color:#475569;text-transform:uppercase;letter-spacing:.07em;margin-bottom:4px}.metric-value{font-size:22px;font-weight:600;color:#f1f5f9;font-family:JetBrains Mono,monospace}.metric-sub{font-size:10px;color:#64748b;margin-top:3px}.nodes-list{display:flex;flex-direction:column;gap:8px}.node-card{background:#13131f99;border:1px solid rgba(30,30,46,.6);border-radius:10px;padding:12px;transition:border-color .2s}.node-card:hover{border-color:#323246cc}.node-card.ready{border-left:3px solid #4ade80}.node-card.notready{border-left:3px solid #ef4444}.node-name{font-size:12px;font-weight:500;font-family:JetBrains Mono,monospace;margin-bottom:8px}.node-status-text{font-weight:400;font-size:10px;color:#ef4444}.node-bars{display:flex;flex-direction:column;gap:5px}.bar-row{display:flex;align-items:center;gap:6px}.bar-label{font-size:9px;color:#475569;width:30px;font-family:JetBrains Mono,monospace;flex-shrink:0}.bar-track{flex:1;height:4px;background:#1e2e3e;border-radius:2px;overflow:hidden}.bar-fill{height:4px;border-radius:2px;transition:width .5s ease}.bar-val{font-size:9px;font-family:JetBrains Mono,monospace;width:28px;text-align:right;flex-shrink:0}.node-meta{display:flex;gap:12px;font-size:9px;color:#475569;font-family:JetBrains Mono,monospace;margin-top:6px;padding-top:6px;border-top:1px solid rgba(30,30,46,.4)}.node-offline-info{font-size:10px;color:#475569}.swimlane{margin-bottom:12px}.swimlane:last-child{margin-bottom:0}.sw-header{display:flex;align-items:center;gap:8px;margin-bottom:6px}.sw-stripe{width:8px;height:8px;border-radius:2px;flex-shrink:0}.sw-name{font-size:11px;font-weight:500;font-family:JetBrains Mono,monospace}.sw-count{font-size:10px;color:#475569}.pods-row{display:flex;flex-wrap:wrap;gap:4px}.pod-chip{font-size:9px;padding:3px 8px;border-radius:6px;font-family:JetBrains Mono,monospace;transition:transform .15s}.pod-chip:hover{transform:scale(1.03)}.heatmap-container{display:flex;flex-direction:column;gap:8px}.heatmap-grid{display:grid;grid-template-columns:repeat(9,1fr);gap:3px}.hm-cell{height:24px;border-radius:3px;cursor:pointer;transition:transform .15s}.hm-cell:hover{transform:scale(1.15)}.heatmap-legend{display:flex;gap:12px}.legend-item{display:flex;align-items:center;gap:4px;font-size:10px;color:#64748b}.legend-dot{width:8px;height:8px;border-radius:2px;display:inline-block}.pipeline-meta{font-size:11px;color:#94a3b8;margin-bottom:4px}.pipeline-service{font-weight:500;color:#e2e8f0}.pipeline-info{color:#64748b}.pipeline-trigger{font-size:10px;color:#475569;margin-bottom:12px}.pipeline-stages{display:flex;align-items:center;gap:0}.p-stage{flex:1;text-align:center;padding:10px 6px;border-radius:8px;border:1px solid transparent;transition:transform .2s}.p-stage:hover{transform:translateY(-1px)}.p-name{font-size:10px;font-weight:500}.p-time{font-size:9px;font-family:JetBrains Mono,monospace;margin-top:2px}.p-arrow{color:#1e3a5f;font-size:12px;padding:0 4px;flex-shrink:0}.events-list{display:flex;flex-direction:column}.event-item{display:flex;gap:8px;padding:8px 0;border-bottom:1px solid rgba(30,30,46,.6);align-items:flex-start}.event-item:last-child{border-bottom:none}.ev-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0;margin-top:5px}.ev-time{font-size:10px;color:#475569;font-family:JetBrains Mono,monospace;min-width:52px;flex-shrink:0}.ev-text{font-size:11px;color:#94a3b8;line-height:1.5}.ev-resource{color:#a78bfa;font-weight:500}.page-footer{position:relative;z-index:1;max-width:1440px;width:100%;margin:0 auto;padding:20px 40px 32px;border-top:1px solid #1e1e2e}.footer-inner{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap}.footer-left{font-size:11px;color:#334155;font-family:JetBrains Mono,monospace}.footer-left a{color:#475569;text-decoration:none;transition:color .2s}.footer-left a:hover{color:#a78bfa}.footer-center{display:flex;align-items:center;gap:16px}.footer-tag{font-size:9px;color:#334155;padding:3px 8px;border:1px solid #1a1a2e;border-radius:4px;font-family:JetBrains Mono,monospace;letter-spacing:.04em;text-transform:uppercase}.footer-right{font-size:10px;color:#334155;font-family:JetBrains Mono,monospace}@media (max-width: 1024px){.grid4{grid-template-columns:repeat(2,1fr)}.heatmap-grid{grid-template-columns:repeat(6,1fr)}}@media (max-width: 768px){.top-nav{padding:10px 16px}.nav-links{display:none}.dashboard-page{padding:16px 16px 24px;gap:12px}.page-footer{padding:16px 16px 20px}.footer-inner{flex-direction:column;align-items:flex-start;gap:8px}.grid2,.grid3,.grid4{grid-template-columns:1fr}.heatmap-grid{grid-template-columns:repeat(6,1fr)}.pipeline-stages{flex-wrap:wrap;gap:4px}.p-arrow{display:none}.phase-header{flex-direction:column;gap:10px;align-items:flex-start}}@media (max-width: 480px){.metric-value{font-size:18px}.node-meta{flex-wrap:wrap;gap:6px}.heatmap-grid{grid-template-columns:repeat(4,1fr)}.pipeline-stages{flex-direction:column;gap:6px}}
