:root{--color-bg:#f9fafb;--color-surface:#fff;--color-surface-muted:#f3f4f6;--color-border:#e5e7eb;--color-border-strong:#d1d5db;--color-text:#111827;--color-text-muted:#6b7280;--color-text-subtle:#9ca3af;--color-primary:#2563eb;--color-primary-dark:#1d4ed8;--color-success:#10b981;--color-warning:#f59e0b;--color-danger:#ef4444;--color-info:#0ea5e9;--radius-sm:.375rem;--radius-md:.5rem;--radius-lg:.75rem;--shadow-card:0 1px 2px 0 #0000000d;--shadow-modal:0 10px 15px -3px #0000001a, 0 4px 6px -4px #0000001a;--font-mono:ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace}*{box-sizing:border-box}body{background:var(--color-bg);color:var(--color-text);margin:0;font-family:system-ui,-apple-system,BlinkMacSystemFont,sans-serif;font-size:14px;line-height:1.5}a{color:var(--color-primary);text-decoration:none}a:hover{text-decoration:underline}button{border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-surface);color:var(--color-text);cursor:pointer;font-family:inherit;font-size:inherit;align-items:center;gap:.375rem;padding:.5rem .875rem;line-height:1;transition:background 80ms,border-color 80ms;display:inline-flex}button:hover{background:var(--color-surface-muted)}button.primary{background:var(--color-primary);border-color:var(--color-primary);color:#fff}button.primary:hover{background:var(--color-primary-dark);border-color:var(--color-primary-dark)}button.danger{background:var(--color-danger);border-color:var(--color-danger);color:#fff}button.outline{background:0 0}button:disabled,button:disabled:hover{background:var(--color-surface-muted);color:var(--color-text-subtle);border-color:var(--color-border);cursor:not-allowed;opacity:1}input,select,textarea{border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-surface);color:var(--color-text);font-family:inherit;font-size:inherit;padding:.5rem .75rem;line-height:1.5}textarea{font-family:var(--font-mono);resize:vertical;min-height:6rem;font-size:12.5px}code,.mono{font-family:var(--font-mono);font-size:.9em}.app-shell{grid-template-columns:240px 1fr;min-height:100vh;display:grid}.sidebar{background:var(--color-surface);border-right:1px solid var(--color-border);padding:1.5rem 1rem}.sidebar-brand{color:var(--color-text);border-bottom:1px solid var(--color-border);margin-bottom:1rem;padding:0 .5rem 1.25rem;font-size:1rem;font-weight:600}.sidebar-nav{flex-direction:column;gap:.125rem;display:flex}.sidebar-nav a{color:var(--color-text);border-radius:var(--radius-sm);padding:.5rem .75rem;font-weight:500}.sidebar-nav a:hover{background:var(--color-surface-muted);text-decoration:none}.sidebar-nav a.active{background:var(--color-primary);color:#fff}.content{max-width:1200px;padding:2rem 2.5rem}.page-header{justify-content:space-between;align-items:center;margin-bottom:1.5rem;display:flex}.page-header h1{margin:0;font-size:1.5rem;font-weight:600}.page-header-actions{gap:.5rem;display:flex}.breadcrumbs{color:var(--color-text-muted);flex-wrap:wrap;align-items:center;gap:.25rem;margin-bottom:.75rem;font-size:.85rem;display:flex}.breadcrumbs a{color:var(--color-text-muted)}.breadcrumbs a:hover{color:var(--color-text)}.breadcrumbs-sep{color:var(--color-text-subtle)}.breadcrumbs-current{color:var(--color-text);font-weight:500}.entity-header{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-card);justify-content:space-between;align-items:flex-start;gap:1.5rem;margin-bottom:1.5rem;padding:1.5rem;display:flex}.entity-header-left{flex-direction:column;gap:.5rem;display:flex}.entity-title{margin:0;font-size:1.5rem;font-weight:600}.entity-subtitle{color:var(--color-text-muted);margin-left:.5rem;font-size:.9rem;font-weight:400}.entity-id-row{flex-wrap:wrap;align-items:center;gap:.5rem;display:flex}.entity-actions{align-items:flex-start;gap:.5rem;display:flex}.section-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-card);margin-bottom:1.5rem;overflow:hidden}.section-header{border-bottom:1px solid var(--color-border);background:var(--color-surface-muted);align-items:center;gap:.5rem;padding:1rem 1.25rem;display:flex}.section-header h2{margin:0;font-size:1rem;font-weight:600}.section-count{color:var(--color-text-muted);margin-left:auto;font-size:.85rem}.section-body{padding:1.25rem}.section-body.compact{padding:0}table{border-collapse:collapse;width:100%}table th{text-align:left;text-transform:uppercase;letter-spacing:.025em;color:var(--color-text-muted);border-bottom:1px solid var(--color-border);background:var(--color-surface-muted);padding:.625rem 1rem;font-size:.8rem;font-weight:600}table td{border-bottom:1px solid var(--color-border);vertical-align:middle;padding:.75rem 1rem}table tbody tr:hover{background:var(--color-surface-muted)}table tbody tr:last-child td{border-bottom:none}.status-badge{text-transform:uppercase;letter-spacing:.025em;border-radius:9999px;align-items:center;gap:.25rem;padding:.125rem .5rem;font-size:.75rem;font-weight:600;display:inline-flex}.status-badge.completed,.status-badge.passed{color:#065f46;background:#d1fae5}.status-badge.failed,.status-badge.aborted,.status-badge.cluster_interrupted{color:#991b1b;background:#fee2e2}.status-badge.running,.status-badge.pending{color:#1e40af;background:#dbeafe}.status-badge.tier{background:var(--color-surface-muted);color:var(--color-text)}.filter-row{flex-wrap:wrap;align-items:center;gap:.75rem;margin-bottom:1rem;display:flex}.filter-row input,.filter-row select{min-width:8rem}.field{flex-direction:column;gap:.25rem;margin-bottom:1rem;display:flex}.field label{color:var(--color-text);font-size:.85rem;font-weight:500}.field .help{color:var(--color-text-muted);font-size:.75rem}.toast{border-radius:var(--radius-sm);margin-bottom:1rem;padding:.625rem 1rem;font-size:.9rem}.toast.success{color:#065f46;background:#ecfdf5;border:1px solid #a7f3d0}.toast.error{color:#991b1b;background:#fef2f2;border:1px solid #fecaca}.modal-backdrop{z-index:50;cursor:default;background:#11182773;border:0;justify-content:center;align-items:center;padding:1rem;display:flex;position:fixed;inset:0}.modal-backdrop:hover{background:#11182773}.modal{background:var(--color-surface);border-radius:var(--radius-md);box-shadow:var(--shadow-modal);width:100%;max-width:32rem;max-height:90vh;padding:1.5rem;overflow:auto}.modal h2{margin:0 0 1rem;font-size:1.125rem;font-weight:600}.modal-actions{justify-content:flex-end;gap:.5rem;margin-top:1.25rem;display:flex}.muted{color:var(--color-text-muted)}.subtle{color:var(--color-text-subtle)}.empty-state,.loading{text-align:center;color:var(--color-text-muted);padding:2rem 1rem}.yaml-block{font-family:var(--font-mono);color:#f9fafb;border-radius:var(--radius-sm);background:#1f2937;max-height:24rem;padding:1rem;font-size:12px;line-height:1.5;overflow:auto}.json-block{font-family:var(--font-mono);background:var(--color-surface-muted);border-radius:var(--radius-sm);white-space:pre-wrap;word-break:break-word;max-height:12rem;padding:.5rem .75rem;font-size:12px;line-height:1.5;overflow:auto}.step-card{border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-surface);margin-bottom:.5rem;padding:.75rem 1rem}.step-card.passed{border-left:3px solid var(--color-success)}.step-card.failed{border-left:3px solid var(--color-danger)}.step-card.running{border-left:3px solid var(--color-info)}.step-card-head{align-items:center;gap:.5rem;margin-bottom:.25rem;display:flex}.step-card-name{font-weight:500}.step-card-duration{color:var(--color-text-muted);font-variant-numeric:tabular-nums;margin-left:auto;font-size:.8rem}.step-card-detail{color:var(--color-text-muted);background:var(--color-surface-muted);border-radius:var(--radius-sm);padding:.075rem .4rem;font-size:.8rem}.id-cell{font-family:var(--font-mono);background:var(--color-surface-muted);border-radius:var(--radius-sm);color:var(--color-text);align-items:center;gap:.375rem;padding:.125rem .5rem;font-size:.85em;display:inline-flex}.id-cell.button{cursor:pointer;border:1px solid var(--color-border)}.id-cell-label{color:var(--color-text);font-family:system-ui,-apple-system,sans-serif;font-weight:500}.id-cell-suffix{color:var(--color-text-muted)}
