:root{--bg: #0f172a;--panel: #1e293b;--panel-2: #273449;--border: #334155;--text: #e2e8f0;--muted: #94a3b8;--primary: #6366f1;--primary-hover: #4f46e5;--success: #22c55e;--warn: #f59e0b;--danger: #ef4444;--info: #38bdf8}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{background:var(--bg);color:var(--text);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Inter,system-ui,sans-serif;font-size:14px;line-height:1.5}a{color:var(--info);text-decoration:none}a:hover{text-decoration:underline}.layout{display:flex;flex-direction:column;min-height:100vh}.topbar{display:flex;align-items:center;justify-content:space-between;padding:12px 24px;border-bottom:1px solid var(--border);background:var(--panel)}.brand{font-weight:700;font-size:16px;letter-spacing:.3px}.brand span{color:var(--primary)}.nav{display:flex;gap:18px}.nav a{color:var(--muted);font-weight:500;padding:4px 0}.nav a.active{color:var(--text);border-bottom:2px solid var(--primary)}.identity{display:flex;align-items:center;gap:10px}.identity .who{color:var(--muted)}.identity .role{font-size:11px;background:var(--panel-2);padding:2px 8px;border-radius:999px}.identity .role.admin{color:var(--warn)}.identity .role.requester{color:var(--info)}button,select,input,textarea{font:inherit;background:var(--panel-2);color:var(--text);border:1px solid var(--border);border-radius:6px;padding:8px 10px}input:focus,select:focus,textarea:focus{outline:2px solid var(--primary);border-color:var(--primary)}button{cursor:pointer;background:var(--primary);border-color:var(--primary);font-weight:500}button:hover{background:var(--primary-hover);border-color:var(--primary-hover)}button.ghost{background:transparent;color:var(--text)}button.ghost:hover{background:var(--panel-2)}button.danger{background:var(--danger);border-color:var(--danger)}button:disabled{opacity:.5;cursor:not-allowed}.container{max-width:1100px;margin:0 auto;padding:24px;width:100%}.h1{font-size:20px;font-weight:700;margin:0 0 4px}.h2{font-size:16px;font-weight:600;margin:24px 0 8px}.muted{color:var(--muted)}.segment{margin-bottom:28px}.segment .head{display:flex;align-items:baseline;gap:12px;margin-bottom:10px}.segment .head h3{margin:0;font-size:15px}.segment .head p{margin:0;color:var(--muted);font-size:13px}.cards{display:grid;gap:12px;grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}.card{background:var(--panel);border:1px solid var(--border);border-radius:10px;padding:14px 16px;display:flex;flex-direction:column;gap:8px}.card.clickable{cursor:pointer;transition:border-color .15s,transform .15s}.card.clickable:hover{border-color:var(--primary)}.card h4{margin:0;font-size:14px}.card p{margin:0;color:var(--muted);font-size:13px}.pill{display:inline-block;font-size:11px;padding:2px 8px;border-radius:999px;background:var(--panel-2);color:var(--muted)}.pill.api{color:#a5b4fc}.pill.command{color:#fbbf24}.field-row{display:grid;gap:6px;margin-bottom:12px}.field-row label{font-size:13px;color:var(--muted)}.field-row .err{color:var(--danger);font-size:12px;min-height:14px}.form-actions{display:flex;gap:10px;margin-top:16px}.banner{border-radius:8px;padding:10px 14px;margin-bottom:14px;font-size:13px;border:1px solid var(--border)}.banner.error{background:#ef44441a;color:#fca5a5;border-color:var(--danger)}.banner.success{background:#22c55e1a;color:#86efac;border-color:var(--success)}.table{width:100%;border-collapse:collapse}.table th,.table td{text-align:left;padding:10px 12px;border-bottom:1px solid var(--border)}.table th{color:var(--muted);font-weight:500;font-size:12px;text-transform:uppercase;letter-spacing:.5px}.table tr.clickable:hover{background:var(--panel);cursor:pointer}.status{display:inline-block;font-size:11px;padding:2px 8px;border-radius:999px;font-weight:600}.status.TO_DO{background:#94a3b82e;color:#cbd5e1}.status.IN_PROGRESS{background:#38bdf82e;color:var(--info)}.status.APPROVED{background:#22c55e2e;color:var(--success)}.status.PROVISIONING{background:#a855f72e;color:#d8b4fe}.status.COMPLETED{background:#6366f12e;color:#a5b4fc}.status.REJECTED,.status.FAILED{background:#ef44442e;color:#fca5a5}.build-row .meta{color:var(--muted);font-size:11px}.build-row .pill-status{display:inline-block;font-size:10px;padding:1px 6px;border-radius:999px;font-weight:600;text-transform:uppercase}.build-row .pill-status.SUCCESS{background:#22c55e2e;color:var(--success)}.build-row .pill-status.FAILURE,.build-row .pill-status.CANCELLED,.build-row .pill-status.TIMEOUT,.build-row .pill-status.INTERNAL_ERROR,.build-row .pill-status.EXPIRED{background:#ef44442e;color:#fca5a5}.build-row .pill-status.WORKING{background:#38bdf82e;color:var(--info)}.build-row .pill-status.QUEUED{background:#94a3b82e;color:#cbd5e1}.detail{display:grid;grid-template-columns:2fr 1fr;gap:20px}.detail .panel{background:var(--panel);border:1px solid var(--border);border-radius:10px;padding:16px}.kv{display:grid;grid-template-columns:140px 1fr;gap:6px 12px;font-size:13px}.kv .k{color:var(--muted)}.timeline{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px}.timeline li{padding:8px 10px;background:var(--panel-2);border-radius:6px;font-size:13px}.timeline .meta{color:var(--muted);font-size:11px;margin-top:2px}.comments{display:flex;flex-direction:column;gap:8px}.comment{background:var(--panel-2);border-radius:6px;padding:8px 10px;font-size:13px}.comment .meta{color:var(--muted);font-size:11px;margin-bottom:2px}.comment .role{font-weight:600}.comment .role.admin{color:var(--warn)}.comment .role.requester{color:var(--info)}pre.log{background:#0b1220;border:1px solid var(--border);border-radius:6px;padding:10px;font-size:12px;overflow-x:auto;margin:0}.auth-shell{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px;background:radial-gradient(60% 50% at 50% 0%,rgba(99,102,241,.18),transparent 70%),radial-gradient(40% 35% at 85% 90%,rgba(56,189,248,.1),transparent 70%),var(--bg)}.auth-card{background:var(--panel);border:1px solid var(--border);border-radius:16px;padding:40px 36px;width:100%;max-width:420px;box-shadow:0 24px 60px #00000059}.auth-brand{font-weight:700;font-size:28px;letter-spacing:.2px;text-align:center;margin-bottom:6px}.auth-brand span{color:var(--primary)}.auth-tagline{color:var(--muted);text-align:center;margin:0 0 28px;font-size:14px}.auth-google-btn{display:flex;align-items:center;justify-content:center;gap:12px;width:100%;padding:12px 16px;background:#fff;color:#1f2937;border:1px solid #d1d5db;border-radius:8px;font-weight:600;font-size:14px;text-decoration:none;cursor:pointer;transition:background .12s ease,border-color .12s ease,transform 80ms ease}.auth-google-btn:hover{background:#f9fafb;border-color:#9ca3af;text-decoration:none}.auth-google-btn:active{transform:translateY(1px)}.g-mark{width:18px;height:18px;display:block}.auth-fineprint{color:var(--muted);font-size:12px;text-align:center;margin:14px 0 0}
