/* =========================================================================
   KEY-FI Cockpit  ·  admin / closer / partner shell
   "Stille Bank" minimal identity (matches /site.css): paper white + ink +
   one pine-green accent, self-hosted Bricolage Grotesque / Hanken Grotesk
   (DSGVO: zero third-party font requests — see /assets/fonts/LICENSE.txt).

   Strategy: redefine every class that admin.html / closer.html / partner.html
   already uses, so we don't need to touch the markup or any JS bindings.
   ========================================================================= */

/* Self-hosted variable fonts (admin pages don't load site.css) */
@font-face {
  font-family: 'Bricolage Grotesque';
  src: url('/assets/fonts/bricolage-grotesque-latin.woff2') format('woff2');
  font-weight: 200 800;
  font-style: normal;
  font-display: swap;
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+2000-206F, U+20AC, U+2122, U+2212, U+FEFF, U+FFFD;
}
@font-face {
  font-family: 'Bricolage Grotesque';
  src: url('/assets/fonts/bricolage-grotesque-latin-ext.woff2') format('woff2');
  font-weight: 200 800;
  font-style: normal;
  font-display: swap;
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
@font-face {
  font-family: 'Hanken Grotesk';
  src: url('/assets/fonts/hanken-grotesk-latin.woff2') format('woff2');
  font-weight: 100 900;
  font-style: normal;
  font-display: swap;
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+2000-206F, U+20AC, U+2122, U+2212, U+FEFF, U+FFFD;
}
@font-face {
  font-family: 'Hanken Grotesk';
  src: url('/assets/fonts/hanken-grotesk-latin-ext.woff2') format('woff2');
  font-weight: 100 900;
  font-style: normal;
  font-display: swap;
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}

/* ------------------------------------------------------------------ tokens */
:root {
  --admin-canvas:     #FBFBF9;
  --admin-paper:      #FFFFFF;
  --admin-paper-warm: #F7F7F3;
  --admin-ink:        #141719;
  --admin-ink-soft:   #3E4549;
  --admin-ink-mute:   #697175;
  --admin-rule:       #E2E3DC;
  --admin-rule-soft:  #ECEDE7;
  --admin-accent:     #0F6B4F;  /* pine — primary action */
  --admin-accent-2:   #0A523C;
  --admin-trust:      #11635C;  /* deep teal — links / trust */
  --admin-trust-2:    #0C4C46;
  --admin-gold:       #B99B6B;
  --admin-signal:     #C0392B;
  --admin-ok:         #1E6B47;
  --admin-warn:       #8A4A0A;
  --admin-hot:        #C2410C;

  --ff-display: 'Bricolage Grotesque', 'Hanken Grotesk', system-ui, -apple-system, 'Segoe UI', sans-serif;
  --ff-sans:    'Hanken Grotesk', system-ui, -apple-system, 'Segoe UI', sans-serif;
  --ff-mono:    ui-monospace, 'SF Mono', 'Cascadia Mono', Menlo, Consolas, monospace;
}

/* ----------------------------------------------------------------- base */
.admin-body {
  margin: 0;
  background: var(--admin-canvas);
  color: var(--admin-ink);
  font-family: var(--ff-sans);
  font-size: 14.5px;
  line-height: 1.5;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  background-image:
    linear-gradient(180deg, #FFFFFF 0%, var(--admin-canvas) 42%, #EEF3F8 100%);
}

.admin-body * { box-sizing: border-box; }
.admin-body a { color: var(--admin-trust); text-decoration: none; }
.admin-body a:hover { color: var(--admin-accent); text-decoration: underline; text-underline-offset: 3px; }
.admin-body button { font: inherit; cursor: pointer; }
.admin-body code, .admin-body pre, .admin-body .mono { font-family: var(--ff-mono); }

.admin-body h1, .admin-body h2, .admin-body h3, .admin-body h4 {
  font-family: var(--ff-display);
  color: var(--admin-ink);
  letter-spacing: -.018em;
  font-weight: 600;
  margin: 0 0 .4em;
  line-height: 1.1;
}
.admin-body h1 { font-size: clamp(28px, 1.4rem + 1vw, 40px); letter-spacing: -.025em; }
.admin-body h2 { font-size: clamp(22px, 1.15rem + 0.5vw, 28px); }
.admin-body h3 { font-size: clamp(17px, 1rem + 0.2vw, 20px); font-weight: 420; }
.admin-body h4 { font-size: 15px; font-weight: 500; font-family: var(--ff-sans); letter-spacing: -.005em; }
.admin-body h1 em, .admin-body h2 em, .admin-body h3 em {
  font-style: normal;
  color: var(--admin-accent);
  font-weight: 600;
}
.admin-body p { margin: 0 0 .9em; max-width: 70ch; }
.admin-body p.lead {
  font-family: var(--ff-display);
  font-size: 17px;
  color: var(--admin-ink-soft);
  font-weight: 600;
  letter-spacing: -.005em;
  line-height: 1.5;
  max-width: 60ch;
}

::selection { background: var(--admin-ink); color: var(--admin-canvas); }

/* ----------------------------------------------------------------- topbar */
.admin-body .topbar {
  position: sticky;
  top: 0;
  z-index: 50;
  display: flex;
  align-items: center;
  gap: 24px;
  padding: 12px 28px;
  background: color-mix(in srgb, var(--admin-canvas) 88%, transparent);
  backdrop-filter: saturate(180%) blur(22px);
  -webkit-backdrop-filter: saturate(180%) blur(22px);
  border-bottom: 1px solid var(--admin-rule-soft);
}
.admin-body .topbar .brand {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  flex-shrink: 0;
}
.admin-body .topbar .brand .mark {
  width: 38px; height: 38px;
  border-radius: 50%;
  background: var(--admin-ink);
  color: var(--admin-canvas);
  display: grid; place-items: center;
  font-family: var(--ff-display);
  font-size: 18px;
  font-weight: 500;
  letter-spacing: -.02em;
  position: relative;
}
.admin-body .topbar .brand .mark::after {
  content: '';
  position: absolute; inset: -3px;
  border: 1px solid var(--admin-gold);
  border-radius: 50%;
  opacity: .55;
}
.admin-body .topbar .brand strong {
  font-family: var(--ff-display);
  font-size: 18px;
  font-weight: 420;
  color: var(--admin-ink);
  letter-spacing: -.012em;
  display: block;
}
.admin-body .topbar .brand small {
  font-family: var(--ff-mono);
  font-size: 10px;
  letter-spacing: .16em;
  text-transform: uppercase;
  color: var(--admin-ink-mute);
  display: block;
  margin-top: 2px;
}
.admin-body .topbar nav {
  margin-left: auto;
  display: flex;
  gap: 18px;
  align-items: center;
}
.admin-body .topbar nav a {
  font-size: 13.5px;
  color: var(--admin-ink-soft);
  padding: 6px 0;
  position: relative;
  text-decoration: none;
}
.admin-body .topbar nav a:hover {
  color: var(--admin-accent);
  text-decoration: none;
}
.admin-body .topbar nav a:hover::after {
  content: '';
  position: absolute;
  left: 0; right: 0; bottom: -2px;
  height: 1px; background: var(--admin-accent);
}

/* ----------------------------------------------------------------- layout */
.admin-body main {
  max-width: 1440px;
  margin: 0 auto;
  padding: 36px 28px 80px;
  display: grid;
  gap: 32px;
}

/* ----------------------------------------------------------------- hero */
.admin-body .hero {
  background: var(--admin-paper);
  border: 1px solid var(--admin-rule);
  border-radius: 24px;
  padding: 36px;
  display: grid;
  grid-template-columns: 1fr;
  gap: 36px;
  align-items: end;
}
@media (min-width: 1000px) {
  .admin-body .hero { grid-template-columns: 1.5fr 1fr; gap: 56px; }
}
.admin-body .hero-copy { min-width: 0; }
.admin-body .hero-copy .eyebrow { margin-bottom: 12px; }
.admin-body .hero-copy h1 { max-width: 26ch; }
.admin-body .hero-actions {
  display: inline-flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-top: 22px;
}

/* ----------------------------------------------------------------- eyebrow */
.admin-body .eyebrow {
  font-family: var(--ff-mono);
  font-size: 11px;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--admin-ink-soft);
  margin: 0 0 var(--admin-eb-mb, 14px);
  display: inline-flex;
  align-items: center;
  gap: 8px;
}
.admin-body .eyebrow::before {
  content: '';
  width: 20px; height: 1px;
  background: var(--admin-accent);
}

/* ----------------------------------------------------------------- buttons */
.admin-body .btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 10px 16px;
  border-radius: 999px;
  border: 1px solid transparent;
  font-family: var(--ff-sans);
  font-size: 13.5px;
  font-weight: 500;
  letter-spacing: -.005em;
  text-decoration: none;
  white-space: nowrap;
  transition: transform 150ms cubic-bezier(.2,.7,.2,1),
              background 150ms cubic-bezier(.2,.7,.2,1),
              color 150ms cubic-bezier(.2,.7,.2,1),
              border-color 150ms cubic-bezier(.2,.7,.2,1);
}
.admin-body .btn:hover { transform: translateY(-1px); text-decoration: none; }
.admin-body .btn:focus-visible { outline: 2px solid var(--admin-accent); outline-offset: 3px; }
.admin-body .btn.primary,
.admin-body .btn[type="submit"] {
  background: var(--admin-accent);
  color: #fff;
  border-color: var(--admin-accent);
}
.admin-body .btn.primary:hover { background: var(--admin-accent-2); }
.admin-body .btn.ghost {
  background: transparent;
  color: var(--admin-ink);
  border-color: var(--admin-rule);
}
.admin-body .btn.ghost:hover { border-color: var(--admin-ink); background: var(--admin-paper-warm); }
.admin-body .btn.danger {
  background: var(--admin-signal);
  color: #fff;
  border-color: var(--admin-signal);
}
.admin-body .btn.success {
  background: var(--admin-trust);
  color: var(--admin-canvas);
  border-color: var(--admin-trust);
}
.admin-body .btn.success:hover { background: var(--admin-trust-2); }

/* small button */
.admin-body .btn.small { padding: 6px 10px; font-size: 12.5px; }

/* ----------------------------------------------------------------- panels */
.admin-body .panel {
  background: var(--admin-paper);
  border: 1px solid var(--admin-rule);
  border-radius: 24px;
  padding: 28px;
  position: relative;
}
.admin-body .panel + .panel { /* spacing handled by main gap */ }
.admin-body .panel.compact { padding: 20px; }

.admin-body .section-head {
  display: grid;
  grid-template-columns: 1fr;
  gap: 16px;
  align-items: end;
  margin-bottom: 24px;
  padding-bottom: 18px;
  border-bottom: 1px solid var(--admin-rule);
}
@media (min-width: 720px) {
  .admin-body .section-head { grid-template-columns: 1.4fr 1fr; gap: 32px; }
}
.admin-body .section-head.compact { padding-bottom: 12px; margin-bottom: 18px; gap: 12px; }
.admin-body .section-head h2 { margin: 6px 0 0; }
.admin-body .section-head p { margin: 0; color: var(--admin-ink-soft); font-size: 14px; }
.admin-body .section-head .actions-row {
  display: inline-flex;
  gap: 10px;
  flex-wrap: wrap;
  align-self: end;
  justify-self: end;
}

