/* USGRP internal portal — shared design system (dev portal + FSA dashboard). */
:root {
  --bg: #070a11;
  --bg-2: #0b111c;
  --panel: #111a28;
  --panel-2: #0d1521;
  --line: #1d2839;
  --line-2: #2a3a52;
  --text: #eef2f8;
  --muted: #9aa8bd;
  --faint: #62718a;
  --accent: #5bd0ff;
  --accent-2: #7c8bff;
  --violet: #b08bff;
  --good: #5fe3a1;
  --warn: #ffc86b;
  --bad: #ff7a8a;
  --amber: #ffb65c;
  --radius: 14px;
  --sidebar: 248px;
  --mono: "JetBrains Mono", ui-monospace, SFMono-Regular, Menlo, monospace;
  --shadow: 0 1px 0 rgba(255,255,255,.03) inset, 0 18px 40px -26px rgba(0,0,0,.8);
}
* { box-sizing: border-box; }
html, body { margin: 0; height: 100%; }
body {
  background:
    radial-gradient(900px 500px at 88% -12%, rgba(91,208,255,.10) 0, transparent 60%),
    radial-gradient(800px 500px at -5% 5%, rgba(124,139,255,.08) 0, transparent 55%),
    var(--bg);
  color: var(--text);
  font: 14px/1.55 -apple-system, BlinkMacSystemFont, "Segoe UI", Inter, Roboto, sans-serif;
  -webkit-font-smoothing: antialiased;
}
a { color: var(--accent); text-decoration: none; }
button, input, select, textarea { font: inherit; color: inherit; }
button { cursor: pointer; }
code, .mono { font-family: var(--mono); font-size: .92em; }
::-webkit-scrollbar { width: 10px; height: 10px; }
::-webkit-scrollbar-thumb { background: #1c2738; border-radius: 6px; border: 2px solid transparent; background-clip: content-box; }
::-webkit-scrollbar-thumb:hover { background: #2a3a52; background-clip: content-box; }

/* ── buttons ── */
.btn { display: inline-flex; align-items: center; gap: 7px; padding: 9px 15px; border-radius: 10px; border: 1px solid var(--line-2); background: linear-gradient(180deg, #18222f, #131c28); font-size: 13px; font-weight: 600; transition: transform .1s, border-color .12s, box-shadow .12s; }
.btn:hover { border-color: var(--accent); transform: translateY(-1px); }
.btn:active { transform: translateY(0); }
.btn-primary { background: linear-gradient(135deg, var(--accent), var(--accent-2)); color: #04121c; border: 0; box-shadow: 0 8px 20px -10px rgba(91,208,255,.6); }
.btn-primary:hover { filter: brightness(1.07); }
.btn-ghost { background: transparent; }
.btn-danger { color: var(--bad); border-color: #3a2530; background: linear-gradient(180deg,#1d141a,#161014); }
.btn-danger:hover { border-color: var(--bad); }
.btn-danger-solid { background: linear-gradient(135deg, #ff8a8a, #e8475a); color: #2a0509; border: 0; font-weight: 700; }
.btn-warn { background: linear-gradient(135deg, #ffd07a, #ff9b3d); color: #2a1800; border: 0; font-weight: 700; }
.btn-sm { padding: 5px 11px; font-size: 12px; border-radius: 8px; }
.btn:disabled { opacity: .4; cursor: not-allowed; transform: none; }

/* ── login ── */
.auth-wrap { min-height: 100vh; display: grid; place-items: center; padding: 24px; }
.auth-card { position: relative; background: linear-gradient(180deg, var(--panel), var(--panel-2)); border: 1px solid var(--line-2); border-radius: 20px; padding: 36px; width: min(410px, 100%); box-shadow: 0 30px 80px -30px rgba(0,0,0,.9), 0 0 0 1px rgba(91,208,255,.04); }
.auth-card::before { content: ''; position: absolute; inset: 0; border-radius: 20px; padding: 1px; background: linear-gradient(180deg, rgba(91,208,255,.4), transparent 40%); -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0); -webkit-mask-composite: xor; mask-composite: exclude; pointer-events: none; }
.auth-badge { display: inline-flex; align-items: center; gap: 8px; font-size: 11.5px; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; color: var(--accent); margin-bottom: 16px; }
.auth-card h1 { margin: 0 0 6px; font-size: 23px; letter-spacing: -.01em; }
.auth-card p { margin: 0 0 22px; color: var(--muted); font-size: 13px; }
.field { display: flex; flex-direction: column; gap: 6px; margin-bottom: 14px; }
.field label { font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: .06em; color: var(--faint); }
input.in, select.in, textarea.in { width: 100%; padding: 11px 13px; background: var(--bg-2); border: 1px solid var(--line-2); border-radius: 10px; font-size: 15px; transition: border-color .12s, box-shadow .12s; }
input.in:focus, select.in:focus, textarea.in:focus { outline: none; border-color: var(--accent); box-shadow: 0 0 0 3px rgba(91,208,255,.14); }
.code-input { letter-spacing: .5em; text-align: center; font-family: var(--mono); font-size: 22px; }
.auth-err { color: var(--bad); font-size: 13px; min-height: 18px; margin-top: 6px; }

/* ── app shell ── */
.shell { display: grid; grid-template-columns: var(--sidebar) 1fr; min-height: 100vh; }
.sidebar { background: linear-gradient(180deg, #0c1320, #0a0f19); border-right: 1px solid var(--line); padding: 16px 12px; position: sticky; top: 0; height: 100vh; overflow-y: auto; }
.brand { display: flex; align-items: center; gap: 11px; padding: 6px 10px 18px; }
.brand-dot { width: 26px; height: 26px; border-radius: 8px; background: linear-gradient(135deg, var(--accent), var(--accent-2)); box-shadow: 0 6px 16px -6px rgba(91,208,255,.7); flex-shrink: 0; }
.brand-name { font-weight: 800; font-size: 15px; letter-spacing: .01em; }
.brand-sub { font-size: 10px; color: var(--faint); text-transform: uppercase; letter-spacing: .12em; }
.nav-group { margin-top: 16px; }
.nav-group-label { font-size: 10px; font-weight: 800; text-transform: uppercase; letter-spacing: .12em; color: var(--faint); padding: 0 10px 7px; }
.nav-item { position: relative; display: flex; align-items: center; gap: 11px; padding: 9px 11px; border-radius: 10px; color: var(--muted); font-weight: 600; font-size: 13.5px; cursor: pointer; transition: background .12s, color .12s; }
.nav-item:hover { background: rgba(255,255,255,.04); color: var(--text); }
.nav-item.active { background: linear-gradient(90deg, rgba(91,208,255,.16), rgba(91,208,255,.04)); color: #fff; }
.nav-item.active::before { content: ''; position: absolute; left: -12px; top: 8px; bottom: 8px; width: 3px; border-radius: 0 3px 3px 0; background: linear-gradient(180deg, var(--accent), var(--accent-2)); }
.nav-item .ic { width: 17px; text-align: center; opacity: .85; font-size: 13px; }
.main { min-width: 0; display: flex; flex-direction: column; }
.topbar { position: sticky; top: 0; z-index: 20; display: flex; align-items: center; gap: 14px; padding: 14px 24px; background: rgba(7,10,17,.78); backdrop-filter: blur(12px); border-bottom: 1px solid var(--line); }
.topbar h2 { margin: 0; font-size: 16px; font-weight: 800; letter-spacing: -.01em; }
.topbar .spacer { flex: 1; }
.who { font-size: 12.5px; color: var(--muted); }
.content { padding: 24px; max-width: 1320px; width: 100%; }
.page-hint { color: var(--muted); font-size: 13px; margin: 0 0 18px; max-width: 80ch; }
.section-h { font-size: 13px; text-transform: uppercase; letter-spacing: .08em; color: var(--faint); margin: 26px 0 12px; }

/* ── hero (home) ── */
.hero { display: flex; align-items: flex-end; justify-content: space-between; gap: 20px; flex-wrap: wrap; padding: 6px 0 22px; }
.hero-eyebrow { font-size: 11.5px; font-weight: 800; letter-spacing: .14em; text-transform: uppercase; color: var(--accent); }
.hero-title { margin: 8px 0 6px; font-size: 28px; font-weight: 850; letter-spacing: -.02em; }
.hero-sub { margin: 0; color: var(--muted); font-size: 13.5px; max-width: 70ch; }
.hero-search { min-width: 280px; flex: 1; max-width: 420px; }

/* ── alerts strip ── */
.alert-strip { display: grid; gap: 12px; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); margin-bottom: 20px; }
.alert { display: flex; align-items: center; gap: 14px; padding: 14px 16px; border-radius: var(--radius); border: 1px solid var(--line-2); background: linear-gradient(180deg, var(--panel), var(--panel-2)); transition: transform .12s, border-color .12s; }
.alert:hover { transform: translateY(-2px); }
.alert-ic { width: 38px; height: 38px; display: grid; place-items: center; border-radius: 11px; font-size: 18px; flex-shrink: 0; }
.alert.a-bad { border-color: rgba(255,122,138,.4); } .alert.a-bad .alert-ic { background: rgba(255,122,138,.16); color: var(--bad); }
.alert.a-warn { border-color: rgba(255,200,107,.4); } .alert.a-warn .alert-ic { background: rgba(255,200,107,.16); color: var(--warn); }
.alert.a-info { border-color: rgba(91,208,255,.4); } .alert.a-info .alert-ic { background: rgba(91,208,255,.16); color: var(--accent); }
.alert-t { font-weight: 700; font-size: 14.5px; }
.alert-s { font-size: 12.5px; color: var(--muted); margin-top: 2px; }
.alert-go { margin-left: auto; color: var(--faint); font-size: 18px; }

/* ── stat tiles ── */
.tiles { display: grid; gap: 14px; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); }
.tile { display: flex; align-items: center; gap: 14px; padding: 16px 18px; border-radius: var(--radius); border: 1px solid var(--line); background: linear-gradient(180deg, var(--panel), var(--panel-2)); box-shadow: var(--shadow); transition: transform .12s, border-color .12s; }
.tile:hover { transform: translateY(-3px); border-color: var(--line-2); }
.tile-ic { width: 46px; height: 46px; border-radius: 13px; display: grid; place-items: center; font-size: 20px; flex-shrink: 0; }
.t-cyan .tile-ic { background: linear-gradient(135deg, rgba(91,208,255,.22), rgba(91,208,255,.05)); color: var(--accent); }
.t-blue .tile-ic { background: linear-gradient(135deg, rgba(124,139,255,.22), rgba(124,139,255,.05)); color: var(--accent-2); }
.t-violet .tile-ic { background: linear-gradient(135deg, rgba(176,139,255,.22), rgba(176,139,255,.05)); color: var(--violet); }
.t-amber .tile-ic { background: linear-gradient(135deg, rgba(255,182,92,.22), rgba(255,182,92,.05)); color: var(--amber); }
.tile-num { font-size: 26px; font-weight: 850; letter-spacing: -.02em; line-height: 1; }
.tile-label { font-size: 13px; font-weight: 600; margin-top: 4px; }
.tile-sub { font-size: 11.5px; color: var(--faint); margin-top: 2px; }

/* ── cards ── */
.cards { display: grid; gap: 14px; grid-template-columns: repeat(auto-fill, minmax(230px, 1fr)); }
.card { background: linear-gradient(180deg, var(--panel), var(--panel-2)); border: 1px solid var(--line); border-radius: var(--radius); padding: 18px; box-shadow: var(--shadow); }
.card h3 { margin: 0 0 12px; font-size: 14.5px; }
.card-head { display: flex; align-items: center; justify-content: space-between; margin-bottom: 10px; }
.card-head h3 { margin: 0; }
.card.clickable { cursor: pointer; transition: transform .12s, border-color .12s; }
.card.clickable:hover { transform: translateY(-2px); border-color: var(--accent); }
.stat-label { font-size: 11px; text-transform: uppercase; letter-spacing: .06em; color: var(--faint); }
.stat-value { font-size: 26px; font-weight: 850; margin-top: 4px; letter-spacing: -.02em; }
.stat-value.good { color: var(--good); } .stat-value.bad { color: var(--bad); }

/* home two-column grid */
.home-grid { display: grid; gap: 14px; grid-template-columns: 1.5fr 1fr; margin-top: 18px; }
.activity { display: flex; flex-direction: column; }
.activity-row { display: flex; align-items: center; gap: 10px; padding: 9px 0; border-top: 1px solid var(--line); cursor: pointer; font-size: 13px; }
.activity-row:first-child { border-top: 0; }
.activity-row:hover { background: rgba(255,255,255,.02); }
.act-sum { flex: 1; min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; color: var(--muted); }
.act-when { font-size: 11.5px; color: var(--faint); white-space: nowrap; }
.big-row { display: flex; justify-content: space-between; align-items: center; padding: 8px 0; border-top: 1px solid var(--line); font-size: 13px; }
.big-row:first-of-type { border-top: 0; }
.big-rows { color: var(--faint); font-family: var(--mono); font-size: 12px; }

/* quick links */
.qlinks { display: grid; gap: 12px; grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)); }
.qlink { display: block; padding: 16px; border-radius: var(--radius); border: 1px solid var(--line); background: linear-gradient(180deg, var(--panel), var(--panel-2)); border-left: 3px solid var(--accent); transition: transform .12s, border-color .12s; }
.qlink:hover { transform: translateY(-2px); }
.qlink-t { font-weight: 700; font-size: 14px; color: var(--text); }
.qlink-s { font-size: 12px; color: var(--muted); margin-top: 3px; }

/* ── tables ── */
.tbl-wrap { border: 1px solid var(--line); border-radius: var(--radius); overflow: auto; background: var(--panel-2); box-shadow: var(--shadow); }
table.tbl { width: 100%; border-collapse: collapse; font-size: 13px; }
table.tbl th { text-align: left; padding: 11px 13px; background: linear-gradient(180deg, #14202f, #101926); border-bottom: 1px solid var(--line); position: sticky; top: 0; font-size: 11px; text-transform: uppercase; letter-spacing: .05em; color: var(--muted); white-space: nowrap; cursor: pointer; user-select: none; z-index: 1; }
table.tbl th:hover { color: var(--text); }
table.tbl td { padding: 10px 13px; border-bottom: 1px solid var(--line); white-space: nowrap; max-width: 360px; overflow: hidden; text-overflow: ellipsis; }
table.tbl tr:last-child td { border-bottom: 0; }
table.tbl tbody tr { transition: background .1s; }
table.tbl tbody tr:hover { background: rgba(91,208,255,.06); cursor: pointer; }
.cell-null { color: var(--faint); font-style: italic; }
.pill { display: inline-block; padding: 2px 9px; border-radius: 999px; font-size: 11px; font-weight: 700; background: var(--line-2); color: var(--muted); }

/* ── toolbar / search ── */
.toolbar { display: flex; gap: 10px; align-items: center; flex-wrap: wrap; margin-bottom: 16px; }
.search { flex: 1; min-width: 200px; max-width: 440px; }
.crumbs { display: flex; gap: 8px; align-items: center; font-size: 13px; color: var(--muted); margin-bottom: 12px; }
.crumbs a { color: var(--accent); }
.pager { display: flex; gap: 8px; align-items: center; margin-top: 12px; justify-content: flex-end; font-size: 13px; color: var(--muted); }

/* schema/table grid */
.grid-list { display: grid; gap: 12px; grid-template-columns: repeat(auto-fill, minmax(215px,1fr)); }
.grid-tile { background: linear-gradient(180deg, var(--panel), var(--panel-2)); border: 1px solid var(--line); border-radius: 12px; padding: 14px 16px; cursor: pointer; transition: transform .12s, border-color .12s; box-shadow: var(--shadow); }
.grid-tile:hover { border-color: var(--accent); transform: translateY(-2px); }
.grid-tile .gt-name { font-weight: 700; font-size: 14px; }
.grid-tile .gt-meta { font-size: 12px; color: var(--faint); margin-top: 4px; }

/* ── modal ── */
.modal-overlay { position: fixed; inset: 0; z-index: 100; background: rgba(4,7,12,.74); backdrop-filter: blur(6px); display: grid; place-items: center; padding: 20px; animation: fade .15s ease; }
@keyframes fade { from { opacity: 0; } }
.modal { background: linear-gradient(180deg, var(--panel), var(--panel-2)); border: 1px solid var(--line-2); border-radius: 18px; width: min(660px, 100%); max-height: 86vh; display: flex; flex-direction: column; box-shadow: 0 40px 100px -30px rgba(0,0,0,.9); animation: pop .16s ease; }
@keyframes pop { from { opacity: 0; transform: translateY(10px) scale(.99); } }
.modal-head { display: flex; align-items: center; gap: 12px; padding: 17px 22px; border-bottom: 1px solid var(--line); }
.modal-head h3 { margin: 0; font-size: 16px; flex: 1; }
.modal-x { background: none; border: 0; color: var(--muted); font-size: 22px; line-height: 1; }
.modal-x:hover { color: var(--text); }
.modal-body { padding: 20px 22px; overflow: auto; }
.modal-foot { display: flex; gap: 10px; justify-content: flex-end; padding: 15px 22px; border-top: 1px solid var(--line); }
.kv { display: grid; grid-template-columns: 210px 1fr; gap: 2px 14px; }
.kv dt { color: var(--faint); font-size: 12px; padding: 8px 0; border-bottom: 1px solid var(--line); }
.kv dd { margin: 0; padding: 8px 0; border-bottom: 1px solid var(--line); font-family: var(--mono); font-size: 12.5px; word-break: break-word; }

/* ── toasts ── */
.toasts { position: fixed; right: 18px; bottom: 18px; z-index: 200; display: flex; flex-direction: column; gap: 10px; }
.toast { background: linear-gradient(180deg, var(--panel), var(--panel-2)); border: 1px solid var(--line-2); border-left: 3px solid var(--accent); border-radius: 11px; padding: 13px 17px; font-size: 13px; box-shadow: 0 16px 44px -16px rgba(0,0,0,.8); animation: toastIn .18s ease; max-width: 360px; }
.toast.good { border-left-color: var(--good); }
.toast.bad { border-left-color: var(--bad); }
@keyframes toastIn { from { opacity: 0; transform: translateY(10px); } }

/* ── misc ── */
.spinner { width: 20px; height: 20px; border: 2px solid var(--line-2); border-top-color: var(--accent); border-radius: 50%; animation: spin .7s linear infinite; display: inline-block; }
@keyframes spin { to { transform: rotate(360deg); } }
.center-pad { display: grid; place-items: center; padding: 70px; color: var(--muted); }
.empty { color: var(--faint); padding: 30px; text-align: center; }

/* audit source badges */
.audit-badge { display: inline-block; padding: 2px 8px; border-radius: 6px; font-size: 10px; font-weight: 700; text-transform: uppercase; letter-spacing: .04em; background: var(--line-2); color: var(--muted); white-space: nowrap; }
.audit-badge.d-edit { background: rgba(91,208,255,.16); color: var(--accent); }
.audit-badge.d-usgrp { background: rgba(124,139,255,.18); color: #aab4ff; }
.audit-badge.d-co { background: rgba(95,227,161,.16); color: var(--good); }
.audit-badge.d-violet { background: rgba(176,139,255,.16); color: var(--violet); }
.audit-badge.d-amber { background: rgba(255,182,92,.16); color: var(--amber); }
.audit-badge.d-blue { background: rgba(124,139,255,.16); color: var(--accent-2); }

/* universal audit log — styled after the staff-portal IT audit log */
table.audit-tbl td { vertical-align: middle; white-space: nowrap; }
.audit-tbl .sev-cell { width: 3px; padding: 0 !important; }
.audit-tbl .sev-cell > i { display: block; width: 3px; min-height: 38px; height: 100%; background: transparent; }
.audit-tbl .sev-cell.sev-critical > i { background: var(--bad); }
.audit-tbl .sev-cell.sev-warning > i { background: var(--warn); }
.act-pill { display: inline-block; padding: 2px 9px; border-radius: 6px; font-size: 10.5px; font-weight: 800; letter-spacing: .01em; border: 1px solid transparent; white-space: nowrap; }
.act-pill.a-create  { background: rgba(95,227,161,.13); color: var(--good); border-color: rgba(95,227,161,.24); }
.act-pill.a-approve { background: rgba(91,208,255,.13); color: var(--accent); border-color: rgba(91,208,255,.24); }
.act-pill.a-reject  { background: rgba(255,122,138,.13); color: var(--bad); border-color: rgba(255,122,138,.26); }
.act-pill.a-change  { background: rgba(255,200,107,.13); color: var(--warn); border-color: rgba(255,200,107,.26); }
.act-pill.a-info    { background: rgba(124,139,255,.12); color: var(--accent-2); border-color: rgba(124,139,255,.20); }
.audit-summary { color: var(--muted); max-width: 360px; overflow: hidden; text-overflow: ellipsis; display: block; }
.audit-chev { transition: transform .15s ease; color: var(--faint); display: inline-block; }
.audit-chev.open { transform: rotate(180deg); }
tr.audit-expand > td { padding: 16px 18px !important; white-space: normal !important; max-width: none !important; background: rgba(255,255,255,.015); }
.diff-box { border: 1px solid var(--line); border-radius: 10px; overflow: hidden; margin-top: 4px; }
.diff-box-head { padding: 7px 12px; border-bottom: 1px solid var(--line); font-size: 10px; font-weight: 800; text-transform: uppercase; letter-spacing: .1em; color: var(--faint); display: flex; gap: 8px; align-items: center; }
.diff-tbl { width: 100%; border-collapse: collapse; font-size: 12px; }
.diff-tbl td { padding: 5px 10px; border-top: 1px solid var(--line); white-space: normal; word-break: break-word; vertical-align: top; }
.diff-tbl tr.same { opacity: .5; }
.diff-key { width: 150px; color: var(--text); font-weight: 600; }
.diff-old { color: var(--bad); background: rgba(255,122,138,.05); font-family: var(--mono); }
.diff-new { color: var(--good); background: rgba(95,227,161,.05); font-family: var(--mono); }
.diff-flag { width: 3px; padding: 0 !important; }
.diff-flag.add { background: var(--good); } .diff-flag.del { background: var(--bad); } .diff-flag.chg { background: var(--warn); }
.diff-cards { display: flex; gap: 12px; align-items: stretch; margin-top: 4px; }
.diff-card { flex: 1; border-radius: 10px; padding: 10px 12px; }
.diff-card.before { border: 1px solid rgba(255,122,138,.22); background: rgba(255,122,138,.05); }
.diff-card.after  { border: 1px solid rgba(95,227,161,.22); background: rgba(95,227,161,.05); }
.diff-card pre { margin: 6px 0 0; white-space: pre-wrap; word-break: break-word; font-size: 12px; font-family: var(--mono); }
.meta-grid { display: grid; grid-template-columns: 140px 1fr; gap: 3px 12px; font-size: 11.5px; }
.meta-grid .mk { color: var(--faint); }
.meta-grid .mv { color: var(--muted); font-family: var(--mono); word-break: break-all; }
.audit-foot { margin-top: 14px; padding-top: 12px; border-top: 1px solid var(--line); display: flex; gap: 18px; align-items: center; flex-wrap: wrap; font-size: 11px; color: var(--faint); }
.audit-foot b { color: var(--muted); font-weight: 600; }
.audit-sub { font-size: 10px; font-weight: 800; text-transform: uppercase; letter-spacing: .1em; color: var(--faint); margin: 14px 0 6px; }
.qstrip { display: grid; grid-template-columns: repeat(auto-fit, minmax(96px,1fr)); gap: 8px; margin-bottom: 16px; }
.qstat { border: 1px solid var(--line); border-radius: 12px; padding: 10px 12px; background: var(--panel-2); }
.qstat .ql { font-size: 9.5px; font-weight: 800; text-transform: uppercase; letter-spacing: .1em; color: var(--faint); }
.qstat .qv { font-size: 19px; font-weight: 800; margin-top: 3px; font-variant-numeric: tabular-nums; }
.src-pills { display: flex; gap: 7px; align-items: center; flex-wrap: wrap; margin-bottom: 16px; }
.src-pills .lbl { font-size: 10px; font-weight: 800; text-transform: uppercase; letter-spacing: .1em; color: var(--faint); margin-right: 2px; }
.src-pill { padding: 4px 11px; border-radius: 999px; font-size: 11px; font-weight: 700; border: 1px solid var(--line-2); background: var(--bg-2); color: var(--muted); cursor: pointer; transition: all .12s; }
.src-pill:hover { color: var(--text); border-color: var(--accent); }
.src-pill.active { background: rgba(91,208,255,.16); border-color: rgba(91,208,255,.5); color: var(--accent); }

@media (max-width: 900px) { .home-grid { grid-template-columns: 1fr; } }
@media (max-width: 820px) {
  .shell { grid-template-columns: 1fr; }
  .sidebar { position: fixed; left: 0; top: 0; transform: translateX(-100%); transition: transform .2s; z-index: 50; width: 264px; }
  .sidebar.open { transform: none; }
  .menu-btn { display: inline-flex !important; }
  .kv { grid-template-columns: 1fr; }
  .kv dt { border-bottom: 0; padding-bottom: 0; }
  .hero-title { font-size: 23px; }
  .topbar { gap: 8px; padding: 12px 14px; }
  .topbar h2 { font-size: 15px; min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
  .content { padding: 18px 14px; }
}
.menu-btn { display: none; }

/* phones — keep the audit log readable without horizontal scrolling */
@media (max-width: 600px) {
  .who { display: none; }
  .audit-tbl .col-hide-sm { display: none; }
  table.audit-tbl td, table.audit-tbl th { white-space: normal; padding: 8px 9px; }
  .audit-tbl .sev-cell { padding: 0 !important; }
  .audit-summary { max-width: 160px; }
  .act-pill { font-size: 9.5px; padding: 2px 6px; }
  tr.audit-expand > td { padding: 12px 12px !important; }
  .diff-cards { flex-direction: column; }
  .meta-grid { grid-template-columns: 96px 1fr; }
  .qstrip { grid-template-columns: repeat(auto-fit, minmax(82px, 1fr)); }
  .audit-foot { gap: 10px 14px; }
}
