@import url('colors_and_type.css');

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
body { background: var(--sp-snow); color: var(--sp-ink); font-family: var(--sp-font-body); font-size: 14px; }

/* Dashboard-scoped tokens — slightly tighter & cooler than marketing */
.spd {
  --spd-sidebar-w: 240px;
  --spd-topbar-h: 60px;
  --spd-card-pad: 20px;
  --spd-row-h: 56px;
  --spd-radius: 6px;
  --spd-hair: 1px solid rgba(47, 36, 24, 0.13);
  --spd-hair-strong: 1px solid rgba(47, 36, 24, 0.22);
}

/* =========================================================================
   App shell
   ========================================================================= */
.spd { min-height: 100vh; display: grid; grid-template-columns: var(--spd-sidebar-w) 1fr; background: var(--sp-snow); color: var(--sp-ink); }

/* ---------- Sidebar ---------- */
.spd-side { background: var(--sp-brown-900); color: var(--sp-paper); padding: 18px 14px; display: flex; flex-direction: column; gap: 4px; position: sticky; top: 0; height: 100vh; }
.spd-side-brand { display: flex; align-items: center; gap: 10px; padding: 10px 8px 20px; border-bottom: 1px solid rgba(244,239,231,0.10); margin-bottom: 14px; }
.spd-side-brand .mark { width: 32px; height: 32px; border-radius: 6px; background: var(--sp-brown-700); display: flex; align-items: center; justify-content: center; font-family: var(--sp-font-display); font-size: 18px; color: var(--sp-paper); }
.spd-side-brand .name { font-family: var(--sp-font-display); font-size: 18px; line-height: 1; color: var(--sp-paper); }
.spd-side-brand .tag { font-size: 10px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--sp-gold-300); margin-top: 3px; }
.spd-side-section { font-size: 10px; letter-spacing: 0.16em; text-transform: uppercase; color: rgba(244,239,231,0.62); padding: 14px 10px 8px; font-weight: 700; }
.spd-side-link { display: flex; align-items: center; gap: 12px; padding: 9px 10px; border-radius: 5px; color: rgba(244,239,231,0.88); font-size: 14px; font-weight: 600; cursor: pointer; transition: background 140ms, color 140ms; text-decoration: none; }
.spd-side-link:hover { background: rgba(244,239,231,0.06); color: var(--sp-paper); }
.spd-side-link.active { background: var(--sp-brown-700); color: var(--sp-paper); }
.spd-side-link .badge { margin-left: auto; font-size: 11px; font-weight: 600; background: var(--sp-gold-500); color: var(--sp-brown-900); padding: 1px 7px; border-radius: 999px; letter-spacing: 0.02em; }
.spd-side-foot { margin-top: auto; padding-top: 14px; border-top: 1px solid rgba(244,239,231,0.10); display: flex; align-items: center; gap: 10px; }
.spd-side-foot .av { width: 32px; height: 32px; border-radius: 50%; background: linear-gradient(135deg, var(--sp-brown-400), var(--sp-brown-600)); display:flex; align-items:center; justify-content:center; color: var(--sp-paper); font-family: var(--sp-font-display); font-size: 14px; flex-shrink:0; }
.spd-side-foot .name-block { font-size: 13px; color: var(--sp-paper); line-height: 1.2; }
.spd-side-foot .role { font-size: 11px; color: rgba(244,239,231,0.55); letter-spacing: 0.04em; }

/* ---------- Main column ---------- */
.spd-main { display: flex; flex-direction: column; min-width: 0; }
.spd-topbar { height: var(--spd-topbar-h); background: var(--sp-white); border-bottom: var(--spd-hair); display: flex; align-items: center; gap: 16px; padding: 0 28px; position: sticky; top: 0; z-index: 10; }
.spd-topbar h1 { font-family: var(--sp-font-display); font-size: 22px; color: var(--sp-brown-900); margin: 0; font-weight: 400; line-height: 1; letter-spacing: 0; }
.spd-topbar .crumbs { color: var(--sp-ink-2); font-size: 12px; letter-spacing: 0.06em; text-transform: uppercase; margin-bottom: 2px; font-weight: 600; }
.spd-topbar .head-block { display: flex; flex-direction: column; }
.spd-topbar .spacer { flex: 1; }
.spd-search { display: flex; align-items: center; gap: 8px; background: var(--sp-snow); border: var(--spd-hair); border-radius: var(--spd-radius); padding: 8px 12px; min-width: 280px; color: var(--sp-ink-3); }
.spd-search input { background: transparent; border: 0; outline: 0; flex: 1; font-family: var(--sp-font-body); font-size: 14px; color: var(--sp-ink); }
.spd-search input::placeholder { color: var(--sp-ink-3); }
.spd-search kbd { font-family: var(--sp-font-mono); font-size: 10px; color: var(--sp-ink-3); border: var(--spd-hair); padding: 2px 5px; border-radius: 3px; }
.spd-topbar .icon-btn { width: 36px; height: 36px; border-radius: var(--spd-radius); display: flex; align-items: center; justify-content: center; color: var(--sp-ink-2); cursor: pointer; position: relative; }
.spd-topbar .icon-btn:hover { background: var(--sp-snow); color: var(--sp-brown-900); }
.spd-topbar .icon-btn .dot { position: absolute; top: 8px; right: 9px; width: 7px; height: 7px; border-radius: 50%; background: var(--sp-warning); border: 2px solid var(--sp-white); }

.spd-page { padding: 24px 28px 48px; max-width: 1400px; }
.spd-page-head { display: flex; justify-content: space-between; align-items: flex-end; gap: 20px; margin-bottom: 20px; }
.spd-page-head h2 { font-family: var(--sp-font-display); font-size: 32px; line-height: 1.1; color: var(--sp-brown-900); margin: 0; font-weight: 400; letter-spacing: 0; }
.spd-page-head .sub { font-size: 14px; color: var(--sp-ink-2); margin-top: 4px; }

/* =========================================================================
   Buttons (compact dashboard variants)
   ========================================================================= */
