/* Qorion Control Plane — enterprise shell design system. Dependency-free. */
:root {
    --bg: #0b0e14;
    --bg-elev: #121620;
    --bg-elev-2: #161b27;
    --panel: #0f131c;
    --border: #232a3a;
    --border-strong: #2f3850;
    --text: #e6e9f0;
    --text-dim: #9aa4ba;
    --text-faint: #6b7488;
    --brand: #5b8cff;
    --brand-dim: #2a3b66;
    --accent: #18b6a6;
    --ok: #2fbf71;
    --warn: #e6a23c;
    --danger: #f0616d;
    --critical: #ff3b5c;
    --shadow: 0 8px 30px rgba(0, 0, 0, 0.35);
    --radius: 10px;
    --radius-sm: 7px;
    --mono: ui-monospace, SFMono-Regular, "SF Mono", Menlo, Consolas, monospace;
    --sans: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Inter, system-ui, sans-serif;
}
* { box-sizing: border-box; }
html, body { margin: 0; height: 100%; }
body {
    font-family: var(--sans);
    background: radial-gradient(1200px 700px at 80% -10%, #16203a 0%, var(--bg) 55%);
    color: var(--text);
    font-size: 14px;
    line-height: 1.5;
    -webkit-font-smoothing: antialiased;
}
a { color: var(--brand); text-decoration: none; }
button { font-family: inherit; }
code, .mono { font-family: var(--mono); font-size: 12.5px; }
.keybox { font-family: var(--mono); font-size: 13px; word-break: break-all; user-select: all; padding: 12px 14px; border: 1px solid var(--border); border-radius: var(--radius-sm); background: var(--bg-elev); color: var(--brand); }

/* Layout */
#app { display: grid; grid-template-columns: 248px 1fr; min-height: 100vh; }
.sidebar {
    background: linear-gradient(180deg, #0d111a, #0a0d14);
    border-right: 1px solid var(--border);
    display: flex; flex-direction: column; padding: 18px 14px; gap: 6px;
    position: sticky; top: 0; height: 100vh;
}
.brand { display: flex; align-items: center; gap: 11px; padding: 6px 8px 16px; }
.brand .logo {
    width: 34px; height: 34px; border-radius: 9px;
    background: linear-gradient(135deg, var(--brand), var(--accent));
    display: grid; place-items: center; font-weight: 800; color: #06121f; font-size: 18px;
    box-shadow: 0 4px 14px rgba(91, 140, 255, 0.4);
}
.brand .title { font-weight: 700; font-size: 15px; letter-spacing: 0.2px; }
.brand .sub { font-size: 11px; color: var(--text-faint); }
.nav-group { font-size: 10.5px; text-transform: uppercase; letter-spacing: 0.8px; color: var(--text-faint); padding: 14px 10px 6px; }
.nav-item {
    display: flex; align-items: center; gap: 10px; padding: 9px 11px; border-radius: var(--radius-sm);
    color: var(--text-dim); cursor: pointer; font-weight: 500; font-size: 13.5px; border: 1px solid transparent;
}
.nav-item:hover { background: var(--bg-elev); color: var(--text); }
.nav-item.active { background: var(--brand-dim); color: #cfe0ff; border-color: var(--border-strong); }
.nav-item .ico { width: 17px; text-align: center; opacity: 0.9; }
.nav-spacer { flex: 1; }
.nav-foot { font-size: 11px; color: var(--text-faint); padding: 8px 10px; border-top: 1px solid var(--border); }

.main { min-width: 0; display: flex; flex-direction: column; }
.topbar {
    display: flex; align-items: center; gap: 14px; padding: 14px 26px;
    border-bottom: 1px solid var(--border); background: rgba(10, 13, 20, 0.7); backdrop-filter: blur(8px);
    position: sticky; top: 0; z-index: 5;
}
.topbar h1 { font-size: 16px; margin: 0; font-weight: 650; }
.topbar .crumb { color: var(--text-faint); font-size: 12.5px; }
.title-wrap { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.title-wrap .crumb { flex-basis: 100%; }
.help-btn { width: 19px; height: 19px; border-radius: 50%; border: 1px solid var(--border); background: var(--bg-elev); color: var(--text-dim); font-size: 12px; font-weight: 700; line-height: 1; cursor: pointer; padding: 0; display: inline-flex; align-items: center; justify-content: center; }
.help-btn:hover { color: var(--brand); border-color: var(--brand); }
.help-btn.on { background: var(--brand); color: #fff; border-color: var(--brand); }
.help-panel { border-bottom: 1px solid var(--border); background: var(--bg-elev); padding: 12px 22px; }
.help-inner { display: flex; gap: 22px; flex-wrap: wrap; align-items: flex-start; max-width: 1100px; }
.help-what { font-size: 13px; color: var(--text); flex: 1 1 320px; line-height: 1.5; }
.help-how { flex: 1 1 320px; }
.help-how-label { font-size: 10.5px; text-transform: uppercase; letter-spacing: 0.6px; color: var(--text-faint); font-weight: 600; }
.help-how ul { margin: 4px 0 0; padding-left: 16px; }
.help-how li { font-size: 12.5px; color: var(--text-dim); line-height: 1.6; }
.topbar .right { margin-left: auto; display: flex; align-items: center; gap: 10px; }
.content { padding: 24px 26px 60px; max-width: 1280px; width: 100%; }

/* Controls */
.btn {
    background: var(--bg-elev); color: var(--text); border: 1px solid var(--border-strong);
    padding: 7px 13px; border-radius: var(--radius-sm); cursor: pointer; font-size: 13px; font-weight: 550;
    display: inline-flex; align-items: center; gap: 7px; transition: background 0.12s, border-color 0.12s;
}
.btn:hover { background: var(--bg-elev-2); border-color: var(--brand); }
.btn.primary { background: linear-gradient(180deg, #5b8cff, #4577f0); border-color: #4577f0; color: #fff; }
.btn.primary:hover { filter: brightness(1.08); }
.btn.ok { border-color: #237a4a; color: #b6f0cf; }
.btn.danger { border-color: #7a2933; color: #ffc2c8; }
.btn:disabled { opacity: 0.45; cursor: not-allowed; }
.btn.sm { padding: 4px 9px; font-size: 12px; }
select, input, textarea {
    background: var(--bg); color: var(--text); border: 1px solid var(--border-strong);
    border-radius: var(--radius-sm); padding: 7px 10px; font-size: 13px; font-family: inherit;
}
select:focus, input:focus, textarea:focus { outline: none; border-color: var(--brand); }
label.fld { display: flex; flex-direction: column; gap: 5px; font-size: 12px; color: var(--text-dim); }

/* Cards & grid */
.grid { display: grid; gap: 16px; }
.cols-4 { grid-template-columns: repeat(4, 1fr); }
.cols-3 { grid-template-columns: repeat(3, 1fr); }
.cols-2 { grid-template-columns: repeat(2, 1fr); }
@media (max-width: 1000px) { .cols-4, .cols-3, .cols-2 { grid-template-columns: 1fr 1fr; } }
.card { background: var(--panel); border: 1px solid var(--border); border-radius: var(--radius); padding: 18px; }
.card.pad-lg { padding: 22px; }
.card h3 { margin: 0 0 4px; font-size: 13px; color: var(--text-dim); font-weight: 600; }
.stat { font-size: 30px; font-weight: 720; letter-spacing: -0.5px; }
.stat-sub { color: var(--text-faint); font-size: 12px; margin-top: 6px; }
.section-title { font-size: 15px; font-weight: 650; margin: 28px 0 12px; display: flex; align-items: center; gap: 10px; }
.section-title:first-child { margin-top: 4px; }

/* Tables */
table { width: 100%; border-collapse: collapse; }
.table-wrap { background: var(--panel); border: 1px solid var(--border); border-radius: var(--radius); overflow: hidden; }
thead th { text-align: left; font-size: 11px; text-transform: uppercase; letter-spacing: 0.6px; color: var(--text-faint); padding: 11px 14px; background: var(--bg-elev); border-bottom: 1px solid var(--border); }
tbody td { padding: 12px 14px; border-bottom: 1px solid var(--border); font-size: 13px; vertical-align: middle; }
tbody tr:last-child td { border-bottom: none; }
tbody tr.click { cursor: pointer; }
tbody tr.click:hover { background: var(--bg-elev); }
.t-name { font-weight: 600; color: var(--text); }
.t-dim { color: var(--text-dim); }

/* Pills / badges */
.pill { display: inline-flex; align-items: center; gap: 6px; padding: 3px 9px; border-radius: 100px; font-size: 11.5px; font-weight: 600; border: 1px solid var(--border-strong); color: var(--text-dim); white-space: nowrap; }
.pill .dot { width: 7px; height: 7px; border-radius: 50%; background: currentColor; }
.pill.ok { color: #7fe0a6; border-color: #1f6b43; background: rgba(47, 191, 113, 0.08); }
.pill.warn { color: #f3c476; border-color: #6e5320; background: rgba(230, 162, 60, 0.08); }
.pill.danger { color: #ff9aa3; border-color: #7a2933; background: rgba(240, 97, 109, 0.08); }
.pill.info { color: #a9c4ff; border-color: var(--brand-dim); background: rgba(91, 140, 255, 0.08); }
.pill.neutral { color: var(--text-dim); }
.pill.crit { color: #fff; border-color: var(--critical); background: rgba(255, 59, 92, 0.16); }

/* Empty state */
.empty { text-align: center; padding: 46px 20px; color: var(--text-faint); }
.empty .ico { font-size: 30px; opacity: 0.5; }
.empty h4 { color: var(--text-dim); margin: 12px 0 4px; font-size: 15px; }

/* Detail */
.kv { display: grid; grid-template-columns: 160px 1fr; gap: 9px 16px; font-size: 13px; }
.kv .k { color: var(--text-faint); }
.kv .v { color: var(--text); }
.detail-head { display: flex; align-items: flex-start; gap: 16px; margin-bottom: 8px; }
.detail-head .meta { flex: 1; }
.detail-head h2 { margin: 0 0 4px; font-size: 22px; letter-spacing: -0.3px; }
.row { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; }
.spread { display: flex; align-items: center; justify-content: space-between; gap: 12px; }
.muted { color: var(--text-faint); }
.gate-blocker { display: flex; gap: 9px; align-items: flex-start; padding: 9px 12px; border: 1px solid #4d2630; background: rgba(240, 97, 109, 0.07); border-radius: var(--radius-sm); margin-top: 8px; font-size: 12.5px; }
.gate-ok { padding: 12px; border: 1px solid #1f6b43; background: rgba(47, 191, 113, 0.07); border-radius: var(--radius-sm); color: #aef0c9; }
.reasons { margin: 8px 0 0; padding-left: 18px; color: var(--text-dim); font-size: 12.5px; }
.reasons li { margin: 3px 0; }

/* Toast & modal */
#toast { position: fixed; bottom: 22px; right: 22px; z-index: 50; display: flex; flex-direction: column; gap: 8px; }
.toast { background: var(--bg-elev-2); border: 1px solid var(--border-strong); border-radius: var(--radius-sm); padding: 11px 15px; box-shadow: var(--shadow); font-size: 13px; min-width: 240px; }
.toast.ok { border-color: #1f6b43; }
.toast.err { border-color: #7a2933; }
.modal-bg { position: fixed; inset: 0; background: rgba(0,0,0,0.6); display: grid; place-items: center; z-index: 40; }
.modal { background: var(--bg-elev); border: 1px solid var(--border-strong); border-radius: var(--radius); padding: 22px; width: 540px; max-width: 92vw; max-height: 86vh; overflow: auto; box-shadow: var(--shadow); }
.modal h3 { margin: 0 0 14px; font-size: 17px; }
.modal .actions { display: flex; justify-content: flex-end; gap: 10px; margin-top: 18px; }
.form-grid { display: grid; gap: 13px; }

/* Login */
.login-wrap { display: grid; place-items: center; min-height: 100vh; }
.login-card { width: 420px; max-width: 92vw; background: var(--panel); border: 1px solid var(--border); border-radius: 14px; padding: 30px; box-shadow: var(--shadow); }
.login-card .brand { padding: 0 0 20px; }
.persona { display: flex; align-items: center; gap: 12px; padding: 12px 14px; border: 1px solid var(--border-strong); border-radius: var(--radius-sm); cursor: pointer; margin-top: 9px; }
.persona:hover { border-color: var(--brand); background: var(--bg-elev); }
.persona .av { width: 34px; height: 34px; border-radius: 50%; background: var(--brand-dim); display: grid; place-items: center; font-weight: 700; color: #cfe0ff; }
.loading { color: var(--text-faint); padding: 40px; text-align: center; }
.bar { height: 7px; background: var(--bg-elev); border-radius: 100px; overflow: hidden; margin-top: 8px; }
.bar > span { display: block; height: 100%; background: linear-gradient(90deg, var(--accent), var(--brand)); transition: width .6s ease; }
@keyframes gen-spin { to { transform: rotate(360deg); } }
.gen-spin { display: inline-block; animation: gen-spin 1s linear infinite; color: var(--accent); }
.gen-step.active { background: var(--bg-elev); border-radius: 8px; margin: 0 -8px; padding-left: 8px; padding-right: 8px; }

/* Wide modal for editors */
.modal.wide { width: 860px; }

/* Inline editors (policy rules / eval scenarios) */
.editor-head { display: flex; align-items: center; justify-content: space-between; margin-top: 6px; }
label.chk { display: flex; align-items: center; gap: 8px; font-size: 12.5px; color: var(--text-dim); }
label.chk input { width: auto; }
.rule-head { display: grid; grid-template-columns: 132px 122px 1.4fr 116px 1.4fr 30px; gap: 8px; font-size: 10.5px; text-transform: uppercase; letter-spacing: 0.5px; color: var(--text-faint); padding: 2px 2px 0; }
.rule-row { display: grid; grid-template-columns: 132px 122px 1.4fr 116px 1.4fr 30px; gap: 8px; align-items: center; margin-top: 7px; }
.rule-row select, .rule-row input { padding: 6px 8px; font-size: 12px; width: 100%; }
.rule-row .r-del { padding: 4px 0; justify-content: center; }
.scn-row { border: 1px solid var(--border); border-radius: var(--radius-sm); padding: 10px; margin-top: 9px; display: flex; flex-direction: column; gap: 7px; background: var(--bg-elev); }
.scn-grid { display: grid; grid-template-columns: 1fr 150px 110px 30px; gap: 8px; align-items: center; }
.scn-grid2 { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; }
.scn-row input, .scn-row select { padding: 6px 8px; font-size: 12px; width: 100%; }

/* Detailed rule list on the Policies / Evaluations views */
.rule-list { display: flex; flex-direction: column; }
.rule-line { display: flex; gap: 8px; align-items: center; flex-wrap: wrap; padding: 6px 0; border-top: 1px solid var(--border); }
.rule-line:first-child { border-top: none; }

/* Approvals queue */
.queue-card { border-left: 3px solid var(--warn); }

/* Workflow Builder Copilot (Surface A) */
.copilot { display: grid; grid-template-columns: 1fr 340px; gap: 16px; align-items: start; }
@media (max-width: 900px) { .copilot { grid-template-columns: 1fr; } }
.cop-left { background: var(--panel); border: 1px solid var(--border); border-radius: var(--radius); padding: 18px; min-height: 360px; display: flex; flex-direction: column; }
.cop-right { background: var(--panel); border: 1px solid var(--border); border-radius: var(--radius); padding: 16px; position: sticky; top: 84px; }
.cop-hero { text-align: center; padding: 18px 8px 10px; }
.cop-ai { width: 46px; height: 46px; margin: 0 auto; border-radius: 13px; display: grid; place-items: center; font-size: 24px; color: #06121f; background: linear-gradient(135deg, var(--brand), var(--accent)); box-shadow: 0 6px 18px rgba(91, 140, 255, 0.4); }
.tpl-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; margin-top: 14px; }
@media (max-width: 560px) { .tpl-grid { grid-template-columns: 1fr; } }
.tpl-card { display: flex; gap: 11px; align-items: center; padding: 13px; border: 1px solid var(--border-strong); border-radius: var(--radius-sm); background: var(--bg-elev); }
.tpl-card:hover { border-color: var(--brand); background: var(--bg-elev-2); }
.tpl-ico { font-size: 22px; width: 30px; text-align: center; }
.cop-scratch { display: flex; gap: 8px; margin-top: 14px; }
.cop-scratch input { flex: 1; }
.cop-thread { flex: 1; display: flex; flex-direction: column; gap: 11px; overflow-y: auto; max-height: 460px; padding: 4px 2px 8px; }
.msg { display: flex; gap: 9px; align-items: flex-start; max-width: 88%; }
.msg.user { align-self: flex-end; flex-direction: row-reverse; }
.msg-ico { width: 26px; height: 26px; flex: none; border-radius: 8px; display: grid; place-items: center; font-size: 14px; color: #06121f; background: linear-gradient(135deg, var(--brand), var(--accent)); }
.msg-body { padding: 9px 13px; border-radius: 12px; font-size: 13.5px; line-height: 1.45; }
.msg.bot .msg-body { background: var(--bg-elev); border: 1px solid var(--border); border-top-left-radius: 4px; }
.msg.user .msg-body { background: var(--brand-dim); border: 1px solid var(--border-strong); color: #cfe0ff; border-top-right-radius: 4px; }
.msg-hint { font-size: 11.5px; color: var(--text-faint); margin-top: 5px; }
.cop-inputbar { display: flex; gap: 8px; margin-top: 12px; }
.cop-inputbar input { flex: 1; }
.cop-ready { margin-top: 12px; padding: 11px 13px; border: 1px solid #1f6b43; background: rgba(47, 191, 113, 0.08); border-radius: var(--radius-sm); color: #aef0c9; font-size: 13px; }
.spec-mirror { display: flex; flex-direction: column; gap: 1px; }
.sm-row { display: grid; grid-template-columns: 92px 1fr; gap: 10px; padding: 8px 0; border-top: 1px solid var(--border); font-size: 12.5px; }
.sm-row:first-child { border-top: none; }
.sm-k { color: var(--text-faint); }
.sm-row.filled .sm-v { color: var(--text); }

/* Inline banner (e.g. drift / re-evaluation required) */
.banner { display: flex; gap: 11px; align-items: flex-start; padding: 12px 15px; border-radius: var(--radius-sm); font-size: 13px; margin-top: 14px; }
.banner > span:first-child { font-size: 16px; }
.banner.warn { border: 1px solid #6e5320; background: rgba(230, 162, 60, 0.09); color: #f3c476; }
.banner.danger { border: 1px solid #7a2933; background: rgba(240, 97, 109, 0.08); color: #ff9aa3; }

/* Runtime connection panel */
.conn-card { padding: 20px; }
.conn-flow { display: flex; align-items: stretch; gap: 14px; }
.conn-node { flex: 1; border: 1px solid var(--border-strong); border-radius: var(--radius-sm); padding: 14px 16px; background: var(--bg-elev); display: flex; flex-direction: column; gap: 3px; }
.conn-node.alt { border-color: var(--accent); }
.conn-node b { font-size: 15px; }
.conn-node span { font-size: 11.5px; color: var(--text-faint); }
.conn-arrow { display: flex; align-items: center; text-align: center; font-size: 10.5px; color: var(--text-faint); line-height: 1.4; white-space: nowrap; }

/* ============ Enhancement pass: filters, charts, tabs, sandbox ============ */

/* Clickable / accented cards */
.card.click { cursor: pointer; transition: border-color .12s, transform .12s; }
.card.click:hover { border-color: var(--border-strong); transform: translateY(-1px); }
.card.accent-warn { border-color: #6e5320; box-shadow: inset 3px 0 0 var(--warn); }
.banner.ok { border: 1px solid #1f6b43; background: rgba(47, 191, 113, 0.07); color: #9fe6bd; }
.banner a { color: inherit; text-decoration: underline; }

/* Search + filter bars */
.search { background: var(--bg-elev); border: 1px solid var(--border); color: var(--text); border-radius: var(--radius-sm); padding: 7px 11px; font-size: 13px; min-width: 240px; }
.filter-bar { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; margin: 0 0 12px; }
.filter-bar.wrap { padding: 12px; background: var(--panel); border: 1px solid var(--border); border-radius: var(--radius); }
.filter-bar .sep { width: 1px; height: 20px; background: var(--border); margin: 0 4px; }
.filter-bar select { background: var(--bg-elev); }
.filter-bar .dt { display: inline-flex; align-items: center; gap: 6px; font-size: 11.5px; color: var(--text-dim); }
.chip { background: var(--bg-elev); border: 1px solid var(--border); color: var(--text-dim); border-radius: 100px; padding: 4px 11px; font-size: 11.5px; cursor: pointer; font-weight: 500; }
.chip:hover { border-color: var(--border-strong); color: var(--text); }
.chip.on { background: rgba(91, 140, 255, 0.14); border-color: var(--brand-dim); color: #bdd1ff; }
.chip.clear { border-style: dashed; }
.summary-row { color: var(--text-dim); font-size: 12px; margin: 0 0 14px; }

/* Status tabs */
.tabs { display: flex; gap: 4px; flex-wrap: wrap; }
.tab { background: transparent; border: 1px solid transparent; color: var(--text-dim); border-radius: var(--radius-sm); padding: 6px 12px; font-size: 12.5px; cursor: pointer; font-weight: 500; }
.tab:hover { background: var(--bg-elev); color: var(--text); }
.tab.on { background: var(--bg-elev); border-color: var(--border-strong); color: var(--text); }
.tab .tab-n { color: var(--text-faint); font-size: 11px; margin-left: 3px; }
.bulk-bar { display: inline-flex; align-items: center; gap: 10px; font-size: 12px; color: var(--text-dim); }

/* Copy / icon buttons */
.icon-btn { background: none; border: none; color: var(--text-faint); cursor: pointer; font-size: 12px; padding: 0 3px; border-radius: 4px; }
.icon-btn:hover { color: var(--brand); background: var(--bg-elev); }
.row-self { background: rgba(91, 140, 255, 0.05); }

/* Sortable headers */
th.sortable { cursor: pointer; user-select: none; }
th.sortable:hover { color: var(--text-dim); }

/* Mini bar chart */
.mini-bar { display: flex; height: 12px; border-radius: 100px; overflow: hidden; background: var(--bg-elev); border: 1px solid var(--border); }
.mb-seg { display: block; height: 100%; }
.mb-low { background: #46527a; }
.mb-medium { background: var(--brand); }
.mb-high { background: var(--warn); }
.mb-critical { background: var(--critical); }
.mb-neutral { background: var(--border-strong); }

/* Sparkline + gauge */
.spark { color: var(--brand); vertical-align: middle; }
.spark circle { fill: currentColor; }
.trend { display: inline-flex; align-items: center; }
.health-wrap { display: inline-flex; align-items: center; gap: 10px; }
.gauge { vertical-align: middle; }
.gauge .g-track { fill: none; stroke: var(--border); stroke-width: 6; }
.gauge .g-fill { fill: none; stroke-width: 6; stroke-linecap: round; transition: stroke-dashoffset .5s ease; }
.gauge.g-ok .g-fill { stroke: var(--ok); }
.gauge.g-warn .g-fill { stroke: var(--warn); }
.gauge.g-danger .g-fill { stroke: var(--danger); }
.gauge .g-num { fill: var(--text); font-size: 17px; font-weight: 700; }
.g-label { display: inline-block; font-size: 11px; color: var(--text-faint); }

/* Live toggle */
.live-toggle { display: inline-flex; align-items: center; gap: 5px; font-size: 11.5px; color: var(--text-dim); cursor: pointer; }

/* Inline CTA (e.g. attach policy) */
.inline-cta { display: inline-flex; align-items: center; gap: 8px; color: #f3c476; font-size: 12px; }

/* Test-run sandbox */
.tr-running { display: flex; align-items: center; gap: 9px; color: var(--text-dim); font-size: 13px; margin-top: 12px; }
.tr-output { margin-top: 12px; }
.tr-label { font-size: 11px; text-transform: uppercase; letter-spacing: 0.6px; color: var(--text-faint); margin-bottom: 5px; }
.tr-text { background: var(--bg-elev); border: 1px solid var(--border); border-radius: var(--radius-sm); padding: 12px 14px; font-size: 13px; white-space: pre-wrap; }
.spin { width: 13px; height: 13px; border: 2px solid var(--border-strong); border-top-color: var(--brand); border-radius: 50%; display: inline-block; animation: spin 0.7s linear infinite; }
@keyframes spin { to { transform: rotate(360deg); } }
.code-block { background: var(--bg-elev); border: 1px solid var(--border); border-radius: var(--radius-sm); padding: 12px; font-family: var(--mono); font-size: 11.5px; max-height: 280px; overflow: auto; white-space: pre-wrap; color: var(--text-dim); }

/* Diagnostics */
.diag { display: flex; flex-direction: column; gap: 8px; margin-top: 12px; }
.diag-row { font-size: 12.5px; color: var(--text-dim); display: flex; align-items: center; gap: 8px; }
.ok-dot { color: var(--ok); font-weight: 700; }
.bad-dot { color: var(--danger); font-weight: 700; }

/* Audit outcome accent */
tr[data-outcome="failure"] td:first-child, tr[data-outcome="denied"] td:first-child { box-shadow: inset 3px 0 0 var(--danger); }
tr[data-outcome="approval_required"] td:first-child { box-shadow: inset 3px 0 0 var(--warn); }
tr[data-outcome="success"] td:first-child { box-shadow: inset 3px 0 0 var(--ok); }

/* Copilot progress + spec-mirror flash */
.cop-progress { display: flex; align-items: center; gap: 10px; margin-bottom: 10px; }
.cop-steps { display: flex; gap: 6px; flex: 1; }
.cop-step { height: 5px; flex: 1; border-radius: 100px; background: var(--border); transition: background .3s; }
.cop-step.done { background: linear-gradient(90deg, var(--brand), var(--accent)); }
.sm-row.flash { animation: flashrow 0.9s ease; }
@keyframes flashrow { 0% { background: rgba(91, 140, 255, 0.22); } 100% { background: transparent; } }

/* SOP hint */
.sop-hint { font-size: 11.5px; }

/* Agent version timeline */
.timeline { display: flex; flex-direction: column; gap: 0; }
.tl-row { display: flex; gap: 12px; padding: 7px 0 7px 2px; position: relative; }
.tl-row:not(:last-child)::before { content: ''; position: absolute; left: 5px; top: 18px; bottom: -2px; width: 1px; background: var(--border); }
.tl-dot { width: 9px; height: 9px; border-radius: 50%; background: var(--brand); margin-top: 5px; flex-shrink: 0; box-shadow: 0 0 0 3px rgba(91,140,255,0.12); }

/* AI approval briefing */
.brief-card { border: 1px solid var(--border); border-radius: var(--radius-sm); background: var(--bg-elev); padding: 12px; margin-top: 8px; }
.brief-rec { font-size: 12.5px; font-weight: 600; padding: 7px 10px; border-radius: var(--radius-sm); }
.brief-rec.ok { color: #9fe6bd; background: rgba(47,191,113,0.08); border: 1px solid #1f6b43; }
.brief-rec.warn { color: #f3c476; background: rgba(230,162,60,0.08); border: 1px solid #6e5320; }

/* NL policy drafter */
.nl-draft { display: flex; gap: 8px; margin: 10px 0 4px; }
.nl-draft input { flex: 1; background: var(--bg-elev); border: 1px solid var(--border); color: var(--text); border-radius: var(--radius-sm); padding: 7px 11px; font-size: 12.5px; }

/* Remediation plan steps */
.rem-step { display: flex; gap: 10px; padding: 6px 0; align-items: flex-start; }
.rem-n { width: 18px; height: 18px; border-radius: 50%; background: var(--brand-dim); color: #cdd9ff; display: grid; place-items: center; font-size: 11px; font-weight: 700; flex-shrink: 0; margin-top: 2px; }
