@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes spin{to{transform:rotate(360deg)}}*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg-base:#0d1117;--bg-primary:#0d1117;--bg-secondary:#161b22;--bg-card:#161b22;--bg-card-solid:#161b22;--bg-card-hover:#1c2128;--bg-elevated:#1c2128;--bg-glass:#161b22;--bg-inset:#010409;--border:#30363d;--border-light:#3d444d;--border-accent:#2f81f7;--text-primary:#e6edf3;--text-secondary:#7d8590;--text-muted:#484f58;--accent:#2f81f7;--accent-light:#58a6ff;--accent-glow:#2f81f726;--green:#3fb950;--green-bg:#3fb9501a;--green-glow:#3fb95026;--red:#f85149;--red-bg:#f851491a;--red-glow:#f8514926;--yellow:#d29922;--yellow-bg:#d299221f;--blue:#2f81f7;--blue-bg:#2f81f71a;--blue-glow:#2f81f726;--orange:#db6d28;--orange-bg:#db6d281f;--sidebar-width:260px;--header-height:56px;--radius:6px;--radius-sm:6px;--radius-xs:4px}html{scroll-behavior:smooth}body{background:var(--bg-base);color:var(--text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Noto Sans,Helvetica,Arial,sans-serif;font-size:14px;line-height:1.5}a{color:inherit;text-decoration:none}button{cursor:pointer;color:inherit;background:0 0;border:none;font-family:inherit}.app{background:var(--bg-base);min-height:100vh;display:flex}.sidebar{width:var(--sidebar-width);background:var(--bg-secondary);border-right:1px solid var(--border);z-index:10;flex-direction:column;height:100vh;display:flex;position:fixed;top:0;left:0}.sidebar-logo{border-bottom:1px solid var(--border);align-items:center;gap:12px;padding:16px 16px 14px;display:flex}.sidebar-logo-icon{background:var(--accent);border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;display:flex}.sidebar-logo h1{color:var(--text-primary);font-size:14px;font-weight:600;line-height:1.3}.sidebar-logo span{color:var(--text-muted);font-size:12px;display:block}.sidebar-section-label{color:var(--text-muted);padding:16px 16px 6px;font-size:12px;font-weight:600}.sidebar-nav{flex-direction:column;flex:1;gap:1px;padding:4px 8px;display:flex;overflow-y:auto}.sidebar-link{border-radius:var(--radius);color:var(--text-secondary);align-items:center;gap:10px;padding:8px 10px;font-size:13px;font-weight:500;transition:background .1s,color .1s;display:flex}.sidebar-link:hover{color:var(--text-primary);background:#ffffff0a}.sidebar-link.active{color:var(--text-primary);background:#2f81f714;font-weight:600}.sidebar-link.active:before{content:"";background:var(--accent);border-radius:0 2px 2px 0;width:3px;height:18px;position:absolute;top:50%;left:0;transform:translateY(-50%)}.sidebar-link svg{flex-shrink:0;width:16px;height:16px}.sidebar-footer{border-top:1px solid var(--border);padding:12px 16px}.sidebar-phase{color:var(--text-secondary);margin-bottom:8px;font-size:12px;font-weight:500}.sidebar-progress{background:var(--bg-inset);border-radius:2px;height:4px;overflow:hidden}.sidebar-progress-fill{background:var(--accent);border-radius:2px;height:100%;transition:width .4s}.main{margin-left:var(--sidebar-width);flex:1;min-height:100vh}.header{height:var(--header-height);border-bottom:1px solid var(--border);background:var(--bg-secondary);z-index:5;justify-content:space-between;align-items:center;padding:0 24px;display:flex;position:sticky;top:0}.header-title{font-size:16px;font-weight:600}.header-meta{align-items:center;gap:12px;display:flex}.header-status{color:var(--green);border:1px solid var(--border);background:0 0;border-radius:20px;align-items:center;gap:6px;padding:4px 10px;font-size:12px;font-weight:500;display:inline-flex}.header-status-dot{background:var(--green);border-radius:50%;width:6px;height:6px}.page{padding:24px;animation:.15s ease-out fadeIn}.grid{gap:16px;display:grid}.grid-4{grid-template-columns:repeat(4,1fr)}.grid-3{grid-template-columns:repeat(3,1fr)}.grid-2{grid-template-columns:repeat(2,1fr)}.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:16px;position:relative;overflow:hidden}.card:hover{border-color:var(--border-light)}.card-header{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.card-title{text-transform:uppercase;letter-spacing:.04em;color:var(--text-muted);font-size:12px;font-weight:500}.card-value{letter-spacing:-.02em;color:var(--text-primary);font-size:28px;font-weight:700;line-height:1.2}.stat-card{position:relative}.stat-card .stat-glow{display:none}.stat-icon{border-radius:var(--radius);justify-content:center;align-items:center;width:36px;height:36px;display:flex}.stat-icon svg{width:18px;height:18px}.badge{white-space:nowrap;border:1px solid #0000;border-radius:20px;align-items:center;gap:4px;padding:2px 8px;font-size:12px;font-weight:500;display:inline-flex}.badge-success{background:var(--green-bg);color:var(--green);border-color:#3fb95033}.badge-error{background:var(--red-bg);color:var(--red);border-color:#f8514933}.badge-warning{background:var(--yellow-bg);color:var(--yellow);border-color:#d2992233}.badge-info{background:var(--blue-bg);color:var(--blue);border-color:#2f81f733}.badge-neutral{color:var(--text-secondary);border-color:var(--border);background:#ffffff0a}.table-wrap{overflow-x:auto}table{border-collapse:collapse;width:100%}th{text-align:left;color:var(--text-secondary);border-bottom:1px solid var(--border);background:var(--bg-inset);padding:8px 12px;font-size:12px;font-weight:600}td{border-bottom:1px solid var(--border);vertical-align:middle;color:var(--text-primary);padding:10px 12px;font-size:13px}tr:last-child td{border-bottom:none}tr:hover td{background:#ffffff04}.section-title{margin-bottom:4px;font-size:20px;font-weight:600}.section-subtitle{color:var(--text-secondary);margin-bottom:20px;font-size:13px}.pipeline-stages{align-items:center;gap:2px;display:flex}.pipeline-stage{border-radius:var(--radius-xs);align-items:center;gap:4px;padding:3px 8px;font-size:11px;font-weight:600;display:flex}.pipeline-stage:hover{opacity:.85}.pipeline-stage-arrow{color:var(--text-muted);margin:0 1px;font-size:12px}.chart-container{width:100%;height:260px}.code-tag{background:var(--bg-inset);border:1px solid var(--border);border-radius:var(--radius-xs);padding:2px 8px;font-family:ui-monospace,SFMono-Regular,SF Mono,Menlo,Consolas,monospace;font-size:12px}.usage-bar-track{background:var(--bg-inset);border-radius:3px;width:100%;height:6px;overflow:hidden}.usage-bar-fill{border-radius:3px;height:100%;transition:width .4s}.runner-card:hover{border-color:var(--border-light)}.pipeline-item{transition:border-color .15s}.pipeline-item:hover{border-color:var(--border-light)}@media (width<=1400px){.grid-4{grid-template-columns:repeat(2,1fr)}}@media (width<=1100px){.grid-3{grid-template-columns:repeat(2,1fr)}}@media (width<=900px){.sidebar{display:none}.main{margin-left:0}.grid-4,.grid-3,.grid-2{grid-template-columns:1fr}.page{padding:16px}}