.spd-btn { display: inline-flex; align-items: center; gap: 8px; font-family: var(--sp-font-body); font-weight: 600; font-size: 13px; padding: 9px 14px; border-radius: var(--spd-radius); border: 1px solid transparent; cursor: pointer; transition: all 140ms; line-height: 1; text-decoration: none; }
.spd-btn-primary { background: var(--sp-brown-900); color: #FFFFFF !important; }
.spd-btn-primary:hover { background: var(--sp-brown-700); }
.spd-btn-secondary { background: var(--sp-white); color: var(--sp-brown-900) !important; border-color: rgba(47,36,24,0.14); }
.spd-btn-secondary:hover { background: var(--sp-snow); border-color: var(--sp-brown-700); }
.spd-btn-preview { background: linear-gradient(180deg, rgba(201,180,136,0.58), rgba(166,139,91,0.30)); color: var(--sp-brown-900) !important; border-color: rgba(138,110,58,0.58); box-shadow: 0 1px 0 rgba(47,36,24,0.05), 0 6px 16px -14px rgba(47,36,24,0.42), inset 0 0 0 1px rgba(255,255,255,0.42); }
.spd-btn-preview:hover { background: linear-gradient(180deg, rgba(201,180,136,0.72), rgba(166,139,91,0.42)); border-color: var(--sp-gold-700); transform: translateY(-1px); box-shadow: 0 7px 18px -12px rgba(47,36,24,0.45), inset 0 0 0 1px rgba(255,255,255,0.48); }
.spd-btn-preview svg { color: var(--sp-gold-700); }
.spd-btn-ghost { background: transparent; color: var(--sp-brown-700) !important; padding: 9px 8px; }
.spd-btn-ghost:hover { color: var(--sp-brown-900) !important; }

/* =========================================================================
   Cards / panels
   ========================================================================= */
.spd-card { background: var(--sp-white); border: var(--spd-hair); border-radius: var(--spd-radius); padding: var(--spd-card-pad); box-shadow: 0 1px 0 rgba(47,36,24,0.02); }
.spd-card-head { display: flex; justify-content: space-between; align-items: center; gap: 12px; margin-bottom: 14px; }
.spd-card-head h3 { font-family: var(--sp-font-body); font-weight: 600; font-size: 14px; color: var(--sp-brown-900); margin: 0; letter-spacing: 0; }
.spd-card-head .head-meta { font-size: 12px; color: var(--sp-ink-3); }

/* =========================================================================
   KPI tile
   ========================================================================= */
.spd-kpi { background: var(--sp-white); border: var(--spd-hair); border-radius: var(--spd-radius); padding: 18px 20px; display: flex; flex-direction: column; gap: 6px; min-height: 138px; position: relative; overflow: hidden; }
.spd-kpi .lbl { font-size: 11px; font-weight: 600; letter-spacing: 0.12em; text-transform: uppercase; color: var(--sp-ink-3); }
.spd-kpi .val { font-family: var(--sp-font-display); font-weight: 400; font-size: 40px; line-height: 1; color: var(--sp-brown-900); margin-top: 2px; }
.spd-kpi .val .unit { font-size: 0.5em; color: var(--sp-gold-700); margin-left: 4px; }
.spd-kpi .delta { display: inline-flex; align-items: center; gap: 4px; font-size: 12px; font-weight: 600; }
.spd-kpi .delta.up { color: var(--sp-success); }
.spd-kpi .delta.down { color: var(--sp-error); }
.spd-kpi .delta .vs { color: var(--sp-ink-3); font-weight: 400; }
.spd-kpi .spark { margin-top: auto; height: 32px; }

/* =========================================================================
   Data table
   ========================================================================= */
.spd-table { width: 100%; border-collapse: collapse; font-size: 13px; }
.spd-table thead th { font-size: 11px; font-weight: 800; letter-spacing: 0.08em; text-transform: uppercase; color: var(--sp-ink-2); text-align: left; padding: 10px 14px; border-bottom: var(--spd-hair-strong); background: var(--sp-snow); }
.spd-table tbody td { padding: 14px; border-bottom: var(--spd-hair); color: var(--sp-ink); vertical-align: middle; font-weight: 500; }
.spd-table tbody tr { cursor: pointer; transition: background 100ms; }
.spd-table tbody tr:hover { background: var(--sp-snow); }
.spd-table tbody tr:last-child td { border-bottom: 0; }
.spd-table .cell-primary { font-weight: 600; color: var(--sp-brown-900); }
.spd-table .cell-secondary { color: var(--sp-ink-2); font-size: 12px; font-weight: 500; }
.spd-table .cell-money { font-family: var(--sp-font-mono); }
.spd-name-cell { display: flex; align-items: center; gap: 12px; }
.spd-name-cell .av { width: 32px; height: 32px; border-radius: 50%; background: linear-gradient(135deg, var(--sp-brown-400), var(--sp-brown-700)); color: var(--sp-paper); font-family: var(--sp-font-display); font-size: 13px; display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.spd-name-cell .nm { font-weight: 600; color: var(--sp-brown-900); }
.spd-name-cell .sub { font-size: 12px; color: var(--sp-ink-3); }

/* =========================================================================
   Status pills, tags, sentiment
   ========================================================================= */
.spd-pill { display: inline-flex; align-items: center; gap: 5px; padding: 3px 9px; border-radius: 999px; font-size: 11px; font-weight: 800; letter-spacing: 0.04em; border: 1px solid currentColor; }
.spd-pill::before { content: ''; width: 6px; height: 6px; border-radius: 50%; background: currentColor; }
.spd-pill.live { background: rgba(79,107,59,0.14); color: var(--sp-success); }
.spd-pill.draft { background: rgba(47,36,24,0.10); color: var(--sp-ink-2); }
.spd-pill.paused { background: rgba(176,122,42,0.16); color: var(--sp-warning); }
.spd-pill.ended { background: rgba(140,58,42,0.14); color: var(--sp-error); }

.spd-tag { display: inline-block; padding: 3px 9px; border-radius: 999px; font-size: 11px; font-weight: 500; background: var(--sp-snow); color: var(--sp-brown-900); border: 1px solid rgba(47,36,24,0.10); margin-right: 4px; }
.spd-tag.gold { background: rgba(166,139,91,0.16); color: var(--sp-gold-700); border-color: rgba(166,139,91,0.30); }

.spd-sent { font-size: 11px; font-weight: 600; padding: 2px 8px; border-radius: 3px; }
.spd-sent.pos { background: rgba(79,107,59,0.14); color: var(--sp-success); }
.spd-sent.neu { background: rgba(47,36,24,0.10); color: var(--sp-ink-2); }
.spd-sent.neg { background: rgba(140,58,42,0.14); color: var(--sp-error); }

/* =========================================================================
   Filter panel
   ========================================================================= */
.spd-filters { display: flex; flex-direction: column; gap: 18px; }
.spd-filter-group { display: flex; flex-direction: column; gap: 8px; padding-bottom: 18px; border-bottom: var(--spd-hair); }
.spd-filter-group:last-child { border-bottom: 0; }
.spd-filter-label { font-size: 11px; font-weight: 600; letter-spacing: 0.10em; text-transform: uppercase; color: var(--sp-ink-2); }
.spd-check { display: flex; align-items: center; gap: 9px; font-size: 13px; cursor: pointer; color: var(--sp-ink); }
.spd-check input { accent-color: var(--sp-brown-700); width: 14px; height: 14px; }
.spd-check .count { margin-left: auto; font-size: 11px; color: var(--sp-ink-3); font-family: var(--sp-font-mono); }
.spd-range { display: flex; align-items: center; gap: 8px; }
.spd-range input[type="number"] { width: 64px; padding: 6px 8px; font-family: var(--sp-font-mono); font-size: 12px; border: var(--spd-hair-strong); border-radius: 4px; background: var(--sp-white); }
.spd-input { background: var(--sp-white); border: var(--spd-hair-strong); border-radius: var(--spd-radius); padding: 8px 12px; font-size: 13px; font-family: var(--sp-font-body); outline: none; transition: border-color 140ms; width: 100%; }
.spd-input:focus { border-color: var(--sp-brown-700); }

/* =========================================================================
   Activity / feed
   ========================================================================= */
.spd-feed { display: flex; flex-direction: column; gap: 4px; }
.spd-feed-item { display: grid; grid-template-columns: 32px 1fr auto; gap: 12px; align-items: flex-start; padding: 12px 4px; border-bottom: var(--spd-hair); }
.spd-feed-item:last-child { border-bottom: 0; }
.spd-feed-item .ico { width: 32px; height: 32px; border-radius: 50%; background: var(--sp-snow); display: flex; align-items: center; justify-content: center; color: var(--sp-brown-700); }
.spd-feed-item .body { font-size: 13px; color: var(--sp-ink); line-height: 1.45; }
.spd-feed-item .body strong { color: var(--sp-brown-900); font-weight: 600; }
.spd-feed-item .when { font-size: 11px; color: var(--sp-ink-3); white-space: nowrap; letter-spacing: 0.02em; }

/* Mention card */
.spd-mention { background: var(--sp-white); border: var(--spd-hair); border-radius: var(--spd-radius); padding: 18px 20px; display: flex; flex-direction: column; gap: 10px; }
.spd-mention-head { display: flex; align-items: center; gap: 10px; font-size: 12px; color: var(--sp-ink-3); }
.spd-mention-source { font-weight: 600; color: var(--sp-brown-900); font-size: 13px; }
.spd-mention-headline { font-family: var(--sp-font-display); font-size: 18px; line-height: 1.25; color: var(--sp-brown-900); font-weight: 400; }
.spd-mention-snippet { font-size: 13px; color: var(--sp-ink-2); line-height: 1.55; }
.spd-mention-foot { display: flex; gap: 8px; align-items: center; padding-top: 8px; border-top: var(--spd-hair); font-size: 12px; color: var(--sp-ink-3); }

/* Market monitoring */
.spd-market-hero { display: grid; grid-template-columns: minmax(0, 1.25fr) minmax(360px, 0.75fr); gap: 18px; align-items: stretch; margin-bottom: 18px; }
.spd-market-hero-copy { background: linear-gradient(135deg, var(--sp-brown-900), var(--sp-brown-700)); color: var(--sp-paper); border-radius: var(--spd-radius); padding: 26px 28px; min-height: 210px; display: flex; flex-direction: column; justify-content: center; }
.spd-market-eyebrow { font-size: 11px; font-weight: 800; letter-spacing: 0.14em; text-transform: uppercase; color: var(--sp-gold-300); margin-bottom: 12px; }
.spd-market-hero-copy h3 { font-family: var(--sp-font-display); font-size: 34px; line-height: 1.08; font-weight: 400; margin: 0 0 10px; color: var(--sp-paper); max-width: 620px; }
.spd-market-hero-copy p { margin: 0; color: rgba(244,239,231,0.78); line-height: 1.6; max-width: 720px; }
.spd-market-metrics { background: var(--sp-white); border: var(--spd-hair); border-radius: var(--spd-radius); padding: 18px; display: grid; grid-template-columns: repeat(2, 1fr); gap: 12px; }
.spd-market-metrics div { background: var(--sp-snow); border: 1px solid rgba(47,36,24,0.08); border-radius: 5px; padding: 16px; display: flex; flex-direction: column; gap: 4px; }
.spd-market-metrics strong { font-family: var(--sp-font-display); font-size: 32px; line-height: 1; font-weight: 400; color: var(--sp-brown-900); }
.spd-market-metrics span { font-size: 11px; color: var(--sp-ink-2); letter-spacing: 0.08em; text-transform: uppercase; font-weight: 700; }
.spd-market-layout { display: grid; grid-template-columns: minmax(0, 1fr) 360px; gap: 18px; align-items: start; }
.spd-market-main,
.spd-market-side,
.spd-market-clusters { display: flex; flex-direction: column; gap: 14px; }
.spd-market-side { position: sticky; top: calc(var(--spd-topbar-h) + 18px); }
.spd-market-report { background: var(--sp-white); border: var(--spd-hair); border-radius: var(--spd-radius); padding: 22px; box-shadow: 0 1px 0 rgba(47,36,24,0.02); }
.spd-market-report-head { display: flex; justify-content: space-between; gap: 18px; align-items: flex-start; margin-bottom: 12px; }
.spd-market-report h3 { font-family: var(--sp-font-display); font-size: 28px; line-height: 1.1; color: var(--sp-brown-900); font-weight: 400; margin: 7px 0 0; }
.spd-market-summary { font-size: 14px; line-height: 1.65; color: var(--sp-ink-2); margin: 0 0 18px; max-width: 900px; }
.spd-market-score-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 10px; margin-bottom: 18px; }
.spd-market-score { border: 1px solid rgba(47,36,24,0.10); background: var(--sp-snow); border-radius: 5px; padding: 12px 14px; display: flex; align-items: baseline; justify-content: space-between; gap: 12px; }
.spd-market-score span { color: var(--sp-ink-2); font-size: 12px; font-weight: 600; }
.spd-market-score strong { font-family: var(--sp-font-mono); font-size: 15px; color: var(--sp-brown-900); }
.spd-market-findings { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 12px; margin-bottom: 18px; }
.spd-market-finding { border-left: 3px solid var(--sp-gold-500); background: rgba(166,139,91,0.08); padding: 14px 14px 13px; border-radius: 0 5px 5px 0; }
.spd-market-finding-kicker { display: flex; justify-content: space-between; gap: 8px; color: var(--sp-gold-700); font-size: 10px; font-weight: 800; letter-spacing: 0.08em; text-transform: uppercase; margin-bottom: 8px; }
.spd-market-finding strong { display: block; color: var(--sp-brown-900); font-size: 14px; line-height: 1.35; margin-bottom: 6px; }
.spd-market-finding p { color: var(--sp-ink-2); font-size: 12px; line-height: 1.5; margin: 0 0 9px; }
.spd-market-action { display: flex; align-items: flex-start; gap: 6px; color: var(--sp-brown-700); font-size: 12px; font-weight: 700; line-height: 1.45; }
.spd-market-source-row { display: flex; flex-wrap: wrap; gap: 8px; padding-top: 14px; border-top: var(--spd-hair); }
.spd-market-source { display: inline-flex; align-items: center; gap: 6px; color: var(--sp-brown-700); background: var(--sp-snow); border: 1px solid rgba(47,36,24,0.10); border-radius: 999px; padding: 5px 9px; text-decoration: none; font-size: 12px; max-width: 260px; }
.spd-market-source span { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.spd-market-source:hover { border-color: rgba(47,36,24,0.24); color: var(--sp-brown-900); }
.spd-market-more-sources { display: inline-flex; align-items: center; color: var(--sp-ink-3); font-size: 12px; padding: 5px 2px; }
.spd-market-presi-note { background: rgba(176,122,42,0.12); color: var(--sp-brown-900); border: 1px solid rgba(176,122,42,0.22); border-radius: 5px; padding: 11px 12px; font-size: 12px; line-height: 1.5; margin-bottom: 12px; }
.spd-market-counts { display: flex; flex-direction: column; gap: 8px; }
.spd-market-counts div { display: flex; align-items: center; justify-content: space-between; gap: 12px; padding: 9px 0; border-bottom: var(--spd-hair); color: var(--sp-ink-2); font-size: 13px; }
.spd-market-counts div:last-child { border-bottom: 0; }
.spd-market-counts strong { font-family: var(--sp-font-mono); color: var(--sp-brown-900); }
.spd-market-cluster { border-bottom: var(--spd-hair); padding-bottom: 13px; }
.spd-market-cluster:last-child { border-bottom: 0; padding-bottom: 0; }
.spd-market-cluster-meta { display: flex; flex-wrap: wrap; align-items: center; gap: 6px; color: var(--sp-ink-3); font-size: 11px; margin-bottom: 7px; }
.spd-market-cluster strong { display: block; color: var(--sp-brown-900); line-height: 1.35; margin-bottom: 6px; }
.spd-market-cluster p { color: var(--sp-ink-2); font-size: 12px; line-height: 1.45; margin: 0 0 7px; display: -webkit-box; -webkit-line-clamp: 3; -webkit-box-orient: vertical; overflow: hidden; }
.spd-market-cluster a { color: var(--sp-brown-700); font-size: 12px; text-decoration: none; font-weight: 700; display: inline-flex; align-items: center; gap: 4px; }
.spd-market-next { display: flex; flex-direction: column; gap: 11px; font-size: 13px; color: var(--sp-ink-2); line-height: 1.45; }
.spd-market-next div { display: grid; grid-template-columns: 16px 1fr; gap: 8px; align-items: start; }

/* =========================================================================
   Candidate detail
   ========================================================================= */
.spd-cd-head { display: grid; grid-template-columns: 96px 1fr auto; gap: 24px; align-items: flex-start; padding-bottom: 24px; border-bottom: var(--spd-hair-strong); margin-bottom: 24px; }
.spd-cd-avatar { width: 96px; height: 96px; border-radius: 50%; background: linear-gradient(135deg, var(--sp-brown-400), var(--sp-brown-700)); color: var(--sp-paper); font-family: var(--sp-font-display); font-size: 36px; display: flex; align-items: center; justify-content: center; box-shadow: inset 0 0 0 1px rgba(47,36,24,0.10); }
.spd-cd-title h2 { font-family: var(--sp-font-display); font-size: 36px; line-height: 1.05; color: var(--sp-brown-900); margin: 0 0 4px; font-weight: 400; }
.spd-cd-title .role { font-size: 15px; color: var(--sp-ink-2); }
.spd-cd-title .meta { display: flex; gap: 14px; margin-top: 12px; font-size: 12px; color: var(--sp-ink-3); }
.spd-cd-title .meta span { display: flex; align-items: center; gap: 5px; }
.spd-cd-grid { display: grid; grid-template-columns: 1.5fr 1fr; gap: 24px; }

.spd-timeline { display: flex; flex-direction: column; gap: 0; }
.spd-timeline-item { display: grid; grid-template-columns: 88px 1fr; gap: 16px; padding: 14px 0; border-top: var(--spd-hair); }
.spd-timeline-item:first-child { border-top: 0; padding-top: 4px; }
.spd-timeline-period { font-family: var(--sp-font-mono); font-size: 11px; color: var(--sp-ink-3); padding-top: 2px; letter-spacing: 0.02em; }
.spd-timeline-role { font-weight: 600; color: var(--sp-brown-900); font-size: 14px; }
.spd-timeline-company { color: var(--sp-ink-2); font-size: 13px; margin-top: 2px; }
.spd-timeline-desc { color: var(--sp-ink-2); font-size: 13px; line-height: 1.5; margin-top: 6px; }

/* Assessment bars */
.spd-score { display: flex; flex-direction: column; gap: 14px; }
.spd-score-row { display: grid; grid-template-columns: 1fr 32px; gap: 12px; align-items: center; }
.spd-score-row .nm { font-size: 13px; color: var(--sp-ink); font-weight: 500; margin-bottom: 4px; }
.spd-score-bar { height: 6px; border-radius: 3px; background: var(--sp-paper-2); overflow: hidden; }
.spd-score-bar > div { height: 100%; background: var(--sp-brown-700); border-radius: 3px; }
.spd-score-row .v { font-family: var(--sp-font-mono); font-size: 12px; color: var(--sp-brown-900); text-align: right; }

/* Empty state */
.spd-empty { padding: 48px 24px; text-align: center; display: flex; flex-direction: column; align-items: center; gap: 8px; }
.spd-empty .icon-wrap { width: 56px; height: 56px; border-radius: 50%; background: var(--sp-paper-2); color: var(--sp-brown-700); display: flex; align-items: center; justify-content: center; margin-bottom: 8px; }
.spd-empty h4 { font-family: var(--sp-font-display); font-size: 22px; color: var(--sp-brown-900); margin: 0; font-weight: 400; }
.spd-empty p { color: var(--sp-ink-2); font-size: 13px; margin: 0; max-width: 320px; }

/* =========================================================================
   v2 — Top-nav shell + executive-search workbench surfaces
   ========================================================================= */

/* ---------- Layout: top-nav variant ---------- */
.spd.spd--topnav { display: block; }
.spd--topnav .spd-main { width: 100%; }
.spd-topnav { background: var(--sp-brown-900); color: var(--sp-paper); padding: 0 24px; display: flex; align-items: center; gap: 8px; height: 56px; position: sticky; top: 0; z-index: 20; }
.spd-topnav-brand { display: flex; align-items: center; gap: 10px; padding-right: 20px; border-right: 1px solid rgba(244,239,231,0.12); margin-right: 12px; }
.spd-topnav-brand .mark { width: 30px; height: 30px; border-radius: 6px; background: var(--sp-brown-700); display:flex; align-items:center; justify-content:center; font-family: var(--sp-font-display); color: var(--sp-paper); font-size: 17px; }
.spd-topnav-brand .name { font-family: var(--sp-font-display); font-size: 16px; line-height: 1; color: var(--sp-paper); }
.spd-topnav-links { display: flex; align-items: center; gap: 2px; flex: 1; }
.spd-topnav-link { padding: 8px 14px; border-radius: 6px; color: rgba(244,239,231,0.72); font-size: 13px; font-weight: 500; cursor: pointer; transition: background 140ms, color 140ms; text-decoration: none; line-height: 1; }
.spd-topnav-link:hover { background: rgba(244,239,231,0.06); color: var(--sp-paper); }
.spd-topnav-link.active { background: var(--sp-brown-700); color: var(--sp-paper); }
.spd-topnav-right { display: flex; align-items: center; gap: 8px; }
.spd-topnav .spd-search { background: rgba(244,239,231,0.08); border-color: rgba(244,239,231,0.12); color: rgba(244,239,231,0.7); padding: 6px 10px; min-width: 260px; }
.spd-topnav .spd-search input { color: var(--sp-paper); }
.spd-topnav .spd-search input::placeholder { color: rgba(244,239,231,0.55); }
.spd-topnav .spd-search kbd { color: rgba(244,239,231,0.65); border-color: rgba(244,239,231,0.18); }
.spd-topnav .icon-btn { color: rgba(244,239,231,0.75); }
.spd-topnav .icon-btn:hover { background: rgba(244,239,231,0.08); color: var(--sp-paper); }
.spd-topnav .icon-btn .dot { border-color: var(--sp-brown-900); }
.spd-topnav-user { display: flex; align-items: center; gap: 8px; padding: 4px 8px 4px 4px; border-radius: 999px; cursor: pointer; }
.spd-topnav-user:hover { background: rgba(244,239,231,0.06); }
.spd-topnav-user .av { width: 28px; height: 28px; border-radius: 50%; background: linear-gradient(135deg, var(--sp-brown-400), var(--sp-brown-700)); display:flex; align-items:center; justify-content:center; color: var(--sp-paper); font-family: var(--sp-font-display); font-size: 12px; }
.spd-topnav-user .nm { font-size: 12px; color: var(--sp-paper); font-weight: 500; }

/* Sub-bar (page-level meta strip directly under topnav) */
.spd-subbar { background: var(--sp-white); border-bottom: var(--spd-hair); padding: 14px 28px; display: flex; align-items: center; gap: 16px; }
.spd-subbar .crumbs { font-size: 12px; color: var(--sp-ink-3); letter-spacing: 0.04em; }
.spd-subbar .crumbs a { color: var(--sp-brown-700); text-decoration: none; }
.spd-subbar .crumbs a:hover { color: var(--sp-brown-900); }
.spd-subbar h1 { font-family: var(--sp-font-display); font-size: 22px; color: var(--sp-brown-900); margin: 0; font-weight: 400; line-height: 1.1; }
.spd-subbar .spacer { flex: 1; }

/* ---------- Page header for detail workspaces ---------- */
.spd-detail-head { background: var(--sp-white); border-bottom: var(--spd-hair); padding: 20px 28px; }
.spd-detail-head .title-row { display: flex; align-items: flex-start; gap: 20px; }
.spd-detail-head h1 { font-family: var(--sp-font-display); font-size: 32px; color: var(--sp-brown-900); margin: 0; font-weight: 400; line-height: 1.1; letter-spacing: 0; }
.spd-detail-head .client { font-size: 13px; color: var(--sp-ink); margin-top: 4px; display: flex; align-items: center; gap: 6px; font-weight: 500; }
.spd-detail-head .actions { margin-left: auto; display: flex; gap: 8px; align-items: center; }
.spd-detail-head .meta-row { display: flex; flex-wrap: wrap; gap: 24px 32px; margin-top: 18px; padding-top: 16px; border-top: var(--spd-hair); }
.spd-meta-item { display: flex; flex-direction: column; gap: 3px; }
.spd-meta-item .k { font-size: 10px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--sp-ink-2); font-weight: 800; }
.spd-meta-item .v { font-size: 13px; font-weight: 600; color: var(--sp-brown-900); display: flex; align-items: center; gap: 6px; }
.spd-meta-item .v.muted { font-weight: 600; color: var(--sp-ink); }
.spd-meta-item .v .num { font-family: var(--sp-font-mono); }

/* ---------- Tabs ---------- */
.spd-tabs { display: flex; gap: 0; background: var(--sp-white); border-bottom: var(--spd-hair); padding: 0 28px; align-items: center; position: sticky; top: 56px; z-index: 9; }
.spd-tabs.no-stick { position: static; }
.spd-tab { padding: 14px 18px; font-size: 13px; font-weight: 700; color: var(--sp-ink-2); cursor: pointer; border-bottom: 2px solid transparent; margin-bottom: -1px; display: inline-flex; align-items: center; gap: 8px; transition: color 140ms, border-color 140ms; line-height: 1; }
.spd-tab:hover { color: var(--sp-brown-900); }
.spd-tab.active { color: var(--sp-brown-900); border-bottom-color: var(--sp-brown-900); }
.spd-tab .count { font-family: var(--sp-font-mono); font-size: 11px; color: var(--sp-ink-2); padding: 1px 6px; background: var(--sp-paper-2); border-radius: 999px; font-weight: 700; }
.spd-tab.active .count { background: var(--sp-brown-100); color: var(--sp-brown-900); }

/* ---------- Insight banner (collapsible) ---------- */
.spd-banner { display: flex; align-items: flex-start; gap: 12px; padding: 14px 18px; border-radius: var(--spd-radius); border: 1px solid; margin-bottom: 14px; font-size: 13px; line-height: 1.5; }
.spd-banner.info  { background: rgba(61,90,117,0.12); border-color: rgba(61,90,117,0.32); color: var(--sp-info); }
.spd-banner.warn  { background: rgba(176,122,42,0.10); border-color: rgba(176,122,42,0.25); color: var(--sp-warning); }
.spd-banner.success { background: rgba(79,107,59,0.10); border-color: rgba(79,107,59,0.22); color: var(--sp-success); }
.spd-banner .icn { flex-shrink: 0; margin-top: 1px; }
.spd-banner .b-body { color: var(--sp-ink); flex: 1; }
.spd-banner .b-body strong { color: var(--sp-brown-900); font-weight: 600; }
.spd-banner .b-dismiss { color: currentColor; opacity: 0.6; cursor: pointer; }
.spd-banner .b-dismiss:hover { opacity: 1; }

/* ---------- Candidate accordion ---------- */
.spd-acc { background: var(--sp-white); border: var(--spd-hair-strong); border-radius: var(--spd-radius); overflow: hidden; }
.spd-acc-row { display: grid; grid-template-columns: 36px 28px minmax(220px, 1.5fr) minmax(140px, 0.9fr) minmax(110px, 0.65fr) 96px 110px 24px; gap: 14px; align-items: center; padding: 14px 18px; border-bottom: var(--spd-hair); cursor: pointer; transition: background 100ms; }
.spd-acc-row:hover { background: var(--sp-snow); }
.spd-acc-row.expanded { background: var(--sp-paper); box-shadow: inset 3px 0 0 var(--sp-brown-700); }
.spd-acc-row:last-of-type:not(.expanded) { border-bottom: 0; }
.spd-acc-rank { font-family: var(--sp-font-mono); font-size: 12px; color: var(--sp-ink-2); text-align: center; font-weight: 700; }
.spd-acc-chev { color: var(--sp-ink-2); transition: transform 140ms; }
.spd-acc-row.expanded .spd-acc-chev { transform: rotate(90deg); color: var(--sp-brown-900); }
.spd-acc-name { font-weight: 600; color: var(--sp-brown-900); font-size: 14px; display: flex; align-items: center; gap: 10px; min-width: 0; }
.spd-acc-name .av { width: 30px; height: 30px; border-radius: 50%; background: linear-gradient(135deg, var(--sp-brown-400), var(--sp-brown-700)); color: var(--sp-paper); font-family: var(--sp-font-display); font-size: 12px; display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.spd-acc-name .nm-text { min-width: 0; }
.spd-acc-name .nm-text .nm { font-weight: 600; color: var(--sp-brown-900); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.spd-acc-name .nm-text .sub { font-size: 12px; color: var(--sp-ink-2); font-weight: 500; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; max-width: 100%; }
.spd-acc-role { font-size: 13px; color: var(--sp-ink); min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.spd-acc-source { font-size: 12px; color: var(--sp-ink-2); display: inline-flex; align-items: center; gap: 6px; font-weight: 500; width: 100%; max-width: 100%; min-width: 0; overflow: hidden; white-space: nowrap; }
.spd-acc-source svg { flex-shrink: 0; }
.spd-acc-source .source-label { display: block; min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.spd-acc-row > .spd-pill { justify-self: start; white-space: nowrap; line-height: 1; min-height: 26px; }

/* Confidence label */
.spd-conf { display: inline-flex; align-items: center; gap: 5px; padding: 3px 8px; border-radius: 4px; font-size: 11px; font-weight: 600; letter-spacing: 0.02em; white-space: nowrap; }
.spd-conf .bars { display: inline-flex; gap: 2px; align-items: flex-end; height: 10px; }
.spd-conf .bars i { display: block; width: 3px; background: currentColor; border-radius: 1px; opacity: 0.3; }
.spd-conf .bars i:nth-child(1) { height: 40%; }
.spd-conf .bars i:nth-child(2) { height: 70%; }
.spd-conf .bars i:nth-child(3) { height: 100%; }
.spd-conf.high  { background: rgba(79,107,59,0.14); color: var(--sp-success); }
.spd-conf.high .bars i { opacity: 1; }
.spd-conf.med   { background: rgba(176,122,42,0.16); color: var(--sp-warning); }
.spd-conf.med .bars i:nth-child(-n+2) { opacity: 1; }
.spd-conf.low   { background: rgba(140,58,42,0.14); color: var(--sp-error); }
.spd-conf.low .bars i:nth-child(1) { opacity: 1; }

/* Expanded body */
.spd-acc-body { background: var(--sp-white); border-bottom: var(--spd-hair-strong); padding: 24px 28px; display: grid; grid-template-columns: minmax(0, 1fr) 320px; gap: 28px; }
.spd-acc-body:last-child { border-bottom: 0; }
.spd-acc-body > * { min-width: 0; }

/* ---------- Assessment panel ---------- */
.spd-assess-section { padding: 16px 0; border-top: var(--spd-hair-strong); }
.spd-assess-section:first-of-type { border-top: 0; padding-top: 0; }
.spd-assess-section h4 { display: flex; align-items: center; gap: 8px; font-family: var(--sp-font-body); font-size: 11px; font-weight: 800; letter-spacing: 0.14em; text-transform: uppercase; color: var(--sp-brown-800); margin: 0 0 10px; }
.spd-assess-section h4 .ico { color: var(--sp-gold-700); }
.spd-assess-section p { font-size: 13.5px; color: var(--sp-ink); line-height: 1.65; margin: 0 0 8px; font-weight: 500; }
.spd-assess-section p:last-child { margin-bottom: 0; }
.spd-assess-section ul { margin: 0; padding-left: 18px; font-size: 13.5px; color: var(--sp-ink); line-height: 1.65; font-weight: 500; }
.spd-assess-section ul li { margin-bottom: 4px; }
.spd-assess-section .more-toggle { font-size: 12px; color: var(--sp-brown-700); cursor: pointer; padding-top: 8px; font-weight: 600; display: inline-flex; align-items: center; gap: 4px; }
.spd-assess-section .more-toggle:hover { color: var(--sp-brown-900); }

/* Key/value pairs for Nøkkelopplysninger */
.spd-kv { display: grid; grid-template-columns: 140px 1fr; gap: 6px 14px; font-size: 13px; }
.spd-kv dt { color: var(--sp-ink-2); font-weight: 700; }
.spd-kv dd { color: var(--sp-ink); margin: 0; font-weight: 600; }
.spd-kv dd.unknown { color: var(--sp-ink-3); font-style: italic; font-weight: 400; }

/* ---------- Facts panel (right rail in expanded candidate) ---------- */
.spd-facts { background: var(--sp-white); border: var(--spd-hair-strong); border-radius: var(--spd-radius); padding: 18px; display: flex; flex-direction: column; gap: 16px; align-self: flex-start; position: sticky; top: 120px; box-shadow: var(--sp-shadow-1); }
.spd-facts .score-block { text-align: center; padding-bottom: 14px; border-bottom: var(--spd-hair); }
.spd-facts .score-block .lbl { font-size: 10px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--sp-ink-2); font-weight: 800; }
.spd-facts .score-block .v { font-family: var(--sp-font-display); font-size: 48px; line-height: 1; color: var(--sp-brown-900); margin-top: 6px; }
.spd-facts .score-block .sub { font-size: 12px; color: var(--sp-success); margin-top: 4px; font-weight: 600; }
.spd-facts .actions { display: flex; flex-direction: column; gap: 6px; }
.spd-link-status { display: flex; align-items: flex-start; gap: 8px; padding: 9px 10px; border: var(--spd-hair); border-radius: var(--spd-radius); background: var(--sp-snow); color: var(--sp-ink-2); font-size: 12px; line-height: 1.35; font-weight: 600; }
.spd-link-status svg { flex-shrink: 0; color: var(--sp-brown-700); margin-top: 1px; }
.spd-rail-section { padding-top: 14px; border-top: var(--spd-hair); }
.spd-rail-section .rail-title { display: flex; align-items: center; gap: 7px; font-size: 10px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--sp-ink-3); font-weight: 800; margin-bottom: 8px; }
.spd-rail-section .rail-title svg { color: var(--sp-gold-700); }
.spd-rail-section .empty-note { padding: 10px; border: var(--spd-hair); border-radius: 4px; background: var(--sp-snow); color: var(--sp-ink-3); font-size: 12px; line-height: 1.35; font-weight: 600; }

/* ---------- Evidence / traceability ---------- */
.spd-trace { background: var(--sp-snow); border: var(--spd-hair-strong); border-radius: var(--spd-radius); padding: 14px 16px; font-family: var(--sp-font-mono); font-size: 11.5px; min-width: 0; }
.spd-trace .t-head { display: flex; justify-content: space-between; align-items: center; margin-bottom: 10px; font-family: var(--sp-font-body); font-size: 11px; font-weight: 800; letter-spacing: 0.14em; text-transform: uppercase; color: var(--sp-brown-800); }
.spd-trace .t-head .ico { color: var(--sp-gold-700); }
.spd-trace .t-step { display: grid; grid-template-columns: 70px minmax(0, 1fr); gap: 10px; padding: 4px 0; color: var(--sp-ink); line-height: 1.55; font-weight: 600; }
.spd-trace .t-step .k { color: var(--sp-ink-2); font-weight: 800; }
.spd-trace .t-hash { font-size: 10.5px; color: var(--sp-ink-2); padding-top: 10px; margin-top: 8px; border-top: var(--spd-hair); display: flex; gap: 6px; align-items: center; flex-wrap: wrap; font-weight: 600; }
.spd-trace .t-hash code { font-family: var(--sp-font-mono); color: var(--sp-brown-700); }

/* Sources list */
.spd-sources { display: flex; flex-direction: column; gap: 6px; min-width: 0; }
.spd-source-row { display: grid; grid-template-columns: 24px minmax(0, 1fr) auto auto; gap: 10px; align-items: center; padding: 8px 10px; background: var(--sp-white); border: var(--spd-hair-strong); border-radius: 4px; font-size: 12px; color: var(--sp-ink); min-width: 0; }
.spd-source-row .ico { color: var(--sp-brown-700); }
.spd-source-row > div { min-width: 0; }
.spd-source-row .nm { font-weight: 600; color: var(--sp-brown-900); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.spd-source-row .date { color: var(--sp-ink-2); font-family: var(--sp-font-mono); font-size: 11px; font-weight: 600; }
.spd-source-open { width: 26px; height: 26px; border: 0; border-radius: 4px; background: transparent; color: var(--sp-brown-700); cursor: pointer; display: inline-flex; align-items: center; justify-content: center; }
.spd-source-open:hover { background: var(--sp-paper); color: var(--sp-brown-900); }
.spd-rail-sources .spd-source-row { grid-template-columns: 20px minmax(0, 1fr) 26px; gap: 8px; padding: 8px; align-items: flex-start; }
.spd-rail-sources .spd-source-row .date { display: block; margin-top: 2px; font-size: 10px; }
.spd-rail-sources .spd-source-open { margin-top: -3px; }

/* ---------- Unknown / private fields ---------- */
.spd-unknown { display: inline-flex; align-items: center; gap: 5px; font-size: 12px; color: var(--sp-ink-3); font-style: italic; font-weight: 400; }
.spd-unknown::before { content: '—'; font-style: normal; margin-right: 2px; }
.spd-private { display: inline-flex; align-items: center; gap: 5px; font-size: 12px; color: var(--sp-ink-3); }

/* ---------- Density variants (tables) ---------- */
.spd-table.dense thead th { padding: 7px 12px; font-size: 10px; }
.spd-table.dense tbody td { padding: 8px 12px; font-size: 12px; }
.spd-table.dense .spd-name-cell .av { width: 24px; height: 24px; font-size: 11px; }
.spd-table.airy thead th { padding: 14px 18px; }
.spd-table.airy tbody td { padding: 20px 18px; font-size: 14px; }

/* Truncation utility */
.spd-trunc { white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }

/* Loading shimmer */
@keyframes spd-shimmer { 0% { background-position: -200px 0; } 100% { background-position: 200px 0; } }
.spd-skeleton { background: linear-gradient(90deg, var(--sp-paper-2) 0%, var(--sp-paper-3) 50%, var(--sp-paper-2) 100%); background-size: 400px 100%; animation: spd-shimmer 1.4s infinite; border-radius: 4px; }
.spd-skeleton.txt { height: 12px; }
.spd-skeleton.row { height: 48px; margin-bottom: 4px; }

/* Focus rings — A11y */
.spd-side-link:focus-visible,
.spd-topnav-link:focus-visible,
.spd-btn:focus-visible,
.spd-tab:focus-visible,
.spd-acc-row:focus-visible,
.spd-input:focus-visible,
.spd-search input:focus-visible {
  outline: 2px solid var(--sp-gold-500);
  outline-offset: 2px;
}

/* Selected state for accordion / rows */
.spd-acc-row.selected { background: var(--sp-brown-100); border-left: 3px solid var(--sp-brown-700); padding-left: 15px; }

/* Disabled state */
.spd-btn[disabled], .spd-btn.disabled { opacity: 0.45; cursor: not-allowed; pointer-events: none; }

/* ---------- Share link / modal ---------- */
.spd-modal-bg { position: fixed; inset: 0; background: rgba(47,36,24,0.55); backdrop-filter: blur(4px); z-index: 100; display: flex; align-items: center; justify-content: center; padding: 24px; }
.spd-modal-card { background: var(--sp-white); border-radius: 8px; max-width: 560px; width: 100%; padding: 28px; box-shadow: 0 24px 60px -12px rgba(47,36,24,0.30); border: var(--spd-hair); }
.spd-modal-card h3 { font-family: var(--sp-font-display); font-size: 24px; color: var(--sp-brown-900); margin: 0 0 6px; font-weight: 400; letter-spacing: 0; }
.spd-modal-card p.lead { font-size: 13px; color: var(--sp-ink-2); margin: 0 0 18px; }
.spd-link-box { display: flex; gap: 0; border: var(--spd-hair-strong); border-radius: 5px; overflow: hidden; margin-bottom: 14px; }
.spd-link-box input { flex: 1; border: 0; padding: 10px 12px; font-family: var(--sp-font-mono); font-size: 12px; color: var(--sp-brown-900); background: var(--sp-snow); outline: none; }
.spd-link-box .copy-btn { background: var(--sp-brown-900); color: var(--sp-paper); border: 0; padding: 0 16px; font-family: var(--sp-font-body); font-size: 12px; font-weight: 600; cursor: pointer; }

/* ---------- Compliance ---------- */
.spd-comp-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; margin-bottom: 14px; }
.spd-comp-card { background: var(--sp-white); border: var(--spd-hair); border-radius: var(--spd-radius); padding: 20px; display: flex; flex-direction: column; gap: 10px; }
.spd-comp-card .head { display: flex; align-items: center; gap: 10px; }
.spd-comp-card .head .ico-wrap { width: 36px; height: 36px; border-radius: 8px; background: var(--sp-paper-2); color: var(--sp-brown-700); display: flex; align-items: center; justify-content: center; }
.spd-comp-card h3 { font-family: var(--sp-font-body); font-size: 14px; color: var(--sp-brown-900); margin: 0; font-weight: 600; letter-spacing: 0; }
.spd-comp-card .badge-state { margin-left: auto; }
.spd-comp-card .body { font-size: 13px; color: var(--sp-ink-2); line-height: 1.55; }
.spd-comp-card .meter { display: flex; align-items: center; gap: 10px; font-size: 12px; color: var(--sp-ink-2); }
.spd-comp-card .meter .bar { flex: 1; height: 6px; background: var(--sp-paper-2); border-radius: 3px; overflow: hidden; }
.spd-comp-card .meter .bar > div { height: 100%; background: var(--sp-success); border-radius: 3px; }

.spd-comp-state { display: inline-flex; align-items: center; gap: 5px; font-size: 11px; padding: 3px 8px; border-radius: 999px; font-weight: 600; letter-spacing: 0.04em; }
.spd-comp-state.ok    { background: rgba(79,107,59,0.14); color: var(--sp-success); }
.spd-comp-state.warn  { background: rgba(176,122,42,0.16); color: var(--sp-warning); }
.spd-comp-state.fail  { background: rgba(140,58,42,0.14); color: var(--sp-error); }

/* Audit log */
.spd-audit { font-family: var(--sp-font-mono); font-size: 12px; }
.spd-audit-row { display: grid; grid-template-columns: 130px 100px 1fr 80px; gap: 14px; align-items: center; padding: 10px 4px; border-bottom: var(--spd-hair); }
.spd-audit-row:last-child { border-bottom: 0; }
.spd-audit-row .ts { color: var(--sp-ink-3); }
.spd-audit-row .actor { color: var(--sp-brown-900); font-weight: 600; font-family: var(--sp-font-body); font-size: 12px; }
.spd-audit-row .action { color: var(--sp-ink); font-family: var(--sp-font-body); }
.spd-audit-row .action strong { color: var(--sp-brown-900); }
.spd-audit-row .hash { color: var(--sp-ink-3); text-align: right; }

.spd-compliance-page { padding: 22px 28px 34px; display: grid; gap: 16px; }
.spd-compliance-hero { display: grid; grid-template-columns: minmax(0, 1fr) 320px; gap: 16px; align-items: stretch; }
.spd-compliance-hero-copy { background: linear-gradient(135deg, var(--sp-brown-900), var(--sp-brown-700)); color: var(--sp-paper); border-radius: var(--spd-radius); padding: 30px; min-height: 230px; display: flex; flex-direction: column; justify-content: center; box-shadow: var(--sp-shadow-2); }
.spd-compliance-hero-copy .eyebrow,
.spd-compliance-section .eyebrow { font-size: 10px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--sp-gold-700); font-weight: 900; margin-bottom: 8px; }
.spd-compliance-hero-copy .eyebrow { color: var(--sp-gold-300); }
.spd-compliance-hero-copy h3 { margin: 0 0 12px; font-family: var(--sp-font-display); font-size: 38px; line-height: 1.05; font-weight: 400; color: var(--sp-paper); letter-spacing: -0.01em; max-width: 780px; }
.spd-compliance-hero-copy p { margin: 0; color: rgba(244,239,231,0.82); font-size: 14px; line-height: 1.65; max-width: 88ch; }
.spd-compliance-status-card { background: var(--sp-white); border: var(--spd-hair); border-radius: var(--spd-radius); padding: 22px; display: flex; flex-direction: column; justify-content: center; gap: 10px; box-shadow: var(--sp-shadow-1); }
.spd-compliance-status-card > span { color: var(--sp-ink-3); font-size: 10px; letter-spacing: 0.14em; text-transform: uppercase; font-weight: 900; }
.spd-compliance-status-card strong { font-family: var(--sp-font-display); font-size: 34px; line-height: 1; color: var(--sp-brown-900); font-weight: 400; }
.spd-compliance-status-card p { margin: 0; color: var(--sp-ink-2); font-size: 13px; line-height: 1.55; font-weight: 550; }
.spd-compliance-status-card .state-row { display: flex; gap: 7px; flex-wrap: wrap; margin-top: 4px; }
.spd-compliance-metrics { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 12px; }
.spd-compliance-metric { background: var(--sp-white); border: var(--spd-hair); border-radius: var(--spd-radius); padding: 16px 18px; box-shadow: var(--sp-shadow-1); border-top: 3px solid rgba(79,107,59,0.32); }
.spd-compliance-metric.warn { border-top-color: rgba(176,122,42,0.42); }
.spd-compliance-metric span { display: block; color: var(--sp-ink-3); font-size: 10px; letter-spacing: 0.12em; text-transform: uppercase; font-weight: 900; }
.spd-compliance-metric strong { display: block; margin-top: 7px; font-family: var(--sp-font-display); font-size: 34px; line-height: 1; color: var(--sp-brown-900); font-weight: 400; }
.spd-compliance-metric p { margin: 7px 0 0; color: var(--sp-ink-2); font-size: 12px; line-height: 1.45; font-weight: 650; }
.spd-compliance-layout { display: grid; grid-template-columns: minmax(0, 1fr) 330px; gap: 16px; align-items: flex-start; }
.spd-compliance-main { display: grid; gap: 16px; min-width: 0; }
.spd-compliance-side { position: sticky; top: 116px; display: grid; gap: 16px; min-width: 0; }
.spd-compliance-section { padding: 22px; min-width: 0; }
.spd-compliance-section.compact h3,
.spd-compliance-section-head h3 { margin: 0; font-family: var(--sp-font-display); font-size: 28px; line-height: 1.08; font-weight: 400; color: var(--sp-brown-900); letter-spacing: -0.01em; }
.spd-compliance-section.compact h3 { font-size: 24px; margin-bottom: 14px; }
.spd-compliance-section-head { display: flex; align-items: flex-start; justify-content: space-between; gap: 18px; padding-bottom: 14px; margin-bottom: 16px; border-bottom: var(--spd-hair); }
.spd-compliance-section-head > span { color: var(--sp-ink-3); font-size: 11px; font-weight: 850; background: var(--sp-snow); border: var(--spd-hair); border-radius: 999px; padding: 5px 9px; white-space: nowrap; }
.spd-compliance-control-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 12px; }
.spd-compliance-control { border: var(--spd-hair); border-radius: 8px; background: var(--sp-snow); padding: 15px; }
.spd-compliance-control .top { display: flex; gap: 10px; align-items: flex-start; justify-content: space-between; margin-bottom: 10px; }
.spd-compliance-control h4 { margin: 0; color: var(--sp-brown-900); font-size: 14px; line-height: 1.3; font-weight: 850; }
.spd-compliance-control p { margin: 0; color: var(--sp-ink-2); font-size: 12.5px; line-height: 1.58; font-weight: 560; }
.spd-trace-proof { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 10px; margin-bottom: 14px; }
.spd-trace-proof div { border: var(--spd-hair); border-radius: 8px; background: var(--sp-snow); padding: 13px; }
.spd-trace-proof strong { display: block; font-family: var(--sp-font-display); font-size: 30px; line-height: 1; color: var(--sp-brown-900); font-weight: 400; }
.spd-trace-proof span { display: block; margin-top: 6px; color: var(--sp-ink-3); font-size: 10px; letter-spacing: 0.10em; text-transform: uppercase; font-weight: 850; }
.spd-compliance-trace-list { display: grid; gap: 8px; }
.trace-example { display: grid; grid-template-columns: minmax(0, 1fr) auto; gap: 14px; align-items: center; border: var(--spd-hair); border-radius: 7px; padding: 11px 12px; }
.trace-example strong { display: block; color: var(--sp-brown-900); font-size: 13px; }
.trace-example span { color: var(--sp-ink-2); font-size: 12px; }
.trace-example .trace-meta { display: flex; gap: 6px; flex-wrap: wrap; justify-content: flex-end; }
.trace-example .trace-meta span { background: var(--sp-paper); color: var(--sp-ink-2); border-radius: 999px; padding: 3px 7px; font-size: 10px; font-weight: 800; }
.spd-compliance-split { display: grid; grid-template-columns: 1.2fr 0.8fr; gap: 14px; }
.spd-gap-list,
.spd-decision-list { display: grid; gap: 8px; }
.gap-row,
.decision-row { display: grid; grid-template-columns: 48px minmax(0, 1fr); gap: 10px; align-items: flex-start; border: var(--spd-hair); border-radius: 7px; padding: 10px; background: var(--sp-snow); }
.gap-row .prio,
.decision-row > span { display: inline-flex; align-items: center; justify-content: center; min-height: 24px; border-radius: 999px; font-size: 10px; font-weight: 900; letter-spacing: 0.08em; }
.gap-row .prio.p1 { background: rgba(140,58,42,0.14); color: var(--sp-error); }
.gap-row .prio.p2 { background: rgba(176,122,42,0.16); color: var(--sp-warning); }
.gap-row .prio.p3,
.decision-row > span { background: rgba(47,36,24,0.10); color: var(--sp-ink-2); }
.gap-row strong,
.decision-row strong { display: block; color: var(--sp-brown-900); font-size: 12.5px; line-height: 1.35; }
.gap-row small,
.decision-row small { display: block; margin-top: 4px; color: var(--sp-ink-3); font-size: 11px; line-height: 1.35; font-weight: 650; }
.spd-compliance-doc-groups { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 12px; }
.doc-group { border: var(--spd-hair); border-radius: 8px; background: var(--sp-snow); padding: 15px; }
.doc-group h4 { margin: 0 0 6px; color: var(--sp-brown-900); font-size: 14px; font-weight: 850; }
.doc-group p { margin: 0 0 12px; color: var(--sp-ink-2); font-size: 12px; line-height: 1.5; }
.doc-group > div { display: flex; flex-wrap: wrap; gap: 7px; }
.doc-pill { display: inline-flex; align-items: center; gap: 7px; max-width: 100%; background: var(--sp-white); border: var(--spd-hair); border-radius: 999px; padding: 5px 8px; }
.doc-pill span { color: var(--sp-gold-700); font-size: 9px; letter-spacing: 0.10em; text-transform: uppercase; font-weight: 900; }
.doc-pill strong { color: var(--sp-ink-2); font-size: 11px; line-height: 1; white-space: nowrap; }
.spd-compliance-kv { display: grid; grid-template-columns: 112px minmax(0, 1fr); gap: 8px 10px; margin: 0; }
.spd-compliance-kv dt { color: var(--sp-ink-3); font-size: 11px; font-weight: 850; }
.spd-compliance-kv dd { margin: 0; color: var(--sp-ink); font-size: 12px; line-height: 1.35; font-weight: 700; }
.spd-prohibited-list,
.spd-date-list { display: grid; gap: 8px; }
.spd-prohibited-list div,
.spd-date-list div { border-left: 3px solid rgba(140,58,42,0.28); background: rgba(140,58,42,0.045); border-radius: 0 6px 6px 0; padding: 9px 10px; }
.spd-prohibited-list span { display: block; color: var(--sp-error); font-size: 10px; font-weight: 900; letter-spacing: 0.10em; margin-bottom: 3px; }
.spd-prohibited-list strong,
.spd-date-list span { display: block; color: var(--sp-ink); font-size: 12px; line-height: 1.35; font-weight: 750; }
.spd-date-list div { border-left-color: rgba(166,139,91,0.36); background: rgba(166,139,91,0.07); }
.spd-date-list strong { display: block; color: var(--sp-gold-700); font-size: 12px; margin-bottom: 3px; }
.spd-date-list small { display: inline-block; margin-top: 7px; color: var(--sp-ink-3); font-size: 9.5px; letter-spacing: 0.10em; text-transform: uppercase; font-weight: 900; }
.spd-compliance-proof-card strong { font-size: 28px; line-height: 1.05; }
.spd-login-page { min-height: 100vh; display: grid; place-items: center; padding: 28px; background: radial-gradient(circle at top left, rgba(201,180,136,0.20), transparent 34%), var(--sp-paper); }
.spd-login-card { width: min(460px, 100%); background: var(--sp-white); border: var(--spd-hair); border-radius: 14px; padding: 34px; box-shadow: var(--sp-shadow-2); }
.spd-login-brand { display: flex; align-items: center; gap: 12px; margin-bottom: 24px; }
.spd-login-brand .mark { width: 34px; height: 34px; border-radius: 8px; display: grid; place-items: center; background: var(--sp-brown-700); color: var(--sp-paper); font-family: var(--sp-font-display); font-size: 17px; }
.spd-login-brand strong { display: block; color: var(--sp-brown-900); font-family: var(--sp-font-display); font-size: 20px; font-weight: 400; line-height: 1; }
.spd-login-brand span { display: block; margin-top: 3px; color: var(--sp-gold-700); font-size: 9px; letter-spacing: 0.16em; text-transform: uppercase; font-weight: 900; }
.spd-login-card h1 { margin: 0 0 10px; font-family: var(--sp-font-display); color: var(--sp-brown-900); font-size: 40px; line-height: 1.04; font-weight: 400; }
.spd-login-card p { margin: 0; color: var(--sp-ink-2); font-size: 14px; line-height: 1.6; font-weight: 560; }
.spd-login-card form { display: grid; gap: 12px; margin-top: 22px; }
.spd-login-card label { color: var(--sp-ink-2); font-size: 11px; letter-spacing: 0.12em; text-transform: uppercase; font-weight: 900; }
.spd-login-card input { width: 100%; border: var(--spd-hair-strong); border-radius: 8px; padding: 12px 13px; font-size: 15px; color: var(--sp-brown-900); background: var(--sp-snow); outline: none; }
.spd-login-card input:focus { border-color: rgba(166,139,91,0.72); box-shadow: 0 0 0 3px rgba(166,139,91,0.16); }
.spd-login-error { margin-top: 16px; padding: 11px 12px; border-radius: 8px; color: var(--sp-error); background: rgba(140,58,42,0.10); font-size: 12px; line-height: 1.45; font-weight: 750; }
.spd-regulatory-frame { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 12px; }
.reg-card { background: var(--sp-snow); border: var(--spd-hair); border-radius: 8px; padding: 15px; }
.reg-card strong { display: block; color: var(--sp-gold-700); font-size: 11px; font-weight: 900; letter-spacing: 0.08em; text-transform: uppercase; margin-bottom: 8px; }
.reg-card h4 { margin: 0 0 8px; color: var(--sp-brown-900); font-size: 14px; line-height: 1.25; font-weight: 850; }
.reg-card p { margin: 0; color: var(--sp-ink-2); font-size: 12px; line-height: 1.55; font-weight: 560; }
.spd-principle-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 12px; }
.principle-card { background: linear-gradient(180deg, var(--sp-white), var(--sp-snow)); border: var(--spd-hair); border-radius: 8px; padding: 16px; }
.principle-card h4 { margin: 0 0 8px; color: var(--sp-brown-900); font-size: 14px; line-height: 1.3; font-weight: 850; }
.principle-card p { margin: 0; color: var(--sp-ink-2); font-size: 12.5px; line-height: 1.58; font-weight: 560; }
.spd-evidence-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 12px; }
.spd-evidence-panel { background: var(--sp-snow); border: var(--spd-hair); border-radius: 8px; padding: 16px; min-width: 0; }
.spd-evidence-panel.wide { grid-column: 1 / -1; }
.spd-evidence-panel h4 { margin: 0 0 8px; color: var(--sp-brown-900); font-size: 15px; line-height: 1.3; font-weight: 850; }
.spd-evidence-panel p { margin: 0 0 12px; color: var(--sp-ink-2); font-size: 13px; line-height: 1.6; font-weight: 560; max-width: 92ch; }
.spd-prohibited-list.promoted { grid-template-columns: repeat(1, minmax(0, 1fr)); }
.spd-dossier-list { display: grid; gap: 8px; margin-bottom: 14px; }
.dossier-row { display: grid; grid-template-columns: 230px minmax(0, 1fr) 160px; gap: 14px; align-items: center; background: var(--sp-snow); border: var(--spd-hair); border-radius: 7px; padding: 12px 14px; }
.dossier-row strong { color: var(--sp-brown-900); font-size: 13px; line-height: 1.35; }
.dossier-row span { color: var(--sp-ink-2); font-size: 12.5px; line-height: 1.4; font-weight: 650; }
.dossier-row em { color: var(--sp-gold-700); font-size: 10px; letter-spacing: 0.08em; text-transform: uppercase; font-style: normal; font-weight: 900; text-align: right; }
.spd-compliance-doc-groups.compact-docs { grid-template-columns: repeat(4, minmax(0, 1fr)); }
.compact-docs .doc-group { padding: 12px; }
.compact-docs .doc-group p { margin-bottom: 0; }
.spd-ownership-lanes { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 12px; }
.ownership-lane { background: var(--sp-snow); border: var(--spd-hair); border-radius: 8px; padding: 14px; }
.ownership-lane h4 { margin: 0 0 10px; color: var(--sp-brown-900); font-size: 13px; letter-spacing: 0.10em; text-transform: uppercase; font-weight: 900; }
.ownership-item { background: var(--sp-white); border: var(--spd-hair); border-radius: 7px; padding: 10px; margin-bottom: 8px; }
.ownership-item:last-child { margin-bottom: 0; }
.ownership-item strong { display: block; color: var(--sp-brown-900); font-size: 12px; line-height: 1.35; }
.ownership-item span { display: block; margin-top: 4px; color: var(--sp-ink-3); font-size: 10.5px; line-height: 1.35; font-weight: 800; text-transform: uppercase; letter-spacing: 0.06em; }
.spd-date-list.timeline { grid-template-columns: repeat(5, minmax(0, 1fr)); display: grid; }
.spd-date-list.timeline div { border-left-color: var(--sp-gold-500); min-height: 88px; }
.spd-doc-package { display: grid; gap: 14px; }
.doc-package-group { background: var(--sp-snow); border: var(--spd-hair); border-radius: 8px; padding: 16px; }
.doc-package-group > h4 { margin: 0 0 5px; color: var(--sp-brown-900); font-size: 15px; font-weight: 850; }
.doc-package-group > p { margin: 0 0 12px; color: var(--sp-ink-2); font-size: 12.5px; line-height: 1.5; font-weight: 600; }
.doc-package-items { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 9px; }
.doc-package-item { display: block; background: var(--sp-white); border: var(--spd-hair); border-radius: 7px; padding: 12px; text-decoration: none; transition: transform 120ms ease, border-color 120ms ease, box-shadow 120ms ease; }
.doc-package-item:hover { transform: translateY(-1px); border-color: rgba(166,139,91,0.42); box-shadow: var(--sp-shadow-1); }
.doc-package-item span { display: block; color: var(--sp-gold-700); font-size: 9.5px; letter-spacing: 0.10em; text-transform: uppercase; font-weight: 900; margin-bottom: 5px; }
.doc-package-item strong { display: block; color: var(--sp-brown-900); font-size: 12.5px; line-height: 1.35; }
.doc-package-item p { margin: 6px 0 0; color: var(--sp-ink-2); font-size: 11.5px; line-height: 1.45; font-weight: 560; }

