/* OpenCode Agent Cockpit — Onyx/Monokai (Catppuccin Mocha) Gate 2 */
:root{--bg-base:#181825;--bg-surface:#1e1e2e;--bg-elevated:#313244;--bg-overlay:#45475a;
--text-primary:#cdd6f4;--text-secondary:#a6adc8;--text-muted:#6c7086;
--accent:#f5c2e7;--accent2:#89b4fa;--accent3:#f9e2af;--success:#a6e3a1;--warn:#fab387;--danger:#f38ba8;
--border:#45475a;--mono:'JetBrains Mono','Fira Code',ui-monospace,monospace;--sans:'Inter',system-ui,sans-serif}
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:var(--sans);background:var(--bg-base);color:var(--text-primary);font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased}
.app{display:grid;grid-template-columns:240px 1fr;grid-template-rows:48px 1fr 28px;grid-template-areas:"header header" "sidebar main" "footer footer";height:100vh}
.header{grid-area:header;background:var(--bg-surface);border-bottom:1px solid var(--border);display:flex;align-items:center;padding:0 16px;gap:12px}
.header .brand{font-family:var(--mono);font-weight:700;color:var(--accent);font-size:13px;letter-spacing:.5px}
.header .sub{color:var(--text-muted);font-size:12px}
.header .badge{background:var(--bg-elevated);color:var(--accent3);padding:2px 8px;border-radius:4px;font-size:11px;font-family:var(--mono)}
.sidebar{grid-area:sidebar;background:var(--bg-surface);border-right:1px solid var(--border);padding:8px 0;overflow-y:auto}
.nav-item{display:flex;align-items:center;gap:10px;padding:8px 16px;color:var(--text-secondary);cursor:pointer;font-size:13px;border-left:2px solid transparent;transition:.15s}
.nav-item:hover{background:var(--bg-elevated);color:var(--text-primary)}
.nav-item.active{background:var(--bg-elevated);color:var(--accent);border-left-color:var(--accent)}
.nav-item .ic{font-family:var(--mono);width:16px;text-align:center;opacity:.7}
.nav-section{padding:8px 16px 4px;font-size:10px;text-transform:uppercase;letter-spacing:1px;color:var(--text-muted);font-weight:600}
.main{grid-area:main;overflow-y:auto;padding:20px 24px;background:var(--bg-base)}
.view{display:none}.view.active{display:block}
.view h1{font-size:18px;margin-bottom:4px;color:var(--text-primary)}.view .lead{color:var(--text-muted);font-size:12px;margin-bottom:20px}
.grid{display:grid;gap:12px}
.grid.cols-2{grid-template-columns:1fr 1fr}.grid.cols-3{grid-template-columns:repeat(3,1fr)}.grid.cols-4{grid-template-columns:repeat(4,1fr)}
.card{background:var(--bg-surface);border:1px solid var(--border);border-radius:8px;padding:14px}
.card h3{font-size:12px;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);margin-bottom:10px}
.card .val{font-family:var(--mono);font-size:22px;color:var(--accent)}
.card .lbl{font-size:11px;color:var(--text-muted);margin-top:4px}
.stat-row{display:flex;justify-content:space-between;padding:6px 0;border-bottom:1px solid var(--border);font-size:13px}
.stat-row:last-child{border:none}
.stat-row .k{color:var(--text-secondary)}.stat-row .v{font-family:var(--mono);color:var(--text-primary)}
table{width:100%;border-collapse:collapse;font-size:12px}
th{text-align:left;padding:8px;background:var(--bg-elevated);color:var(--text-muted);font-weight:600;text-transform:uppercase;font-size:10px;letter-spacing:.5px;border-bottom:1px solid var(--border)}
td{padding:8px;border-bottom:1px solid var(--border);color:var(--text-secondary)}
tr:hover td{background:var(--bg-elevated)}
.badge{display:inline-block;padding:2px 8px;border-radius:4px;font-size:10px;font-family:var(--mono);font-weight:600;text-transform:uppercase}
.badge.ok{background:#1e3a2e;color:var(--success)}.badge.warn{background:#3a2e1e;color:var(--warn)}
.badge.danger{background:#3a1e2a;color:var(--danger)}.badge.info{background:#1e2a3a;color:var(--accent2)}
.badge.quarantine{background:#3a1e2a;color:var(--danger)}.badge.repair{background:#3a3320;color:var(--accent3)}
.blocker{background:#2a1820;border-left:3px solid var(--danger);padding:12px;border-radius:4px;margin-bottom:8px}
.blocker .bid{font-family:var(--mono);color:var(--danger);font-size:11px;font-weight:700}.blocker .bnote{color:var(--text-secondary);font-size:12px;margin-top:4px}.blocker .bmit{color:var(--success);font-size:11px;margin-top:6px}
.connector-tiers{display:grid;gap:12px}
.tier{background:var(--bg-surface);border:1px solid var(--border);border-radius:8px;padding:12px}
.tier h4{font-size:11px;text-transform:uppercase;color:var(--text-muted);margin-bottom:8px;letter-spacing:.5px}
.chips{display:flex;flex-wrap:wrap;gap:4px}
.chip{background:var(--bg-elevated);padding:3px 8px;border-radius:3px;font-size:11px;font-family:var(--mono);color:var(--text-secondary)}
.chip.a{color:var(--success)}.chip.b{color:var(--accent2)}.chip.c{color:var(--warn)}
.action-ledger{font-family:var(--mono);font-size:11px}
.console{background:#0d0d17;border:1px solid var(--border);border-radius:6px;padding:12px;font-family:var(--mono);font-size:11px;color:var(--success);max-height:240px;overflow-y:auto;line-height:1.6}
.console .ts{color:var(--text-muted)}.console .lvl-i{color:var(--accent2)}.console .lvl-w{color:var(--warn)}
.footer{grid-area:footer;background:var(--bg-surface);border-top:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;padding:0 16px;font-size:11px;color:var(--text-muted);font-family:var(--mono)}
.footer .pulse{width:6px;height:6px;border-radius:50%;background:var(--success);display:inline-block;margin-right:6px;animation:pulse 2s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.3}}
@media(max-width:768px){.app{grid-template-columns:1fr;grid-template-areas:"header" "sidebar" "main" "footer";grid-template-rows:48px auto 1fr 28px}.sidebar{max-height:200px;border-right:none;border-bottom:1px solid var(--border)}.grid.cols-2,.grid.cols-3,.grid.cols-4{grid-template-columns:1fr}}
