*{box-sizing:border-box}body,html,#root{margin:0;padding:0;height:100%;font-family:Segoe UI,system-ui,sans-serif;color:#1a1a1a}.app{height:100%;display:flex;flex-direction:column}.topbar{background:#2c3e50;color:#fff;padding:10px 24px;font-weight:600;font-size:15px;display:flex;align-items:center;justify-content:space-between;gap:12px}.topbar .logo{font-size:16px}.topbar .meta{display:flex;gap:8px;font-weight:400;font-size:12px}.topbar .badge{background:#ffffff26;border-radius:4px;padding:2px 8px}.topbar .badge.mock{background:#f0a500;color:#1f2530;font-weight:600}.topbar .badge.asu{background:#2c8a3a;font-weight:600}.layout{flex:1;display:flex;min-height:0}.sidebar{width:260px;background:#f4f6f9;border-right:1px solid #d8dee4;padding:12px 0;overflow-y:auto}.sidebar a{display:block;padding:8px 18px;color:#2c3e50;text-decoration:none;font-size:14px}.sidebar a:hover{background:#e3e8ef}.sidebar a.active{background:#2c3e50;color:#fff;font-weight:600}.sidebar .nav-section{padding:16px 18px 6px;font-size:11px;text-transform:uppercase;color:#6b7785;letter-spacing:.05em}.content{flex:1;padding:24px 28px;overflow:auto;background:#fff}.content h1{font-size:22px;margin:0 0 18px}.content h2{font-size:16px;margin:18px 0 8px}.form-row{display:flex;gap:12px;align-items:center;margin-bottom:10px;flex-wrap:wrap}.form-row label{min-width:180px;font-size:13px;color:#4a5563}.form-row input,.form-row select,.form-row textarea{padding:6px 10px;border:1px solid #c3cdd8;border-radius:4px;font-size:13px;min-width:220px}button{padding:6px 12px;border:1px solid #c3cdd8;background:#fff;border-radius:4px;cursor:pointer;font-size:13px;font-family:inherit}button:hover{background:#f4f6f9}button.primary{padding:8px 18px;background:#2c3e50;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:14px}button.primary:hover:not(:disabled){background:#34495e}button.primary:disabled{opacity:.5;cursor:not-allowed}button.danger{background:#c0392b;color:#fff;border-color:#c0392b}table{width:100%;border-collapse:collapse;font-size:13px}table th,table td{border-bottom:1px solid #e0e4e9;padding:8px 10px;text-align:left}table th{background:#f4f6f9;font-weight:600}.status-tag{display:inline-block;padding:2px 8px;border-radius:10px;font-size:11px;font-weight:600}.status-tag.Running{background:#fff3cd;color:#856404}.status-tag.Succeeded{background:#d4edda;color:#155724}.status-tag.Failed{background:#f8d7da;color:#721c24}.status-tag.Simple{background:#e7f0ff;color:#234fa9}.status-tag.Base{background:#d4edda;color:#155724}.status-tag.WithTargets{background:#fff3cd;color:#856404}.status-tag.BaseAndTargets{background:#f6d7f7;color:#6f2f7c}.notice{padding:12px 14px;background:#fff8e1;border-left:4px solid #f5b800;font-size:13px;margin-bottom:16px}.error{padding:12px 14px;background:#fdecea;border-left:4px solid #e74c3c;font-size:13px;margin-bottom:16px}.success{padding:12px 14px;background:#d4edda;border-left:4px solid #2c8a3a;font-size:13px;margin-bottom:16px;color:#155724}.dashboard-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:16px;margin-top:16px}.card{background:#fff;border:1px solid #d8dee4;border-radius:6px;padding:16px;display:flex;flex-direction:column;gap:8px}.card h3{margin:0;font-size:14px;color:#6b7785;font-weight:600;text-transform:uppercase;letter-spacing:.05em}.card .value{font-size:32px;font-weight:700;color:#1f2530}.card .subvalue{font-size:13px;color:#6b7785}.card .actions{margin-top:auto;display:flex;gap:8px}.card .actions a{color:#2c63d3;text-decoration:none;font-size:13px}.card .actions a:hover{text-decoration:underline}.card .breakdown{display:flex;flex-direction:column;gap:4px;font-size:13px}.card .breakdown .row{display:flex;justify-content:space-between}.card .breakdown .row span{color:#6b7785}.card .breakdown .row b{color:#1f2530}.progress{display:flex;align-items:center;gap:8px;margin:6px 0;font-size:12px}.progress .dot{width:10px;height:10px;border-radius:50%;background:#c3cdd8}.progress .dot.running{background:#f0a500}.progress .dot.success{background:#2c8a3a}.progress .dot.error{background:#c0392b}.progress .label{color:#4a5563}.progress .count{color:#6b7785;margin-left:auto}.chips{display:flex;gap:8px;margin:12px 0}.chip{padding:4px 12px;border-radius:14px;border:1px solid #d8dee4;background:#fff;cursor:pointer;font-size:12px}.chip.active{background:#2c3e50;color:#fff;border-color:#2c3e50}