/* ---------- Source library / file row ---------- */
.spd-file-list { display: flex; flex-direction: column; gap: 4px; }
.spd-file-row { display: grid; grid-template-columns: 36px 1fr 140px 90px 110px 24px; gap: 14px; align-items: center; padding: 12px 14px; border-radius: 5px; cursor: pointer; transition: background 100ms; border: 1px solid transparent; }
.spd-file-row:hover { background: var(--sp-snow); }
.spd-file-row.selected { background: var(--sp-brown-100); border-color: rgba(47,36,24,0.10); }
.spd-file-row .ico-wrap { width: 36px; height: 36px; border-radius: 6px; background: var(--sp-paper-2); color: var(--sp-brown-700); display: flex; align-items: center; justify-content: center; }
.spd-file-row .nm { font-weight: 600; color: var(--sp-brown-900); font-size: 13px; }
.spd-file-row .sub { font-size: 11px; color: var(--sp-ink-3); }
.spd-file-row .meta { font-size: 12px; color: var(--sp-ink-2); }
.spd-file-row .size { font-family: var(--sp-font-mono); font-size: 11px; color: var(--sp-ink-3); }

/* Document preview */
.spd-doc-preview { background: var(--sp-white); border: var(--spd-hair); border-radius: var(--spd-radius); padding: 32px; max-height: 600px; overflow-y: auto; }
.spd-doc-preview h1, .spd-doc-preview h2 { font-family: var(--sp-font-display); font-weight: 400; color: var(--sp-brown-900); margin: 0 0 12px; letter-spacing: 0; }
.spd-doc-preview h1 { font-size: 28px; }
.spd-doc-preview h2 { font-size: 20px; margin-top: 24px; }
.spd-doc-preview p { font-size: 14px; color: var(--sp-ink); line-height: 1.65; margin: 0 0 12px; max-width: 64ch; }
.spd-doc-preview code { font-family: var(--sp-font-mono); font-size: 13px; background: var(--sp-snow); padding: 1px 4px; border-radius: 3px; }