/* ----------------------------------------------------------------- forms */
.admin-body label {
  display: block;
  font-family: var(--ff-mono);
  font-size: 11px;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--admin-ink-mute);
  margin-bottom: 12px;
}
/* `<input>` with no explicit type defaults to text — catch it via :not([type]) */
.admin-body input:not([type]),
.admin-body input[type="text"],
.admin-body input[type="email"],
.admin-body input[type="tel"],
.admin-body input[type="number"],
.admin-body input[type="date"],
.admin-body input[type="datetime-local"],
.admin-body input[type="search"],
.admin-body input[type="url"],
.admin-body input[type="password"],
.admin-body select,
.admin-body textarea {
  display: block;            /* drop below the label text instead of sitting beside it */
  width: 100%;
  margin-top: 6px;
  padding: 10px 12px;
  background: var(--admin-paper);
  border: 1px solid var(--admin-rule);
  border-radius: 6px;
  font-family: var(--ff-mono);
  font-size: 14px;
  color: var(--admin-ink);
  letter-spacing: 0;
  text-transform: none;
  transition: border-color 150ms cubic-bezier(.2,.7,.2,1), background 150ms cubic-bezier(.2,.7,.2,1);
}
.admin-body input:not([type]):focus,
.admin-body input[type="text"]:focus,
.admin-body input[type="email"]:focus,
.admin-body input[type="tel"]:focus,
.admin-body input[type="number"]:focus,
.admin-body input[type="date"]:focus,
.admin-body input[type="datetime-local"]:focus,
.admin-body input[type="search"]:focus,
.admin-body input[type="url"]:focus,
.admin-body input[type="password"]:focus,
.admin-body select:focus,
.admin-body textarea:focus {
  outline: none;
  border-color: var(--admin-ink);
  background: var(--admin-paper-warm);
}
/* a11y: restore a visible keyboard focus ring for inputs (mouse focus stays ring-free). */
.admin-body input:focus-visible,
.admin-body select:focus-visible,
.admin-body textarea:focus-visible { outline: 2px solid var(--admin-accent); outline-offset: 2px; }
/* a11y: dynamically-injected mini links/buttons need a visible keyboard focus ring too. */
.admin-body .mini-link:focus-visible { outline: 2px solid var(--admin-accent); outline-offset: 2px; }
/* a11y: skip link (hidden until focused) + screen-reader-only helper. */
.admin-body .skip-link { position: absolute; left: -999px; top: 0; z-index: 1000; background: var(--admin-ink); color: var(--admin-paper-warm); padding: 10px 16px; border-radius: 0 0 8px 0; text-decoration: none; }
.admin-body .skip-link:focus { left: 0; }
.admin-body .sr-only { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0; }
.admin-body textarea { font-family: var(--ff-sans); font-size: 14px; min-height: 80px; resize: vertical; }
.admin-body label.check {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-family: var(--ff-sans);
  font-size: 13.5px;
  letter-spacing: 0;
  text-transform: none;
  color: var(--admin-ink-soft);
}
.admin-body input[type="checkbox"], .admin-body input[type="radio"] {
  width: 16px; height: 16px;
  accent-color: var(--admin-trust);
}

/* control group rows (filter bars etc.) */
.admin-body .controls,
.admin-body .actions-row {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  align-items: center;
}
/* Forms intended as vertical stacks (e.g. partner mobile lead form) — override .controls flex */
.admin-body .mobile-form,
.admin-body form.mobile-form.controls {
  display: grid !important;
  grid-template-columns: 1fr;
  gap: 14px;
  align-items: stretch;
  max-width: 720px;
}
@media (min-width: 720px) {
  .admin-body .mobile-form,
  .admin-body form.mobile-form.controls {
    grid-template-columns: 1fr 1fr;
  }
}

.admin-body .cockpit-form,
.admin-body .calc-form,
.admin-body .decision-form,
.admin-body .advanced-controls {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: 14px 18px;
  margin-top: 8px;
  align-items: start;
}
.admin-body .discovery-collapse__intro {
  margin: 0 0 16px;
  color: var(--admin-ink-soft);
  font-size: 14px;
  line-height: 1.6;
  max-width: 72ch;
}
/* The source/filter boxes are tall; kept inside the field grid they stretched a
   row and scattered the inputs. Give them their own full-width rows and lay the
   checkboxes out in a short, multi-column grid. */
.admin-body .cockpit-form .source-box {
  grid-column: 1 / -1;
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
  gap: 8px 18px;
  align-items: start;
}
.admin-body .cockpit-form .source-box > strong { grid-column: 1 / -1; }
.admin-body .cockpit-form > button[type="submit"] { grid-column: 1 / -1; justify-self: start; }

/* status pills */
.admin-body .status,
.admin-body .status-pill {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 4px 10px;
  border-radius: 999px;
  font-family: var(--ff-mono);
  font-size: 11px;
  letter-spacing: .1em;
  text-transform: uppercase;
  background: var(--admin-paper-warm);
  border: 1px solid var(--admin-rule);
  color: var(--admin-ink-soft);
}
.admin-body .status.ok,    .admin-body .status-pill.ok    { color: var(--admin-ok);     border-color: color-mix(in srgb, var(--admin-ok) 35%, var(--admin-rule)); background: color-mix(in srgb, var(--admin-ok) 8%, var(--admin-paper)); }
.admin-body .status.warn,  .admin-body .status-pill.warn  { color: var(--admin-warn);   border-color: color-mix(in srgb, var(--admin-warn) 35%, var(--admin-rule)); background: color-mix(in srgb, var(--admin-warn) 10%, var(--admin-paper)); }
.admin-body .status.error, .admin-body .status-pill.error { color: var(--admin-signal); border-color: color-mix(in srgb, var(--admin-signal) 35%, var(--admin-rule)); background: color-mix(in srgb, var(--admin-signal) 10%, var(--admin-paper)); }
.admin-body .status.hot,   .admin-body .status-pill.hot   { color: var(--admin-hot);    border-color: color-mix(in srgb, var(--admin-hot) 35%, var(--admin-rule)); background: color-mix(in srgb, var(--admin-hot) 9%, var(--admin-paper)); }

/* Visual QA: readiness/source cards are assembled from pill + title + note.
   Keep each part on its own line so labels never concatenate in narrow cards. */
.admin-body .source-health-grid > article,
.admin-body .readiness-grid > article {
  display: grid;
  gap: 8px;
  align-content: start;
  min-width: 0;
}
.admin-body .source-health-grid > article .status-pill,
.admin-body .readiness-grid > article .status-pill {
  justify-self: start;
}
.admin-body .source-health-grid > article strong,
.admin-body .readiness-grid > article strong {
  display: block;
  color: var(--admin-rail, var(--admin-ink));
  line-height: 1.25;
}
.admin-body .source-health-grid > article small,
.admin-body .readiness-grid > article small {
  display: block;
  line-height: 1.45;
  color: var(--admin-ink-soft);
}
.admin-body .autonomous-plan-grid {
  margin-top: 14px;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
}
.admin-body .autonomous-plan-card {
  border-color: color-mix(in srgb, var(--admin-trust) 18%, var(--admin-rule));
}
.admin-body .autonomous-plan-card.is-blocked {
  background: color-mix(in srgb, var(--admin-ink-mute) 5%, var(--admin-paper-warm));
}
.admin-body .autonomous-plan-card p {
  margin: 0;
  color: var(--admin-ink-soft);
  line-height: 1.45;
}
.admin-body .autonomous-source-box {
  grid-column: 1 / -1;
}

/* ----------------------------------------------------------------- system-card / pipeline */
.admin-body .system-card {
  background: var(--admin-paper-warm);
  border: 1px solid var(--admin-rule);
  border-radius: 10px;
  padding: 20px;
  display: grid;
  gap: 14px;
}
.admin-body .pipeline {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 8px 14px;
  align-items: baseline;
  padding-bottom: 14px;
  border-bottom: 1px dashed var(--admin-rule);
}
.admin-body .pipeline span {
  font-family: var(--ff-mono);
  font-size: 10px;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--admin-ink-mute);
}
.admin-body .pipeline b {
  font-family: var(--ff-sans);
  font-weight: 500;
  font-size: 13.5px;
  color: var(--admin-ink);
}
.admin-body .mini-metric {
  display: flex;
  align-items: baseline;
  gap: 10px;
}
.admin-body .mini-metric strong {
  font-family: var(--ff-display);
  font-size: 32px;
  font-weight: 600;
  letter-spacing: -.02em;
  color: var(--admin-accent);
  line-height: 1;
}
.admin-body .mini-metric span {
  font-family: var(--ff-mono);
  font-size: 11px;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--admin-ink-mute);
}
.admin-body .operator-guide {
  margin-top: 4px;
  padding: 18px;
  border: 1px solid color-mix(in srgb, var(--admin-accent) 22%, var(--admin-rule));
  border-radius: 18px;
  background:
    linear-gradient(135deg, rgba(0,113,227,.08), rgba(10,122,104,.04) 58%, rgba(255,255,255,.92)),
    var(--admin-paper);
  box-shadow: 0 18px 46px -34px rgba(0, 68, 140, .42);
}
.admin-body .operator-guide .eyebrow {
  margin-bottom: 8px;
  color: var(--admin-accent-2);
}
.admin-body .operator-guide h2 {
  font-size: 21px;
  margin-bottom: 14px;
}
.admin-body .operator-guide__steps {
  display: grid;
  gap: 10px;
}
.admin-body .operator-guide__steps a {
  display: grid;
  grid-template-columns: 34px 1fr;
  gap: 2px 12px;
  align-items: start;
  padding: 12px;
  border-radius: 14px;
  background: rgba(255,255,255,.78);
  border: 1px solid rgba(210,210,215,.82);
  color: var(--admin-ink);
  text-decoration: none;
}
.admin-body .operator-guide__steps a:hover {
  border-color: color-mix(in srgb, var(--admin-accent) 38%, var(--admin-rule));
  box-shadow: 0 14px 34px -30px rgba(0, 83, 170, .7);
  transform: translateY(-1px);
}
.admin-body .operator-guide__steps strong {
  grid-row: span 2;
  width: 30px;
  height: 30px;
  border-radius: 50%;
  display: grid;
  place-items: center;
  background: var(--admin-ink);
  color: #fff;
  font-family: var(--ff-mono);
  font-size: 12px;
}
.admin-body .operator-guide__steps span {
  font-weight: 600;
  color: var(--admin-ink);
}
.admin-body .operator-guide__steps small {
  color: var(--admin-ink-mute);
  line-height: 1.35;
}

/* ----------------------------------------------------------------- KPI grids */
.admin-body .dashboard-grid,
.admin-body .cockpit-kpis,
.admin-body .calc-kpis,
.admin-body .quality-score-grid,
.admin-body .source-health-grid,
.admin-body .roles-board,
.admin-body .readiness-grid,
.admin-body .readiness-board,
.admin-body .roadmap-grid,
.admin-body .risk-board,
.admin-body .bar-board,
.admin-body .meeting-steps,
.admin-body .landing-sections,
.admin-body .mail-grid,
.admin-body .meta-plan,
.admin-body .comparison-grid,
.admin-body .source-legend,
.admin-body .two-column-cards,
.admin-body .scenario-buttons {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 14px;
}
.admin-body .quality-score-grid { grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); }
.admin-body .scenario-buttons { grid-template-columns: repeat(auto-fit, minmax(140px, 1fr)); gap: 8px; }

/* generic KPI tile */
.admin-body .kpi,
.admin-body .empty-card,
.admin-body .safe-card,
.admin-body .source-box,
.admin-body .letter-card,
.admin-body .export-preview-card,
.admin-body .danger-card {
  background: var(--admin-paper-warm);
  border: 1px solid var(--admin-rule);
  border-radius: 10px;
  padding: 18px 18px 16px;
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.admin-body .export-preview-card.success {
  border-color: color-mix(in srgb, var(--admin-ok) 38%, var(--admin-rule));
  background: color-mix(in srgb, var(--admin-ok) 7%, var(--admin-paper-warm));
}
.admin-body .export-preview-card.error {
  border-color: color-mix(in srgb, var(--admin-signal) 35%, var(--admin-rule));
  background: color-mix(in srgb, var(--admin-signal) 8%, var(--admin-paper-warm));
}
.admin-body .kpi small,
.admin-body .empty-card small,
.admin-body .safe-card small,
.admin-body .source-box small,
.admin-body .letter-card small,
.admin-body .export-preview-card small {
  font-family: var(--ff-mono);
  font-size: 10px;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--admin-ink-mute);
}
.admin-body .kpi strong,
.admin-body .safe-card strong {
  font-family: var(--ff-display);
  font-size: 26px;
  font-weight: 600;
  letter-spacing: -.02em;
  color: var(--admin-ink);
  line-height: 1.1;
}
.admin-body .kpi p,
.admin-body .empty-card p,
.admin-body .source-box p,
.admin-body .letter-card p {
  margin: 4px 0 0;
  font-size: 13px;
  color: var(--admin-ink-soft);
}
.admin-body .danger-card {
  border-color: color-mix(in srgb, var(--admin-signal) 35%, var(--admin-rule));
  background: color-mix(in srgb, var(--admin-signal) 6%, var(--admin-paper));
}
.admin-body .danger-card h4 { color: var(--admin-signal); }

/* ----------------------------------------------------------------- splits */
.admin-body .split {
  display: grid;
  grid-template-columns: 1fr;
  gap: 22px;
  background: var(--admin-paper);
  border: 1px solid var(--admin-rule);
  border-radius: 24px;
  padding: 28px;
}
@media (min-width: 900px) {
  .admin-body .split { grid-template-columns: 1fr 1fr; gap: 36px; }
}

