:root{--bg:#0f1117;--bg-card:#1a1b23;--bg-hover:#22232d;--border:#2e303a;--text:#9ca3af;--text-h:#f3f4f6;--accent:#6366f1;--accent-light:#818cf8;--green:#22c55e;--red:#ef4444;--yellow:#eab308;--mono:ui-monospace, Consolas, monospace;--sans:system-ui, -apple-system, sans-serif}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--sans);color:var(--text);background:var(--bg);font-size:14px;line-height:1.5}.app{flex-direction:column;min-height:100vh;display:flex}.header{border-bottom:1px solid var(--border);background:var(--bg-card);justify-content:space-between;align-items:center;padding:16px 24px;display:flex}.header h1{color:var(--text-h);letter-spacing:-.3px;font-size:18px;font-weight:600}.main{flex:1;display:flex}.sidebar{border-right:1px solid var(--border);flex-direction:column;width:320px;display:flex;overflow-y:auto}.content{flex:1;padding:24px;overflow-y:auto}.empty-state{height:100%;color:var(--text);justify-content:center;align-items:center;font-size:15px;display:flex}.health-bar{font-size:13px;font-family:var(--mono);align-items:center;gap:8px;display:flex}.health-dot{background:var(--green);border-radius:50%;width:8px;height:8px}.health-dot.error{background:var(--red)}.health-dot.loading{background:var(--yellow)}.launcher{border-bottom:1px solid var(--border);padding:16px}.launcher button{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:6px;width:100%;padding:10px 16px;font-size:14px;font-weight:500;transition:background .15s}.launcher button:hover{background:var(--accent-light)}.launcher button:disabled{opacity:.5;cursor:not-allowed}.run-list-header{text-transform:uppercase;letter-spacing:.5px;color:var(--text);border-bottom:1px solid var(--border);padding:12px 16px;font-size:12px;font-weight:600}.run-item{cursor:pointer;border-bottom:1px solid var(--border);align-items:center;gap:10px;padding:10px 16px;transition:background .1s;display:flex}.run-item:hover{background:var(--bg-hover)}.run-item.selected{background:var(--bg-hover);border-left:3px solid var(--accent)}.run-item .status-icon{flex-shrink:0}.run-item .run-info{flex:1;min-width:0}.run-item .run-id{font-family:var(--mono);color:var(--text-h);font-size:13px}.run-item .run-meta{color:var(--text);font-size:12px}.run-detail h2{color:var(--text-h);margin-bottom:20px;font-size:20px;font-weight:600}.run-summary{grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:12px;margin-bottom:24px;display:grid}.stat-card{background:var(--bg-card);border:1px solid var(--border);border-radius:8px;padding:16px}.stat-card .label{text-transform:uppercase;letter-spacing:.5px;color:var(--text);margin-bottom:4px;font-size:12px}.stat-card .value{color:var(--text-h);font-size:24px;font-weight:600}.stat-card .value.success{color:var(--green)}.stat-card .value.fail{color:var(--red)}.steps-table{border-collapse:collapse;width:100%;margin-bottom:24px}.steps-table th{text-align:left;text-transform:uppercase;letter-spacing:.5px;color:var(--text);border-bottom:2px solid var(--border);padding:8px 12px;font-size:12px;font-weight:600}.steps-table td{border-bottom:1px solid var(--border);padding:10px 12px;font-size:13px}.steps-table .step-name{font-family:var(--mono);color:var(--text-h)}.badge{border-radius:4px;padding:2px 8px;font-size:12px;font-weight:500;display:inline-block}.badge.completed{color:var(--green);background:#22c55e26}.badge.failed{color:var(--red);background:#ef444426}.lint-card{background:var(--bg-card);border:1px solid var(--border);border-radius:8px;padding:20px}.lint-card h3{color:var(--text-h);margin-bottom:12px;font-size:14px;font-weight:600}.lint-grid{grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:12px;display:grid}.lint-item .lint-label{color:var(--text);margin-bottom:2px;font-size:12px}.lint-item .lint-value{color:var(--text-h);font-size:18px;font-weight:600}.artifacts-section{margin-top:24px}.artifacts-section h3{color:var(--text-h);margin-bottom:12px;font-size:14px;font-weight:600}.artifact-list{flex-direction:column;gap:4px;display:flex}.artifact-item{background:var(--bg-card);border:1px solid var(--border);font-family:var(--mono);color:var(--text-h);cursor:pointer;border-radius:6px;justify-content:space-between;align-items:center;padding:8px 12px;font-size:13px;transition:background .1s;display:flex}.artifact-item:hover{background:var(--bg-hover)}.artifact-item .size{color:var(--text);font-size:12px}.header-right{align-items:center;gap:16px;display:flex}.logout-btn{color:var(--text);border:1px solid var(--border);cursor:pointer;background:0 0;border-radius:6px;padding:6px 14px;font-size:13px;transition:all .15s}.logout-btn:hover{color:var(--text-h);border-color:var(--text)}.login-page{background:var(--bg);justify-content:center;align-items:center;min-height:100vh;display:flex}.login-form{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;flex-direction:column;gap:16px;width:360px;padding:40px 32px;display:flex}.login-form h1{color:var(--text-h);text-align:center;font-size:20px;font-weight:600}.login-form p{color:var(--text);text-align:center;margin-bottom:8px;font-size:14px}.login-form input{background:var(--bg);color:var(--text-h);border:1px solid var(--border);border-radius:6px;outline:none;padding:10px 14px;font-size:14px;transition:border-color .15s}.login-form input:focus{border-color:var(--accent)}.login-form button{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:6px;margin-top:4px;padding:10px 16px;font-size:14px;font-weight:500;transition:background .15s}.login-form button:hover{background:var(--accent-light)}.login-form button:disabled{opacity:.5;cursor:not-allowed}.login-error{color:var(--red);text-align:center;background:#ef444426;border-radius:6px;padding:8px 12px;font-size:13px}