/* Candidate report detail */
.spd-report-page { padding: 20px 28px 48px; max-width: 1360px; }
.spd-report-hero { display: grid; grid-template-columns: minmax(0, 1fr) 330px; gap: 24px; padding: 26px; margin-bottom: 14px; }
.spd-report-hero-main { display: flex; align-items: flex-start; gap: 18px; min-width: 0; }
.spd-report-avatar { width: 64px; height: 64px; border-radius: 50%; background: linear-gradient(135deg,var(--sp-brown-400),var(--sp-brown-800)); color: var(--sp-paper); font-family: var(--sp-font-display); font-size: 24px; display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.spd-report-hero .eyebrow,
.spd-report-panel .eyebrow { font-size: 10px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--sp-ink-3); font-weight: 800; margin-bottom: 5px; }
.spd-report-hero h2 { font-family: var(--sp-font-display); font-size: 34px; line-height: 1.05; font-weight: 400; color: var(--sp-brown-900); margin: 0 0 4px; letter-spacing: 0; }
.spd-report-hero .role { margin: 0 0 14px; color: var(--sp-ink-2); font-size: 14px; font-weight: 600; }
.spd-report-hero .verdict { margin: 0; color: var(--sp-ink); font-size: 15px; line-height: 1.65; max-width: 78ch; font-weight: 600; }
.spd-report-gap { display: inline-flex; align-items: flex-start; gap: 7px; margin-top: 14px; border: 1px solid rgba(176,122,42,0.28); background: rgba(176,122,42,0.08); color: var(--sp-brown-900); border-radius: 5px; padding: 8px 10px; font-size: 12.5px; line-height: 1.4; font-weight: 700; }
.spd-report-gap svg { color: var(--sp-warning); flex-shrink: 0; margin-top: 1px; }
.spd-report-hero-side { border-left: var(--spd-hair); padding-left: 22px; display: grid; gap: 14px; align-content: start; }
.spd-report-match { background: var(--sp-snow); border: var(--spd-hair); border-radius: var(--spd-radius); padding: 16px; }
.spd-report-match strong { display: block; font-family: var(--sp-font-display); font-size: 42px; line-height: 1; color: var(--sp-brown-900); font-weight: 400; }
.spd-report-match span { display: block; margin-top: 4px; color: var(--sp-brown-800); font-size: 12px; font-weight: 800; letter-spacing: 0.08em; text-transform: uppercase; }
.spd-report-match p { margin: 8px 0 0; color: var(--sp-ink-2); font-size: 12.5px; line-height: 1.45; font-weight: 600; }
.spd-report-stat-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 8px; }
.spd-report-stat-grid .stat { border: var(--spd-hair); border-radius: 5px; background: var(--sp-white); padding: 10px; }
.spd-report-stat-grid .stat strong { display: block; font-family: var(--sp-font-display); font-size: 26px; line-height: 1; color: var(--sp-brown-900); font-weight: 400; }
.spd-report-stat-grid .stat span { display: block; margin-top: 4px; color: var(--sp-ink-3); font-size: 10px; font-weight: 800; letter-spacing: 0.10em; text-transform: uppercase; }
.spd-report-nav { display: flex; gap: 6px; margin: 0 0 14px; padding: 8px; border: var(--spd-hair); border-radius: var(--spd-radius); background: var(--sp-white); position: sticky; top: 56px; z-index: 7; }
.spd-report-nav button { border: 0; border-radius: 5px; background: transparent; color: var(--sp-ink-2); padding: 9px 12px; display: inline-flex; align-items: center; gap: 7px; font-family: var(--sp-font-body); font-size: 12px; font-weight: 800; cursor: pointer; }
.spd-report-nav button:hover { background: var(--sp-snow); color: var(--sp-brown-900); }
.spd-report-nav button.active { background: var(--sp-brown-900); color: var(--sp-paper); }
.spd-report-layout { display: grid; grid-template-columns: minmax(0, 1fr) 360px; gap: 16px; align-items: flex-start; }
.spd-report-maincol { display: grid; gap: 16px; min-width: 0; }
.spd-report-sidecol { display: grid; gap: 16px; min-width: 0; position: sticky; top: 122px; }
.spd-report-two { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 16px; }
.spd-report-panel { padding: 22px; min-width: 0; }
.spd-report-panel-head { display: flex; align-items: flex-start; gap: 10px; margin-bottom: 14px; padding-bottom: 14px; border-bottom: var(--spd-hair); }
.spd-report-panel-head .ico { width: 28px; height: 28px; border-radius: 6px; background: var(--sp-paper); color: var(--sp-brown-700); display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.spd-report-panel h3 { font-family: var(--sp-font-display); font-size: 24px; line-height: 1.12; color: var(--sp-brown-900); margin: 0; font-weight: 400; letter-spacing: 0; }
.spd-report-blocks { display: grid; gap: 11px; min-width: 0; }
.spd-report-blocks h4 { font-size: 11px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--sp-brown-800); margin: 8px 0 0; font-weight: 900; }
.spd-report-blocks p { margin: 0; color: var(--sp-ink); font-size: 13.5px; line-height: 1.68; font-weight: 500; max-width: 92ch; }
.spd-report-blocks ul { margin: 0; padding-left: 18px; color: var(--sp-ink); font-size: 13.5px; line-height: 1.62; font-weight: 500; }
.spd-report-blocks li { margin-bottom: 5px; }
.spd-report-blocks blockquote { margin: 0; border-left: 3px solid var(--sp-gold-500); background: var(--sp-snow); border-radius: 4px; padding: 10px 12px; color: var(--sp-ink-2); font-size: 13px; line-height: 1.55; font-weight: 600; }
.spd-report-table-wrap { overflow-x: auto; border: var(--spd-hair); border-radius: 5px; background: var(--sp-white); }
.spd-report-table { width: 100%; min-width: 680px; border-collapse: collapse; }
.spd-report-table th,
.spd-report-table td { border-bottom: var(--spd-hair); padding: 8px 10px; text-align: left; vertical-align: top; font-size: 12px; line-height: 1.45; color: var(--sp-ink); }
.spd-report-table th { background: var(--sp-paper); color: var(--sp-ink-2); font-size: 10px; letter-spacing: 0.10em; text-transform: uppercase; font-weight: 900; }
.spd-report-table tr:last-child td { border-bottom: 0; }
.spd-report-more { border: var(--spd-hair); border-radius: 5px; background: var(--sp-snow); color: var(--sp-ink-2); padding: 8px 10px; font-size: 12px; font-weight: 700; }
.spd-report-side-note { margin: 0; color: var(--sp-ink-2); font-size: 13px; line-height: 1.55; font-weight: 600; }
.spd-report-source-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 10px; }
.spd-report-source-card { border: var(--spd-hair); border-radius: 5px; background: var(--sp-snow); padding: 12px; min-width: 0; }
.spd-report-source-card .label { color: var(--sp-brown-900); font-size: 13px; font-weight: 800; margin-bottom: 5px; }
.spd-report-source-card .path { color: var(--sp-ink); font-family: var(--sp-font-mono); font-size: 11px; line-height: 1.4; word-break: break-word; }
.spd-report-source-card .meta { color: var(--sp-ink-3); font-size: 11px; font-weight: 700; margin-top: 8px; }
.spd-report-empty h3 { font-family: var(--sp-font-display); font-size: 24px; line-height: 1.1; font-weight: 400; color: var(--sp-brown-900); margin: 0 0 8px; letter-spacing: 0; }
.spd-report-empty p { margin: 0; color: var(--sp-ink-2); font-size: 14px; line-height: 1.6; }