/* ----------------------------------------------------------------- meeting / decision blocks */
.admin-body .meeting-mode,
.admin-body .product-decision,
.admin-body .simple-plan,
.admin-body .calculator,
.admin-body .direct-mail,
.admin-body .analytics-panel,
.admin-body .source-health-panel,
.admin-body .quality-cockpit-panel,
.admin-body .legal-safety,
.admin-body .legal-note {
  /* inherits .panel above; nothing extra needed except subtle accent for legal-note */
}
.admin-body .legal-note {
  border-left: 3px solid var(--admin-gold);
  background: color-mix(in srgb, var(--admin-gold) 5%, var(--admin-paper));
}

.admin-body .decision-summary {
  background: var(--admin-paper-warm);
  border: 1px dashed var(--admin-rule);
  border-radius: 8px;
  padding: 14px;
  font-family: var(--ff-mono);
  font-size: 12.5px;
  color: var(--admin-ink-soft);
  white-space: pre-wrap;
  margin-top: 12px;
}

/* ----------------------------------------------------------------- table-wrap */
.admin-body .table-wrap {
  overflow-x: auto;
  border: 1px solid var(--admin-rule);
  border-radius: 10px;
  background: var(--admin-paper);
}
.admin-body table {
  width: 100%;
  border-collapse: collapse;
  font-size: 13.5px;
}
.admin-body th, .admin-body td {
  padding: 12px 14px;
  text-align: left;
  border-bottom: 1px solid var(--admin-rule-soft);
  vertical-align: top;
}
.admin-body th {
  font-family: var(--ff-mono);
  font-size: 11px;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--admin-ink-mute);
  font-weight: 500;
  background: var(--admin-paper-warm);
  border-bottom: 1px solid var(--admin-rule);
  position: sticky; top: 0; z-index: 1;
}
.admin-body td { color: var(--admin-ink); }
.admin-body td .mono, .admin-body td.mono { font-family: var(--ff-mono); }
.admin-body tr:hover td { background: color-mix(in srgb, var(--admin-accent) 4%, var(--admin-paper)); }

/* ----------------------------------------------------------------- landing-list (lead cards in closer briefing) */
.admin-body .landing-list {
  display: grid;
  gap: 10px;
  font-size: 13.5px;
  color: var(--admin-ink-soft);
}
.admin-body .landing-list > article,
.admin-body .landing-list > div {
  background: var(--admin-paper);
  border: 1px solid var(--admin-rule);
  border-radius: 8px;
  padding: 10px 12px;
}

/* ---- Inbox triage rows (landing-leads daily driver) ---- */
.admin-body .lead-inbox-summary { font-family: var(--ff-mono); font-size: 12px; letter-spacing: .04em; color: var(--admin-ink-mute); padding: 2px 2px 8px; }
.admin-body .lead-inbox-summary strong { color: var(--admin-ink); }
.admin-body .landing-list > .lead-row { display: grid; gap: 8px; cursor: pointer; transition: border-color .15s ease, box-shadow .15s ease; }
.admin-body .landing-list > .lead-row:hover { border-color: color-mix(in srgb, var(--admin-accent) 40%, var(--admin-rule)); }
.admin-body .landing-list > .lead-row:focus-visible { outline: 2px solid var(--admin-accent); outline-offset: 2px; }
.admin-body .lead-row__top { display: flex; align-items: center; justify-content: space-between; gap: 10px; }
.admin-body .lead-row__top strong { font-size: 14.5px; color: var(--admin-ink); }
.admin-body .lead-row__meta small { color: var(--admin-ink-mute); font-size: 12px; }
.admin-body .lead-row__product { display: flex; align-items: baseline; gap: 8px; }
.admin-body .lead-row__product span { font-family: var(--ff-mono); font-size: 10px; letter-spacing: .12em; text-transform: uppercase; color: var(--admin-ink-mute); }
.admin-body .lead-row__product strong { color: var(--admin-ink); font-size: 14px; }
.admin-body .lead-row__detail { background: var(--admin-paper-warm); border-radius: 10px; padding: 12px 14px; }
.admin-body .lead-row__detail small strong { color: var(--admin-ink); }
.admin-body .lead-row__detail small { color: var(--admin-ink-soft); font-size: 12.5px; line-height: 1.7; }
.admin-body .lead-timeline { list-style: none; margin: 10px 0 0; padding: 10px 0 0; border-top: 1px solid var(--admin-rule); display: grid; gap: 8px; }
.admin-body .lead-timeline li { display: grid; grid-template-columns: minmax(110px, 0.45fr) 1fr; gap: 8px; align-items: start; }
.admin-body .lead-timeline b { color: var(--admin-ink); font-size: 12.5px; font-weight: 600; }
.admin-body .lead-timeline span { color: var(--admin-ink-soft); font-size: 12.5px; line-height: 1.5; }
.admin-body .lead-row__actions { display: flex; flex-wrap: wrap; gap: 8px 14px; align-items: center; justify-content: space-between; }
.admin-body .lead-row__contact, .admin-body .lead-row__statusbtns { display: inline-flex; align-items: center; gap: 6px; flex-wrap: wrap; }
.admin-body .lead-row .dot { color: var(--admin-rule); }
.admin-body .chip--on { color: var(--admin-trust); border-color: color-mix(in srgb, var(--admin-trust) 35%, var(--admin-rule)); background: color-mix(in srgb, var(--admin-trust) 8%, var(--admin-paper)); }
.admin-body .chip--off { color: var(--admin-ink-mute); }
.admin-body .empty-card--error { color: var(--admin-signal); border-color: color-mix(in srgb, var(--admin-signal) 35%, var(--admin-rule)) !important; background: color-mix(in srgb, var(--admin-signal) 7%, var(--admin-paper)) !important; }

/* live-poll indicator */
.admin-body .inbox-live { font-family: var(--ff-mono); font-size: 11px; letter-spacing: .05em; padding: 3px 9px; border-radius: 999px; border: 1px solid var(--admin-rule); display: inline-flex; align-items: center; gap: 6px; color: var(--admin-ink-mute); }
.admin-body .inbox-live::before { content: ""; width: 7px; height: 7px; border-radius: 50%; background: var(--admin-ink-mute); }
.admin-body .inbox-live.is-live { color: var(--admin-ok); border-color: color-mix(in srgb, var(--admin-ok) 35%, var(--admin-rule)); }
.admin-body .inbox-live.is-live::before { background: var(--admin-ok); }
.admin-body .inbox-live.is-down { color: var(--admin-signal); border-color: color-mix(in srgb, var(--admin-signal) 35%, var(--admin-rule)); }
.admin-body .inbox-live.is-down::before { background: var(--admin-signal); }

/* skeleton loading rows */
.admin-body .lead-row--skeleton { cursor: default; }
.admin-body .lead-row--skeleton span { display: block; height: 10px; border-radius: 4px; background: linear-gradient(90deg, var(--admin-rule-soft), var(--admin-rule), var(--admin-rule-soft)); background-size: 200% 100%; animation: inboxShimmer 1.2s ease-in-out infinite; }
.admin-body .lead-row--skeleton span:nth-child(1) { width: 55%; }
.admin-body .lead-row--skeleton span:nth-child(2) { width: 80%; }
.admin-body .lead-row--skeleton span:nth-child(3) { width: 40%; }
@keyframes inboxShimmer { 0% { background-position: 200% 0; } 100% { background-position: -200% 0; } }
@media (prefers-reduced-motion: reduce) { .admin-body .lead-row--skeleton span { animation: none; } }

/* ============================================================ B-2: hierarchy
   Primary work area (inbox) reads as the hub; discovery + reference panels
   recede. No new JS, no markup contracts touched — pure presentation. */

/* Inbox = primary. Warm accent rule on top + soft lift so it owns the fold. */
.admin-body .inbox-panel {
  border-color: color-mix(in srgb, var(--admin-accent) 26%, var(--admin-rule));
  box-shadow: 0 14px 34px -32px color-mix(in srgb, var(--admin-accent) 70%, transparent);
  overflow: hidden;
}
.admin-body .inbox-panel::before {
  content: ""; position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--admin-accent), var(--admin-gold));
}
.admin-body .inbox-panel .section-head { align-items: center; }
.admin-body .inbox-panel .section-head .inbox-live { justify-self: end; }

/* Inbox KPI strip — real counts computed from the fetched leads (no fake data). */
.admin-body .inbox-kpis {
  display: grid; grid-template-columns: repeat(2, 1fr); gap: 10px; margin-bottom: 18px;
}
@media (min-width: 640px) { .admin-body .inbox-kpis { grid-template-columns: repeat(4, 1fr); } }
.admin-body .inbox-kpi {
  background: var(--admin-paper-warm); border: 1px solid var(--admin-rule);
  border-radius: 10px; padding: 12px 14px; display: grid; gap: 3px;
}
.admin-body .inbox-kpi strong { font-family: var(--ff-display); font-size: 26px; line-height: 1; color: var(--admin-ink); }
.admin-body .inbox-kpi span { font-family: var(--ff-mono); font-size: 10.5px; letter-spacing: .06em; text-transform: uppercase; color: var(--admin-ink-mute); }

/* Lead sprint: first-screen workflow for broad, compliant candidate discovery. */
.admin-body .lead-sprint-board {
  display: grid;
  gap: 16px;
  margin-bottom: 18px;
  padding: 20px;
  border: 1px solid color-mix(in srgb, var(--admin-accent) 18%, var(--admin-rule));
  border-radius: 14px;
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--admin-paper) 96%, var(--admin-accent) 4%), var(--admin-paper-warm));
}
.admin-body .lead-sprint-board__main {
  display: grid;
  grid-template-columns: 1fr;
  gap: 14px;
  align-items: start;
}
@media (min-width: 900px) {
  .admin-body .lead-sprint-board__main { grid-template-columns: minmax(0, 1fr) minmax(260px, 0.42fr); }
}
.admin-body .lead-sprint-board h3 {
  margin-bottom: 8px;
  max-width: 28ch;
}
.admin-body .lead-sprint-board p {
  color: var(--admin-ink-soft);
  margin-bottom: 0;
}
.admin-body .lead-sprint-truth {
  display: grid;
  gap: 6px;
  padding: 12px 14px;
  border-left: 3px solid var(--admin-trust);
  background: color-mix(in srgb, var(--admin-trust) 6%, var(--admin-paper));
  border-radius: 8px;
}
.admin-body .lead-sprint-truth strong {
  font-family: var(--ff-mono);
  font-size: 11px;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--admin-trust-2);
}
.admin-body .lead-sprint-truth span,
.admin-body .lead-sprint-summary span {
  color: var(--admin-ink-soft);
  font-size: 13.5px;
  line-height: 1.45;
}
.admin-body .lead-sprint-fields {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 12px;
}
.admin-body .lead-sprint-fields label {
  display: grid;
  gap: 6px;
  min-width: 0;
}
.admin-body .lead-sprint-fields label > span {
  font-family: var(--ff-mono);
  font-size: 10.5px;
  letter-spacing: .11em;
  text-transform: uppercase;
  color: var(--admin-ink-mute);
}
.admin-body .lead-sprint-fields input,
.admin-body .lead-sprint-fields select {
  width: 100%;
  min-height: 42px;
  border: 1px solid var(--admin-rule);
  border-radius: 8px;
  padding: 10px 12px;
  background: var(--admin-paper);
  color: var(--admin-ink);
}
.admin-body .lead-sprint-fields input:focus,
.admin-body .lead-sprint-fields select:focus {
  outline: 2px solid color-mix(in srgb, var(--admin-accent) 35%, transparent);
  border-color: var(--admin-accent);
}
.admin-body .lead-sprint-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}
.admin-body .lead-sprint-actions .btn {
  min-height: 44px;
}
.admin-body .lead-sprint-summary {
  display: grid;
  gap: 4px;
  padding-top: 12px;
  border-top: 1px solid var(--admin-rule-soft);
  color: var(--admin-ink-soft);
}
.admin-body .lead-sprint-summary strong {
  color: var(--admin-ink);
}

