/* KecoSync sandbox — Keco dark theme.
   Palette: teal #40827d, gold #fdd617, ink #0d1f1e, dim #1a2f2d, mist #e0e6e5.
   The whole point of the color hierarchy is "null is a value" — nullish text
   is muted but VISIBLE (never hidden), so an all-nulls loan is legible. */

:root {
  --bg:           #0d1f1e;
  --bg-2:         #10262a;
  --panel:        #142f31;
  --panel-hi:     #1a3a3d;
  --line:         #223e40;
  --text:         #e0e6e5;
  --text-dim:     #8fa6a3;
  --text-null:    #5c7c78;
  --teal:         #40827d;
  --teal-hi:      #58a29c;
  --gold:         #fdd617;
  --gold-dim:     #a99009;
  --alert:        #d55663;
  --warn:         #dc9a3d;
  --ok:           #3f9d6b;
  --info:         #4d8fbd;
}

* { box-sizing: border-box; }

body {
  margin: 0;
  background: var(--bg);
  color: var(--text);
  font-family: ui-sans-serif, "Segoe UI", "SF Pro Text", system-ui, sans-serif;
  font-size: 14px;
  line-height: 1.45;
}

code { font-family: "JetBrains Mono", "Cascadia Mono", ui-monospace, monospace; font-size: 12.5px; color: var(--text-dim); }

.topbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: 48px;
  padding: 0 20px;
  background: linear-gradient(180deg, var(--panel-hi) 0%, var(--panel) 100%);
  border-bottom: 1px solid var(--line);
}
.brand { display: flex; align-items: baseline; gap: 8px; }
.brand-mark { color: var(--gold); font-size: 18px; }
.brand-name { color: var(--teal-hi); font-weight: 600; letter-spacing: 0.5px; }
.brand-tag { color: var(--text-null); font-size: 11px; letter-spacing: 1px; text-transform: uppercase; }
.topbar-right { display: flex; align-items: center; gap: 10px; }
.persona {
  width: 26px; height: 26px; border-radius: 50%;
  display: inline-flex; align-items: center; justify-content: center;
  font-weight: 700; font-size: 12px;
  border: 1px solid var(--line);
}
.persona.kash { background: #2d4a3a; color: #a4d9b2; }
.persona.kala { background: #2b3f56; color: #a1c1e0; }
.user { color: var(--text-dim); font-size: 12px; }

.shell { display: grid; grid-template-columns: 240px 1fr; min-height: calc(100vh - 48px); }

.sidebar {
  background: var(--bg-2);
  border-right: 1px solid var(--line);
  padding: 16px 12px;
  overflow-y: auto;
}
.nav-group { margin-bottom: 24px; }
.nav-group-label {
  font-size: 10px; letter-spacing: 1.5px; text-transform: uppercase;
  color: var(--text-null); margin: 0 6px 6px;
}
.nav-item {
  display: block; padding: 6px 10px; margin-bottom: 2px;
  border-radius: 4px; text-decoration: none; color: var(--text-dim);
  font-size: 13px;
}
.nav-item:hover { background: var(--panel); color: var(--text); }
.nav-item.active { background: var(--panel-hi); color: var(--gold); border-left: 2px solid var(--teal); padding-left: 8px; }
.addr {
  font-family: "JetBrains Mono", ui-monospace, monospace;
  font-size: 11.5px; color: var(--text-null);
  padding: 3px 6px;
}
.meta { padding: 3px 6px; font-size: 11.5px; color: var(--text-null); }

.content { padding: 24px 28px; overflow-y: auto; }

.page-head { margin-bottom: 20px; }
.page-head h1 {
  margin: 0 0 4px;
  font-size: 20px;
  color: var(--text);
  font-weight: 500;
}
.page-sub { color: var(--text-null); font-size: 12px; font-family: "JetBrains Mono", ui-monospace, monospace; margin-left: 12px; }

.filter-bar { display: flex; flex-wrap: wrap; gap: 6px; margin-top: 10px; }
.filter-chip {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 4px 10px;
  border: 1px solid var(--line);
  border-radius: 12px;
  text-decoration: none;
  color: var(--text-dim);
  font-size: 12px;
  background: var(--panel);
}
.filter-chip:hover { border-color: var(--teal); color: var(--text); }
.filter-chip.active { background: var(--teal); color: var(--bg); border-color: var(--teal-hi); }
.filter-chip .count {
  background: var(--bg);
  color: var(--text-null);
  padding: 0 6px;
  border-radius: 8px;
  font-size: 11px;
}
.filter-chip.active .count { background: var(--bg-2); color: var(--gold); }

.card-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(420px, 1fr));
  gap: 12px;
}
.loan-card {
  display: block;
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: 6px;
  padding: 14px 16px;
  text-decoration: none;
  color: var(--text);
  transition: border-color 0.12s ease, background 0.12s ease;
}
.loan-card:hover { border-color: var(--teal-hi); background: var(--panel-hi); }
.loan-card-head { display: flex; justify-content: space-between; align-items: center; margin-bottom: 8px; }
.loan-card-badges { display: flex; gap: 4px; flex-wrap: wrap; }
.loan-card-amount { font-size: 18px; font-weight: 600; color: var(--gold); }
.loan-card-addr { font-size: 14px; color: var(--text); margin-bottom: 10px; }
.loan-card-meta {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 8px;
  padding: 8px 0; border-top: 1px solid var(--line); border-bottom: 1px solid var(--line);
  font-size: 11.5px;
}
.meta-cell { display: flex; flex-direction: column; gap: 2px; }
.meta-cell label {
  color: var(--text-null); font-size: 10px; text-transform: uppercase; letter-spacing: 0.7px;
}
.meta-cell value { color: var(--text); font-family: "JetBrains Mono", ui-monospace, monospace; font-size: 12px; }
.loan-card-foot {
  display: flex; justify-content: space-between; align-items: center;
  margin-top: 8px; font-size: 11px;
}
.sources { display: flex; gap: 4px; }
.conf { font-family: "JetBrains Mono", ui-monospace, monospace; }
.conf-high { color: var(--ok); }
.conf-mid  { color: var(--warn); }
.conf-low  { color: var(--alert); }