/* Active filter chips bar */
.spd-active-chips { display: flex; align-items: center; gap: 6px; padding: 10px 18px; flex-wrap: wrap; background: var(--sp-paper); border-bottom: var(--spd-hair-strong); }
.spd-active-chips .lbl { font-size: 11px; color: var(--sp-ink-2); letter-spacing: 0.08em; text-transform: uppercase; font-weight: 800; margin-right: 4px; }
.spd-chip-active { display: inline-flex; align-items: center; gap: 6px; padding: 4px 6px 4px 10px; background: var(--sp-white); border: var(--spd-hair-strong); border-radius: 999px; font-size: 12px; color: var(--sp-brown-900); font-weight: 500; }
.spd-chip-active .x { width: 16px; height: 16px; border-radius: 50%; display: flex; align-items: center; justify-content: center; color: var(--sp-ink-3); cursor: pointer; }
.spd-chip-active .x:hover { background: var(--sp-paper-2); color: var(--sp-brown-900); }

/* Search context tabs: role spec, role understanding and strategy */
.spd-context-layout { display: grid; grid-template-columns: minmax(0, 1fr) 320px; gap: 18px; align-items: flex-start; }
.spd-context-layout.single { grid-template-columns: minmax(0, 1fr); }
.spd-context-card { padding: 24px; min-width: 0; }
.spd-context-head { display: flex; justify-content: space-between; gap: 18px; padding-bottom: 18px; border-bottom: var(--spd-hair); margin-bottom: 18px; }
.spd-context-head .eyebrow,
.spd-context-side .eyebrow { font-size: 10px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--sp-ink-3); font-weight: 800; margin-bottom: 6px; }
.spd-context-head h3 { font-family: var(--sp-font-display); font-size: 28px; line-height: 1.1; font-weight: 400; color: var(--sp-brown-900); margin: 0 0 8px; letter-spacing: 0; }
.spd-context-head p { margin: 0; color: var(--sp-ink-2); font-size: 14px; line-height: 1.6; max-width: 76ch; font-weight: 500; }
.spd-context-badge { align-self: flex-start; white-space: nowrap; border: var(--spd-hair); border-radius: 999px; padding: 5px 9px; color: var(--sp-ink-2); background: var(--sp-snow); font-size: 11px; font-weight: 700; }
.spd-context-sections { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 14px; margin-top: 16px; }
.spd-context-section { border: var(--spd-hair); border-radius: var(--spd-radius); background: var(--sp-snow); padding: 16px; min-width: 0; }
.spd-context-section h4,
.spd-context-side h4 { margin: 0 0 10px; font-family: var(--sp-font-body); font-size: 11px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--sp-brown-800); font-weight: 800; }
.spd-context-section p { margin: 0 0 10px; color: var(--sp-ink); font-size: 13.5px; line-height: 1.65; font-weight: 500; }
.spd-context-section p:last-child { margin-bottom: 0; }
.spd-context-section ul { margin: 0; padding-left: 18px; color: var(--sp-ink); font-size: 13px; line-height: 1.55; font-weight: 500; }
.spd-context-section li { margin-bottom: 5px; }
.spd-context-table-wrap { overflow-x: auto; border: var(--spd-hair); border-radius: 5px; background: var(--sp-white); margin-top: 12px; }
.spd-context-card > .spd-context-table-wrap { margin: 0 0 16px; }
.spd-context-table { width: 100%; border-collapse: collapse; min-width: 520px; }
.spd-context-table th,
.spd-context-table td { padding: 8px 10px; border-bottom: var(--spd-hair); vertical-align: top; text-align: left; font-size: 12px; line-height: 1.45; color: var(--sp-ink); }
.spd-context-table th { color: var(--sp-ink-2); font-weight: 800; letter-spacing: 0.08em; text-transform: uppercase; background: var(--sp-paper); }
.spd-context-table tr:last-child td { border-bottom: 0; }
.spd-context-empty { border: var(--spd-hair); border-radius: var(--spd-radius); background: var(--sp-snow); padding: 16px; color: var(--sp-ink-2); font-size: 13px; font-weight: 600; }
.spd-context-side { position: sticky; top: 120px; padding: 18px; }
.spd-query-list { display: flex; flex-direction: column; gap: 8px; }
.spd-query-list code { display: block; border: var(--spd-hair); border-radius: 5px; background: var(--sp-snow); color: var(--sp-brown-900); padding: 8px 9px; font-family: var(--sp-font-mono); font-size: 11px; line-height: 1.45; white-space: normal; word-break: break-word; }

/* =========================================================================
   v2.1 — Light top-nav · privacy modes · module cards · client shell
   ========================================================================= */

/* ---------- Light top-nav variant (client-ready chrome) ---------- */
.spd-topnav.light { background: var(--sp-white); color: var(--sp-brown-900); border-bottom: var(--spd-hair); }
.spd-topnav.light .spd-topnav-brand { border-right-color: rgba(47,36,24,0.10); }
.spd-topnav.light .spd-topnav-brand .mark { background: var(--sp-brown-900); }
.spd-topnav.light .spd-topnav-brand .name { color: var(--sp-brown-900); }
.spd-topnav.light .spd-topnav-link { color: var(--sp-ink-2); }
.spd-topnav.light .spd-topnav-link:hover { background: var(--sp-snow); color: var(--sp-brown-900); }
.spd-topnav.light .spd-topnav-link.active { background: var(--sp-brown-100); color: var(--sp-brown-900); }
.spd-topnav.light .spd-search { background: var(--sp-snow); border-color: rgba(47,36,24,0.10); color: var(--sp-ink-3); }
.spd-topnav.light .spd-search input { color: var(--sp-ink); }
.spd-topnav.light .spd-search input::placeholder { color: var(--sp-ink-3); }
.spd-topnav.light .spd-search kbd { color: var(--sp-ink-3); border-color: rgba(47,36,24,0.10); }
.spd-topnav.light .icon-btn { color: var(--sp-ink-2); }
.spd-topnav.light .icon-btn:hover { background: var(--sp-snow); color: var(--sp-brown-900); }
.spd-topnav.light .icon-btn .dot { border-color: var(--sp-white); }
.spd-topnav.light .spd-topnav-user .av { color: var(--sp-paper); }
.spd-topnav.light .spd-topnav-user .nm { color: var(--sp-brown-900); }

/* Mode toggle pill — flip between internal / client preview */
.spd-mode { display: inline-flex; align-items: center; gap: 6px; padding: 5px 10px 5px 7px; border-radius: 999px; font-size: 11px; font-weight: 600; letter-spacing: 0.04em; background: var(--sp-paper-2); color: var(--sp-brown-900); cursor: pointer; border: var(--spd-hair); }
.spd-mode .dot { width: 8px; height: 8px; border-radius: 50%; background: var(--sp-brown-700); }
.spd-mode.client .dot { background: var(--sp-gold-700); }
.spd-mode:hover { background: var(--sp-paper-3); }

/* ---------- Privacy / sensitivity markers ---------- */
.spd-privacy-pill { display: inline-flex; align-items: center; gap: 4px; padding: 2px 7px; border-radius: 3px; font-size: 10px; font-weight: 700; letter-spacing: 0.10em; text-transform: uppercase; }
.spd-privacy-pill.internal { background: rgba(176,122,42,0.14); color: var(--sp-warning); }
.spd-privacy-pill.client-safe { background: rgba(79,107,59,0.14); color: var(--sp-success); }
.spd-privacy-pill.private { background: rgba(140,58,42,0.12); color: var(--sp-error); }

.spd-kv dd.internal { color: var(--sp-ink); position: relative; padding-left: 0; }
.spd-kv dd.internal::after { content: 'INTERNT'; display: inline-block; margin-left: 8px; font-size: 9px; font-weight: 700; letter-spacing: 0.10em; padding: 1px 5px; border-radius: 2px; background: rgba(176,122,42,0.16); color: var(--sp-warning); vertical-align: 2px; }
.spd-kv dd.private { color: var(--sp-ink-3); font-style: italic; font-weight: 400; }
.spd-kv dd.private::before { content: ''; display: inline-block; width: 10px; height: 10px; background: currentColor; mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Crect x='4' y='11' width='16' height='10' rx='2' fill='none' stroke='black' stroke-width='1.5'/%3E%3Cpath d='M8 11V7a4 4 0 0 1 8 0v4' fill='none' stroke='black' stroke-width='1.5'/%3E%3C/svg%3E") no-repeat center / contain; vertical-align: -1px; margin-right: 5px; }

/* ---------- Module entry cards (Oversikt) ---------- */
.spd-modules { display: grid; grid-template-columns: repeat(2, 1fr); gap: 16px; }
.spd-module { background: var(--sp-white); border: var(--spd-hair); border-radius: 8px; padding: 24px; cursor: pointer; transition: box-shadow 220ms, transform 220ms, border-color 220ms; display: flex; flex-direction: column; gap: 16px; min-height: 200px; text-decoration: none; color: inherit; }
.spd-module:hover { box-shadow: var(--sp-shadow-2); border-color: rgba(47,36,24,0.18); }
.spd-module .head { display: flex; align-items: center; gap: 14px; }
.spd-module .ico-wrap { width: 44px; height: 44px; border-radius: 8px; background: var(--sp-paper-2); color: var(--sp-brown-700); display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.spd-module .titleblk h3 { font-family: var(--sp-font-display); font-weight: 400; font-size: 22px; line-height: 1.1; color: var(--sp-brown-900); margin: 0; letter-spacing: 0; }
.spd-module .titleblk p { font-size: 12px; color: var(--sp-ink-3); margin: 4px 0 0; letter-spacing: 0.02em; }
.spd-module .stats { display: flex; gap: 24px; padding-top: 14px; border-top: var(--spd-hair); margin-top: auto; }
.spd-module .stat .v { font-family: var(--sp-font-display); font-size: 26px; line-height: 1; color: var(--sp-brown-900); font-weight: 400; }
.spd-module .stat .l { font-size: 11px; letter-spacing: 0.10em; text-transform: uppercase; color: var(--sp-ink-3); margin-top: 3px; font-weight: 600; }
.spd-module .arrow { display: inline-flex; align-items: center; gap: 6px; font-size: 13px; font-weight: 600; color: var(--sp-brown-700); }

/* ---------- Reason codes (Under terskel) ---------- */
.spd-reason { display: inline-flex; align-items: center; gap: 5px; padding: 2px 8px; border-radius: 4px; font-size: 11px; font-weight: 500; background: rgba(140,58,42,0.10); color: var(--sp-error); border: 1px solid rgba(140,58,42,0.20); }
.spd-reason.warn { background: rgba(176,122,42,0.12); color: var(--sp-warning); border-color: rgba(176,122,42,0.22); }

/* Under-threshold review queue */
.spd-under-queue { display: flex; flex-direction: column; gap: 10px; }
.spd-under-head { background: var(--sp-white); border: var(--spd-hair); border-radius: var(--spd-radius); padding: 16px 18px; display: flex; align-items: center; justify-content: space-between; gap: 18px; }
.spd-under-head h3 { margin: 0; font-family: var(--sp-font-display); font-size: 22px; line-height: 1.1; font-weight: 400; color: var(--sp-brown-900); letter-spacing: 0; }
.spd-under-head p { margin: 4px 0 0; font-size: 13px; color: var(--sp-ink-2); font-weight: 500; }
.spd-under-head .meta { display: flex; gap: 8px; flex-wrap: wrap; justify-content: flex-end; }
.spd-under-head .meta span { border: var(--spd-hair); border-radius: 999px; padding: 5px 9px; font-size: 11px; font-weight: 700; color: var(--sp-ink-2); background: var(--sp-snow); white-space: nowrap; }
.spd-under-row { background: var(--sp-white); border: var(--spd-hair); border-radius: var(--spd-radius); display: grid; grid-template-columns: minmax(0, 1fr) 168px; gap: 18px; padding: 16px 18px; box-shadow: var(--sp-shadow-1); }
.spd-under-main { min-width: 0; display: grid; gap: 12px; }
.spd-under-person { display: flex; align-items: center; gap: 12px; min-width: 0; }
.spd-under-person .av { width: 34px; height: 34px; border-radius: 50%; background: linear-gradient(135deg,var(--sp-brown-400),var(--sp-brown-700)); color: var(--sp-paper); display: flex; align-items: center; justify-content: center; flex-shrink: 0; font-family: var(--sp-font-display); font-size: 13px; }
.spd-under-person .nm { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; font-weight: 700; color: var(--sp-brown-900); }
.spd-under-person .sub { font-size: 12px; color: var(--sp-ink-2); margin-top: 2px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; max-width: 72ch; }
.spd-under-tag { border: var(--spd-hair); border-radius: 999px; background: var(--sp-paper); color: var(--sp-ink-2); padding: 2px 7px; font-size: 10px; font-weight: 800; letter-spacing: 0.08em; text-transform: uppercase; }
.spd-under-reason { border-left: 3px solid rgba(140,58,42,0.26); background: rgba(140,58,42,0.055); border-radius: 5px; padding: 10px 12px; }
.spd-under-reason .label,
.spd-under-recommend .label { font-size: 10px; letter-spacing: 0.12em; text-transform: uppercase; font-weight: 800; color: var(--sp-error); margin-bottom: 5px; }
.spd-under-reason p,
.spd-under-recommend p { margin: 0; color: var(--sp-ink); font-size: 13.5px; line-height: 1.55; font-weight: 600; }
.spd-under-recommend { border-left: 3px solid rgba(79,107,59,0.24); background: rgba(79,107,59,0.06); border-radius: 5px; padding: 10px 12px; }
.spd-under-recommend .label { color: var(--sp-success); }
.spd-under-chips { display: flex; flex-wrap: wrap; gap: 6px; }
.spd-under-chips span { background: var(--sp-snow); border: var(--spd-hair); border-radius: 999px; padding: 5px 9px; max-width: 64ch; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; font-size: 11px; color: var(--sp-ink-2); font-weight: 600; }
.spd-under-details { border: var(--spd-hair); border-radius: 5px; background: var(--sp-snow); padding: 0; }
.spd-under-details summary { list-style: none; cursor: pointer; display: flex; align-items: center; gap: 6px; padding: 9px 10px; color: var(--sp-brown-700); font-size: 12px; font-weight: 800; }
.spd-under-details summary::-webkit-details-marker { display: none; }
.spd-under-details[open] summary { border-bottom: var(--spd-hair); }
.spd-under-details .detail-body { padding: 10px 12px; display: grid; gap: 8px; }
.spd-under-details p { margin: 0; color: var(--sp-ink-2); font-size: 12.5px; line-height: 1.55; font-weight: 500; }
.spd-under-side { border-left: var(--spd-hair); padding-left: 18px; display: flex; flex-direction: column; align-items: flex-end; justify-content: center; gap: 10px; }
.spd-under-side .score { text-align: right; }
.spd-under-side .score span { display: block; font-size: 10px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--sp-ink-3); font-weight: 800; }
.spd-under-side .score strong { display: block; margin-top: 2px; font-family: var(--sp-font-display); font-size: 34px; line-height: 1; font-weight: 400; color: var(--sp-brown-900); }
.spd-under-side .spd-btn { width: 100%; justify-content: center; padding: 8px 10px; font-size: 12px; }

/* ---------- Client shell ---------- */
.spd-client { min-height: 100vh; background: var(--sp-snow); }
.spd-client-banner { background: var(--sp-paper-2); border-bottom: var(--spd-hair); padding: 10px 28px; display: flex; align-items: center; gap: 14px; font-size: 12px; color: var(--sp-ink-2); }
.spd-client-banner .ico { color: var(--sp-gold-700); }
.spd-client-banner strong { color: var(--sp-brown-900); font-weight: 600; }
.spd-client-banner .spacer { flex: 1; }
.spd-client-watermark { position: fixed; inset: 0; pointer-events: none; z-index: 1; opacity: 0.04; display: grid; grid-template-columns: repeat(auto-fill, 280px); align-content: start; gap: 60px; padding: 100px; transform: rotate(-20deg); transform-origin: top left; }
.spd-client-watermark span { font-family: var(--sp-font-display); font-size: 36px; color: var(--sp-brown-900); letter-spacing: 0.02em; white-space: nowrap; }
.spd-client-content { position: relative; z-index: 2; max-width: 980px; margin: 0 auto; padding: 36px 28px 80px; }
.spd-client-hero { display: flex; align-items: flex-start; gap: 16px; padding-bottom: 28px; border-bottom: var(--spd-hair); margin-bottom: 28px; }
.spd-client-hero .badge-approved { display: inline-flex; align-items: center; gap: 5px; padding: 4px 10px; border-radius: 999px; font-size: 11px; font-weight: 600; letter-spacing: 0.04em; background: rgba(79,107,59,0.14); color: var(--sp-success); }
.spd-client-hero h1 { font-family: var(--sp-font-display); font-size: 36px; line-height: 1.1; color: var(--sp-brown-900); margin: 8px 0 4px; font-weight: 400; letter-spacing: 0; }
.spd-client-hero .sub { font-size: 14px; color: var(--sp-ink-2); }
.spd-client-hero .right { margin-left: auto; text-align: right; font-size: 12px; color: var(--sp-ink-3); }
.spd-client-hero .right .key { font-weight: 600; color: var(--sp-brown-900); font-size: 14px; }

.spd-client-card { background: var(--sp-white); border: var(--spd-hair); border-radius: 8px; padding: 28px; margin-bottom: 14px; }
.spd-client-card .row1 { display: grid; grid-template-columns: 80px 1fr auto; gap: 20px; align-items: flex-start; }
.spd-client-card .av { width: 80px; height: 80px; border-radius: 50%; background: linear-gradient(135deg, var(--sp-brown-400), var(--sp-brown-700)); color: var(--sp-paper); font-family: var(--sp-font-display); font-size: 30px; display: flex; align-items: center; justify-content: center; box-shadow: inset 0 0 0 1px rgba(47,36,24,0.10); }
.spd-client-card h2 { font-family: var(--sp-font-display); font-size: 28px; line-height: 1.1; color: var(--sp-brown-900); margin: 0 0 4px; font-weight: 400; letter-spacing: 0; }
.spd-client-card .role { font-size: 14px; color: var(--sp-ink-2); }
.spd-client-card .rank { font-family: var(--sp-font-mono); font-size: 11px; color: var(--sp-ink-3); padding: 4px 10px; background: var(--sp-snow); border-radius: 999px; }
.spd-client-card .body { margin-top: 22px; display: grid; grid-template-columns: 1.5fr 1fr; gap: 32px; }
.spd-client-card h3 { font-family: var(--sp-font-body); font-size: 11px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--sp-ink-2); font-weight: 600; margin: 0 0 10px; }
.spd-client-card p { font-size: 14px; color: var(--sp-ink); line-height: 1.65; margin: 0 0 14px; }