/* Discovery is secondary — collapsed by default; summary is a quiet toggle bar. */
.admin-body .discovery-collapse > summary {
  cursor: pointer; list-style: none; display: flex; flex-wrap: wrap; align-items: baseline; gap: 4px 12px;
  padding: 12px 14px; border: 1px dashed var(--admin-rule); border-radius: 10px;
  background: var(--admin-paper-warm); color: var(--admin-ink-soft);
}
.admin-body .discovery-collapse > summary::-webkit-details-marker { display: none; }
.admin-body .discovery-collapse__hint { font-size: 13.5px; }
.admin-body .discovery-collapse > summary::after {
  content: "▾"; margin-left: auto; font-family: var(--ff-mono); font-size: 11px; color: var(--admin-ink-mute);
}
.admin-body .discovery-collapse[open] > summary::after { content: "▴"; }
.admin-body .discovery-collapse > summary:hover { border-color: color-mix(in srgb, var(--admin-accent) 40%, var(--admin-rule)); }
.admin-body .discovery-collapse[open] > summary { margin-bottom: 18px; }
/* Force the native collapse: author display:grid on the form would otherwise
   override the UA rule that hides a closed <details>'s non-summary content. */
.admin-body details.discovery-collapse:not([open]) > *:not(summary) { display: none; }

/* Reference panels recede: warm ground, dashed edge, smaller heading. AA-safe. */
.admin-body .panel--ref { background: var(--admin-paper-warm); border-style: dashed; }
.admin-body .panel--ref > h2,
.admin-body .panel--ref .section-head h2 { font-size: 19px; }
.admin-body .panel--ref > .eyebrow,
.admin-body .panel--ref .section-head .eyebrow { color: var(--admin-ink-mute); }

/* ----------------------------------------------------------------- closer brief cards */
.admin-body .brief-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: 14px;
}
.admin-body .brief-card {
  background: var(--admin-paper-warm) !important;
  border: 1px solid var(--admin-rule) !important;
  border-radius: 10px !important;
  padding: 16px !important;
  color: var(--admin-ink);
}
.admin-body .brief-card h3 {
  margin: 0 0 10px;
  font-family: var(--ff-display);
  font-size: 18px;
  font-weight: 420;
  color: var(--admin-ink);
}
.admin-body .brief-card.hot      { border-color: color-mix(in srgb, var(--admin-hot) 50%, var(--admin-rule)) !important; }
.admin-body .brief-card.overdue  { border-color: color-mix(in srgb, var(--admin-signal) 55%, var(--admin-rule)) !important; }
.admin-body .brief-card.hot h3      { color: var(--admin-hot); }
.admin-body .brief-card.overdue h3  { color: var(--admin-signal); }

.admin-body .chips {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-top: 8px;
}
.admin-body .chips .chip {
  border: 1px solid var(--admin-rule);
  background: var(--admin-paper);
  border-radius: 999px;
  padding: 3px 9px;
  font-family: var(--ff-mono);
  font-size: 11px;
  color: var(--admin-ink-soft);
  letter-spacing: .04em;
}
.admin-body .actions {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  margin-top: 12px;
}
.admin-body .muted { color: var(--admin-ink-mute); }
.admin-body .muted-copy { color: var(--admin-ink-mute); font-size: 12.5px; }

/* ----------------------------------------------------------------- lead detail drawer (slides over) */
.admin-body .lead-detail-drawer {
  position: fixed;
  top: 0; right: 0; bottom: 0;
  width: min(560px, 100vw);
  background: var(--admin-paper);
  border-left: 1px solid var(--admin-rule);
  box-shadow: -20px 0 60px -20px rgba(26,23,20,.25);
  padding: 32px;
  overflow-y: auto;
  z-index: 80;
  /* Default: closed (slid off-screen). JS toggles .open OR removes .hidden. */
  transform: translateX(100%);
  visibility: hidden;
  transition: transform 320ms cubic-bezier(.2,.7,.2,1), visibility 0s 320ms;
}
.admin-body .lead-detail-drawer.open {
  transform: translateX(0);
  visibility: visible;
  transition: transform 320ms cubic-bezier(.2,.7,.2,1), visibility 0s 0s;
}
.admin-body .lead-detail-drawer.hidden { transform: translateX(100%); visibility: hidden; }
.admin-body .lead-detail-close {
  position: absolute;
  top: 18px; right: 18px;
  width: 36px; height: 36px;
  border-radius: 50%;
  border: 1px solid var(--admin-rule);
  background: var(--admin-paper);
  display: grid; place-items: center;
  font-size: 18px;
  color: var(--admin-ink-soft);
}
.admin-body .lead-detail-close:hover { background: var(--admin-ink); color: var(--admin-canvas); border-color: var(--admin-ink); }
.admin-body .lead-detail-body { padding-top: 8px; display: grid; gap: 14px; }
.admin-body .lead-sales-brief {
  display: grid;
  gap: 12px;
  padding: 16px;
  border: 1px solid color-mix(in srgb, var(--admin-accent) 24%, var(--admin-rule));
  border-radius: 18px;
  background: linear-gradient(180deg, var(--admin-paper), var(--admin-paper-warm));
}
.admin-body .lead-sales-brief h3 { margin: 0; font-family: var(--ff-display); font-size: clamp(20px, 2.2vw, 26px); }
.admin-body .lead-sales-opening { margin: 0; color: var(--admin-ink); line-height: 1.5; }
.admin-body .lead-sales-brief__grid { display: grid; gap: 10px; grid-template-columns: repeat(auto-fit, minmax(160px, 1fr)); }
.admin-body .lead-sales-brief__grid article { padding: 12px; border: 1px solid var(--admin-rule); border-radius: 14px; background: rgba(255,255,255,.55); }
.admin-body .lead-sales-brief__grid span { display: block; color: var(--admin-ink-soft); font-size: 11px; font-weight: 800; letter-spacing: .08em; text-transform: uppercase; }
.admin-body .lead-sales-brief__grid strong { display: block; margin-top: 4px; font-size: 16px; }
.admin-body .lead-sales-brief__grid small { display: block; margin-top: 4px; color: var(--admin-ink-soft); line-height: 1.4; }
.admin-body .lead-sales-brief__actions { display: flex; flex-wrap: wrap; gap: 8px; }
.admin-body .lead-sales-guard { margin: 0; color: var(--admin-ink-soft); font-size: 13px; line-height: 1.45; }
.admin-body .lead-detail-technical { border-top: 1px solid var(--admin-rule); padding-top: 10px; }
.admin-body .lead-detail-technical summary { cursor: pointer; color: var(--admin-ink-soft); font-weight: 800; }

/* ----------------------------------------------------------------- misc */
.admin-body .hidden { display: none !important; }
.admin-body .check, .admin-body .legal-safety {
  font-size: 13.5px;
  color: var(--admin-ink-soft);
}
.admin-body .placeholder,
.admin-body .empty {
  background: var(--admin-paper-warm);
  border: 1px dashed var(--admin-rule);
  border-radius: 8px;
  padding: 24px;
  text-align: center;
  color: var(--admin-ink-mute);
  font-size: 13px;
}
.admin-body code {
  background: var(--admin-paper-warm);
  border: 1px solid var(--admin-rule);
  padding: 1px 6px;
  border-radius: 4px;
  font-size: 12.5px;
  color: var(--admin-ink);
}

/* ----------------------------------------------------------------- generator-specific quick wins */
.admin-body .export-preview-trigger {
  border: 1px solid var(--admin-rule);
  background: var(--admin-paper-warm);
  color: var(--admin-ink);
  border-radius: 999px;
  padding: 8px 14px;
  font-size: 13px;
  font-family: var(--ff-sans);
  cursor: pointer;
  transition: background 150ms cubic-bezier(.2,.7,.2,1);
}
.admin-body .export-preview-trigger:hover { background: var(--admin-ink); color: var(--admin-canvas); border-color: var(--admin-ink); }
/* Export confirm dialog — was rendered as an unstyled div appended to <body>,
   so it flowed to the bottom behind the fixed sidebar. Give it a real overlay. */