.badge {
  display: inline-block;
  padding: 2px 8px;
  border-radius: 10px;
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.3px;
  border: 1px solid transparent;
}
.status-early     { background: #1c3648; color: #7ab4d5; border-color: #2c4a5e; }
.status-mid       { background: #1e394b; color: #8cc0dc; border-color: #325267; }
.status-review    { background: #3a3a1e; color: #d6cf7f; border-color: #57532c; }
.status-approved  { background: #1f3f28; color: #78d18b; border-color: #305f3a; }
.status-funded    { background: #2b4a20; color: #a3e08b; border-color: #4a7233; }
.status-closed    { background: var(--gold-dim); color: var(--bg); border-color: var(--gold); }
.status-denied    { background: #4a1c22; color: #e78896; border-color: #6b2c34; }
.status-terminal  { background: #3a3a3a; color: #b5b5b5; border-color: #555; }
.status-hold      { background: #402d1c; color: #dcb37f; border-color: #603e2a; }
.status-unknown   { background: var(--panel); color: var(--text-null); border-color: var(--line); }

.review-proposed  { background: #2a2a3a; color: #a8a8c4; border-color: #40405a; }
.review-needs     { background: #4a3c1c; color: #e9c674; border-color: #6c592a; }
.review-confirmed { background: #1c3a3a; color: #7dc4c0; border-color: #2c5854; }
.review-final     { background: #1f3f28; color: #82d99a; border-color: #305f3a; }
.review-rejected  { background: #4a1c22; color: #e78896; border-color: #6b2c34; }
.review-none      { background: var(--panel); color: var(--text-null); border-color: var(--line); }

.tier-base  { background: #223e40; color: #8fcfca; border-color: #2f5c5e; }
.tier-1b    { background: #3a4720; color: #c8dc82; border-color: #526a2f; }
.tier-2b    { background: #4a4020; color: #e0c86b; border-color: #6c5e2f; }
.tier-disc  { background: #402440; color: #d09fd0; border-color: #5f395f; }
.tier-none  { background: var(--panel); color: var(--text-null); border-color: var(--line); }

.chip {
  display: inline-block;
  padding: 1px 7px;
  border-radius: 8px;
  font-size: 10px;
  font-weight: 600;
  letter-spacing: 0.3px;
  border: 1px solid transparent;
}
.src-ma       { background: #2a3f4a; color: #91c1d8; border-color: #3e5c6c; }
.src-hs       { background: #40331f; color: #ffb95c; border-color: #6b552c; }
.src-sql      { background: #2f3a1e; color: #a0c66b; border-color: #4c5c2c; }
.src-leila    { background: #40243f; color: #d78ad3; border-color: #6c3e6a; }
.src-intake   { background: #2b2b3e; color: #a5a5cc; border-color: #43435c; }
.src-unknown  { background: var(--panel); color: var(--text-null); border-color: var(--line); }

.nullish { color: var(--text-null); font-style: italic; }

.loan-head {
  display: grid; grid-template-columns: 1fr auto;
  gap: 20px;
  padding: 16px 20px;
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: 6px;
  margin-bottom: 16px;
}
.loan-head-badges { display: flex; gap: 6px; margin-bottom: 8px; }
.loan-head-addr { margin: 0 0 8px; font-size: 20px; color: var(--gold); font-weight: 500; }
.loan-head-meta { display: flex; gap: 18px; font-size: 12px; color: var(--text-dim); flex-wrap: wrap; }
.loan-head-meta code { color: var(--text-dim); }
.loan-head-sources { margin-top: 8px; display: flex; gap: 4px; }
.loan-head-r { display: grid; grid-template-columns: repeat(2, 1fr); gap: 6px 20px; align-content: start; }
.loan-head-r .stat { text-align: right; }
.loan-head-r .stat label {
  display: block;
  font-size: 10px; text-transform: uppercase; color: var(--text-null); letter-spacing: 0.8px;
}
.loan-head-r .stat value { font-size: 14px; color: var(--text); }

.tabs { display: flex; gap: 2px; margin-bottom: 12px; border-bottom: 1px solid var(--line); }
.tab {
  padding: 8px 16px;
  text-decoration: none;
  color: var(--text-dim);
  font-size: 12.5px;
  border: 1px solid transparent;
  border-bottom: none;
  border-radius: 4px 4px 0 0;
}
.tab:hover { color: var(--text); background: var(--panel); }
.tab.active {
  background: var(--panel);
  color: var(--gold);
  border-color: var(--line);
  border-bottom: 1px solid var(--panel);
  margin-bottom: -1px;
}

.tab-body { min-height: 300px; }

.grid-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }

.panel {
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: 6px;
  padding: 14px 18px;
  margin-bottom: 12px;
}
.panel h2 {
  margin: 0 0 10px;
  font-size: 13px; letter-spacing: 0.5px; text-transform: uppercase;
  color: var(--teal-hi);
  border-bottom: 1px solid var(--line);
  padding-bottom: 6px;
}
dl.kv { display: grid; grid-template-columns: max-content 1fr; gap: 6px 16px; margin: 0; font-size: 13px; }
dl.kv dt { color: var(--text-null); }
dl.kv dd { margin: 0; color: var(--text); }

.hint { color: var(--text-dim); font-size: 12px; margin: 8px 0 0; font-style: italic; }
.empty { color: var(--text-null); padding: 40px; text-align: center; background: var(--panel); border: 1px dashed var(--line); border-radius: 6px; }

.trace, .cid-list { margin: 0; padding-left: 16px; font-size: 12px; }
.cid-list li { list-style: none; margin-left: -16px; margin-bottom: 4px; }

table.mini, table.tbl { width: 100%; border-collapse: collapse; font-size: 12.5px; }
table.mini th, table.tbl th {
  text-align: left; padding: 6px 10px; color: var(--text-null);
  font-size: 10.5px; text-transform: uppercase; letter-spacing: 0.7px;
  border-bottom: 1px solid var(--line);
  font-weight: 500;
}
table.mini td, table.tbl td {
  padding: 6px 10px; border-bottom: 1px solid var(--line); color: var(--text);
}
table.tbl tbody tr:hover { background: var(--panel-hi); }
table.mini.prov code { color: var(--gold-dim); }

.timeline { list-style: none; padding: 0; margin: 0; }
.ev {
  display: grid; grid-template-columns: 180px 1fr;
  gap: 16px;
  padding: 10px 14px;
  border-left: 3px solid var(--line);
  margin-bottom: 4px;
  background: var(--panel);
}
.ev-ts { font-family: "JetBrains Mono", ui-monospace, monospace; font-size: 11.5px; color: var(--text-null); }
.ev-head { display: flex; gap: 12px; margin-bottom: 4px; }
.ev-kind { font-weight: 600; font-size: 12px; color: var(--gold-dim); }
.ev-actor { font-size: 11.5px; color: var(--text-dim); }
.ev-reason { color: var(--text); font-size: 13px; margin-bottom: 4px; }
.ev-change { font-size: 12px; color: var(--text-dim); }
.ev-change code { color: var(--teal-hi); }

.ev-created  { border-left-color: var(--info); }
.ev-status   { border-left-color: var(--teal); }
.ev-review   { border-left-color: var(--gold); }
.ev-doc      { border-left-color: #a08cd8; }
.ev-call     { border-left-color: #dc9a3d; }
.ev-tier     { border-left-color: var(--gold); }
.ev-comm     { border-left-color: var(--ok); }
.ev-lo       { border-left-color: var(--teal-hi); }
.ev-other    { border-left-color: var(--line); }

.doc-ok       { background: #1f3f28; color: #78d18b; border-color: #305f3a; }
.doc-pending  { background: #402d1c; color: #dcb37f; border-color: #603e2a; }
.doc-exp      { background: #4a1c22; color: #e78896; border-color: #6b2c34; }
.doc-none     { background: var(--panel); color: var(--text-null); border-color: var(--line); }

.call-card {
  background: var(--panel-hi);
  border: 1px solid var(--line);
  border-radius: 4px;
  padding: 10px 12px;
  margin-bottom: 8px;
}
.call-head {
  display: grid; grid-template-columns: 80px 1fr auto auto; gap: 8px;
  font-size: 12px; align-items: center;
}
.call-dir { padding: 1px 6px; border-radius: 8px; font-size: 10.5px; text-transform: uppercase; }
.call-dir.inbound  { background: #1f3f28; color: #78d18b; }
.call-dir.outbound { background: #1c3648; color: #7ab4d5; }
.call-title { font-weight: 500; color: var(--text); }
.call-dur, .call-ts { color: var(--text-null); font-family: "JetBrains Mono", ui-monospace, monospace; font-size: 11.5px; }
.call-summary { margin-top: 6px; font-size: 12.5px; color: var(--text); }

.light {
  display: inline-block;
  width: 10px; height: 10px; border-radius: 50%;
  vertical-align: middle;
}
.light.green  { background: var(--ok);    box-shadow: 0 0 6px var(--ok); }
.light.yellow { background: var(--warn);  box-shadow: 0 0 6px var(--warn); }
.light.red    { background: var(--alert); box-shadow: 0 0 6px var(--alert); }
.light.gray   { background: var(--text-null); }

/* ---- HubSpot sync banner ---- */

.hs-banner {
  display: flex; align-items: center; gap: 12px;
  background: linear-gradient(90deg, #40331f 0%, #3a2d1a 100%);
  border: 1px solid #6b552c; border-radius: 6px;
  padding: 8px 14px; margin-bottom: 16px;
  font-size: 12.5px;
}
.hs-banner .hs-tag {
  font-weight: 600; color: #ffb95c; letter-spacing: 0.5px;
  text-transform: uppercase; font-size: 10.5px;
}
.hs-banner .hs-mode { color: var(--text); font-family: "JetBrains Mono", ui-monospace, monospace; font-size: 11.5px; }
.hs-banner .hs-log { margin-left: auto; color: var(--gold); text-decoration: none; font-size: 12px; }
.hs-banner .hs-log:hover { text-decoration: underline; }

/* ---- editable field UX ---- */

dl.kv dd .edit-pencil {
  margin-left: 8px; color: var(--text-null); text-decoration: none;
  padding: 1px 4px; border-radius: 4px; font-size: 11px;
}
dl.kv dd .edit-pencil:hover { color: var(--gold); background: var(--bg-2); }
dl.kv dd.editing { padding: 4px 0; }

form.inline {
  display: flex; flex-wrap: wrap; align-items: center; gap: 6px;
  margin: 0;
}
form.inline input[type="text"],
form.inline input[type="number"],
form.inline input[type="date"],
form.inline select {
  background: var(--bg-2); color: var(--text);
  border: 1px solid var(--teal);
  border-radius: 4px;
  padding: 4px 8px;
  font: inherit;
  min-width: 180px;
}
form.inline input:focus, form.inline select:focus {
  outline: none;
  border-color: var(--gold);
  box-shadow: 0 0 0 2px rgba(253, 214, 23, 0.15);
}

button, .btn-primary, .btn-cancel, .btn-save, .btn-undo {
  border: 1px solid var(--line); border-radius: 4px;
  padding: 5px 12px; font-size: 12px; cursor: pointer;
  text-decoration: none; display: inline-block;
  font-family: inherit;
}
.btn-save     { background: var(--teal);  color: var(--bg);      border-color: var(--teal-hi); }
.btn-save:hover { background: var(--teal-hi); }
.btn-cancel   { background: var(--panel); color: var(--text-dim);}
.btn-cancel:hover { background: var(--panel-hi); color: var(--text); }
.btn-primary  { background: var(--gold-dim); color: var(--bg); border-color: var(--gold); font-weight: 500; }
.btn-primary:hover { background: var(--gold); }
.btn-undo     { background: var(--panel-hi); color: var(--warn); border-color: var(--warn); }
.btn-undo:hover { background: var(--warn); color: var(--bg); }

.edit-scope { font-size: 10.5px; margin-left: 8px; padding: 1px 6px; border-radius: 8px; }
.edit-scope.scope-local { color: var(--teal-hi); background: rgba(88, 162, 156, 0.08); }
.edit-scope.scope-ext   { color: #ffb95c; background: rgba(255, 185, 92, 0.08); }

.ro-tag {
  display: inline-block; font-size: 10px; margin-left: 8px;
  color: var(--text-null); background: var(--bg-2);
  padding: 1px 6px; border-radius: 6px; letter-spacing: 0.4px; text-transform: uppercase;
}

.flash {
  background: var(--ok); color: var(--bg);
  padding: 8px 14px; margin-bottom: 12px;
  border-radius: 4px; font-size: 13px; font-weight: 500;
}

/* ---- audit log ---- */

table.audit td { vertical-align: top; }
table.audit td code { color: var(--gold-dim); }
.ekind-local     { background: var(--panel-hi); color: var(--teal-hi); border-color: var(--teal); }
.ekind-pending   { background: #402d1c; color: var(--warn); border-color: #6b4c2a; }
.ekind-written   { background: #1f3f28; color: var(--ok); border-color: #305f3a; }
.ekind-failed    { background: #4a1c22; color: var(--alert); border-color: #6b2c34; }
.ekind-reversed  { background: #3a3a3a; color: #b5b5b5; border-color: #555; }

.muted { color: var(--text-null); }

form.inline button { margin-left: 4px; }

/* ---- intake form ---- */

.intake-form dl.form-kv {
  display: grid; grid-template-columns: 160px 1fr;
  gap: 8px 12px;
}
.intake-form dl.form-kv dd input[type="text"],
.intake-form dl.form-kv dd input[type="number"],
.intake-form dl.form-kv dd select {
  width: 100%;
  background: var(--bg-2); color: var(--text);
  border: 1px solid var(--line);
  border-radius: 4px; padding: 6px 10px;
  font: inherit;
}
.intake-form dl.form-kv dd input:focus,
.intake-form dl.form-kv dd select:focus {
  outline: none; border-color: var(--gold);
  box-shadow: 0 0 0 2px rgba(253, 214, 23, 0.15);
}
.form-actions { margin: 16px 0; display: flex; gap: 10px; }

/* ---- inbox action ---- */
.intake-btn { margin-left: auto; padding: 5px 12px; font-size: 12px; }

/* new event kind */
.ev-updated { border-left-color: var(--gold); }

/* new source chip for sandbox */
.src-sandbox { background: #2b2b3e; color: #cccccc; border-color: #48485f; }

/* ---- F6 commission formula debug ---- */
.warn-banner {
  background: #402d1c; color: var(--warn); border: 1px solid #6b552c;
  padding: 8px 14px; border-radius: 4px; margin-bottom: 12px; font-size: 13px;
}
ol.derivation { list-style: none; padding: 0; margin: 0; }
ol.derivation li {
  border-left: 3px solid var(--teal); padding: 8px 14px; margin-bottom: 8px;
  background: var(--panel-hi);
}
.step-name { font-weight: 600; color: var(--gold-dim); font-size: 13px; margin-bottom: 4px; }
.step-formula { color: var(--text-dim); font-size: 12.5px; margin-bottom: 4px; }
.step-formula code { color: var(--teal-hi); }
.step-result { color: var(--text); font-family: "JetBrains Mono", ui-monospace, monospace; font-size: 13px; }
.step-note { color: var(--text-null); font-size: 12px; margin-top: 4px; font-style: italic; }
.step-table { margin-top: 8px; max-width: 260px; }
.step-table tr.row-active { background: rgba(253, 214, 23, 0.08); }
.crumb { color: var(--text-dim); font-size: 12.5px; margin-top: 4px; }
.crumb a { color: var(--teal-hi); text-decoration: none; }
.crumb a:hover { color: var(--gold); }

/* ---- F5 attorney report ---- */

.grid-3.stats-strip {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 10px;
  margin-bottom: 16px;
}
.stat-tile {
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: 6px;
  padding: 12px 16px;
}
.stat-tile label {
  display: block;
  font-size: 10.5px; letter-spacing: 0.7px; text-transform: uppercase;
  color: var(--text-null); margin-bottom: 4px;
}
.stat-tile value {
  font-size: 20px;
  color: var(--gold);
  font-weight: 500;
  font-family: "JetBrains Mono", ui-monospace, monospace;
}

/* ---- substrate page density regime badges ---- */
.z-green   { background: #1f3f28; color: #78d18b; border-color: #305f3a; }
.z-yellow  { background: #3a3a1e; color: #d6cf7f; border-color: #57532c; }
.z-orange  { background: #402d1c; color: #dcb37f; border-color: #603e2a; }
.z-red     { background: #4a1c22; color: #e78896; border-color: #6b2c34; }
.z-unknown { background: var(--panel); color: var(--text-null); border-color: var(--line); }

.reg-legend { list-style: none; padding: 0; }
.reg-legend li { padding: 4px 0; color: var(--text); }

/* ---- sync status page ---- */
.doc-alert { background: #4a1c22; color: #e78896; border-color: #6b2c34; }

.empty-inbox {
  background: var(--panel);
  border: 1px dashed var(--line);
  border-radius: 8px;
  padding: 60px 40px;
  text-align: center;
}
.empty-inbox h2 { color: var(--gold); margin-top: 0; font-weight: 500; }
.empty-inbox p { color: var(--text-dim); margin: 10px 0; }
.empty-inbox p:last-child { margin-top: 24px; }

/* ---- Search bar ---- */
.search-bar {
  display: flex;
  gap: 8px;
  margin-top: 16px;
  align-items: center;
}
.search-bar input[type="search"] {
  flex: 1;
  padding: 10px 14px;
  border: 1px solid var(--line);
  background: var(--bg-2);
  color: var(--mist);
  border-radius: 6px;
  font-size: 15px;
  min-width: 400px;
}
.search-bar input[type="search"]:focus {
  outline: none;
  border-color: var(--gold);
  box-shadow: 0 0 0 2px rgba(253, 214, 23, 0.15);
}
.search-bar .btn-search {
  padding: 10px 20px;
  background: var(--teal);
  color: var(--mist);
  border: none;
  border-radius: 6px;
  cursor: pointer;
  font-size: 14px;
}
.search-bar .btn-search:hover { background: #4c9c95; }
.search-bar .btn-clear {
  color: var(--text-dim);
  text-decoration: none;
  font-size: 13px;
  padding: 4px 10px;
}
.search-bar .btn-clear:hover { color: var(--mist); }

mark {
  background: var(--gold);
  color: var(--ink);
  padding: 0 2px;
  border-radius: 2px;
  font-weight: 600;
}

/* ---- Pager ---- */
.pager {
  margin-top: 32px;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 20px;
  padding: 20px 0;
  border-top: 1px solid var(--line);
}
.pg-prev, .pg-next {
  color: var(--gold);
  text-decoration: none;
  padding: 8px 16px;
  border: 1px solid var(--line);
  border-radius: 4px;
  background: var(--panel);
}
.pg-prev:hover, .pg-next:hover { background: var(--panel-hi); }
.pg-info { color: var(--text-dim); font-size: 14px; }

/* ---- Doc count badge on loan card ---- */
.doc-count {
  display: inline-block;
  padding: 2px 7px;
  background: rgba(253, 214, 23, 0.15);
  color: var(--gold);
  border-radius: 4px;
  font-size: 11px;
  font-weight: 600;
}

/* ---- MA source panel on attachments tab ---- */
.ma-source-row {
  display: flex;
  gap: 12px;
  align-items: center;
  flex-wrap: wrap;
  margin-bottom: 12px;
}
.btn-secondary {
  padding: 10px 20px;
  background: var(--panel-hi);
  color: var(--mist);
  border: 1px solid var(--line);
  border-radius: 6px;
  text-decoration: none;
  font-size: 14px;
  cursor: pointer;
  display: inline-block;
}
.btn-secondary:hover { border-color: var(--gold); color: var(--gold); }

/* ---- Call/audio player ---- */
.call-audio-row {
  display: flex;
  align-items: center;
  gap: 10px;
  margin: 10px 0;
}
.call-audio {
  flex: 1;
  filter: invert(0.85) hue-rotate(160deg) sepia(0.2);
}
.call-audio-row .btn-secondary { white-space: nowrap; }
.call-noaudio {
  padding: 6px 10px;
  color: var(--text-dim);
  font-style: italic;
  font-size: 13px;
}

/* ---- Truncate long doc names ---- */
.docname {
  display: inline-block;
  max-width: 320px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  vertical-align: middle;
}

/* ---- Deal-sheet sub-heading inside a panel ---- */
.panel-sub {
  margin: 16px 0 6px 0;
  padding-top: 10px;
  border-top: 1px dashed var(--border-dim);
  font-size: 13px;
  letter-spacing: 0.5px;
  color: var(--text-dim);
  text-transform: uppercase;
}

/* ---- State-over-time timeline (pipeline stage history) ---- */
.state-timeline-wrap {
  margin-top: 12px;
  padding-top: 10px;
  border-top: 1px dashed var(--border-dim);
}
.state-timeline-label {
  font-size: 11px;
  letter-spacing: 0.6px;
  color: var(--text-dim);
  text-transform: uppercase;
  margin-bottom: 6px;
}
.state-timeline-empty { font-style: italic; }
.state-timeline {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  counter-reset: st;
}
.state-timeline .st-node {
  display: flex;
  flex-direction: column;
  gap: 2px;
  padding: 6px 10px;
  border-radius: 6px;
  background: rgba(255,255,255,0.03);
  border: 1px solid var(--border-dim);
  min-width: 110px;
  position: relative;
}
.state-timeline .st-node.current {
  border-color: var(--gold);
  background: rgba(255,215,0,0.08);
}
.state-timeline .st-node + .st-node::before {
  content: "→";
  position: absolute;
  left: -12px;
  top: 50%;
  transform: translateY(-50%);
  color: var(--text-dim);
  font-size: 12px;
}
.state-timeline .st-date {
  font-size: 11px;
  color: var(--text-dim);
}
.state-timeline .st-badge { font-size: 12px; }
.state-timeline .st-dur {
  font-size: 10px;
  color: var(--text-dim);
  font-family: monospace;
}

/* ---- Dashboard ---- */
.kpi-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 12px;
  margin-bottom: 18px;
}
.kpi {
  background: rgba(255,255,255,0.03);
  border: 1px solid var(--border-dim);
  border-radius: 8px;
  padding: 14px 16px;
}
.kpi label { display:block; font-size:11px; text-transform:uppercase; letter-spacing:0.6px; color: var(--text-dim); margin-bottom:6px; }
.kpi value { display:block; font-size:22px; font-weight:600; color: var(--text); }

.funnel { width: 100%; border-collapse: collapse; }
.funnel th, .funnel td { padding: 8px 10px; border-bottom: 1px solid var(--border-dim); text-align: left; }
.funnel th { font-size: 11px; text-transform: uppercase; letter-spacing: 0.6px; color: var(--text-dim); }
.funnel td.num, .funnel th.num { text-align: right; font-variant-numeric: tabular-nums; }
.funnel .bar-cell { width: 30%; }
.funnel .bar { height: 8px; border-radius: 4px; background: var(--gold, #d4af37); opacity: 0.75; }
.funnel .bar.dim { background: var(--border-dim); }
.funnel .stage-link { text-decoration: none; }
.funnel tr.row-null td { color: var(--text-dim); }

/* ---- Filter bar sub-labels + pipeline chips ---- */
.filter-label { font-size: 11px; text-transform: uppercase; letter-spacing: 0.6px; color: var(--text-dim); margin-right: 8px; }
.filter-chip.pchip { border-color: var(--gold); }
.filter-chip.pchip.active { background: var(--gold); color: #111; }

/* ---- Sign out button ---- */
.btn-signout {
  background: transparent; color: var(--text-dim); border: 1px solid var(--border-dim);
  border-radius: 4px; padding: 3px 10px; font-size: 12px; cursor: pointer;
}
.btn-signout:hover { color: var(--text); border-color: var(--gold); }

/* ---- Sub-panel heading ---- */
.panel h2 + h2.panel-sub, .panel .panel-sub { margin-top: 14px; }
