/* /assets/audit-shared.css — Real-app visual identity, cloned for /audit-full-demo */
:root {
  --bg-base:#0a0f1c; --bg-elev-1:#0f1626; --bg-elev-2:#111827; --bg-elev-3:#18223a;
  --border:#1f2937; --border-strong:#2a3651;
  --accent:#00d4ff; --accent-soft:rgba(0,212,255,.12); --accent-glow:rgba(0,212,255,.45);
  --success:#10b981; --warn:#f59e0b; --danger:#ef4444;
  --text:#f9fafb; --text-dim:#9ca3af; --text-faint:#5f6c84;
  --font-display:"IBM Plex Sans",system-ui,sans-serif;
  --font-ui:"IBM Plex Sans",system-ui,sans-serif;
  --font-mono:"IBM Plex Mono",ui-monospace,monospace;
  --topbar-h:60px;
}
* { box-sizing: border-box; }
html, body {
  margin: 0; padding: 0; background: var(--bg-base); color: var(--text);
  font-family: var(--font-ui); min-height: 100vh; -webkit-font-smoothing: antialiased;
}
a { color: var(--accent); text-decoration: none; }
a:focus-visible, button:focus-visible, .btn:focus-visible, input:focus-visible {
  outline: 2px solid var(--accent); outline-offset: 3px; border-radius: 8px;
}

