*{box-sizing:border-box;margin:0;padding:0}:root{--bg:#09090b;--bg-card:#111113;--bg-card-hover:#18181b;--bg-elevated:#1c1c1f;--bg-input:#0d0d0f;--border:#27272a;--border-hover:#3f3f46;--text:#fafafa;--text-secondary:#a1a1aa;--text-muted:#71717a;--accent:#6366f1;--accent-hover:#818cf8;--accent-muted:#6366f126;--green:#22c55e;--green-muted:#22c55e26;--red:#ef4444;--red-muted:#ef444426;--yellow:#eab308;--yellow-muted:#eab30826;--orange:#f97316;--orange-muted:#f9731626;--blue:#3b82f6;--blue-muted:#3b82f626;--radius:8px;--radius-lg:12px}body{background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;font-family:-apple-system,BlinkMacSystemFont,Inter,Segoe UI,system-ui,sans-serif;line-height:1.5}a{color:var(--accent-hover);text-decoration:none}a:hover{color:var(--accent)}.layout{min-height:100vh;display:flex}.sidebar{background:var(--bg-card);border-right:1px solid var(--border);z-index:50;flex-direction:column;flex-shrink:0;width:240px;display:flex;position:fixed;top:0;bottom:0;left:0}.sidebar-logo{border-bottom:1px solid var(--border);align-items:center;gap:.6rem;padding:1.25rem 1.25rem 1rem;display:flex}.sidebar-logo span{letter-spacing:-.02em;font-size:1rem;font-weight:700}.sidebar-logo .logo-icon{background:linear-gradient(135deg,var(--accent),#a855f7);border-radius:6px;justify-content:center;align-items:center;width:28px;height:28px;display:flex}.sidebar nav{flex-direction:column;flex:1;gap:2px;padding:.5rem .75rem;display:flex}.sidebar nav a{border-radius:var(--radius);color:var(--text-muted);align-items:center;gap:.65rem;padding:.55rem .75rem;font-size:.875rem;font-weight:450;transition:all .15s;display:flex}.sidebar nav a:hover{color:var(--text);background:var(--bg-card-hover)}.sidebar nav a.active,.sidebar nav a[data-active=true]{color:var(--text);background:var(--accent-muted)}.sidebar nav a svg{opacity:.7;flex-shrink:0;width:18px;height:18px}.sidebar nav a:hover svg,.sidebar nav a.active svg{opacity:1}.sidebar-section{text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);padding:.75rem 1rem;font-size:.7rem;font-weight:600}.sidebar-footer{border-top:1px solid var(--border);padding:.75rem 1rem}.main{flex:1;max-width:1100px;margin-left:240px;padding:2rem 2.5rem}.page-header{justify-content:space-between;align-items:flex-start;margin-bottom:1.75rem;display:flex}.page-header h2{letter-spacing:-.02em;font-size:1.5rem;font-weight:700}.page-subtitle{color:var(--text-muted);margin-top:.25rem;font-size:.875rem}.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);margin-bottom:.5rem;padding:1rem 1.25rem;transition:all .15s}.card:hover{border-color:var(--border-hover)}.card-clickable{cursor:pointer}.card-clickable:hover{background:var(--bg-card-hover)}.card-link{color:inherit;display:block}.card-link:hover{color:inherit;text-decoration:none}.stat-grid{grid-template-columns:repeat(4,1fr);gap:.75rem;margin-bottom:2rem;display:grid}.stat-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.25rem}.stat-card .stat-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;font-size:.75rem;font-weight:500}.stat-card .stat-value{letter-spacing:-.03em;margin-top:.25rem;font-size:2rem;font-weight:700}.badge{text-transform:uppercase;letter-spacing:.03em;border-radius:100px;align-items:center;gap:.3rem;padding:.2rem .55rem;font-size:.7rem;font-weight:600;display:inline-flex}.badge-completed{background:var(--green-muted);color:var(--green)}.badge-running{background:var(--blue-muted);color:var(--blue)}.badge-pending{color:var(--text-muted);background:#71717a26}.badge-failed{background:var(--red-muted);color:var(--red)}.badge-waiting_approval{background:var(--orange-muted);color:var(--orange)}.badge-skipped{color:var(--text-muted);background:#71717a1a}.btn{border-radius:var(--radius);border:1px solid var(--border);background:var(--bg-card);color:var(--text);cursor:pointer;white-space:nowrap;justify-content:center;align-items:center;gap:.4rem;padding:.5rem 1rem;font-size:.85rem;font-weight:500;transition:all .15s;display:inline-flex}.btn:hover{background:var(--bg-card-hover);border-color:var(--border-hover)}.btn-primary{background:var(--accent);border-color:var(--accent);color:#fff}.btn-primary:hover{background:var(--accent-hover);border-color:var(--accent-hover)}.btn-green{background:var(--green);border-color:var(--green);color:#fff}.btn-green:hover{opacity:.9}.btn-red{background:var(--red);border-color:var(--red);color:#fff}.btn-red:hover{opacity:.9}.btn-ghost{background:0 0;border-color:#0000}.btn-ghost:hover{background:var(--bg-card-hover)}.btn-sm{padding:.35rem .75rem;font-size:.8rem}.btn:disabled{opacity:.5;cursor:not-allowed}.row{align-items:center;gap:.75rem;display:flex}.row-between{justify-content:space-between;align-items:center;display:flex}.gap-sm{gap:.4rem}.text-secondary{color:var(--text-secondary)}.text-muted{color:var(--text-muted)}.text-sm{font-size:.85rem}.text-xs{font-size:.75rem}.mono{font-family:SF Mono,Fira Code,JetBrains Mono,monospace}.mt-1{margin-top:.5rem}.mt-2{margin-top:1rem}.steps-timeline{flex-direction:column;gap:0;display:flex}.step-item{gap:1rem;padding:.75rem 0;display:flex;position:relative}.step-item:not(:last-child):before{content:"";background:var(--border);width:2px;position:absolute;top:2.25rem;bottom:0;left:11px}.step-dot{z-index:1;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:24px;height:24px;display:flex}.step-dot-completed{background:var(--green-muted);color:var(--green)}.step-dot-running{background:var(--blue-muted);color:var(--blue)}.step-dot-failed{background:var(--red-muted);color:var(--red)}.step-dot-pending{color:var(--text-muted);background:#71717a26}.step-dot-waiting_approval{background:var(--orange-muted);color:var(--orange)}.step-dot-skipped{color:var(--text-muted);background:#71717a1a}.step-content{flex:1;min-width:0}.step-output{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius);white-space:pre-wrap;word-break:break-word;max-height:400px;color:var(--text-secondary);margin-top:.5rem;padding:.75rem 1rem;font-family:SF Mono,Fira Code,monospace;font-size:.8rem;line-height:1.6;overflow-y:auto}.filter-bar{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);gap:.35rem;width:fit-content;margin-bottom:1.25rem;padding:.25rem;display:flex}.filter-bar button{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:6px;padding:.35rem .75rem;font-size:.8rem;font-weight:450;transition:all .15s}.filter-bar button:hover{color:var(--text);background:var(--bg-card-hover)}.filter-bar button.active{background:var(--accent);color:#fff}.progress-dots{align-items:center;gap:3px;display:flex}.progress-dot{background:var(--border);border-radius:50%;width:6px;height:6px}.progress-dot-completed{background:var(--green)}.progress-dot-running{background:var(--blue);animation:1.5s infinite pulse}.progress-dot-failed{background:var(--red)}.progress-dot-waiting_approval{background:var(--orange)}.empty{text-align:center;color:var(--text-muted);padding:4rem 2rem}.empty-icon{opacity:.3;width:48px;height:48px;margin:0 auto 1rem}.spinner{border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;width:14px;height:14px;animation:.6s linear infinite spin;display:inline-block}@keyframes spin{to{transform:rotate(360deg)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:100;background:#000000bf;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal-content{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);max-height:85vh;padding:1.75rem;overflow-y:auto;box-shadow:0 20px 60px #00000080}.input{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius);width:100%;color:var(--text);padding:.55rem .75rem;font-size:.875rem;transition:border-color .15s;display:block}.input:focus{border-color:var(--accent);outline:none}.input::placeholder{color:var(--text-muted)}.input-label{color:var(--text-secondary);margin-bottom:.35rem;font-size:.75rem;font-weight:500;display:block}.yaml-editor{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius);width:100%;min-height:300px;color:var(--text);resize:vertical;padding:1rem;font-family:SF Mono,Fira Code,JetBrains Mono,monospace;font-size:.825rem;line-height:1.65;transition:border-color .15s;display:block}.yaml-editor:focus{border-color:var(--accent);outline:none}.user-info{align-items:center;gap:.6rem;display:flex}.user-avatar{border:1px solid var(--border);border-radius:50%;width:28px;height:28px}.alert{border-radius:var(--radius);align-items:center;gap:.5rem;margin-bottom:1rem;padding:.75rem 1rem;font-size:.85rem;display:flex}.alert-success{background:var(--green-muted);color:var(--green);border:1px solid #22c55e33}.alert-error{background:var(--red-muted);color:var(--red);border:1px solid #ef444433}.alert-info{background:var(--blue-muted);color:var(--blue);border:1px solid #3b82f633}.alert-warning{background:var(--orange-muted);color:var(--orange);border:1px solid #f9731633}