.spd-client-report-hero { display: grid; grid-template-columns: minmax(0, 1fr) 260px; gap: 28px; align-items: flex-start; padding: 18px 0 34px; border-bottom: var(--spd-hair); margin-bottom: 22px; }
.spd-client-report-hero .badge-approved { display: inline-flex; align-items: center; gap: 5px; padding: 4px 10px; border-radius: 999px; font-size: 11px; font-weight: 700; letter-spacing: 0.04em; background: rgba(79,107,59,0.14); color: var(--sp-success); }
.spd-client-report-hero h1 { font-family: var(--sp-font-display); font-size: 52px; line-height: 0.98; color: var(--sp-brown-900); margin: 10px 0 8px; font-weight: 400; letter-spacing: -0.02em; }
.spd-client-report-hero .sub { font-size: 15px; color: var(--sp-ink-2); margin-bottom: 18px; }
.spd-client-report-hero p { max-width: 760px; font-size: 18px; line-height: 1.55; color: var(--sp-ink); margin: 0; }
.spd-client-report-hero .right { text-align: right; font-size: 12px; color: var(--sp-ink-3); padding-top: 20px; }
.spd-client-report-hero .right .key { font-weight: 700; color: var(--sp-brown-900); font-size: 14px; }
.spd-client-report-intro { display: grid; grid-template-columns: 260px minmax(0, 1fr); gap: 14px; margin-bottom: 22px; }
.spd-client-score-card,
.spd-client-fact-card,
.spd-client-stat-strip { background: var(--sp-white); border: var(--spd-hair); border-radius: 10px; box-shadow: var(--sp-shadow-1); }
.spd-client-score-card { padding: 20px; background: linear-gradient(145deg, var(--sp-brown-900), var(--sp-brown-700)); color: var(--sp-paper); }
.spd-client-score-card span { display: block; font-size: 10px; line-height: 1.4; letter-spacing: 0.14em; text-transform: uppercase; color: rgba(244,239,231,0.72); font-weight: 800; }
.spd-client-score-card strong { display: block; margin: 12px 0 10px; font-family: var(--sp-font-display); font-weight: 400; font-size: 48px; line-height: 0.95; }
.spd-client-score-card p { margin: 0; font-size: 13px; line-height: 1.55; color: rgba(244,239,231,0.82); }
.spd-client-fact-card { padding: 18px; }
.spd-client-fact-card .eyebrow,
.spd-client-reading-nav .eyebrow,
.spd-client-section-head .eyebrow,
.spd-client-next-step .eyebrow { font-size: 10px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--sp-gold-700); font-weight: 900; margin-bottom: 9px; }
.spd-client-fact-card dl { margin: 0; display: grid; grid-template-columns: 160px minmax(0, 1fr); gap: 8px 14px; font-size: 12.5px; line-height: 1.45; }
.spd-client-fact-card dt { color: var(--sp-ink-3); font-weight: 800; }
.spd-client-fact-card dd { margin: 0; color: var(--sp-ink); font-weight: 650; }
.spd-client-stat-strip { grid-column: 1 / -1; display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); overflow: hidden; }
.spd-client-stat-strip div { padding: 14px 16px; border-right: var(--spd-hair); }
.spd-client-stat-strip div:last-child { border-right: 0; }
.spd-client-stat-strip strong { display: block; font-family: var(--sp-font-display); font-size: 30px; line-height: 1; font-weight: 400; color: var(--sp-brown-900); }
.spd-client-stat-strip span { display: block; margin-top: 5px; color: var(--sp-ink-3); font-size: 10px; letter-spacing: 0.12em; text-transform: uppercase; font-weight: 850; }
.spd-client-reading-layout { display: grid; grid-template-columns: 220px minmax(0, 1fr); gap: 22px; align-items: flex-start; }
.spd-client-reading-nav { position: sticky; top: 18px; background: rgba(255,255,255,0.84); border: var(--spd-hair); border-radius: 10px; padding: 14px; backdrop-filter: blur(10px); box-shadow: var(--sp-shadow-1); }
.spd-client-reading-nav a { display: block; color: var(--sp-ink-2); text-decoration: none; padding: 8px 9px; border-radius: 5px; font-size: 12px; font-weight: 750; }
.spd-client-reading-nav a:hover { background: var(--sp-snow); color: var(--sp-brown-900); }
.spd-client-report-main { display: grid; gap: 16px; min-width: 0; }
.spd-client-candidate-card { display: grid; grid-template-columns: 82px minmax(0, 1fr); gap: 18px; align-items: center; background: var(--sp-white); border: var(--spd-hair); border-radius: 12px; padding: 22px; box-shadow: var(--sp-shadow-1); }
.spd-client-candidate-card .av { width: 82px; height: 82px; border-radius: 50%; background: linear-gradient(135deg, var(--sp-brown-400), var(--sp-brown-700)); color: var(--sp-paper); font-family: var(--sp-font-display); font-size: 30px; display: flex; align-items: center; justify-content: center; }
.spd-client-candidate-card .rank { font-family: var(--sp-font-mono); font-size: 10px; color: var(--sp-ink-3); padding: 4px 9px; background: var(--sp-snow); border-radius: 999px; }
.spd-client-candidate-card h2 { font-family: var(--sp-font-display); font-size: 32px; line-height: 1.05; color: var(--sp-brown-900); margin: 8px 0 4px; font-weight: 400; }
.spd-client-candidate-card p { margin: 0; color: var(--sp-ink-2); font-size: 14px; }
.spd-client-candidate-card .meta { display: flex; gap: 14px; flex-wrap: wrap; margin-top: 10px; color: var(--sp-ink-3); font-size: 12px; font-weight: 650; }
.spd-client-candidate-card .meta span { display: inline-flex; align-items: center; gap: 5px; }
.spd-client-report-section { background: var(--sp-white); border: var(--spd-hair); border-radius: 12px; padding: 28px; box-shadow: var(--sp-shadow-1); scroll-margin-top: 20px; }
.spd-client-section-head { border-bottom: var(--spd-hair); padding-bottom: 14px; margin-bottom: 18px; }
.spd-client-section-head h2 { margin: 0; font-family: var(--sp-font-display); font-size: 34px; line-height: 1.05; font-weight: 400; letter-spacing: -0.01em; color: var(--sp-brown-900); }
.spd-client-overview-grid { display: grid; grid-template-columns: minmax(0, 1.3fr) minmax(260px, 0.7fr); gap: 24px; }
.spd-client-overview-grid h3 { margin: 0 0 10px; color: var(--sp-brown-900); font-size: 13px; letter-spacing: 0.12em; text-transform: uppercase; font-weight: 900; }
.spd-client-overview-grid ul { margin: 0; padding-left: 18px; color: var(--sp-ink); font-size: 13.5px; line-height: 1.62; font-weight: 550; }
.spd-client-overview-grid li { margin-bottom: 7px; }
.spd-client-report-blocks { display: grid; gap: 12px; min-width: 0; }
.spd-client-report-blocks h4 { margin: 10px 0 0; color: var(--sp-brown-800); font-size: 12px; letter-spacing: 0.12em; text-transform: uppercase; font-weight: 900; }
.spd-client-report-blocks p,
.spd-client-report-blocks li { color: var(--sp-ink); font-size: 14px; line-height: 1.7; font-weight: 520; }
.spd-client-report-blocks p { margin: 0; max-width: 88ch; }
.spd-client-report-blocks ul { margin: 0; padding-left: 18px; }
.spd-client-report-blocks li { margin-bottom: 6px; }
.spd-client-report-blocks blockquote { margin: 0; border-left: 3px solid var(--sp-gold-500); background: var(--sp-snow); border-radius: 6px; padding: 12px 14px; color: var(--sp-ink-2); font-size: 13px; line-height: 1.62; font-weight: 650; }
.spd-client-table-wrap { overflow-x: auto; border: var(--spd-hair); border-radius: 8px; background: var(--sp-white); }
.spd-client-table { width: 100%; min-width: 620px; border-collapse: collapse; }
.spd-client-table th,
.spd-client-table td { padding: 9px 11px; border-bottom: var(--spd-hair); vertical-align: top; text-align: left; color: var(--sp-ink); font-size: 12.5px; line-height: 1.5; }
.spd-client-table th { background: var(--sp-paper); color: var(--sp-ink-2); font-size: 10px; letter-spacing: 0.10em; text-transform: uppercase; font-weight: 900; }
.spd-client-table tr:last-child td { border-bottom: 0; }
.spd-client-timeline { display: grid; gap: 0; margin: 0 0 18px; border: var(--spd-hair); border-radius: 10px; overflow: hidden; background: var(--sp-snow); }
.spd-client-timeline-item { display: grid; grid-template-columns: 22px minmax(0, 1fr); gap: 10px; padding: 12px 14px; border-bottom: var(--spd-hair); }
.spd-client-timeline-item:last-child { border-bottom: 0; }
.spd-client-timeline-item .dot { width: 9px; height: 9px; border-radius: 50%; background: var(--sp-gold-700); margin-top: 4px; box-shadow: 0 0 0 4px rgba(176,122,42,0.12); }
.spd-client-timeline-item strong { display: block; color: var(--sp-brown-900); font-size: 13px; line-height: 1.35; }
.spd-client-timeline-item span { display: block; margin-top: 3px; color: var(--sp-ink-2); font-size: 12px; line-height: 1.45; }
.spd-client-next-step { display: flex; justify-content: space-between; align-items: center; gap: 18px; background: var(--sp-brown-900); color: var(--sp-paper); border-radius: 12px; padding: 24px; box-shadow: var(--sp-shadow-2); }
.spd-client-next-step h2 { margin: 0 0 8px; font-family: var(--sp-font-display); font-size: 30px; line-height: 1.05; font-weight: 400; }
.spd-client-next-step p { margin: 0; max-width: 72ch; color: rgba(244,239,231,0.78); font-size: 13.5px; line-height: 1.6; }
.spd-client-next-step .spd-btn { white-space: nowrap; }
.spd-client-fallback-card { margin-top: 16px; }

.spd-client-empty { background: var(--sp-white); border: var(--spd-hair); border-radius: 14px; padding: 44px 38px; box-shadow: var(--sp-shadow-1); max-width: 720px; margin: 32px auto 0; }
.spd-client-empty .eyebrow { display: inline-flex; align-items: center; gap: 6px; font-size: 11px; font-weight: 900; letter-spacing: 0.12em; text-transform: uppercase; color: var(--sp-gold-700); margin-bottom: 14px; }
.spd-client-empty h1 { font-family: var(--sp-font-display); font-size: 38px; line-height: 1.05; font-weight: 400; color: var(--sp-brown-900); margin: 0 0 8px; }
.spd-client-empty .sub { font-size: 13px; color: var(--sp-ink-3); font-weight: 700; margin: 0 0 18px; }
.spd-client-empty > p { font-size: 14.5px; line-height: 1.7; color: var(--sp-ink-2); max-width: 60ch; margin: 0; font-weight: 560; }
.spd-client-empty-actions { display: flex; gap: 10px; flex-wrap: wrap; margin-top: 22px; }
.spd-client-empty-note { margin-top: 22px; padding: 14px 16px; background: var(--sp-snow); border: var(--spd-hair); border-radius: 8px; display: flex; gap: 10px; align-items: flex-start; font-size: 12.5px; color: var(--sp-ink-3); line-height: 1.55; }

.spd-client-foot { background: var(--sp-brown-900); color: rgba(244,239,231,0.8); padding: 22px 28px; font-size: 12px; line-height: 1.5; display: flex; gap: 24px; align-items: center; flex-wrap: wrap; }
.spd-client-foot strong { color: var(--sp-paper); font-weight: 600; }

/* ---------- Module dashboard side info ---------- */
.spd-side-rail { display: flex; flex-direction: column; gap: 14px; }