/* ─── Topbar (clone of app-dashboard.html) ─────────────────────── */
.topbar {
  position: fixed; top: var(--audit-banner-h, 56px); left: 0; right: 0;
  height: var(--topbar-h);
  background: rgba(10,15,28,.94); backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border-bottom: 1px solid var(--border); z-index: 90;
  display: flex; align-items: center; padding: 0 24px; gap: 24px;
}
.topbar .brand { font-family: var(--font-display); font-weight: 700; font-size: 17px; letter-spacing: -0.01em; }
.topbar .brand span { color: var(--accent); }
.topbar .tier {
  font-family: var(--font-mono); font-size: 10px; color: var(--accent);
  letter-spacing: .16em; text-transform: uppercase;
  padding: 4px 10px; border: 1px solid var(--accent); border-radius: 999px;
  background: var(--accent-soft); min-height: 22px;
  display: inline-flex; align-items: center;
}
.topbar .tier.admin { background: linear-gradient(135deg,#10b981,#059669); color: #0a0f1c; border-color: #10b981; }
.topbar .nav { display: flex; gap: 18px; }
.topbar .nav a {
  font-family: var(--font-ui); font-size: 14px; color: var(--text-dim);
  font-weight: 500; padding: 6px 0; border-bottom: 2px solid transparent;
  transition: all .15s; min-height: 36px; display: inline-flex; align-items: center;
}
.topbar .nav a:hover, .topbar .nav a.active {
  color: var(--text); border-bottom-color: var(--accent);
}
.topbar .spacer { flex: 1; }
.topbar .who { font-family: var(--font-mono); font-size: 12px; color: var(--text-dim); }
.topbar .logout {
  font-family: var(--font-mono); font-size: 12px; color: var(--text-faint);
  padding: 8px 14px; border: 1px solid var(--border-strong);
  border-radius: 8px; cursor: pointer; background: transparent;
  min-height: 36px; transition: all .15s;
}
.topbar .logout:hover { border-color: var(--danger); color: var(--danger); }

@media (max-width: 780px) {
  .topbar {
    padding: 0 14px; gap: 10px; flex-wrap: wrap;
    height: auto; min-height: var(--topbar-h);
    padding-top: 8px; padding-bottom: 8px;
  }
  .topbar .nav {
    order: 99; width: 100%; overflow-x: auto;
    padding-top: 6px; border-top: 1px solid var(--border); margin-top: 6px;
    -webkit-overflow-scrolling: touch; scrollbar-width: none;
  }
  .topbar .nav::-webkit-scrollbar { display: none; }
  .topbar .nav a { white-space: nowrap; font-size: 13px; flex-shrink: 0; }
  .topbar .who { display: none; }
}

/* ─── Main / freshness bar ─────────────────────────────────────── */
main {
  padding: calc(var(--audit-banner-h, 56px) + var(--topbar-h) + 32px) 24px 100px;
  max-width: 1280px; margin: 0 auto;
}
@media (max-width: 780px) {
  main { padding-top: calc(var(--audit-banner-h, 76px) + var(--topbar-h) + 84px); }
}
@media (max-width: 480px) { main { padding-left: 16px; padding-right: 16px; padding-bottom: 64px; } }

.data-freshness-bar {
  position: fixed;
  top: calc(var(--audit-banner-h, 56px) + var(--topbar-h));
  left: 0; right: 0;
  font-family: var(--font-mono); font-size: 10.5px; color: var(--text-faint);
  background: rgba(0,212,255,.04); border-bottom: 1px solid var(--border);
  padding: 8px 24px; letter-spacing: .06em; text-align: center; z-index: 80;
}
.data-freshness-bar .df-update { color: var(--accent); font-weight: 600; }

/* If a page uses the freshness bar, bump main */
main.has-freshness { padding-top: calc(var(--audit-banner-h, 56px) + var(--topbar-h) + 64px); }
@media (max-width: 780px) {
  main.has-freshness { padding-top: calc(var(--audit-banner-h, 76px) + var(--topbar-h) + 116px); }
}

/* ─── Hero / typography ────────────────────────────────────────── */
.hero-eyebrow-sub {
  font-family: var(--font-mono); font-size: 9.5px;
  letter-spacing: .18em; text-transform: uppercase;
  color: var(--text-faint); margin-bottom: 6px;
}
.hero-eyebrow {
  font-family: var(--font-mono); font-size: 11px; letter-spacing: .18em;
  text-transform: uppercase; color: var(--accent); margin-bottom: 10px; font-weight: 600;
}
.hero-h1 {
  font-family: var(--font-display); font-weight: 700;
  font-size: clamp(28px, 3.6vw, 42px); letter-spacing: -0.02em;
  line-height: 1.05; margin: 0 0 8px;
}
.hero-h1 span {
  background: linear-gradient(135deg, var(--accent), #62f1ff);
  -webkit-background-clip: text; background-clip: text; color: transparent;
}
.hero-lede {
  color: var(--text-dim); font-size: 15px; line-height: 1.55;
  max-width: 720px; margin: 0 0 32px;
}
@media (max-width: 480px) { .hero-h1 { font-size: 26px; } .hero-lede { font-size: 13.5px; } }

/* ─── Buttons ──────────────────────────────────────────────────── */
.btn {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 12px 22px; border-radius: 10px;
  border: 1px solid var(--border-strong);
  font-family: var(--font-ui); font-weight: 600; font-size: 14px;
  cursor: pointer; background: var(--bg-elev-2); color: var(--text);
  transition: all .15s; text-decoration: none; min-height: 44px;
}
.btn:hover { background: var(--bg-elev-3); border-color: var(--accent); }
.btn.primary {
  background: linear-gradient(135deg, var(--accent), #00aacc);
  color: var(--bg-base); border-color: transparent;
  box-shadow: 0 0 0 1px var(--accent), 0 0 16px var(--accent-glow);
}
.btn.primary:hover { filter: brightness(1.08); transform: translateY(-1px); }
.btn.success {
  background: linear-gradient(135deg, var(--success), #059669);
  color: var(--bg-base); border-color: transparent;
  box-shadow: 0 0 0 1px var(--success), 0 0 16px rgba(16,185,129,.3);
}
.cta-row { display: flex; gap: 12px; flex-wrap: wrap; margin-bottom: 32px; align-items: center; }

/* Demo-disabled note */
.demo-note {
  display: inline-flex; align-items: center; gap: 6px;
  font-family: var(--font-mono); font-size: 10px; letter-spacing: .12em;
  text-transform: uppercase; color: var(--text-faint); font-weight: 600;
}
.demo-note::before { content: ""; width: 6px; height: 6px; border-radius: 999px;
  background: var(--warn); box-shadow: 0 0 4px var(--warn); }

/* ─── Stat cards ───────────────────────────────────────────────── */
.grid-cols-3 {
  display: grid; grid-template-columns: repeat(3, 1fr);
  gap: 18px; margin-bottom: 32px;
}
@media (max-width: 880px) { .grid-cols-3 { grid-template-columns: 1fr; } }
.stat-card {
  background: linear-gradient(180deg, var(--bg-elev-1), rgba(15,22,38,.6));
  border: 1px solid var(--border-strong); border-radius: 14px; padding: 22px;
  position: relative;
}
.stat-card.glow {
  border-color: var(--accent);
  box-shadow: 0 0 0 1px var(--accent), 0 20px 60px rgba(0,212,255,.12);
}
.stat-card .lbl {
  font-family: var(--font-mono); font-size: 11px; color: var(--text-faint);
  letter-spacing: .12em; text-transform: uppercase; margin-bottom: 8px;
}
.stat-card .val {
  font-family: var(--font-display); font-weight: 700;
  font-size: 30px; letter-spacing: -0.02em; color: var(--text); line-height: 1.05;
}
.stat-card .val.accent {
  background: linear-gradient(135deg, var(--accent), #62f1ff);
  -webkit-background-clip: text; background-clip: text; color: transparent;
}
.stat-card .val.success { color: var(--success); }
.stat-card .val.warn { color: var(--warn); }
.stat-card .val.faint { color: var(--text-faint); font-size: 18px; font-weight: 600; letter-spacing: .05em; }
.stat-card .sub { color: var(--text-faint); font-family: var(--font-mono); font-size: 11px; margin-top: 6px; line-height: 1.45; }
.stat-card .src-lbl {
  font-family: var(--font-mono); font-size: 9.5px; color: var(--text-faint);
  letter-spacing: .08em; margin-top: 10px; opacity: .78;
}

/* ─── Section headers ──────────────────────────────────────────── */
.section-h {
  font-family: var(--font-mono); font-size: 11px; letter-spacing: .16em;
  text-transform: uppercase; color: var(--accent); margin: 36px 0 14px;
  font-weight: 700; display: flex; align-items: center; justify-content: space-between;
  border-bottom: 1px solid var(--border); padding-bottom: 10px;
}
.section-meta {
  font-family: var(--font-mono); font-size: 10px; color: var(--text-faint);
  letter-spacing: .06em; margin-top: 6px; margin-bottom: 14px;
}

/* ─── Provenance tag pills ─────────────────────────────────────── */
.prov-tag {
  display: inline-flex; align-items: center; gap: 6px;
  font-family: var(--font-mono); font-size: 9.5px; letter-spacing: .12em;
  text-transform: uppercase; padding: 3px 8px; border-radius: 999px;
  font-weight: 700; vertical-align: middle;
}
.prov-tag.real { background: rgba(16,185,129,.12); color: var(--success); border: 1px solid rgba(16,185,129,.4); }
.prov-tag.anon { background: rgba(0,212,255,.12); color: var(--accent); border: 1px solid rgba(0,212,255,.4); }
.prov-tag.processing { background: rgba(245,158,11,.12); color: var(--warn); border: 1px solid rgba(245,158,11,.4); }
.prov-tag.placeholder { background: rgba(107,114,128,.10); color: var(--text-faint); border: 1px solid var(--border-strong); }
.prov-tag .pd { width: 5px; height: 5px; border-radius: 999px; background: currentColor; box-shadow: 0 0 4px currentColor; }

/* ─── Anonymization strip ──────────────────────────────────────── */
.anon-strip {
  background: linear-gradient(90deg, rgba(0,212,255,.06), transparent);
  border: 1px solid var(--border-strong); border-left: 3px solid var(--accent);
  border-radius: 10px; padding: 12px 18px; margin-bottom: 22px;
  display: flex; align-items: center; gap: 12px; flex-wrap: wrap;
  font-size: 13px; color: var(--text-dim); line-height: 1.5;
}
.anon-strip strong { color: var(--text); font-weight: 600; }
.anon-strip .as-icon { font-family: var(--font-mono); color: var(--accent); font-weight: 700; }

/* ─── Snap row (used on dashboard + snapshots) ─────────────────── */
.snap-list { display: flex; flex-direction: column; gap: 10px; }
.snap-row {
  background: linear-gradient(180deg, var(--bg-elev-1), rgba(15,22,38,.6));
  border: 1px solid var(--border); border-radius: 12px;
  padding: 16px 20px;
  display: grid; grid-template-columns: 130px 1fr 180px 60px;
  gap: 16px; align-items: center; transition: all .15s;
  border-left: 3px solid transparent;
}
.snap-row:hover { background: var(--bg-elev-2); border-left-color: var(--accent); transform: translateX(2px); }
.snap-row .date { font-family: var(--font-mono); font-size: 12px; color: var(--text-faint); letter-spacing: .04em; }
.snap-row .label { font-family: var(--font-display); font-weight: 600; color: var(--text); font-size: 15px; }
.snap-row .meta { color: var(--text-faint); font-family: var(--font-mono); font-size: 11px; margin-top: 3px; letter-spacing: .04em; }
.snap-row .gap { font-family: var(--font-mono); font-weight: 700; color: var(--success); text-align: right; font-size: 16px; }
.snap-row .arrow { color: var(--text-faint); text-align: right; }
@media (max-width: 720px) {
  .snap-row { grid-template-columns: 1fr; gap: 6px; padding: 14px; }
  .snap-row .arrow { display: none; }
  .snap-row .gap { text-align: left; }
}

/* ─── Empty + methodology callouts ─────────────────────────────── */
.empty {
  padding: 48px 22px; text-align: center;
  background: linear-gradient(180deg, var(--bg-elev-1), rgba(15,22,38,.5));
  border: 1px dashed var(--border-strong); border-radius: 14px;
  color: var(--text-faint); font-family: var(--font-mono);
}
.empty .big { font-family: var(--font-display); font-size: 18px; color: var(--text-dim); margin-bottom: 8px; font-weight: 700; }
.empty p { margin: 6px 0 16px; line-height: 1.6; color: var(--text-faint); font-size: 13px; }

.method-callout {
  background: var(--bg-elev-1); border: 1px solid var(--border);
  border-radius: 10px; padding: 14px 18px; margin-top: 18px;
  font-family: var(--font-mono); font-size: 11.5px;
  color: var(--text-faint); line-height: 1.6;
}
.method-callout strong { color: var(--text); font-weight: 600; }
.method-callout code { background: var(--bg-elev-3); color: var(--accent); padding: 1px 5px; border-radius: 4px; font-size: 11px; }

/* ─── Upgrade card ─────────────────────────────────────────────── */
.upgrade {
  background: linear-gradient(135deg, rgba(245,158,11,.06), rgba(245,158,11,.02));
  border: 1px solid var(--warn); border-radius: 14px;
  padding: 24px; margin-top: 32px;
}
.upgrade h3 { font-family: var(--font-display); font-weight: 700; font-size: 20px; margin: 0 0 8px; }
.upgrade p { color: var(--text-dim); font-size: 14px; line-height: 1.55; margin: 0 0 16px; }

/* ─── Reusable: CPT + payer tables ─────────────────────────────── */
.cpt-table-wrap, .payer-table {
  background: var(--bg-elev-1); border: 1px solid var(--border);
  border-radius: 12px; overflow: hidden;
}
.cpt-row {
  display: grid; grid-template-columns: 80px 1.7fr 100px 100px 100px 110px 80px;
  gap: 14px; padding: 13px 18px; border-bottom: 1px solid var(--border);
  align-items: center; font-size: 13.5px;
}
.cpt-row:last-child { border-bottom: none; }
.cpt-row.head {
  background: var(--bg-elev-2); font-family: var(--font-mono); font-size: 10px;
  letter-spacing: .14em; text-transform: uppercase; color: var(--text-faint);
  font-weight: 600; padding: 11px 18px;
}
.cpt-row .cpt-code { font-family: var(--font-mono); font-weight: 700; color: var(--accent); font-size: 13px; }
.cpt-row .cpt-desc { color: var(--text-dim); font-size: 13px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.cpt-row .num { font-family: var(--font-mono); font-weight: 600; color: var(--text); text-align: right; }
.cpt-row .num.dim { color: var(--text-dim); font-weight: 500; }
.cpt-row .num.bad { color: var(--danger); }
.cpt-row .num.good { color: var(--success); }
.cpt-row .band { display: flex; align-items: center; gap: 6px; font-family: var(--font-mono); font-size: 11px; color: var(--text-dim); }
.cpt-row .band .badge { padding: 3px 7px; border-radius: 999px; font-weight: 700; font-size: 10px; letter-spacing: .04em; }
.cpt-row .band .badge.low { background: rgba(239,68,68,.12); color: var(--danger); border: 1px solid rgba(239,68,68,.4); }
.cpt-row .band .badge.mid { background: rgba(245,158,11,.12); color: var(--warn); border: 1px solid rgba(245,158,11,.4); }
.cpt-row .band .badge.high { background: rgba(16,185,129,.12); color: var(--success); border: 1px solid rgba(16,185,129,.4); }
.cpt-row .band .badge.top { background: rgba(0,212,255,.12); color: var(--accent); border: 1px solid rgba(0,212,255,.4); }
.cpt-row .masked { filter: blur(5px); user-select: none; }

@media (max-width: 880px) {
  .cpt-row { grid-template-columns: 64px 1fr 80px 80px; gap: 10px; padding: 11px 12px; font-size: 12.5px; }
  .cpt-row.head > div:nth-child(5), .cpt-row.head > div:nth-child(6), .cpt-row.head > div:nth-child(7) { display: none; }
  .cpt-row > div:nth-child(5), .cpt-row > div:nth-child(6), .cpt-row > div:nth-child(7) { display: none; }
  .cpt-row .cpt-desc { font-size: 11.5px; }
}

.payer-row {
  display: grid; grid-template-columns: 1fr 100px 130px 140px 100px;
  gap: 14px; padding: 14px 18px; border-bottom: 1px solid var(--border);
  align-items: center; font-size: 13.5px;
}
.payer-row:last-child { border-bottom: none; }
.payer-row.head {
  background: var(--bg-elev-2); font-family: var(--font-mono); font-size: 10px;
  letter-spacing: .14em; text-transform: uppercase; color: var(--text-faint); font-weight: 600;
}
.payer-row .pname { font-family: var(--font-display); font-weight: 600; color: var(--text); font-size: 14.5px; }
.payer-row .pname .badge {
  display: inline-block; font-family: var(--font-mono); font-size: 9px;
  letter-spacing: .12em; text-transform: uppercase; color: var(--accent);
  background: var(--accent-soft); padding: 2px 7px; border-radius: 999px;
  margin-left: 8px; font-weight: 700; vertical-align: middle;
  border: 1px solid rgba(0,212,255,.4);
}
.payer-row .pname .badge.warn { color: var(--warn); background: rgba(245,158,11,.12); border-color: rgba(245,158,11,.4); }
.payer-row .num { font-family: var(--font-mono); font-weight: 600; color: var(--text); text-align: right; }
.payer-row .delta-pos { color: var(--success); font-family: var(--font-mono); font-weight: 700; text-align: right; }
.payer-row .delta-neg { color: var(--danger); font-family: var(--font-mono); font-weight: 700; text-align: right; }
@media (max-width: 780px) {
  .payer-row { grid-template-columns: 1fr 100px; gap: 10px; padding: 12px 14px; }
  .payer-row.head > div:nth-child(3), .payer-row.head > div:nth-child(4), .payer-row.head > div:nth-child(5) { display: none; }
  .payer-row > div:nth-child(3), .payer-row > div:nth-child(4), .payer-row > div:nth-child(5) { display: none; }
}

/* Opportunity tiles */
.opp-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px; margin-bottom: 22px; }
@media (max-width: 780px) { .opp-grid { grid-template-columns: 1fr; } }
.opp-tile {
  background: var(--bg-elev-1); border: 1px solid var(--border-strong);
  border-radius: 12px; padding: 18px; border-left: 3px solid var(--success);
}
.opp-tile.warn { border-left-color: var(--warn); }
.opp-tile.danger { border-left-color: var(--danger); }
.opp-tile .ot-lbl { font-family: var(--font-mono); font-size: 10px; letter-spacing: .14em;
  text-transform: uppercase; color: var(--text-faint); font-weight: 600; margin-bottom: 8px; }
.opp-tile .ot-amt { font-family: var(--font-display); font-weight: 700; font-size: 22px;
  color: var(--text); letter-spacing: -0.02em; margin-bottom: 6px; }
.opp-tile .ot-amt.success { color: var(--success); }
.opp-tile .ot-amt.danger { color: var(--danger); }
.opp-tile .ot-amt.warn { color: var(--warn); }
.opp-tile .ot-meta { color: var(--text-dim); font-size: 12.5px; line-height: 1.55; }

/* AI recommendations card */
.rec-list { display: flex; flex-direction: column; gap: 14px; }
.rec-card {
  background: var(--bg-elev-1); border: 1px solid var(--border-strong);
  border-left: 4px solid var(--accent); border-radius: 12px; padding: 20px 22px;
}
.rec-card.urgent { border-left-color: var(--danger); background: linear-gradient(135deg, rgba(239,68,68,.05), rgba(239,68,68,.01)); }
.rec-card.warn { border-left-color: var(--warn); background: linear-gradient(135deg, rgba(245,158,11,.05), rgba(245,158,11,.01)); }
.rec-card .rh { display: flex; align-items: center; gap: 10px; margin-bottom: 8px; flex-wrap: wrap; }
.rec-card .rh .rank { font-family: var(--font-mono); font-size: 10px; letter-spacing: .16em; text-transform: uppercase; color: var(--text-faint); font-weight: 700; }
.rec-card .rh .tag { font-family: var(--font-mono); font-size: 9.5px; letter-spacing: .14em; text-transform: uppercase; padding: 3px 8px; border-radius: 999px; font-weight: 700; }
.rec-card .rh .tag.urgent { background: rgba(239,68,68,.14); color: var(--danger); border: 1px solid rgba(239,68,68,.4); }
.rec-card .rh .tag.med { background: rgba(245,158,11,.14); color: var(--warn); border: 1px solid rgba(245,158,11,.4); }
.rec-card .rh .tag.low { background: rgba(0,212,255,.14); color: var(--accent); border: 1px solid rgba(0,212,255,.4); }
.rec-card h4 { font-family: var(--font-display); font-weight: 700; font-size: 16.5px; margin: 0 0 8px; color: var(--text); letter-spacing: -0.01em; line-height: 1.35; }
.rec-card h4 code { font-family: var(--font-mono); background: var(--bg-elev-3); color: var(--accent); padding: 1px 6px; border-radius: 4px; font-size: 14px; }
.rec-card .rb { color: var(--text-dim); font-size: 13.5px; line-height: 1.6; margin: 0 0 12px; }
.rec-card .rb strong { color: var(--text); font-weight: 600; }
.rec-card .rf { display: flex; align-items: center; gap: 14px; flex-wrap: wrap; font-family: var(--font-mono); font-size: 11px; color: var(--text-faint); letter-spacing: .04em; }
.rec-card .rf .recovery { color: var(--success); font-weight: 700; }

/* Standardized card */
.card {
  background: linear-gradient(180deg, var(--bg-elev-1), rgba(15,22,38,.6));
  border: 1px solid var(--border-strong); border-radius: 14px;
  padding: 24px; margin-bottom: 18px;
}
.card h2 { font-family: var(--font-display); font-weight: 700; font-size: 22px;
  margin: 0 0 8px; letter-spacing: -0.01em; }
.card .lede { color: var(--text-dim); font-size: 14px; line-height: 1.55; margin: 0 0 16px; }

/* Profile / on-file */
.profile-card {
  background: linear-gradient(135deg, rgba(0,212,255,.05), rgba(0,212,255,.01));
  border: 1px solid var(--border-strong); border-left: 3px solid var(--accent);
  border-radius: 12px; padding: 22px;
  display: grid; grid-template-columns: 1fr 1fr; gap: 24px;
  margin-bottom: 18px;
}
@media (max-width: 780px) { .profile-card { grid-template-columns: 1fr; } }
.profile-card .pc-lbl { font-family: var(--font-mono); font-size: 10px;
  letter-spacing: .16em; text-transform: uppercase; color: var(--accent);
  font-weight: 700; margin-bottom: 8px; }
.profile-card .pc-val { font-family: var(--font-display); font-weight: 700;
  font-size: 18px; color: var(--text); line-height: 1.3; margin-bottom: 4px; }
.profile-card .pc-meta { color: var(--text-dim); font-size: 13.5px; line-height: 1.55; }
.profile-field {
  background: var(--bg-elev-2); border: 1px solid var(--border);
  border-radius: 10px; padding: 14px 16px; margin-bottom: 10px;
}
.profile-field .pf-lbl { font-family: var(--font-mono); font-size: 10px;
  color: var(--text-faint); letter-spacing: .12em; text-transform: uppercase;
  margin-bottom: 6px; }
.profile-field .pf-val { color: var(--text); font-size: 14.5px; font-weight: 500; line-height: 1.4; }
.pii-redact {
  display: inline-block; background: rgba(95,108,132,.18);
  color: var(--text-faint); font-family: var(--font-mono);
  font-size: 12px; letter-spacing: .12em; padding: 2px 8px;
  border-radius: 6px; border: 1px dashed var(--border-strong);
}

/* Persona-state banner (drives different headlines per persona) */
.persona-banner {
  background: linear-gradient(135deg, rgba(0,212,255,.08), rgba(0,212,255,.01));
  border: 1px solid var(--accent); border-radius: 12px;
  padding: 14px 20px; margin-bottom: 18px;
  display: flex; gap: 14px; align-items: center; flex-wrap: wrap;
}
.persona-banner .pb-tag {
  font-family: var(--font-mono); font-size: 10px; letter-spacing: .14em;
  text-transform: uppercase; color: var(--accent); font-weight: 700;
}
.persona-banner .pb-body { color: var(--text-dim); font-size: 13.5px; line-height: 1.5; flex: 1; min-width: 240px; }
.persona-banner .pb-body strong { color: var(--text); font-weight: 600; }

.persona-banner.set-pw { border-color: var(--warn); background: linear-gradient(135deg, rgba(245,158,11,.08), rgba(245,158,11,.01)); }
.persona-banner.set-pw .pb-tag { color: var(--warn); }
.persona-banner.processing { border-color: var(--warn); background: linear-gradient(135deg, rgba(245,158,11,.08), rgba(245,158,11,.01)); }
.persona-banner.processing .pb-tag { color: var(--warn); }

/* Reduced motion */
@media (prefers-reduced-motion: reduce) {
  * { animation-duration: .01ms !important; transition-duration: .01ms !important; }
}