.admin-body .export-preview-modal { position: fixed; inset: 0; z-index: 1200; display: none; place-items: center; padding: 20px; background: rgba(11,18,32,.55); backdrop-filter: blur(4px); -webkit-backdrop-filter: blur(4px); }
.admin-body .export-preview-modal.open { display: grid; }
.admin-body .export-preview-dialog { position: relative; background: var(--admin-paper); color: var(--admin-ink); width: min(560px, 100%); max-height: 88vh; overflow: auto; border-radius: 20px; border: 1px solid var(--admin-rule); box-shadow: 0 40px 120px -40px rgba(0,0,0,.6); padding: 22px 24px; }
.admin-body .export-preview-summary-grid { display: grid; gap: 12px; margin: 14px 0; }
.admin-body .export-preview-summary-grid article { display: grid; gap: 3px; padding: 12px 14px; border: 1px solid var(--admin-rule); border-radius: 14px; }
.admin-body .export-preview-summary-grid article span { font-size: 12px; color: var(--admin-ink-soft); text-transform: uppercase; letter-spacing: .04em; }
.admin-body .export-preview-summary-grid article small { color: var(--admin-ink-soft); word-break: break-all; }
.admin-body .export-risk-note { padding: 12px 14px; border-radius: 12px; background: rgba(138,74,10,.08); color: var(--admin-warn); font-size: 13.5px; line-height: 1.5; }
.admin-body .export-confirm-actions { display: flex; gap: 10px; margin-top: 16px; flex-wrap: wrap; }
.admin-body .lead-email-draft { width: 100%; margin: 8px 0; padding: 10px 12px; border: 1px solid var(--admin-rule); border-radius: 12px; font: inherit; font-size: 13px; line-height: 1.5; resize: vertical; background: #fff; color: var(--admin-ink); }

/* ----------------------------------------------------------------- helpers */
.admin-body .row { display: flex; gap: 12px; align-items: center; }
.admin-body .row-wrap { display: flex; gap: 12px; align-items: center; flex-wrap: wrap; }
.admin-body .stack { display: grid; gap: 10px; }
.admin-body .right { margin-left: auto; }

/* ----------------------------------------------------------------- focus/keyboard */
.admin-body *:focus-visible { outline-offset: 3px; }

/* ----------------------------------------------------------------- print */
@media print {
  .admin-body { background: #fff; color: #000; }
  .admin-body .topbar, .admin-body .actions, .admin-body .lead-detail-drawer { display: none; }
}


/* 2026-06-09: visible admin access + calm Apple-like refinement */
.admin-body .auth-top-trigger {
  border: 1px solid color-mix(in srgb, var(--admin-accent) 24%, var(--admin-rule));
  background: color-mix(in srgb, var(--admin-accent) 8%, #fff);
  color: var(--admin-accent);
  border-radius: 999px;
  padding: 8px 13px;
  font-weight: 600;
  white-space: nowrap;
}
.admin-body .auth-top-trigger:hover {
  background: var(--admin-accent);
  color: #fff;
}
.admin-body .auth-card {
  border: 1px solid color-mix(in srgb, var(--admin-accent) 18%, var(--admin-rule));
  border-radius: 28px;
  background: color-mix(in srgb, #fff 88%, var(--admin-canvas));
  box-shadow: 0 20px 70px -44px rgba(0, 113, 227, .32);
  padding: 22px;
}
.admin-body .auth-card-inner {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: 18px;
  align-items: center;
}
@media (min-width: 820px) {
  .admin-body .auth-card-inner { grid-template-columns: 1fr minmax(320px, .75fr); }
}
.admin-body .auth-card strong {
  display: block;
  font-size: 18px;
  letter-spacing: -.02em;
  margin-bottom: 4px;
}
.admin-body .auth-card .muted-copy,
.admin-body .auth-card .auth-message {
  color: var(--admin-ink-mute);
  margin: 0;
}
.admin-body .auth-form {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: 10px;
}
@media (min-width: 640px) {
  .admin-body .auth-form { grid-template-columns: minmax(0, 1fr) auto auto; }
}
.admin-body.auth-gate-locked,
.admin-body.auth-gate-checking {
  min-height: 100dvh;
}
.admin-body.auth-gate-locked .topbar nav,
.admin-body.auth-gate-checking .topbar nav,
.admin-body.auth-gate-locked .guide-top-trigger,
.admin-body.auth-gate-checking .guide-top-trigger,
.admin-body.auth-gate-locked .admin-sidebar,
.admin-body.auth-gate-checking .admin-sidebar,
.admin-body.auth-gate-locked footer,
.admin-body.auth-gate-checking footer {
  display: none !important;
}
.admin-body.auth-gate-locked main,
.admin-body.auth-gate-checking main {
  width: min(1120px, 100%);
  min-height: calc(100dvh - 74px);
  margin: 0 auto;
  padding: clamp(22px, 5vw, 64px) 18px;
  display: grid;
  place-items: center;
}
.admin-body.auth-gate-locked main > :not(#lead-os-admin-auth),
.admin-body.auth-gate-checking main > :not(#lead-os-admin-auth) {
  display: none !important;
}
.admin-body.auth-gate-unlocked #lead-os-admin-auth.auth-screen {
  display: none !important;
}
.admin-body .auth-screen {
  width: min(980px, 100%);
  padding: clamp(22px, 4vw, 40px);
  border-radius: 28px;
}
.admin-body .auth-screen[hidden] {
  display: none !important;
}
.admin-body .auth-screen__copy h1 {
  max-width: 12ch;
  font-size: clamp(34px, 4vw, 58px);
  line-height: .98;
  letter-spacing: -.045em;
  color: var(--admin-rail);
}
.admin-body .auth-screen__copy .muted-copy {
  max-width: 54ch;
  font-size: 15px;
  line-height: 1.65;
}
.admin-body .auth-screen .auth-message {
  min-height: 1.5em;
  font-weight: 600;
  color: var(--admin-ink-soft);
}
.admin-body .auth-form--screen {
  align-self: stretch;
  grid-template-columns: 1fr;
  gap: 14px;
  padding: 18px;
  border: 1px solid rgba(10,29,47,.095);
  border-radius: 22px;
  background: linear-gradient(180deg, rgba(255,255,255,.92), rgba(248,251,255,.9));
}
.admin-body .auth-form--screen .auth-field {
  margin: 0;
}
.admin-body .auth-form--screen input[type="password"] {
  min-height: 48px;
  font-size: 15px;
}
.admin-body .auth-remember {
  display: inline-flex;
  align-items: center;
  gap: 9px;
  margin: 0;
  color: var(--admin-ink-soft);
  font-family: var(--ff-sans);
  font-size: 13.5px;
  letter-spacing: 0;
  text-transform: none;
}
.admin-body .auth-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}
.admin-body .auth-actions .btn {
  justify-content: center;
}
.admin-body .auth-screen:not(.has-token) #lead-os-admin-logout {
  display: none;
}
.admin-body .auth-screen__checks {
  grid-column: 1 / -1;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
  margin-top: 4px;
}
.admin-body .auth-screen__checks article {
  display: grid;
  gap: 5px;
  padding: 14px 16px;
  border: 1px solid rgba(10,29,47,.09);
  border-radius: 18px;
  background: rgba(255,255,255,.72);
}
.admin-body .auth-screen__checks strong {
  margin: 0;
  font-size: 14px;
  color: var(--admin-rail);
}
.admin-body .auth-screen__checks span {
  color: var(--admin-ink-soft);
  font-size: 13px;
  line-height: 1.45;
}
@media (min-width: 820px) {
  .admin-body .auth-screen.auth-card .auth-card-inner,
  .admin-body .auth-screen {
    grid-template-columns: minmax(0, 1fr) minmax(320px, .78fr);
  }
  .admin-body .auth-screen {
    display: grid;
    gap: 22px;
    align-items: center;
  }
}
@media (max-width: 720px) {
  .admin-body .auth-screen__checks { grid-template-columns: 1fr; }
  .admin-body .auth-actions .btn { width: 100%; }
}
.admin-body .hero,
.admin-body .panel,
.admin-body .system-card {
  box-shadow: 0 30px 80px -56px rgba(29, 29, 31, .28);
}
.admin-body .eyebrow { text-transform: none; letter-spacing: .01em; font-family: var(--ff-sans); font-weight: 600; }
.admin-body .eyebrow::before { display: none; }

/* =========================================================================
   Premium operator cockpit redesign pass · 2026-06-12
   Scope: admin, partner, closer. Non-technical cockpit, finance-grade calm.
   ========================================================================= */
:root {
  /* Stille Bank recolor · 2026-07-02 — legacy premium tokens now alias the
     shared ink/pine identity so every downstream rule follows automatically. */
  --admin-canvas-premium: #F3F3EE;
  --admin-rail: #141719;
  --admin-blue-premium: #0F6B4F;
  --admin-teal-premium: #11635C;
  --admin-shadow-premium: 0 1px 2px rgba(20,23,25,.06);
}
.admin-body {
  background:
    radial-gradient(900px 520px at 100% -10%, color-mix(in srgb, var(--admin-accent) 14%, transparent), transparent 60%),
    radial-gradient(720px 500px at -8% 12%, color-mix(in srgb, var(--admin-trust) 12%, transparent), transparent 58%),
    linear-gradient(180deg, #FFFFFF 0%, var(--admin-canvas-premium) 44%, #EAF1F8 100%);
  min-height: 100dvh;
}
.admin-body::before {
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: -1;
  opacity: .34;
  background-image:
    linear-gradient(rgba(10,29,47,.045) 1px, transparent 1px),
    linear-gradient(90deg, rgba(10,29,47,.035) 1px, transparent 1px);
  background-size: 44px 44px;
  mask-image: linear-gradient(180deg, #000, transparent 78%);
}
.admin-body .topbar {
  min-height: 72px;
  background: color-mix(in srgb, #FFFFFF 82%, transparent);
  border-bottom-color: rgba(10,29,47,.09);
  box-shadow: 0 18px 60px -54px rgba(10,29,47,.65);
}
.admin-body .topbar .brand .mark {
  border-radius: 16px;
  background: linear-gradient(145deg, #071625, #103354);
  box-shadow: 0 18px 46px -30px rgba(10,29,47,.8), inset 0 1px 0 rgba(255,255,255,.18);
}
.admin-body .topbar .brand .mark::after { border-radius: 19px; border-color: color-mix(in srgb, var(--admin-accent) 36%, transparent); }
.admin-body .topbar nav a {
  border-radius: 999px;
  padding: 8px 10px;
  transition: background 180ms cubic-bezier(.2,.7,.2,1), color 180ms cubic-bezier(.2,.7,.2,1), transform 180ms cubic-bezier(.2,.7,.2,1);
}
.admin-body .topbar nav a:hover {
  background: color-mix(in srgb, var(--admin-accent) 80%, transparent);
  color: var(--admin-blue-premium);
  transform: translateY(-1px);
}
.admin-body .auth-top-trigger,
.admin-body .lang-switch button {
  border-radius: 999px;
  border: 1px solid rgba(10,29,47,.12);
  background: rgba(255,255,255,.76);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.8);
}
.admin-body main { gap: 28px; }
.admin-body .hero,
.admin-body .panel,
.admin-body .system-card,
.admin-body .brief-card,
.admin-body .comparison-grid > article,
.admin-body .landing-list > article,
.admin-body .operator-guide,
.admin-body .quality-score-grid > article,
.admin-body .meeting-steps button,
.admin-body .kpi,
.admin-body .controls,
.admin-body .source-box {
  border: 1px solid rgba(10,29,47,.105);
  box-shadow: var(--admin-shadow-premium);
}
.admin-body .hero {
  position: relative;
  overflow: hidden;
  background:
    linear-gradient(135deg, rgba(255,255,255,.96), rgba(247,250,253,.92));
  border-radius: 32px;
  padding: clamp(28px, 3.2vw, 48px);
}
.admin-body .hero::before {
  content: "";
  position: absolute;
  inset: 18px 18px auto auto;
  width: min(440px, 40vw);
  height: min(440px, 40vw);
  border-radius: 120px;
  background: radial-gradient(circle at 55% 35%, color-mix(in srgb, var(--admin-accent) 16%, transparent), transparent 62%);
  border: 1px solid color-mix(in srgb, var(--admin-accent) 13%, transparent);
  transform: rotate(9deg);
}
.admin-body .hero > * { position: relative; }
.admin-body .hero-copy h1 {
  max-width: 17ch;
  font-size: clamp(36px, 2.5vw + 1.1rem, 64px);
  line-height: .98;
  letter-spacing: -.05em;
  color: var(--admin-rail);
  text-wrap: balance;
}
.admin-body p.lead { color: #344054; max-width: 56ch; }
.admin-body .panel {
  border-radius: 28px;
  background: rgba(255,255,255,.88);
  backdrop-filter: blur(12px);
}
.admin-body .section-head {
  border-bottom-color: rgba(10,29,47,.09);
  align-items: start;
}
.admin-body .section-head h2 { text-wrap: balance; color: var(--admin-rail); }
.admin-body .system-card,
.admin-body .operator-guide {
  border-radius: 26px;
  background:
    linear-gradient(180deg, rgba(255,255,255,.9), rgba(244,247,251,.92));
}
.admin-body .pipeline {
  display: grid;
  grid-template-columns: minmax(74px,.42fr) 1fr;
  gap: 10px 14px;
  align-items: center;
}
.admin-body .pipeline span {
  color: #667085;
  font-family: var(--ff-mono);
  letter-spacing: .12em;
  text-transform: uppercase;
  font-size: 10.5px;
}
.admin-body .pipeline b {
  color: var(--admin-rail);
  font-weight: 600;
}
.admin-body .operator-guide__steps a,
.admin-body .meeting-steps button {
  border-radius: 20px;
  background: linear-gradient(180deg, #FFFFFF, #F8FBFF);
  transition: transform 180ms cubic-bezier(.2,.7,.2,1), border-color 180ms cubic-bezier(.2,.7,.2,1), box-shadow 180ms cubic-bezier(.2,.7,.2,1);
}
.admin-body .operator-guide__steps a:hover,
.admin-body .meeting-steps button:hover {
  transform: translateY(-3px);
  border-color: color-mix(in srgb, var(--admin-accent) 28%, transparent);
  text-decoration: none;
}
.admin-body .btn.primary,
.admin-body .btn[type="submit"] {
  background: linear-gradient(135deg, var(--admin-blue-premium), var(--admin-teal-premium));
  border-color: transparent;
}
.admin-body .btn.ghost {
  background: rgba(255,255,255,.76);
  border-color: rgba(10,29,47,.12);
}
.admin-body .btn:hover { transform: translateY(-1px); box-shadow: 0 22px 54px -38px rgba(10,29,47,.55); }
.admin-body .dashboard-grid,
.admin-body .cockpit-kpis,
.admin-body .brief-grid,
.admin-body .comparison-grid,
.admin-body .quality-score-grid {
  gap: 18px;
}
.admin-body .kpi,
.admin-body .quality-score-grid > article,
.admin-body .comparison-grid > article,
.admin-body .brief-card,
.admin-body .landing-list > article {
  border-radius: 22px;
  background: linear-gradient(180deg, #FFFFFF, #F8FBFF);
}
.admin-body .kpi strong,
.admin-body .comparison-grid h3,
.admin-body .mini-metric strong {
  font-variant-numeric: tabular-nums;
  color: var(--admin-rail);
}
.admin-body .controls input,
.admin-body .controls select,
.admin-body .controls textarea,
.admin-body input,
.admin-body select,
.admin-body textarea {
  border-radius: 15px;
  border-color: rgba(10,29,47,.13);
  background: rgba(255,255,255,.88);
}
.admin-body .controls input:focus,
.admin-body .controls select:focus,
.admin-body .controls textarea:focus,
.admin-body input:focus,
.admin-body select:focus,
.admin-body textarea:focus {
  outline: 3px solid color-mix(in srgb, var(--admin-accent) 16%, transparent);
  border-color: color-mix(in srgb, var(--admin-accent) 56%, transparent);
}
.admin-body .landing-list > article,
.admin-body .brief-card { overflow: hidden; }
.admin-body .landing-list > article::before,
.admin-body .brief-card::before {
  content: "";
  display: block;
  height: 4px;
  margin: -1px -1px 14px;
  background: linear-gradient(90deg, color-mix(in srgb, var(--admin-accent) 72%, transparent), color-mix(in srgb, var(--admin-trust) 70%, transparent));
}
.admin-body .source-health-panel,
.admin-body .v2-cockpit-panel,
.admin-body .analytics-panel { scroll-margin-top: 96px; }
@media (min-width: 1180px) {
  .admin-body .hero { grid-template-columns: minmax(0,1.1fr) minmax(420px,.9fr); }
  .admin-body .dashboard-grid.cockpit-kpis { grid-template-columns: repeat(4, minmax(0,1fr)); }
}
@media (max-width: 780px) {
  .admin-body .topbar { flex-wrap: wrap; padding: 12px 16px; gap: 10px; }
  .admin-body .topbar nav { order: 3; width: 100%; overflow-x: auto; padding-bottom: 2px; margin-left: 0; }
  .admin-body main { padding: 22px 14px 64px; }
  .admin-body .hero, .admin-body .panel { border-radius: 22px; padding: 20px; }
  .admin-body .hero-copy h1 { max-width: 12ch; }
}

/* Visual QA refinements · 2026-06-12
   Browser smoke: meeting-step buttons needed explicit internal layout so
   number, title and helper never concatenate visually. */
.admin-body .meeting-steps {
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
}
.admin-body .meeting-steps button {
  display: grid;
  grid-template-columns: 28px minmax(0, 1fr);
  grid-template-rows: auto auto;
  align-items: center;
  gap: 3px 10px;
  text-align: left;
  min-height: 62px;
  padding: 12px 14px;
}
.admin-body .meeting-steps button strong {
  grid-row: 1 / span 2;
  width: 28px;
  height: 28px;
  border-radius: 999px;
  display: grid;
  place-items: center;
  background: var(--admin-rail);
  color: #fff;
  font-family: var(--ff-mono);
  font-size: 11px;
}
.admin-body .meeting-steps button span {
  display: block;
  font-weight: 600;
  color: var(--admin-rail);
  line-height: 1.18;
}
.admin-body .meeting-steps button small {
  display: block;
  color: #667085;
  line-height: 1.25;
}


/* Sidebar + channel separation pass · 2026-06-12
   Audit finding: admin.html had too many tools stacked in one long rail. This
   adds a persistent section menu on desktop, a horizontal touch menu on mobile,
   and a dedicated channel-readiness module for lead outreach decisions. */
.admin-body main > [data-admin-page][hidden] {
  display: none !important;
}
.admin-body select[multiple] {
  min-height: 154px;
  padding-block: 10px;
}
.admin-body .admin-sidebar {
  position: sticky;
  top: 88px;
  z-index: 35;
  display: flex;
  gap: 8px;
  overflow-x: auto;
  padding: 10px 16px;
  margin: 0 auto;
  max-width: 1440px;
  background: rgba(255,255,255,.84);
  border: 1px solid rgba(10,29,47,.09);
  border-radius: 999px;
  box-shadow: 0 20px 70px -58px rgba(10,29,47,.72);
  backdrop-filter: blur(18px);
  -webkit-backdrop-filter: blur(18px);
  scroll-snap-type: x proximity;
  scrollbar-width: thin;
  -webkit-overflow-scrolling: touch;
}
.admin-body .admin-sidebar__label {
  flex: 0 0 auto;
  margin: 0;
  padding: 8px 10px;
  color: #667085;
  font-size: 12px;
  font-weight: 700;
  white-space: nowrap;
}
.admin-body .admin-sidebar a {
  flex: 0 0 auto;
  min-height: 40px;
  display: inline-flex;
  align-items: center;
  padding: 8px 12px;
  border-radius: 999px;
  color: var(--admin-rail);
  font-size: 13px;
  font-weight: 650;
  text-decoration: none;
  white-space: nowrap;
  scroll-snap-align: start;
}
.admin-body .admin-sidebar a:hover,
.admin-body .admin-sidebar a:focus-visible,
.admin-body .admin-sidebar a[aria-current="page"],
.admin-body .admin-sidebar a[aria-current="true"],
.admin-body .topbar nav a[aria-current="page"],
.admin-body .topbar nav a[aria-current="true"] {
  background: color-mix(in srgb, var(--admin-accent) 10%, transparent);
  color: var(--admin-blue-premium);
  text-decoration: none;
}
.admin-body .admin-sidebar a:focus-visible {
  /* Explicit keyboard-focus ring (≥3:1) so it doesn't rely on the UA default,
     which some browsers suppress under the global outline-offset-only rule. */
  outline: 2px solid var(--admin-blue-premium);
  outline-offset: 2px;
}
/* Grouped sidebar: on the mobile/tablet horizontal rail the group wrapper is
   transparent (labels + links flow inline as before); the desktop @media turns
   each group into its own vertical block. */
.admin-body .admin-sidebar__group { display: contents; }
.admin-body .admin-sidebar__ico { flex: 0 0 auto; margin-right: 9px; font-size: 15px; line-height: 1; }
.admin-body .admin-sidebar a > span:last-child { overflow: hidden; text-overflow: ellipsis; }
.admin-body .channel-audit {
  border-color: color-mix(in srgb, var(--admin-trust) 20%, transparent);
  background:
    linear-gradient(135deg, rgba(255,255,255,.94), rgba(242,248,247,.90));
}
.admin-body .channel-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(230px, 1fr));
  gap: 14px;
}
.admin-body .channel-card {
  min-height: 178px;
  padding: 18px;
  border: 1px solid rgba(10,29,47,.10);
  border-radius: 22px;
  background: linear-gradient(180deg, #FFFFFF, #F8FBFF);
  box-shadow: var(--admin-shadow-premium);
}
.admin-body .channel-card span {
  display: inline-flex;
  margin-bottom: 14px;
  padding: 4px 9px;
  border-radius: 999px;
  font-size: 11px;
  font-family: var(--ff-mono);
  letter-spacing: .08em;
  text-transform: uppercase;
  border: 1px solid rgba(10,29,47,.10);
  background: rgba(255,255,255,.78);
}
.admin-body .channel-card h3 {
  margin-bottom: 8px;
  font-size: 18px;
  font-weight: 650;
  color: var(--admin-rail);
}
.admin-body .channel-card p {
  margin: 0;
  color: #475467;
  font-size: 13.5px;
  line-height: 1.55;
}
.admin-body .channel-card.is-ready span { color: var(--admin-ok); border-color: rgba(30,107,71,.24); background: rgba(30,107,71,.08); }
.admin-body .channel-card.is-conditional span { color: var(--admin-warn); border-color: rgba(138,74,10,.24); background: rgba(138,74,10,.08); }
.admin-body .channel-card.is-partial span { color: var(--admin-blue-premium); border-color: color-mix(in srgb, var(--admin-accent) 24%, transparent); background: color-mix(in srgb, var(--admin-accent) 80%, transparent); }
.admin-body .channel-card.is-off span { color: var(--admin-signal); border-color: rgba(187,53,32,.24); background: rgba(187,53,32,.08); }
.admin-body .inbox-panel .landing-list {
  max-height: min(68vh, 760px);
  overflow: auto;
  padding-right: 4px;
  scroll-padding-block: 12px;
}
.admin-body .lead-results-wrap {
  max-height: min(72vh, 780px);
  overflow: auto;
}
.admin-body .lead-results-wrap thead th {
  position: sticky;
  top: 0;
  z-index: 2;
  background: rgba(248,251,255,.96);
  backdrop-filter: blur(14px);
}
.admin-body .firma-havuzu-tools { display: flex; gap: 12px; align-items: center; flex-wrap: wrap; margin-bottom: 12px; }
.admin-body #firmaHavuzuSearch, .admin-body #leadRowsSearch { flex: 1 1 260px; min-height: 42px; padding: 8px 14px; border: 1px solid rgba(10,29,47,.14); border-radius: 12px; font: inherit; background: #fff; }
.admin-body .firma-havuzu-count { color: #667085; font-size: 13px; font-weight: 650; white-space: nowrap; }
.admin-body .firma-havuzu-contactonly { display: inline-flex; align-items: center; gap: 6px; font-size: 13px; color: #475467; white-space: nowrap; cursor: pointer; }
.admin-body .firma-havuzu-wrap { max-height: min(72vh, 780px); overflow: auto; }
.admin-body .firma-havuzu-wrap thead th { position: sticky; top: 0; z-index: 2; background: rgba(248,251,255,.96); backdrop-filter: blur(14px); }
.admin-body .firma-havuzu-wrap th.sortable { cursor: pointer; user-select: none; white-space: nowrap; }
.admin-body .firma-havuzu-wrap th.sortable::after { content: '↕'; opacity: .35; margin-left: 6px; font-size: 11px; }
.admin-body .firma-havuzu-wrap th.sortable[aria-sort="ascending"]::after { content: '↑'; opacity: 1; }
.admin-body .firma-havuzu-wrap th.sortable[aria-sort="descending"]::after { content: '↓'; opacity: 1; }
.admin-body #firmaHavuzuRows tr.lead-row { cursor: pointer; }
.admin-body #firmaHavuzuRows tr.lead-row:hover { background: color-mix(in srgb, var(--admin-accent) 50%, transparent); }
.admin-body #firmaHavuzuRows tr.pool-sales-row td { vertical-align: top; }
.admin-body #firmaHavuzuRows tr.pool-sales-row td:first-child { width: 96px; }
.admin-body #firmaHavuzuRows tr.pool-sales-row small { display: block; margin-top: 4px; color: var(--admin-ink-soft); line-height: 1.35; }
.admin-body #firmaHavuzuRows tr.pool-sales-row strong { color: var(--admin-ink); }
.admin-body #firmaHavuzuRows .pool-row-source { color: var(--admin-ink-mute); font-size: 11.5px; }
.admin-body #firmaHavuzuRows .firma-havuzu-detail { margin-top: 8px; }
.admin-body #leadRows tr.lead-row { cursor: pointer; }
.admin-body #leadRows tr.lead-row:hover { background: color-mix(in srgb, var(--admin-accent) 50%, transparent); }
.admin-body .lead-results-wrap td { vertical-align: top; }
.admin-body .panel,
.admin-body .hero { scroll-margin-top: 156px; }
@media (min-width: 960px) {
  .admin-body .topbar nav { display: none; }
  .admin-body .admin-sidebar {
    position: fixed;
    left: 24px;
    top: 96px;
    bottom: 24px;
    width: 236px;
    max-width: none;
    margin: 0;
    padding: 18px 14px;
    flex-direction: column;
    overflow-x: hidden;
    overflow-y: auto;
    border-radius: 28px;
    align-items: stretch;
  }
  .admin-body .admin-sidebar__label {
    padding: 0 10px 8px;
    letter-spacing: .02em;
  }
  .admin-body .admin-sidebar a {
    width: 100%;
    justify-content: flex-start;
    border-radius: 16px;
  }
  .admin-body .admin-sidebar__group { display: flex; flex-direction: column; gap: 4px; }
  .admin-body .admin-sidebar__group + .admin-sidebar__group {
    margin-top: 12px;
    padding-top: 12px;
    border-top: 1px solid rgba(10,29,47,.08);
  }
  .admin-body main {
    max-width: 1220px;
    margin-left: calc(236px + 48px);
    margin-right: max(28px, calc((100vw - 1504px) / 2));
    padding-top: 28px;
  }
  .admin-body footer {
    margin-left: calc(236px + 48px);
  }
  .admin-body .panel,
  .admin-body .hero { scroll-margin-top: 104px; }
}
@media (max-width: 780px) {
  .admin-body .admin-sidebar {
    top: 132px;
    margin: 8px 12px 0;
    border-radius: 20px;
    padding: 8px;
  }
  .admin-body .admin-sidebar__label { display: none; }
  .admin-body .admin-sidebar a {
    min-height: 44px;
    font-size: 12.5px;
    padding: 9px 11px;
  }
  .admin-body .channel-grid { grid-template-columns: 1fr; }
  .admin-body .channel-card { min-height: auto; }
  .admin-body .section-head .actions-row { justify-self: stretch; }
  .admin-body .actions-row .btn,
  .admin-body .actions-row button,
  .admin-body .actions-row a { width: 100%; justify-content: center; }
  .admin-body .table-wrap table { min-width: 760px; }
}

/* Reference-board density correction · 2026-06-12
   The section containers themselves must not become grids; only their inner
   card groups should. This keeps the lower reference modules readable instead
   of creating large empty left columns. */
.admin-body .source-legend,
.admin-body .roles-board,
.admin-body .readiness-board,
.admin-body .risk-board {
  display: block;
}
.admin-body .source-legend .comparison-grid,
.admin-body .roles-board .comparison-grid,
.admin-body .readiness-board .readiness-grid,
.admin-body .risk-board .two-column-cards {
  margin-top: 18px;
}
.admin-body .readiness-grid article,
.admin-body .source-legend .comparison-grid > article,
.admin-body .roles-board .comparison-grid > article {
  min-height: auto;
}

/* How-to-use guide — operator onboarding overlay (admin-guide.js) */
.guide-top-trigger {
  appearance: none; border: 1px solid var(--admin-rule); background: var(--admin-paper);
  color: var(--admin-ink-soft); font: inherit; font-size: 13px; font-weight: 600;
  padding: 7px 13px; border-radius: 999px; cursor: pointer; white-space: nowrap;
}
.guide-top-trigger:hover { background: var(--admin-blue-premium); color: #fff; border-color: var(--admin-blue-premium); }
.guide-top-trigger:focus-visible { outline: 2px solid var(--admin-blue-premium); outline-offset: 2px; }
.admin-guide {
  position: fixed; inset: 0; z-index: 1000; display: grid; place-items: center; padding: 20px;
  background: rgba(11,18,32,.55); backdrop-filter: blur(4px); -webkit-backdrop-filter: blur(4px);
}
.admin-guide__card {
  background: var(--admin-paper); color: var(--admin-ink); width: min(720px, 100%);
  max-height: 88vh; overflow: auto; border-radius: 20px; border: 1px solid var(--admin-rule);
  box-shadow: 0 40px 120px -40px rgba(0,0,0,.6);
}
.admin-guide__card:focus-visible { outline: 2px solid var(--admin-blue-premium); outline-offset: -2px; }
.admin-guide__head {
  display: flex; align-items: center; justify-content: space-between; gap: 16px;
  padding: 18px 22px; position: sticky; top: 0; background: var(--admin-paper);
  border-bottom: 1px solid var(--admin-rule); z-index: 1;
}
.admin-guide__title { margin: 0; font-size: 18px; }
.admin-guide__close {
  appearance: none; border: 1px solid var(--admin-rule); background: transparent;
  color: var(--admin-ink-soft); width: 34px; height: 34px; border-radius: 50%;
  cursor: pointer; font-size: 14px; line-height: 1; flex: 0 0 auto;
}
.admin-guide__close:hover { background: var(--admin-ink); color: var(--admin-canvas); border-color: var(--admin-ink); }
.admin-guide__close:focus-visible { outline: 2px solid var(--admin-blue-premium); outline-offset: 2px; }
.admin-guide__body { padding: 6px 22px 26px; }
.admin-guide__intro { color: var(--admin-ink-soft); font-size: 14.5px; line-height: 1.6; margin: 14px 0 20px; }
.admin-guide__section { margin: 0 0 18px; }
.admin-guide__section h3 { margin: 0 0 8px; font-size: 15px; color: var(--admin-blue-premium); }
.admin-guide__section ul { margin: 0; padding-left: 18px; }
.admin-guide__section li { margin: 0 0 7px; font-size: 14px; line-height: 1.55; color: var(--admin-ink-soft); }
@media (max-width: 600px) {
  .admin-guide__card { border-radius: 14px; }
  .admin-guide__head, .admin-guide__body { padding-left: 16px; padding-right: 16px; }
}

.admin-body .lead-detail-timeline { margin: 10px 0 0; padding-left: 18px; display: grid; gap: 8px; }
.admin-body .lead-detail-timeline li { padding-left: 4px; }
.admin-body .lead-detail-timeline span { display: block; color: var(--admin-ink-soft); font-size: 12px; text-transform: uppercase; letter-spacing: .08em; }
.admin-body .lead-detail-timeline strong { display: block; font-size: 13.5px; }
.admin-body .lead-detail-timeline small { display: block; color: var(--admin-ink-soft); }
.admin-body .email-plan-list { margin: 10px 0 0; padding-left: 18px; display: grid; gap: 7px; color: var(--admin-ink-soft); font-size: 13.5px; line-height: 1.45; }

/* =========================================================================
   Clarity pass · 2026-07-02
   Panel users are non-technical insurance advisors (TR/DE). Goals:
   minimalist canvas (no decorative grid/gradients), unmistakable buttons,
   plain-language labels (no terminal-style mono uppercase), comfortable
   reading sizes. Appended last on purpose: same-specificity overrides win
   by cascade order, so earlier passes stay untouched.
   ========================================================================= */

/* --- 1 · Quiet canvas: flat ground, no grid overlay, one soft shadow --- */
.admin-body {
  font-size: 15px;
  background: linear-gradient(180deg, #FFFFFF 0%, #F4F7FB 34%, #EFF4F9 100%);
}
.admin-body::before { display: none; }
.admin-body .hero::before { display: none; }
.admin-body .hero,
.admin-body .panel,
.admin-body .system-card,
.admin-body .brief-card,
.admin-body .comparison-grid > article,
.admin-body .landing-list > article,
.admin-body .operator-guide,
.admin-body .quality-score-grid > article,
.admin-body .meeting-steps button,
.admin-body .kpi,
.admin-body .controls,
.admin-body .source-box,
.admin-body .channel-card {
  box-shadow: 0 1px 2px rgba(10, 29, 47, .06);
}
.admin-body .operator-guide {
  background: #F7FAFE;
  border-color: color-mix(in srgb, var(--admin-accent) 18%, transparent);
}
.admin-body .admin-sidebar { box-shadow: 0 1px 3px rgba(10, 29, 47, .08); }
.admin-body .topbar { box-shadow: none; }

/* --- 2 · Buttons: bigger, bolder, clear primary/secondary hierarchy --- */
.admin-body .btn {
  min-height: 44px;
  padding: 11px 22px;
  font-size: 15px;
  font-weight: 600;
  letter-spacing: 0;
}
.admin-body .btn.primary,
.admin-body .btn[type="submit"] {
  background: var(--admin-blue-premium);
  border-color: var(--admin-blue-premium);
  color: #fff;
}
.admin-body .btn.primary:hover,
.admin-body .btn[type="submit"]:hover { background: #0F56B3; border-color: #0F56B3; }
.admin-body .btn.ghost {
  background: #fff;
  border: 1.5px solid rgba(10, 29, 47, .28);
  color: var(--admin-rail);
}
.admin-body .btn.ghost:hover {
  background: #fff;
  border-color: var(--admin-blue-premium);
  color: var(--admin-blue-premium);
}
.admin-body .btn:hover { transform: none; box-shadow: none; }
.admin-body .btn.small { min-height: 34px; padding: 6px 14px; font-size: 13.5px; }
.admin-body .guide-top-trigger,
.admin-body .auth-top-trigger { min-height: 40px; font-size: 14px; }

/* --- 3 · Plain-language labels: retire mono-uppercase micro type --- */
.admin-body label,
.admin-body .lead-sprint-fields label > span {
  font-family: var(--ff-sans);
  font-size: 13.5px;
  font-weight: 600;
  letter-spacing: 0;
  text-transform: none;
  color: #344054;
}
.admin-body .eyebrow { font-size: 12.5px; color: #667085; }
.admin-body .pipeline span,
.admin-body .mini-metric span,
.admin-body .kpi small,
.admin-body .empty-card small,
.admin-body .safe-card small,
.admin-body .source-box small,
.admin-body .letter-card small,
.admin-body .export-preview-card small,
.admin-body .inbox-kpi span,
.admin-body .lead-row__product span,
.admin-body .lead-sprint-truth strong,
.admin-body .lead-detail-timeline span,
.admin-body .export-preview-summary-grid article span,
.admin-body .channel-card span,
.admin-body .topbar .brand small,
.admin-body .lead-inbox-summary,
.admin-body .inbox-live {
  font-family: var(--ff-sans);
  text-transform: none;
  letter-spacing: .01em;
}
.admin-body .pipeline span { font-size: 12px; font-weight: 600; }
.admin-body .mini-metric span,
.admin-body .inbox-kpi span { font-size: 12.5px; font-weight: 600; }
.admin-body .kpi small,
.admin-body .empty-card small,
.admin-body .safe-card small,
.admin-body .source-box small,
.admin-body .letter-card small,
.admin-body .export-preview-card small { font-size: 12px; }
.admin-body .lead-row__product span,
.admin-body .lead-sprint-truth strong { font-size: 12px; font-weight: 700; }
.admin-body .topbar .brand small { font-size: 11px; letter-spacing: .04em; }

/* status message bar reads as a sentence, not a code badge */
.admin-body .status {
  font-family: var(--ff-sans);
  font-size: 13.5px;
  letter-spacing: 0;
  text-transform: none;
  padding: 10px 14px;
  border-radius: 12px;
  line-height: 1.5;
}
.admin-body .status-pill {
  font-family: var(--ff-sans);
  font-size: 12px;
  font-weight: 600;
  letter-spacing: .02em;
  text-transform: none;
}
/* `.status-pill.placeholder` inherited the big dashed empty-state box styles
   from the generic `.placeholder` rule; keep it a compact pill. */
.admin-body .status-pill.placeholder {
  padding: 4px 12px;
  border: 1px solid var(--admin-rule);
  border-radius: 999px;
  background: var(--admin-paper-warm);
  text-align: left;
  color: var(--admin-ink-mute);
}
.admin-body .chips .chip { font-family: var(--ff-sans); font-size: 12px; letter-spacing: 0; }

/* --- 4 · Tables: readable headers and cells --- */
.admin-body th {
  font-family: var(--ff-sans);
  font-size: 12.5px;
  font-weight: 650;
  letter-spacing: .01em;
  text-transform: none;
  color: #475467;
}
.admin-body table { font-size: 14px; }

/* --- 5 · Forms: sans everywhere, comfortable targets --- */
.admin-body input:not([type]),
.admin-body input[type="text"],
.admin-body input[type="email"],
.admin-body input[type="tel"],
.admin-body input[type="number"],
.admin-body input[type="date"],
.admin-body input[type="datetime-local"],
.admin-body input[type="search"],
.admin-body input[type="url"],
.admin-body input[type="password"],
.admin-body select,
.admin-body textarea {
  font-family: var(--ff-sans);
  font-size: 15px;
  min-height: 44px;
}
.admin-body select[multiple] { font-size: 14px; min-height: 176px; }
.admin-body select[multiple] option { padding: 7px 10px; border-radius: 6px; }
.admin-body label.check { font-size: 14px; font-weight: 500; }
.admin-body input[type="checkbox"], .admin-body input[type="radio"] { width: 18px; height: 18px; }
.admin-body .muted-copy { font-size: 13.5px; }

/* ads measurement status block (Reklam page) */
.admin-body .ads-measure-block {
  margin: 6px 0 22px;
  padding-bottom: 20px;
  border-bottom: 1px solid var(--admin-rule-soft);
}
.admin-body .ads-measure-block h3 { margin-bottom: 4px; }
.admin-body .ads-measure-block .muted-copy { max-width: 78ch; margin-bottom: 12px; }

/* meta-plan label/value pairs were unstyled and ran together inline */
.admin-body .meta-plan .meta-item {
  display: grid;
  gap: 4px;
  padding: 12px 14px;
  background: var(--admin-paper-warm);
  border: 1px solid var(--admin-rule-soft);
  border-radius: 12px;
  align-content: start;
}
.admin-body .meta-plan .meta-item span {
  font-size: 12px;
  font-weight: 600;
  color: #667085;
}
.admin-body .meta-plan .meta-item strong {
  font-weight: 500;
  font-size: 14px;
  line-height: 1.45;
  color: var(--admin-ink);
  overflow-wrap: anywhere;
}

/* --- 6 · Hero: compact, vertically balanced, less shouty --- */
.admin-body .hero { align-items: center; }
.admin-body .hero-copy h1 {
  font-size: clamp(30px, 1.6rem + 1.6vw, 46px);
  letter-spacing: -.035em;
  line-height: 1.04;
}
.admin-body .auth-screen__copy h1 { font-size: clamp(30px, 3vw, 46px); }

/* =========================================================================
   Stille Bank harmonisation pass · 2026-07-02
   Cockpit adopts the public site's minimal identity: flat paper canvas,
   ink + pine, hairlines instead of navy-tinted glass. Appended last so
   cascade order wins over every earlier pass without touching them.
   ========================================================================= */
.admin-body {
  background: var(--admin-canvas);
  color: var(--admin-ink);
}
.admin-body .topbar {
  background: color-mix(in srgb, var(--admin-paper) 96%, transparent);
  border-bottom: 1px solid var(--admin-rule);
  box-shadow: none;
}
.admin-body .topbar .brand .mark {
  border-radius: 12px;
  background: var(--admin-ink);
  box-shadow: none;
}
.admin-body .topbar .brand .mark::after { content: none; }
.admin-body .topbar nav a { border-radius: 10px; }
.admin-body .topbar nav a:hover {
  background: var(--admin-canvas-soft, #F3F3EE);
  color: var(--admin-ink);
  transform: none;
}
.admin-body .auth-top-trigger,
.admin-body .lang-switch button {
  border: 1px solid var(--admin-rule);
  background: var(--admin-paper);
  box-shadow: none;
}

/* Surfaces: white card + hairline, flat */
.admin-body .hero,
.admin-body .panel,
.admin-body .system-card,
.admin-body .brief-card,
.admin-body .comparison-grid > article,
.admin-body .landing-list > article,
.admin-body .operator-guide,
.admin-body .quality-score-grid > article,
.admin-body .meeting-steps button,
.admin-body .kpi,
.admin-body .controls,
.admin-body .source-box,
.admin-body .channel-card {
  border-color: var(--admin-rule);
  background: var(--admin-paper);
  box-shadow: none;
}
.admin-body .hero,
.admin-body .panel { border-radius: 20px; }
.admin-body .system-card,
.admin-body .operator-guide,
.admin-body .kpi,
.admin-body .quality-score-grid > article,
.admin-body .comparison-grid > article,
.admin-body .brief-card,
.admin-body .landing-list > article { border-radius: 16px; }
.admin-body .operator-guide {
  background: color-mix(in srgb, var(--admin-accent) 5%, var(--admin-paper));
  border-color: color-mix(in srgb, var(--admin-accent) 22%, var(--admin-rule));
}
.admin-body .operator-guide__steps a,
.admin-body .meeting-steps button {
  background: var(--admin-paper);
  border-radius: 12px;
}
.admin-body .landing-list > article::before,
.admin-body .brief-card::before {
  background: var(--admin-accent);
  height: 3px;
}

/* Buttons: wide, decisive, pine primary */
.admin-body .btn {
  min-height: 48px;
  padding: 12px 26px;
  font-size: 15px;
  font-weight: 650;
  border-radius: 12px;
}
.admin-body .btn.primary,
.admin-body .btn[type="submit"] {
  background: var(--admin-accent);
  border-color: var(--admin-accent);
  color: #fff;
}
.admin-body .btn.primary:hover,
.admin-body .btn[type="submit"]:hover {
  background: var(--admin-accent-2);
  border-color: var(--admin-accent-2);
}
.admin-body .btn.ghost {
  background: var(--admin-paper);
  border: 1.5px solid var(--admin-rule);
  color: var(--admin-ink);
}
.admin-body .btn.ghost:hover {
  border-color: var(--admin-ink);
  color: var(--admin-ink);
  background: var(--admin-paper);
}
.admin-body .btn.small { min-height: 36px; padding: 7px 16px; border-radius: 10px; }

/* Forms: hairline + pine focus */
.admin-body .controls input,
.admin-body .controls select,
.admin-body .controls textarea,
.admin-body input,
.admin-body select,
.admin-body textarea {
  border-radius: 10px;
  border-color: var(--admin-rule);
  background: var(--admin-paper);
}
.admin-body .controls input:focus,
.admin-body .controls select:focus,
.admin-body .controls textarea:focus,
.admin-body input:focus,
.admin-body select:focus,
.admin-body textarea:focus {
  outline: 3px solid color-mix(in srgb, var(--admin-accent) 22%, transparent);
  border-color: var(--admin-accent);
}

/* Numbers stay tabular for scanning */
.admin-body .kpi strong,
.admin-body .comparison-grid h3,
.admin-body .mini-metric strong { font-variant-numeric: tabular-nums; }


/* Operator flow: simple insurance-sales work queue above deep marketing telemetry */
.admin-body .operator-flow-panel {
  display: grid;
  gap: 18px;
}
.admin-body .operator-flow {
  display: grid;
  gap: 18px;
  padding: 18px;
  border: 1px solid var(--admin-rule);
  border-radius: 18px;
  background: color-mix(in srgb, var(--admin-accent) 4%, var(--admin-paper));
}
.admin-body .operator-flow__steps {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
}
.admin-body .operator-step {
  display: grid;
  grid-template-columns: auto 1fr;
  column-gap: 12px;
  row-gap: 2px;
  align-items: start;
  padding: 14px;
  border: 1px solid var(--admin-rule-soft);
  border-radius: 14px;
  background: var(--admin-paper);
}
.admin-body .operator-step span {
  display: grid;
  place-items: center;
  width: 30px;
  height: 30px;
  border-radius: 999px;
  background: var(--admin-canvas-soft, #F3F3EE);
  color: var(--admin-ink);
  font-weight: 750;
}
.admin-body .operator-step.is-active span {
  background: var(--admin-accent);
  color: #fff;
}
.admin-body .operator-step strong,
.admin-body .operator-step small { grid-column: 2; }
.admin-body .operator-step small { color: var(--admin-muted); line-height: 1.35; }
.admin-body .operator-focus-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
}
.admin-body .operator-focus-grid > article {
  display: grid;
  gap: 7px;
  padding: 16px;
  border: 1px solid var(--admin-rule);
  border-radius: 14px;
  background: var(--admin-paper);
  box-shadow: none;
}
.admin-body .operator-focus-grid strong {
  font-size: clamp(28px, 4vw, 44px);
  line-height: 1;
  letter-spacing: -.04em;
  font-variant-numeric: tabular-nums;
}
.admin-body .operator-next-card {
  display: grid;
  gap: 10px;
  padding: 18px;
  border: 1px solid color-mix(in srgb, var(--admin-accent) 28%, var(--admin-rule));
  border-left: 5px solid var(--admin-accent);
  border-radius: 16px;
  background: var(--admin-paper);
}
.admin-body .operator-next-card.is-waiting {
  border-left-color: #A96B2C;
}
.admin-body .operator-next-card strong {
  font-size: clamp(20px, 2vw, 28px);
  letter-spacing: -.025em;
}
.admin-body .operator-next-card p { margin: 0; color: var(--admin-ink); }
.admin-body .operator-next-card small { color: var(--admin-muted); line-height: 1.45; }
.admin-body .operator-next-card__top,
.admin-body .operator-next-card__actions {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 10px;
}
.admin-body .operator-next-card__top { justify-content: space-between; color: var(--admin-muted); font-weight: 650; }
.admin-body .operator-next-card__offer,
.admin-body .operator-next-card__reason {
  display: grid;
  gap: 4px;
  padding: 12px 14px;
  border: 1px solid var(--admin-rule-soft);
  border-radius: 12px;
  background: color-mix(in srgb, #fff 58%, var(--admin-paper));
}
.admin-body .operator-next-card__offer b,
.admin-body .operator-next-card__reason b { font-size: 12px; text-transform: uppercase; letter-spacing: .08em; color: var(--admin-muted); }
.admin-body .operator-next-card__actions .btn { min-height: 42px; }
.admin-body .operator-next-action {
  display: grid;
  gap: 4px;
  padding: 14px;
  border-radius: 12px;
  background: color-mix(in srgb, var(--admin-accent) 8%, var(--admin-paper));
}
.admin-body .operator-next-action b { font-size: 12px; text-transform: uppercase; letter-spacing: .08em; color: var(--admin-muted); }
.admin-body .operator-next-action span { font-weight: 650; }
.admin-body .operator-quick-guide {
  border: 1px solid var(--admin-rule-soft);
  border-radius: 14px;
  background: color-mix(in srgb, #fff 58%, var(--admin-paper));
  overflow: hidden;
}
.admin-body .operator-quick-guide summary {
  cursor: pointer;
  padding: 13px 15px;
  font-weight: 750;
  color: var(--admin-ink);
}
.admin-body .operator-quick-guide[open] summary { border-bottom: 1px solid var(--admin-rule-soft); }
.admin-body .operator-quick-guide .operator-action-rail { padding: 14px; }
.admin-body .operator-action-rail {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
}
.admin-body .operator-action-rail article {
  display: grid;
  gap: 7px;
  padding: 15px;
  border: 1px dashed color-mix(in srgb, var(--admin-accent) 26%, var(--admin-rule));
  border-radius: 14px;
  background: color-mix(in srgb, #fff 64%, var(--admin-paper));
}
.admin-body .operator-action-rail span {
  font-size: 12px;
  font-weight: 800;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--admin-accent);
}
.admin-body .operator-action-rail strong {
  font-size: 16px;
  color: var(--admin-ink);
}
.admin-body .operator-action-rail small {
  color: var(--admin-muted);
  line-height: 1.4;
}
.admin-body .operator-detail-drawer {
  border: 1px solid var(--admin-rule);
  border-radius: 16px;
  background: var(--admin-paper);
  overflow: hidden;
}
.admin-body .operator-detail-drawer summary {
  cursor: pointer;
  padding: 15px 18px;
  font-weight: 700;
}
.admin-body .operator-detail-drawer[open] summary {
  border-bottom: 1px solid var(--admin-rule-soft);
}
.admin-body .operator-detail-drawer > *:not(summary) {
  margin: 14px 18px;
}
.admin-body .operator-guard { margin-top: 0; }
@media (max-width: 900px) {
  .admin-body .operator-flow__steps,
  .admin-body .operator-focus-grid,
  .admin-body .operator-action-rail { grid-template-columns: 1fr; }
}

/* Daily sales priority: make the list page answer "who first?" before tables. */
.admin-body .daily-priority-panel,
.admin-body .firma-havuzu-panel {
  border-color: color-mix(in srgb, var(--admin-accent) 22%, var(--admin-rule));
}
.admin-body .daily-priority-grid,
.admin-body .pool-priority-strip {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 12px;
  margin-bottom: 16px;
}
.admin-body .daily-priority-grid article,
.admin-body .pool-priority-strip article {
  display: grid;
  gap: 6px;
  padding: 16px;
  border: 1px solid var(--admin-rule);
  border-radius: 16px;
  background: linear-gradient(180deg, var(--admin-paper), var(--admin-paper-warm));
}
.admin-body .daily-priority-grid span,
.admin-body .pool-priority-strip span {
  width: fit-content;
  border-radius: 999px;
  padding: 4px 9px;
  background: color-mix(in srgb, var(--admin-accent) 12%, transparent);
  color: var(--admin-trust-2);
  font-size: 12px;
  font-weight: 700;
}
.admin-body .daily-priority-grid strong,
.admin-body .pool-priority-strip strong {
  font-family: var(--ff-display);
  font-size: clamp(19px, 2vw, 24px);
  line-height: 1.12;
}
.admin-body .daily-priority-grid small,
.admin-body .pool-priority-strip small {
  color: var(--admin-ink-soft);
  line-height: 1.45;
}
.admin-body .priority-card__next {
  display: grid;
  gap: 2px;
  padding-top: 8px;
  border-top: 1px solid color-mix(in srgb, var(--admin-rule) 75%, transparent);
}
.admin-body .priority-card__next b {
  color: var(--admin-ink-soft);
  font-size: 11px;
  letter-spacing: .08em;
  text-transform: uppercase;
}
.admin-body .priority-card__next em {
  color: var(--admin-ink);
  font-style: normal;
  font-weight: 800;
}
.admin-body .panel--secondary {
  background: var(--admin-paper-warm);
  border-style: dashed;
}

/* Operator action card: #exports first viewport — sales action before technical export details. */
.admin-body .operator-action-card {
  display: grid;
  gap: 16px;
  margin: 10px 0 24px;
  padding: 20px;
  border: 1px solid var(--admin-rule);
  border-radius: 16px;
  background: linear-gradient(180deg, var(--admin-paper), var(--admin-paper-warm));
}
.admin-body .operator-action-card__grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 12px;
}
.admin-body .operator-action-card__grid article {
  display: grid;
  gap: 7px;
  padding: 16px;
  border: 1px solid var(--admin-rule-soft);
  border-radius: 12px;
  background: var(--admin-paper);
  align-content: start;
}
.admin-body .operator-action-card__grid article.operator-action-card__message {
  grid-column: 1 / -1;
}
.admin-body .operator-action-card__grid span {
  width: fit-content;
  border-radius: 999px;
  padding: 4px 9px;
  background: color-mix(in srgb, var(--admin-accent) 12%, transparent);
  color: var(--admin-trust-2);
  font-size: 12px;
  font-weight: 700;
}
.admin-body .operator-action-card__grid strong {
  font-family: var(--ff-display);
  font-size: clamp(17px, 1.8vw, 22px);
  line-height: 1.2;
  color: var(--admin-ink);
  overflow-wrap: anywhere;
}
.admin-body .operator-action-card__message strong {
  white-space: pre-line;
}
.admin-body .operator-action-card .actions-row {
  margin-top: 2px;
}
.admin-body .exports-technical-details {
  margin-top: 4px;
}
.admin-body .exports-technical-details .discovery-collapse__hint {
  min-width: 100%;
}