/* Print / PDF-safe layout */
@media print {
  .spd-topnav, .spd-topbar, .spd-side, .spd-tabs, .actions, .spd-active-chips { display: none !important; }
  .spd, .spd-main, .spd-detail-head, .spd-card, .spd-client-card { background: #fff !important; box-shadow: none !important; border-color: rgba(0,0,0,0.15) !important; }
  body { background: #fff !important; }
  .spd-acc-body { page-break-inside: avoid; }
  .spd-acc-row { page-break-inside: avoid; }
  a { color: inherit; text-decoration: none; }
}

/* Responsive — laptop down */
@media (max-width: 1280px) {
  .spd-acc-row { grid-template-columns: 28px 24px minmax(200px, 1.35fr) minmax(110px, 0.75fr) minmax(90px, 0.55fr) 82px 100px 22px; gap: 10px; padding: 12px 14px; }
  .spd-acc-body { padding: 18px 16px; grid-template-columns: 1fr; }
  .spd-facts { position: static; }
  .spd-context-layout { grid-template-columns: 1fr; }
  .spd-context-side { position: static; }
  .spd-under-row { grid-template-columns: 1fr; }
  .spd-under-side { border-left: 0; border-top: var(--spd-hair); padding-left: 0; padding-top: 12px; align-items: flex-start; }
  .spd-under-side .score { text-align: left; }
  .spd-report-hero,
  .spd-report-layout { grid-template-columns: 1fr; }
  .spd-report-hero-side { border-left: 0; border-top: var(--spd-hair); padding-left: 0; padding-top: 16px; }
  .spd-report-sidecol { position: static; }
  .spd-market-hero,
  .spd-market-layout { grid-template-columns: 1fr; }
  .spd-market-side { position: static; }
  .spd-compliance-hero,
  .spd-compliance-layout { grid-template-columns: 1fr; }
  .spd-compliance-side { position: static; }
  .spd-regulatory-frame,
  .spd-principle-grid,
  .spd-compliance-doc-groups.compact-docs,
  .spd-ownership-lanes,
  .spd-date-list.timeline,
  .doc-package-items { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .dossier-row { grid-template-columns: 180px minmax(0, 1fr); }
  .dossier-row em { grid-column: 1 / -1; text-align: left; }
}
@media (max-width: 900px) {
  .spd-topnav { flex-wrap: wrap; height: auto; padding: 8px 16px; }
  .spd-topnav-links { order: 3; width: 100%; overflow-x: auto; padding: 6px 0; }
  .spd-topnav .spd-search { display: none; }
  .spd-acc-row { grid-template-columns: 24px 22px 1fr 80px 22px; gap: 10px; }
  .spd-acc-row .spd-acc-role,
  .spd-acc-row .spd-acc-source,
  .spd-acc-row .spd-conf { display: none; }
  .spd-modules { grid-template-columns: 1fr; }
  .spd-comp-grid { grid-template-columns: 1fr; }
  .spd-detail-head .meta-row { gap: 14px; }
  .spd-context-sections { grid-template-columns: 1fr; }
  .spd-context-head { flex-direction: column; }
  .spd-report-page { padding: 16px; }
  .spd-report-hero-main { flex-direction: column; }
  .spd-report-nav { overflow-x: auto; position: static; }
  .spd-report-two,
  .spd-report-source-grid,
  .spd-report-stat-grid { grid-template-columns: 1fr; }
  .spd-market-hero-copy h3 { font-size: 28px; }
  .spd-market-metrics,
  .spd-market-score-grid,
  .spd-market-findings { grid-template-columns: 1fr; }
  .spd-market-report-head { flex-direction: column; }
  .spd-compliance-page { padding: 16px; }
  .spd-compliance-hero-copy h3 { font-size: 30px; }
  .spd-compliance-metrics,
  .spd-compliance-control-grid,
  .spd-trace-proof,
  .spd-compliance-split,
  .spd-compliance-doc-groups,
  .spd-regulatory-frame,
  .spd-principle-grid,
  .spd-evidence-grid,
  .spd-compliance-doc-groups.compact-docs,
  .spd-ownership-lanes,
  .spd-date-list.timeline,
  .doc-package-items { grid-template-columns: 1fr; }
  .trace-example { grid-template-columns: 1fr; }
  .trace-example .trace-meta { justify-content: flex-start; }
  .dossier-row { grid-template-columns: 1fr; }
}

/* =========================================================================
   AGENT SURFACES — chrome pill, slide-over, agent room, attribution
   ========================================================================= */

/* ---------- Topbar: slim global search ---------- */
.spd-global-search {
  display: flex; align-items: center; gap: 8px;
  height: 38px; padding: 0 14px;
  background: var(--sp-snow); border: var(--spd-hair); border-radius: 999px;
  color: var(--sp-ink-3); width: 220px;
  transition: all 160ms var(--sp-ease-out);
}
.spd-global-search:focus-within {
  background: var(--sp-white);
  border-color: var(--sp-brown-700);
  color: var(--sp-brown-900);
  width: 280px;
}
.spd-global-search input {
  background: transparent; border: 0; outline: 0; flex: 1; min-width: 0;
  font-family: var(--sp-font-body); font-size: 13px; color: var(--sp-ink);
}
.spd-global-search input::placeholder { color: var(--sp-ink-3); }

/* ---------- Topbar: token chip (demoted) ---------- */
.spd-token-chip {
  display: inline-flex; align-items: center; gap: 6px;
  height: 38px; padding: 0 12px;
  background: var(--sp-snow); border: var(--spd-hair); border-radius: 999px;
  font-family: var(--sp-font-mono); font-size: 11px; font-weight: 600;
  color: var(--sp-ink-2); cursor: pointer; transition: all 140ms;
}
.spd-token-chip:hover { background: var(--sp-paper); border-color: var(--sp-brown-700); color: var(--sp-brown-900); }
.spd-token-chip svg { color: var(--sp-gold-700); }
.spd-token-chip .num { letter-spacing: 0.02em; }
.spd-token-chip.warn { color: var(--sp-warning); }
.spd-token-chip.warn svg { color: var(--sp-warning); }
.spd-token-chip.crit { color: var(--sp-error); border-color: var(--sp-error); }
.spd-token-chip.crit svg { color: var(--sp-error); }

/* ---------- Topbar: agent presence (THE headline element) ---------- */
.spd-agent-presence {
  display: grid;
  grid-template-columns: 40px minmax(0, 1fr) auto;
  align-items: center; gap: 10px;
  height: 44px; padding: 4px 12px 4px 4px;
  background: linear-gradient(180deg, var(--sp-white), var(--sp-snow));
  border: 1px solid rgba(47, 36, 24, 0.16);
  border-radius: 999px;
  cursor: pointer;
  transition: all 160ms var(--sp-ease-out);
  width: 330px;
  text-align: left;
  box-shadow: 0 1px 2px rgba(47, 36, 24, 0.04);
  font-family: var(--sp-font-body);
}
.spd-agent-presence:hover {
  background: var(--sp-white);
  border-color: var(--sp-brown-700);
  box-shadow: 0 4px 14px -4px rgba(47, 36, 24, 0.18), 0 1px 2px rgba(47, 36, 24, 0.06);
  transform: translateY(-1px);
}
.spd-agent-presence:focus-visible {
  outline: 2px solid var(--sp-brown-700); outline-offset: 2px;
}

.spd-agent-presence .av {
  position: relative;
  width: 38px; height: 38px; border-radius: 50%;
  flex-shrink: 0;
  display: flex; align-items: center; justify-content: center;
}
.spd-agent-presence .av-inner {
  position: relative; z-index: 2;
  width: 32px; height: 32px; border-radius: 50%;
  background: linear-gradient(135deg, var(--sp-brown-700), var(--sp-brown-900));
  color: var(--sp-paper);
  display: flex; align-items: center; justify-content: center;
  font-family: var(--sp-font-display); font-size: 14px; font-weight: 400;
  letter-spacing: 0;
}
.spd-agent-presence .av-ring {
  position: absolute; inset: 0; border-radius: 50%;
  pointer-events: none;
}

/* Working state: spinning arc */
.spd-agent-presence.is-working .av-ring {
  background: conic-gradient(
    from 0deg,
    transparent 0deg,
    transparent 200deg,
    var(--sp-success) 260deg,
    var(--sp-success) 340deg,
    transparent 360deg
  );
  -webkit-mask: radial-gradient(circle, transparent 16px, #000 17px, #000 19px, transparent 20px);
          mask: radial-gradient(circle, transparent 16px, #000 17px, #000 19px, transparent 20px);
  animation: spd-presence-spin 2.2s linear infinite;
}
.spd-agent-presence.is-working .av-inner::after {
  content: ''; position: absolute; bottom: -1px; right: -1px;
  width: 9px; height: 9px; border-radius: 50%;
  background: var(--sp-success); border: 2px solid var(--sp-white);
  z-index: 3;
}
.spd-agent-presence.is-waiting .av-ring {
  border: 2px solid var(--sp-warning);
  animation: spd-presence-pulse 2.2s ease-in-out infinite;
}
.spd-agent-presence.is-waiting .av-inner::after {
  content: ''; position: absolute; bottom: -1px; right: -1px;
  width: 9px; height: 9px; border-radius: 50%;
  background: var(--sp-warning); border: 2px solid var(--sp-white);
  z-index: 3;
}
.spd-agent-presence.is-paused .av-inner::after {
  content: ''; position: absolute; bottom: -1px; right: -1px;
  width: 9px; height: 9px; border-radius: 50%;
  background: var(--sp-ink-3); border: 2px solid var(--sp-white);
  z-index: 3;
}
@keyframes spd-presence-spin {
  to { transform: rotate(360deg); }
}
@keyframes spd-presence-pulse {
  0%, 100% { opacity: 0.4; transform: scale(1); }
  50%      { opacity: 1;   transform: scale(1.04); }
}

.spd-agent-presence .presence-text {
  display: flex; flex-direction: column; line-height: 1.25;
  min-width: 0; gap: 2px;
}
.spd-agent-presence .presence-name {
  font-family: var(--sp-font-body); font-size: 13px; font-weight: 700;
  color: var(--sp-brown-900);
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
  display: flex; align-items: center; gap: 6px;
  letter-spacing: 0;
}
.spd-agent-presence .presence-badge {
  display: inline-flex; align-items: center; justify-content: center;
  min-width: 18px; height: 18px; padding: 0 5px;
  background: var(--sp-brown-900); color: var(--sp-paper);
  border-radius: 999px;
  font-family: var(--sp-font-body); font-size: 10px; font-weight: 700;
  letter-spacing: 0; line-height: 1;
}
.spd-agent-presence.is-waiting .presence-badge { background: var(--sp-warning); }
.spd-agent-presence .presence-status {
  font-size: 11px; color: var(--sp-ink-3); letter-spacing: 0.01em;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
  font-weight: 500;
}
.spd-agent-presence .presence-kbd {
  font-family: var(--sp-font-mono); font-size: 10px;
  background: var(--sp-paper); color: var(--sp-ink-3);
  padding: 2px 6px; border-radius: 4px;
  border: var(--spd-hair);
  flex-shrink: 0;
  letter-spacing: 0;
}
.spd-agent-presence:hover .presence-kbd {
  background: var(--sp-white); color: var(--sp-brown-700); border-color: var(--sp-brown-700);
}

/* Topbar bell tweaks (now button) */
.spd-topbar .icon-btn {
  width: 38px; height: 38px; border-radius: 999px;
  background: transparent; border: 0; padding: 0;
}
.spd-topbar .icon-btn .dot {
  position: absolute; top: 9px; right: 10px;
  width: 8px; height: 8px;
}

/* ---------- Slide-over agent panel ---------- */
.spd-slideover-bg {
  position: fixed; inset: 0; background: rgba(47, 36, 24, 0.32);
  z-index: 90; backdrop-filter: blur(2px);
  animation: spd-fade-in 180ms var(--sp-ease-out);
}
@keyframes spd-fade-in { from { opacity: 0; } to { opacity: 1; } }
.spd-slideover {
  position: fixed; top: 0; right: 0; bottom: 0;
  width: 460px; max-width: 100%; z-index: 95;
  background: var(--sp-white); border-left: var(--spd-hair-strong);
  display: flex; flex-direction: column;
  box-shadow: -20px 0 40px -20px rgba(47, 36, 24, 0.22);
  animation: spd-slide-in 240ms var(--sp-ease-out);
}
@keyframes spd-slide-in { from { transform: translateX(20px); opacity: 0; } to { transform: translateX(0); opacity: 1; } }

.spd-slideover-head {
  padding: 18px 20px; border-bottom: var(--spd-hair);
  display: flex; align-items: center; gap: 12px;
}
.spd-slideover-head .av {
  width: 40px; height: 40px; border-radius: 50%;
  background: linear-gradient(135deg, var(--sp-brown-700), var(--sp-brown-900));
  color: var(--sp-paper); display: flex; align-items: center; justify-content: center;
  font-family: var(--sp-font-display); font-size: 16px;
}
.spd-slideover-head .meta { flex: 1; min-width: 0; }
.spd-slideover-head .meta .name {
  font-family: var(--sp-font-display); font-size: 18px;
  color: var(--sp-brown-900); line-height: 1;
}
.spd-slideover-head .meta .sub {
  font-size: 11px; color: var(--sp-ink-3); margin-top: 4px;
  letter-spacing: 0.06em; text-transform: uppercase; font-weight: 600;
}
.spd-slideover-head .close {
  width: 32px; height: 32px; border-radius: var(--spd-radius);
  display: flex; align-items: center; justify-content: center;
  color: var(--sp-ink-3); cursor: pointer; background: transparent; border: 0;
}
.spd-slideover-head .close:hover { background: var(--sp-snow); color: var(--sp-brown-900); }

.spd-slideover-body { flex: 1; overflow-y: auto; padding: 18px 20px 24px; }
.spd-slideover-section { margin-bottom: 20px; }
.spd-slideover-section h4 {
  font-size: 11px; letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--sp-ink-3); margin: 0 0 10px; font-weight: 700;
}
.spd-slideover-foot {
  padding: 14px 20px; border-top: var(--spd-hair);
  display: flex; gap: 8px;
}

.spd-now-item {
  display: grid; grid-template-columns: 14px 1fr; gap: 10px;
  padding: 10px 0; border-bottom: var(--spd-hair);
}
.spd-now-item:last-child { border-bottom: 0; }
.spd-now-dot {
  width: 8px; height: 8px; border-radius: 50%; margin-top: 6px;
  background: var(--sp-brown-700); flex-shrink: 0;
}
.spd-now-dot.running { background: var(--sp-success); box-shadow: 0 0 0 4px rgba(79,107,59,0.18); animation: spd-pulse 1.6s ease-in-out infinite; }
.spd-now-dot.done    { background: var(--sp-ink-3); }
.spd-now-dot.waiting { background: var(--sp-warning); box-shadow: 0 0 0 4px rgba(176,122,42,0.18); }
@keyframes spd-pulse { 0%,100% { box-shadow: 0 0 0 4px rgba(79,107,59,0.18); } 50% { box-shadow: 0 0 0 8px rgba(79,107,59,0.08); } }
.spd-now-item .title { font-size: 13px; font-weight: 600; color: var(--sp-brown-900); line-height: 1.35; }
.spd-now-item .detail { font-size: 12px; color: var(--sp-ink-2); margin-top: 3px; line-height: 1.45; }
.spd-now-item .meta {
  font-size: 11px; color: var(--sp-ink-3); margin-top: 6px;
  font-family: var(--sp-font-mono); letter-spacing: 0.02em;
}
.spd-now-item .progress-track {
  height: 3px; background: var(--sp-paper-3); border-radius: 999px;
  margin-top: 8px; overflow: hidden;
}
.spd-now-item .progress-fill { height: 100%; background: var(--sp-brown-700); border-radius: 999px; }
.spd-now-item.waiting .progress-fill { background: var(--sp-warning); }
.spd-now-item.done .progress-fill { background: var(--sp-success); }

/* ---------- Tasking input ---------- */
.spd-task-input {
  display: grid; grid-template-columns: 14px 1fr auto; gap: 10px;
  background: var(--sp-snow); border: var(--spd-hair); border-radius: var(--spd-radius);
  padding: 10px 12px; align-items: center;
}
.spd-task-input input {
  background: transparent; border: 0; outline: 0; flex: 1;
  font-family: var(--sp-font-body); font-size: 13px; color: var(--sp-ink);
  min-width: 0;
}
.spd-task-input input::placeholder { color: var(--sp-ink-3); }

/* ---------- In-workflow agent strip ---------- */
.spd-agent-strip {
  display: grid; grid-template-columns: 36px 1fr auto; gap: 14px;
  align-items: center;
  padding: 12px 18px;
  background: linear-gradient(180deg, var(--sp-snow), var(--sp-paper));
  border: var(--spd-hair); border-radius: var(--spd-radius);
  margin: 0 28px 14px;
}
.spd-agent-strip .av {
  width: 36px; height: 36px; border-radius: 50%;
  background: linear-gradient(135deg, var(--sp-brown-700), var(--sp-brown-900));
  color: var(--sp-paper); display: flex; align-items: center; justify-content: center;
  font-family: var(--sp-font-display); font-size: 14px; position: relative;
}
.spd-agent-strip .av::after {
  content: ''; position: absolute; bottom: 0; right: 0;
  width: 10px; height: 10px; border-radius: 50%;
  background: var(--sp-success); border: 2px solid var(--sp-paper);
}
.spd-agent-strip .body { min-width: 0; }
.spd-agent-strip .body .lbl {
  font-size: 10px; letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--sp-gold-700); font-weight: 700;
}
.spd-agent-strip .body .what {
  font-size: 13px; color: var(--sp-brown-900); font-weight: 600;
  margin-top: 2px; line-height: 1.4;
}
.spd-agent-strip .body .meta {
  font-size: 11px; color: var(--sp-ink-3); margin-top: 4px;
  display: flex; gap: 14px; flex-wrap: wrap; align-items: center;
}
.spd-agent-strip .body .meta span { display: inline-flex; align-items: center; gap: 4px; }
.spd-agent-strip .actions { display: flex; gap: 6px; flex-shrink: 0; }
.spd-agent-strip .actions .spd-btn { padding: 6px 10px; font-size: 12px; }

/* ---------- Agent attribution byline in audit / candidate rows ---------- */
.spd-agent-byline {
  display: inline-flex; align-items: center; gap: 5px;
  font-size: 11px; color: var(--sp-gold-700); font-weight: 600;
  letter-spacing: 0.04em;
}
.spd-agent-byline .av {
  width: 16px; height: 16px; border-radius: 50%;
  background: linear-gradient(135deg, var(--sp-brown-700), var(--sp-brown-900));
  color: var(--sp-paper); display: flex; align-items: center; justify-content: center;
  font-family: var(--sp-font-display); font-size: 9px;
}

/* ---------- Voice / pushback banner (extends spd-banner) ---------- */
.spd-banner.agent {
  background: linear-gradient(180deg, rgba(201,180,136,0.34), rgba(166,139,91,0.18));
  border: 1px solid rgba(138,110,58,0.36);
}
.spd-banner.agent .icn { color: var(--sp-gold-700); }
.spd-banner.agent .agent-byline {
  display: inline-flex; align-items: center; gap: 5px;
  font-size: 11px; color: var(--sp-gold-700); font-weight: 700;
  letter-spacing: 0.06em; text-transform: uppercase; margin-bottom: 3px;
}
.spd-banner.agent strong { color: var(--sp-brown-900); }

/* =========================================================================
   AGENT ROOM ("Din agent" module)
   ========================================================================= */
.spd-agent-room { padding: 0 28px 48px; max-width: 1400px; margin: 0 auto; }

.spd-agent-hero {
  display: grid; grid-template-columns: minmax(0, 1fr) 360px; gap: 20px;
  margin: 16px 0 20px;
}
.spd-agent-hero .spd-agent-hero-main {
  background: linear-gradient(180deg, var(--sp-snow), var(--sp-paper));
  border: var(--spd-hair); border-radius: var(--spd-radius); padding: 22px 24px;
  display: grid; grid-template-columns: 56px 1fr; gap: 16px;
  align-items: start;
}
.spd-agent-hero .spd-agent-hero-main .av {
  width: 56px; height: 56px; border-radius: 50%;
  background: linear-gradient(135deg, var(--sp-brown-700), var(--sp-brown-900));
  color: var(--sp-paper); display: flex; align-items: center; justify-content: center;
  font-family: var(--sp-font-display); font-size: 22px; position: relative;
}
.spd-agent-hero .spd-agent-hero-main .av::after {
  content: ''; position: absolute; bottom: 1px; right: 1px;
  width: 14px; height: 14px; border-radius: 50%;
  background: var(--sp-success); border: 3px solid var(--sp-paper);
}
.spd-agent-hero .eyebrow {
  font-size: 11px; letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--sp-gold-700); font-weight: 700;
}
.spd-agent-hero h2 {
  font-family: var(--sp-font-display); font-size: 32px; color: var(--sp-brown-900);
  margin: 4px 0 4px; line-height: 1.05; font-weight: 400;
}
.spd-agent-hero .role { font-size: 13px; color: var(--sp-ink-2); }
.spd-agent-hero .what {
  margin-top: 12px; padding: 10px 14px;
  background: var(--sp-white); border: var(--spd-hair); border-radius: var(--spd-radius);
  font-size: 13px; color: var(--sp-brown-900); display: flex; gap: 10px; align-items: center;
}
.spd-agent-hero .what .dot {
  width: 10px; height: 10px; border-radius: 50%; background: var(--sp-success);
  box-shadow: 0 0 0 4px rgba(79,107,59,0.18);
  animation: spd-pulse 1.6s ease-in-out infinite;
  flex-shrink: 0;
}
.spd-agent-hero .what strong { color: var(--sp-brown-900); }

.spd-agent-hero-side {
  background: var(--sp-brown-900); color: var(--sp-paper);
  border-radius: var(--spd-radius); padding: 22px 22px;
  display: flex; flex-direction: column; gap: 8px;
}
.spd-agent-hero-side .lbl {
  font-size: 10px; letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--sp-gold-300); font-weight: 700;
}
.spd-agent-hero-side .big {
  font-family: var(--sp-font-display); font-size: 40px; color: var(--sp-paper); line-height: 1; margin-top: 4px;
}
.spd-agent-hero-side .sub { font-size: 12px; color: rgba(244,239,231,0.72); }
.spd-agent-hero-side .meter-track {
  height: 6px; background: rgba(244,239,231,0.16); border-radius: 999px; overflow: hidden;
  margin-top: 8px;
}
.spd-agent-hero-side .meter-fill { height: 100%; background: var(--sp-gold-500); border-radius: 999px; }
.spd-agent-hero-side .meter-fill.warn { background: var(--sp-warning); }
.spd-agent-hero-side .meter-fill.crit { background: var(--sp-error); }
.spd-agent-hero-side .meta-row {
  display: flex; justify-content: space-between; font-size: 11px; color: rgba(244,239,231,0.72);
  padding-top: 10px; margin-top: 4px;
  border-top: 1px solid rgba(244,239,231,0.16);
  gap: 14px; flex-wrap: wrap;
}

/* ---------- Agent room nav (sub-tabs) ---------- */
.spd-agent-room-nav {
  display: flex; gap: 4px; flex-wrap: wrap;
  border-bottom: var(--spd-hair); margin-bottom: 18px;
}
.spd-agent-room-nav button {
  background: transparent; border: 0; padding: 10px 14px;
  font-family: var(--sp-font-body); font-size: 13px; font-weight: 600;
  color: var(--sp-ink-2); cursor: pointer; display: inline-flex; align-items: center; gap: 7px;
  border-bottom: 2px solid transparent; margin-bottom: -1px;
  letter-spacing: 0;
}
.spd-agent-room-nav button:hover { color: var(--sp-brown-900); }
.spd-agent-room-nav button.active {
  color: var(--sp-brown-900); border-bottom-color: var(--sp-brown-700);
}
.spd-agent-room-nav button .count {
  font-size: 11px; background: var(--sp-paper-3); padding: 1px 6px; border-radius: 999px;
  font-weight: 700; color: var(--sp-brown-900);
}

/* ---------- Agent room: shared card layout ---------- */
.spd-agent-card-grid {
  display: grid; grid-template-columns: 1fr 1fr; gap: 16px;
}
.spd-agent-card-grid.single { grid-template-columns: 1fr; }
.spd-agent-card-grid.thirds { grid-template-columns: 1fr 1fr 1fr; }

.spd-agent-card {
  background: var(--sp-white); border: var(--spd-hair); border-radius: var(--spd-radius);
  padding: 18px 20px;
}
.spd-agent-card-head {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.spd-agent-card-head .icn {
  width: 28px; height: 28px; border-radius: var(--spd-radius);
  background: var(--sp-paper); color: var(--sp-brown-700);
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.spd-agent-card-head h3 {
  font-size: 14px; color: var(--sp-brown-900); margin: 0; font-weight: 600;
}
.spd-agent-card-head .lbl {
  font-size: 11px; letter-spacing: 0.10em; text-transform: uppercase;
  color: var(--sp-gold-700); font-weight: 700;
}
.spd-agent-card-head .head-meta {
  margin-left: auto; font-size: 11px; color: var(--sp-ink-3);
}

/* ---------- Inbox cards ---------- */
.spd-inbox-list { display: flex; flex-direction: column; gap: 12px; }
.spd-inbox-item {
  background: var(--sp-white); border: var(--spd-hair); border-left: 3px solid var(--sp-brown-700);
  border-radius: var(--spd-radius);
  padding: 16px 18px;
}
.spd-inbox-item.high { border-left-color: var(--sp-warning); }
.spd-inbox-item .kind {
  font-size: 10px; letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--sp-gold-700); font-weight: 700; margin-bottom: 4px;
}
.spd-inbox-item h4 { font-size: 14px; color: var(--sp-brown-900); margin: 0 0 6px; font-weight: 600; }
.spd-inbox-item p { font-size: 13px; color: var(--sp-ink-2); margin: 0 0 10px; line-height: 1.55; }
.spd-inbox-item .ctx {
  font-size: 11px; color: var(--sp-ink-3); font-family: var(--sp-font-mono);
  margin-bottom: 10px;
}
.spd-inbox-item .choices { display: flex; gap: 6px; flex-wrap: wrap; }
.spd-inbox-item .choices button {
  background: var(--sp-snow); border: var(--spd-hair); border-radius: var(--spd-radius);
  padding: 6px 12px; font-family: var(--sp-font-body); font-size: 12px; font-weight: 600;
  color: var(--sp-brown-900); cursor: pointer; transition: all 140ms;
}
.spd-inbox-item .choices button:hover { background: var(--sp-paper); border-color: var(--sp-brown-700); }
.spd-inbox-item .choices button.primary { background: var(--sp-brown-900); color: var(--sp-paper); border-color: transparent; }
.spd-inbox-item .when { font-size: 11px; color: var(--sp-ink-3); margin-top: 10px; }

/* ---------- Memory grid (Hva agenten har lært) ---------- */
.spd-memory-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.spd-memory-item {
  background: var(--sp-white); border: var(--spd-hair); border-radius: var(--spd-radius);
  padding: 14px 16px;
}
.spd-memory-item h4 { font-size: 13px; color: var(--sp-brown-900); margin: 0 0 6px; font-weight: 600; line-height: 1.4; }
.spd-memory-item p { font-size: 12px; color: var(--sp-ink-2); margin: 0 0 10px; line-height: 1.5; }
.spd-memory-item .foot {
  font-size: 11px; color: var(--sp-ink-3); display: flex; justify-content: space-between;
  padding-top: 8px; border-top: var(--spd-hair);
}
.spd-memory-item .conf {
  font-weight: 700; color: var(--sp-brown-900); letter-spacing: 0.04em;
}
.spd-memory-stats {
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 12px; margin-bottom: 16px;
}
.spd-memory-stats .stat {
  background: var(--sp-white); border: var(--spd-hair); border-radius: var(--spd-radius);
  padding: 14px; text-align: center;
}
.spd-memory-stats .stat .v {
  font-family: var(--sp-font-display); font-size: 28px; color: var(--sp-brown-900); line-height: 1;
}
.spd-memory-stats .stat .l {
  font-size: 10px; letter-spacing: 0.10em; text-transform: uppercase; color: var(--sp-ink-3);
  font-weight: 700; margin-top: 6px;
}

/* ---------- Routines / Standards list ---------- */
.spd-routine-list, .spd-standards-list { display: flex; flex-direction: column; gap: 10px; }
.spd-routine-item, .spd-standard-item {
  background: var(--sp-white); border: var(--spd-hair); border-radius: var(--spd-radius);
  padding: 14px 16px;
  display: grid; grid-template-columns: 1fr auto; gap: 12px;
  align-items: start;
}
.spd-routine-item h4, .spd-standard-item h4 {
  font-size: 13px; color: var(--sp-brown-900); margin: 0 0 4px; font-weight: 600;
}
.spd-routine-item .cad {
  font-family: var(--sp-font-mono); font-size: 11px; color: var(--sp-gold-700);
  letter-spacing: 0.02em; margin-bottom: 4px;
}
.spd-routine-item p, .spd-standard-item p {
  font-size: 12px; color: var(--sp-ink-2); margin: 0 0 6px; line-height: 1.55;
}
.spd-routine-item .runs {
  font-size: 11px; color: var(--sp-ink-3); font-family: var(--sp-font-mono);
}
.spd-routine-item .state {
  padding: 3px 9px; border-radius: 999px; font-size: 11px; font-weight: 700;
  background: var(--sp-paper-2); color: var(--sp-brown-900);
}
.spd-routine-item .state.active { background: rgba(79,107,59,0.16); color: var(--sp-success); }
.spd-routine-item .state.paused { background: rgba(176,122,42,0.16); color: var(--sp-warning); }
.spd-standard-item .src {
  font-size: 11px; color: var(--sp-ink-3); font-style: italic;
}
.spd-standard-item .edit {
  background: transparent; border: var(--spd-hair); color: var(--sp-brown-700);
  padding: 5px 10px; border-radius: var(--spd-radius); font-size: 11px; font-weight: 600;
  cursor: pointer;
}
.spd-standard-item .edit:hover { background: var(--sp-snow); color: var(--sp-brown-900); }

/* ---------- Conversation thread ---------- */
.spd-chat { display: flex; flex-direction: column; gap: 10px; }
.spd-chat-msg { display: grid; grid-template-columns: 28px 1fr; gap: 10px; }
.spd-chat-msg .av {
  width: 28px; height: 28px; border-radius: 50%; flex-shrink: 0;
  display: flex; align-items: center; justify-content: center;
  font-family: var(--sp-font-display); font-size: 12px;
}
.spd-chat-msg .av.agent {
  background: linear-gradient(135deg, var(--sp-brown-700), var(--sp-brown-900)); color: var(--sp-paper);
}
.spd-chat-msg .av.user {
  background: var(--sp-paper-3); color: var(--sp-brown-900);
}
.spd-chat-msg .bubble {
  background: var(--sp-white); border: var(--spd-hair); border-radius: var(--spd-radius);
  padding: 10px 14px;
}
.spd-chat-msg.agent .bubble { background: var(--sp-snow); border-color: rgba(138,110,58,0.30); }
.spd-chat-msg .bubble .body { font-size: 13px; color: var(--sp-brown-900); line-height: 1.55; }
.spd-chat-msg .bubble .when { font-size: 10px; color: var(--sp-ink-3); margin-top: 4px; font-family: var(--sp-font-mono); }
.spd-chat-form {
  margin-top: 14px; display: grid; grid-template-columns: 1fr auto; gap: 8px;
}
.spd-chat-form input {
  background: var(--sp-snow); border: var(--spd-hair); border-radius: var(--spd-radius);
  padding: 10px 14px; font-family: var(--sp-font-body); font-size: 13px; outline: 0;
}
.spd-chat-form input:focus { border-color: var(--sp-brown-700); background: var(--sp-white); }

/* ---------- Drift / operations ---------- */
.spd-drift-meter {
  background: var(--sp-white); border: var(--spd-hair); border-radius: var(--spd-radius);
  padding: 18px 20px;
}
.spd-drift-meter .row {
  display: flex; justify-content: space-between; align-items: baseline; margin-bottom: 10px;
}
.spd-drift-meter .big {
  font-family: var(--sp-font-display); font-size: 36px; color: var(--sp-brown-900); line-height: 1;
}
.spd-drift-meter .limit { font-size: 13px; color: var(--sp-ink-3); }
.spd-drift-meter .meter-track {
  height: 8px; background: var(--sp-paper-3); border-radius: 999px; overflow: hidden;
  margin: 6px 0 8px;
}
.spd-drift-meter .meter-fill { height: 100%; background: var(--sp-brown-700); border-radius: 999px; }
.spd-drift-meter .meter-fill.warn { background: var(--sp-warning); }
.spd-drift-meter .meter-fill.crit { background: var(--sp-error); }
.spd-drift-meter .legend { font-size: 11px; color: var(--sp-ink-3); display: flex; justify-content: space-between; }
.spd-drift-bars { display: flex; flex-direction: column; gap: 8px; }
.spd-drift-bar { display: grid; grid-template-columns: 140px 1fr 70px; gap: 10px; align-items: center; font-size: 12px; }
.spd-drift-bar .lbl { color: var(--sp-ink-2); }
.spd-drift-bar .track { height: 6px; background: var(--sp-paper-3); border-radius: 999px; overflow: hidden; }
.spd-drift-bar .fill { height: 100%; background: var(--sp-brown-700); border-radius: 999px; }
.spd-drift-bar .num { text-align: right; font-family: var(--sp-font-mono); font-size: 11px; color: var(--sp-ink-2); }

.spd-drift-events {
  display: flex; flex-direction: column; gap: 0;
}
.spd-drift-event {
  display: grid; grid-template-columns: 100px 70px 1fr; gap: 12px;
  padding: 10px 0; border-bottom: var(--spd-hair); font-size: 12px;
  align-items: center;
}
.spd-drift-event:last-child { border-bottom: 0; }
.spd-drift-event .ts { font-family: var(--sp-font-mono); font-size: 11px; color: var(--sp-ink-3); }
.spd-drift-event .kind {
  font-size: 10px; padding: 2px 7px; border-radius: 999px; text-align: center;
  background: var(--sp-paper-2); color: var(--sp-brown-900); font-weight: 700;
  letter-spacing: 0.04em; text-transform: uppercase;
}
.spd-drift-event .kind.memory { background: rgba(166,139,91,0.30); color: var(--sp-gold-700); }
.spd-drift-event .kind.config { background: rgba(61,90,117,0.16); color: var(--sp-info); }
.spd-drift-event .body { color: var(--sp-ink-2); }

/* ---------- Settings ---------- */
.spd-settings-list { display: flex; flex-direction: column; gap: 12px; }
.spd-settings-row {
  display: grid; grid-template-columns: 200px 1fr; gap: 16px;
  padding: 14px 16px; background: var(--sp-white);
  border: var(--spd-hair); border-radius: var(--spd-radius);
  align-items: center;
}
.spd-settings-row .lbl { font-size: 12px; color: var(--sp-ink-2); font-weight: 600; }
.spd-settings-row .v { font-size: 13px; color: var(--sp-brown-900); display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.spd-settings-row .v .pill {
  font-size: 11px; padding: 2px 8px; border-radius: 999px;
  background: var(--sp-paper-2); color: var(--sp-brown-900); font-weight: 600;
}
.spd-settings-row .v .pill.ok { background: rgba(79,107,59,0.18); color: var(--sp-success); }
.spd-settings-row .v .pill.warn { background: rgba(176,122,42,0.18); color: var(--sp-warning); }
.spd-settings-row .v .pill.muted { background: var(--sp-paper-2); color: var(--sp-ink-3); }

/* ---------- Learnings widget (Oversikt insert) ---------- */
.spd-learnings-card {
  background: linear-gradient(180deg, var(--sp-snow), var(--sp-paper));
  border: var(--spd-hair); border-radius: var(--spd-radius);
  padding: 18px 20px;
}
.spd-learnings-card .head {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.spd-learnings-card .head .av {
  width: 28px; height: 28px; border-radius: 50%;
  background: linear-gradient(135deg, var(--sp-brown-700), var(--sp-brown-900)); color: var(--sp-paper);
  display: flex; align-items: center; justify-content: center;
  font-family: var(--sp-font-display); font-size: 12px;
}
.spd-learnings-card .head .lbl {
  font-size: 10px; letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--sp-gold-700); font-weight: 700;
}
.spd-learnings-card .head h3 { font-size: 14px; color: var(--sp-brown-900); margin: 0; font-weight: 600; }
.spd-learnings-card .items { display: flex; flex-direction: column; gap: 0; }
.spd-learnings-card .item {
  display: grid; grid-template-columns: 1fr auto; gap: 10px;
  padding: 8px 0; border-bottom: var(--spd-hair); font-size: 12px;
  align-items: baseline;
}
.spd-learnings-card .item:last-child { border-bottom: 0; }
.spd-learnings-card .item .claim { color: var(--sp-brown-900); font-weight: 600; line-height: 1.4; }
.spd-learnings-card .item .src { color: var(--sp-ink-3); font-size: 11px; white-space: nowrap; }

/* =========================================================================
   ADMIN AGENT — konsernpuls
   ========================================================================= */
.spd-pulse-grid {
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 12px;
  margin: 0 0 20px;
}
.spd-pulse-tile {
  background: var(--sp-white); border: var(--spd-hair); border-radius: var(--spd-radius);
  padding: 16px 18px;
}
.spd-pulse-tile .lbl {
  font-size: 10px; letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--sp-ink-3); font-weight: 700;
}
.spd-pulse-tile .v {
  font-family: var(--sp-font-display); font-size: 30px; color: var(--sp-brown-900); margin-top: 4px; line-height: 1;
}
.spd-pulse-tile .sub { font-size: 11px; color: var(--sp-ink-3); margin-top: 6px; }
.spd-pulse-tile .delta { font-size: 12px; font-weight: 700; }
.spd-pulse-tile .delta.up { color: var(--sp-success); }
.spd-pulse-tile .delta.down { color: var(--sp-error); }

.spd-company-grid {
  display: grid; grid-template-columns: repeat(2, 1fr); gap: 12px;
}
.spd-company-card {
  background: var(--sp-white); border: var(--spd-hair); border-radius: var(--spd-radius);
  padding: 16px 18px;
}
.spd-company-card .head {
  display: flex; align-items: baseline; gap: 10px; margin-bottom: 8px;
}
.spd-company-card .head .name {
  font-size: 14px; color: var(--sp-brown-900); font-weight: 600;
}
.spd-company-card .head .sector {
  font-size: 11px; color: var(--sp-ink-3); letter-spacing: 0.04em;
}
.spd-company-card .head .pill {
  margin-left: auto; font-size: 10px; padding: 2px 7px; border-radius: 999px;
  font-weight: 700; letter-spacing: 0.04em; text-transform: uppercase;
}
.spd-company-card .head .pill.connected { background: rgba(79,107,59,0.18); color: var(--sp-success); }
.spd-company-card .head .pill.partial { background: rgba(176,122,42,0.18); color: var(--sp-warning); }
.spd-company-card .stats {
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 8px; margin: 12px 0;
}
.spd-company-card .stat .v {
  font-family: var(--sp-font-display); font-size: 18px; color: var(--sp-brown-900); line-height: 1;
}
.spd-company-card .stat .l {
  font-size: 10px; letter-spacing: 0.06em; text-transform: uppercase;
  color: var(--sp-ink-3); font-weight: 700; margin-top: 3px;
}
.spd-company-card .foot {
  font-size: 11px; color: var(--sp-ink-3); padding-top: 8px; border-top: var(--spd-hair);
  display: flex; gap: 12px;
}
.spd-company-card .note { font-size: 12px; color: var(--sp-ink-2); margin-top: 6px; font-style: italic; }

/* ---------- Fleet (consultant agent aggregate) ---------- */
.spd-fleet-card {
  background: var(--sp-brown-900); color: var(--sp-paper);
  border-radius: var(--spd-radius); padding: 22px 24px;
}
.spd-fleet-card .lbl {
  font-size: 10px; letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--sp-gold-300); font-weight: 700;
}
.spd-fleet-card h3 {
  font-family: var(--sp-font-display); font-size: 24px; color: var(--sp-paper);
  margin: 6px 0 14px; font-weight: 400;
}
.spd-fleet-grid {
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 14px;
}
.spd-fleet-grid .item .v {
  font-family: var(--sp-font-display); font-size: 30px; color: var(--sp-paper); line-height: 1;
}
.spd-fleet-grid .item .l {
  font-size: 10px; letter-spacing: 0.10em; text-transform: uppercase;
  color: rgba(244,239,231,0.62); font-weight: 700; margin-top: 6px;
}
.spd-fleet-note {
  margin-top: 16px; padding-top: 14px; border-top: 1px solid rgba(244,239,231,0.16);
  font-size: 12px; color: rgba(244,239,231,0.72); line-height: 1.55;
}

/* ---------- Responsive trims ---------- */
@media (max-width: 1200px) {
  .spd-agent-hero { grid-template-columns: 1fr; }
  .spd-memory-grid { grid-template-columns: 1fr; }
  .spd-pulse-grid { grid-template-columns: repeat(2, 1fr); }
  .spd-company-grid { grid-template-columns: 1fr; }
  .spd-memory-stats { grid-template-columns: repeat(2, 1fr); }
  .spd-fleet-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 960px) {
  .spd-agent-card-grid, .spd-agent-card-grid.thirds { grid-template-columns: 1fr; }
  .spd-slideover { width: 90%; }
  .spd-agent-strip { grid-template-columns: 32px 1fr; }
  .spd-agent-strip .actions { grid-column: 1 / -1; justify-content: flex-end; }
  .spd-settings-row { grid-template-columns: 1fr; }
}

