/* ================================================================
   Dark dashboard theme — scoped to body.dash-dark
   Applies to all /admin/* and /promoter/* pages so the dashboards
   match the landing aesthetic. Loaded after app.css so it overrides.
   ================================================================ */

body.dash-dark {
  --dd-bg:           #0b1220;
  --dd-bg-alt:       #0f172a;
  --dd-surface:      #1e293b;
  --dd-surface-2:    #0f172a;
  --dd-surface-3:    #15233a;
  --dd-border:       rgba(255,255,255,0.08);
  --dd-border-soft:  rgba(255,255,255,0.05);
  --dd-text:         #f8fafc;
  --dd-text-soft:    #cbd5e1;
  --dd-text-muted:   #94a3b8;
  --dd-text-faint:   #64748b;
  --dd-accent:       #ec6b1c;
  --dd-accent-soft:  rgba(236, 107, 28, 0.15);

  /* Override the light-theme tokens from app.css so any component that uses
     `var(--bg-sunk)` / `var(--fg)` etc. on a dash page picks a dark surface
     instead of the original `#f1f5f9`. Without these overrides the admin
     support inbox detail page renders inset boxes (Original message, AI
     draft, Claude review reason) as near-white panels on a dark page,
     making the white-on-white text unreadable. */
  --bg-sunk:    var(--dd-surface-3);
  --bg-soft:    var(--dd-surface-2);
  --bg-card:    var(--dd-surface);
  --bg-app:     var(--dd-bg);
  --fg:         var(--dd-text);
  --fg-muted:   var(--dd-text-muted);
  --border:     var(--dd-border);
  --border-soft: var(--dd-border-soft);

  background: linear-gradient(180deg, var(--dd-bg-alt) 0%, var(--dd-bg) 100%);
  color: var(--dd-text);
  min-height: 100vh;
}

/* ---------- Header / nav ---------- */
body.dash-dark .site-header {
  background: rgba(11, 18, 32, 0.92);
  border-bottom: 1px solid var(--dd-border);
  backdrop-filter: blur(8px);
}
body.dash-dark .brand { color: var(--dd-text); }
body.dash-dark .brand-mark { background: var(--dd-accent); color: #0f172a; }
body.dash-dark .nav a { color: var(--dd-text-soft); }
body.dash-dark .nav a:hover { color: var(--dd-text); }
body.dash-dark .nav a.btn-secondary {
  border: 1px solid var(--dd-border);
  color: var(--dd-text-soft);
  background: transparent;
  border-radius: 999px;
}
body.dash-dark .nav a.btn-secondary:hover {
  border-color: var(--dd-accent);
  color: var(--dd-text);
}
body.dash-dark .nav a.btn-primary {
  background: var(--dd-accent);
  color: #0f172a;
  border-radius: 999px;
  font-weight: 700;
}
body.dash-dark .nav a.btn-primary:hover { filter: brightness(1.1); }

/* ---------- Dash shell + sidebar ---------- */
body.dash-dark .dash-shell {
  background: transparent;
}
body.dash-dark .dash-sidebar {
  background: var(--dd-bg);
  border-right: 1px solid var(--dd-border);
  color: var(--dd-text-soft);
}
body.dash-dark .dash-sidebar .eyebrow {
  color: var(--dd-accent);
  font-family: ui-monospace, SFMono-Regular, Menlo, monospace;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.18em;
  text-transform: uppercase;
}
body.dash-dark .dash-sidebar > div:first-child {
  border-bottom-color: var(--dd-border) !important;
}
body.dash-dark .menu a {
  color: var(--dd-text-soft);
  padding: 8px 12px;
  border-radius: 8px;
  transition: background 0.15s, color 0.15s;
  display: block;
  text-decoration: none;
}
body.dash-dark .menu a:hover {
  background: rgba(255,255,255,0.04);
  color: var(--dd-text);
}
body.dash-dark .menu a.active {
  background: var(--dd-accent-soft);
  color: var(--dd-accent);
  font-weight: 600;
  box-shadow: inset 2px 0 0 var(--dd-accent);
}
body.dash-dark .menu .group-label {
  color: var(--dd-text-faint);
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  padding: 16px 12px 6px;
}

body.dash-dark .dash-main { color: var(--dd-text); }

/* ---------- Headings ---------- */
body.dash-dark h1,
body.dash-dark h2,
body.dash-dark h3,
body.dash-dark h4 { color: var(--dd-text); }
body.dash-dark h1 { font-weight: 800; letter-spacing: -0.02em; }

/* ---------- Eyebrow + utility text ---------- */
body.dash-dark .eyebrow {
  color: var(--dd-accent);
  font-family: ui-monospace, SFMono-Regular, Menlo, monospace;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.18em;
  text-transform: uppercase;
}
body.dash-dark .muted { color: var(--dd-text-muted); }
body.dash-dark .mono-sm { color: var(--dd-text-muted); }
body.dash-dark p { color: var(--dd-text-soft); }
body.dash-dark a { color: var(--dd-accent); }
body.dash-dark a:hover { filter: brightness(1.15); }
body.dash-dark code {
  background: var(--dd-surface-2);
  color: var(--dd-text-soft);
  padding: 2px 6px;
  border-radius: 4px;
  font-size: 0.9em;
}
body.dash-dark hr {
  border: 0;
  border-top: 1px solid var(--dd-border);
}

/* ---------- Cards ---------- */
body.dash-dark .card,
body.dash-dark .card-flat,
body.dash-dark .card-padless {
  background: var(--dd-surface);
  border: 1px solid var(--dd-border);
  color: var(--dd-text-soft);
  border-radius: 14px;
  box-shadow: 0 20px 40px -20px rgba(0,0,0,0.4);
}
body.dash-dark .card-flat { box-shadow: none; background: var(--dd-surface-3); }
body.dash-dark .card-header {
  background: var(--dd-surface-3);
  border-bottom: 1px solid var(--dd-border);
  padding: var(--s-4, 16px) var(--s-5, 20px);
  border-radius: 14px 14px 0 0;
}
body.dash-dark .card-header h3 { margin: 0; color: var(--dd-text); }

/* ---------- Stat cards (overview metrics) ---------- */
body.dash-dark .stat-card {
  background: var(--dd-surface);
  border: 1px solid var(--dd-border);
  border-radius: 12px;
  padding: var(--s-4, 16px) var(--s-5, 20px);
}
body.dash-dark .stat-card .label {
  color: var(--dd-text-faint);
  font-family: ui-monospace, SFMono-Regular, Menlo, monospace;
  font-size: 11px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}
body.dash-dark .stat-card .value {
  color: var(--dd-text);
  font-size: 32px;
  font-weight: 800;
  letter-spacing: -0.02em;
  margin-top: 4px;
}

/* ---------- Tables ---------- */
body.dash-dark .table { color: var(--dd-text-soft); border-collapse: collapse; }
body.dash-dark .table thead th {
  background: var(--dd-surface-3);
  color: var(--dd-text-faint);
  border-bottom: 1px solid var(--dd-border);
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  padding: 12px 16px;
}
body.dash-dark .table tbody td {
  border-bottom: 1px solid var(--dd-border-soft);
  padding: 14px 16px;
  color: var(--dd-text-soft);
}
body.dash-dark .table tbody tr:hover td { background: rgba(255,255,255,0.025); }
body.dash-dark .table tbody tr:last-child td { border-bottom: 0; }
body.dash-dark .table strong { color: var(--dd-text); }
body.dash-dark .table a { color: var(--dd-accent); }

/* ---------- Form inputs ---------- */
body.dash-dark .input,
body.dash-dark .select,
body.dash-dark .textarea,
body.dash-dark input[type=text],
body.dash-dark input[type=email],
body.dash-dark input[type=password],
body.dash-dark input[type=number],
body.dash-dark input[type=date],
body.dash-dark input[type=time],
body.dash-dark input[type=datetime-local],
body.dash-dark input[type=search],
body.dash-dark input[type=url],
body.dash-dark select,
body.dash-dark textarea {
  background: var(--dd-surface-2);
  border: 1px solid #334155;
  color: var(--dd-text);
  padding: 10px 13px;
  border-radius: 8px;
  font-size: 14px;
  transition: border-color 0.15s, box-shadow 0.15s;
}
body.dash-dark .input::placeholder,
body.dash-dark textarea::placeholder,
body.dash-dark input::placeholder { color: var(--dd-text-faint); }
body.dash-dark .input:focus,
body.dash-dark .select:focus,
body.dash-dark .textarea:focus,
body.dash-dark input:focus,
body.dash-dark select:focus,
body.dash-dark textarea:focus {
  outline: none;
  border-color: var(--dd-accent);
  box-shadow: 0 0 0 3px rgba(236,107,28,0.18);
}
body.dash-dark .field label,
body.dash-dark label {
  color: var(--dd-text-soft);
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}
body.dash-dark .field .help,
body.dash-dark .help,
body.dash-dark span.help { color: var(--dd-text-muted); font-size: 12px; }

/* ---------- Buttons ---------- */
body.dash-dark .btn-primary {
  background: var(--dd-accent);
  color: #0f172a;
  border: 0;
  border-radius: 8px;
  font-weight: 700;
  box-shadow: 0 6px 16px -6px rgba(236,107,28,0.5);
}
body.dash-dark .btn-primary:hover { filter: brightness(1.1); }
body.dash-dark .btn-secondary {
  background: var(--dd-surface-3);
  border: 1px solid var(--dd-border);
  color: var(--dd-text-soft);
  border-radius: 8px;
}
body.dash-dark .btn-secondary:hover {
  border-color: var(--dd-accent);
  color: var(--dd-text);
}
body.dash-dark .btn-ghost {
  background: transparent;
  border: 1px solid transparent;
  color: var(--dd-text-soft);
  border-radius: 8px;
}
body.dash-dark .btn-ghost:hover {
  background: rgba(255,255,255,0.04);
  color: var(--dd-text);
}
body.dash-dark .btn-block { width: 100%; }
body.dash-dark .btn-lg { padding: 14px 22px; font-size: 16px; }

/* ---------- Badges ---------- */
body.dash-dark .badge {
  background: var(--dd-surface-3);
  color: var(--dd-text-soft);
  border: 1px solid var(--dd-border);
  padding: 3px 9px;
  border-radius: 999px;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.03em;
}
body.dash-dark .badge-success {
  background: rgba(34,197,94,0.12);
  color: #86efac;
  border-color: rgba(34,197,94,0.3);
}
body.dash-dark .badge-warning {
  background: rgba(217,119,6,0.12);
  color: #fcd34d;
  border-color: rgba(217,119,6,0.3);
}
body.dash-dark .badge-danger {
  background: rgba(220,38,38,0.12);
  color: #fca5a5;
  border-color: rgba(220,38,38,0.3);
}
body.dash-dark .badge-info {
  background: rgba(59,130,246,0.12);
  color: #93c5fd;
  border-color: rgba(59,130,246,0.3);
}
body.dash-dark .badge-neutral {
  background: var(--dd-surface-3);
  color: var(--dd-text-muted);
  border-color: var(--dd-border);
}

/* ---------- Alerts ---------- */
body.dash-dark .alert {
  border-radius: 10px;
  padding: 12px 16px;
  border: 1px solid;
}
body.dash-dark .alert-success {
  background: rgba(34,197,94,0.1);
  border-color: rgba(34,197,94,0.3);
  color: #d1fae5;
}
body.dash-dark .alert-warning {
  background: rgba(217,119,6,0.1);
  border-color: rgba(217,119,6,0.35);
  color: #fef3c7;
}
body.dash-dark .alert-danger {
  background: rgba(220,38,38,0.1);
  border-color: rgba(220,38,38,0.35);
  color: #fecaca;
}
body.dash-dark .alert-info {
  background: rgba(59,130,246,0.1);
  border-color: rgba(59,130,246,0.3);
  color: #bfdbfe;
}

/* ---------- Empty states ---------- */
body.dash-dark .empty-state {
  text-align: center;
  color: var(--dd-text-muted);
}
body.dash-dark .empty-state h3 { color: var(--dd-text); }

/* ---------- Misc ---------- */
body.dash-dark .checkfield label { text-transform: none; letter-spacing: 0; color: var(--dd-text-soft); }
body.dash-dark .row.between { color: inherit; }
body.dash-dark .activity-cell { color: var(--dd-text-muted); }
body.dash-dark .activity-cell .activity-money { color: var(--dd-text); }

/* ============ AUTH SHELL (login + signup pages) ============
   Applies whenever body has landing-dark + the page uses .auth-shell. */
body.landing-dark .auth-shell {
  min-height: calc(100vh - 80px);
  display: flex;
  align-items: center;
  justify-content: center;
  /* No background — inherits the #0a0a0a from body.landing-dark so the auth
     pages flow visually with the rest of the public site (homepage, services,
     legal pages all use the same base). */
  padding: var(--s-10, 40px) var(--s-5, 20px);
}
body.landing-dark .auth-card {
  background: #141414;
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 16px;
  padding: clamp(28px, 4vw, 44px);
  max-width: 440px;
  width: 100%;
  box-shadow: 0 30px 80px -30px rgba(0,0,0,0.5);
}
body.landing-dark .auth-card h1 {
  color: #ffffff;
  font-size: clamp(28px, 4vw, 36px);
  font-weight: 900;
  letter-spacing: -0.02em;
  margin: 0 0 var(--s-2, 8px);
}
body.landing-dark .auth-card .lead {
  color: #94a3b8;
  font-size: 15px;
  margin: 0 0 var(--s-6, 24px);
}
body.landing-dark .auth-card .field { margin-bottom: var(--s-4, 16px); }
body.landing-dark .auth-card label {
  display: block;
  color: #cbd5e1;
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  margin-bottom: 6px;
}
body.landing-dark .auth-card .input,
body.landing-dark .auth-card input[type=text],
body.landing-dark .auth-card input[type=email],
body.landing-dark .auth-card input[type=password] {
  width: 100%;
  background: #0a0a0a;
  border: 1px solid rgba(255,255,255,0.12);
  color: #f8fafc;
  padding: 12px 14px;
  border-radius: 10px;
  font-size: 15px;
  box-sizing: border-box;
  transition: border-color 0.15s, box-shadow 0.15s;
}
body.landing-dark .auth-card input:focus {
  outline: none;
  border-color: #ec6b1c;
  box-shadow: 0 0 0 3px rgba(236,107,28,0.18);
}
body.landing-dark .auth-card .help {
  color: #64748b;
  font-size: 12px;
}
body.landing-dark .auth-card .btn-primary {
  background: #ec6b1c !important;
  color: #0f172a !important;
  border: 0 !important;
  border-radius: 999px;
  padding: 14px 28px;
  font-weight: 800;
  font-size: 16px;
  width: 100%;
  box-shadow: 0 8px 22px -8px rgba(236,107,28,0.6);
  cursor: pointer;
  transition: filter 0.15s, transform 0.15s;
}
body.landing-dark .auth-card .btn-primary:hover { filter: brightness(1.1); transform: translateY(-1px); }
body.landing-dark .auth-card .alert-danger {
  background: rgba(220,38,38,0.12);
  border: 1px solid rgba(220,38,38,0.4);
  color: #fecaca;
  padding: 10px 14px;
  border-radius: 10px;
  margin-bottom: var(--s-4, 16px);
  font-size: 14px;
}
body.landing-dark .auth-card .alert-info {
  background: rgba(59,130,246,0.12);
  border: 1px solid rgba(59,130,246,0.35);
  color: #bfdbfe;
  padding: 10px 14px;
  border-radius: 10px;
  margin-bottom: var(--s-4, 16px);
  font-size: 14px;
}
body.landing-dark .auth-card .muted { color: #64748b; }
body.landing-dark .auth-card a { color: #ec6b1c; }
body.landing-dark .auth-card a:hover { filter: brightness(1.15); }

/* Help page TOC sidebar */
body.dash-dark .help-toc a { color: var(--dd-text-muted); }
body.dash-dark .help-toc a:hover { background: rgba(255,255,255,0.04); color: var(--dd-text); }
body.dash-dark .help-toc .group-label { color: var(--dd-text-faint); }
body.dash-dark .help-content h2 {
  border-bottom-color: var(--dd-border);
}
body.dash-dark .help-content code { background: var(--dd-surface-2); }
body.dash-dark .help-content .callout {
  background: var(--dd-surface);
  border-left-color: var(--dd-accent);
}
body.dash-dark .help-content .callout.warn { background: rgba(217,119,6,0.06); border-left-color: #d97706; }
body.dash-dark .help-content table.steps td { border-bottom-color: var(--dd-border); color: var(--dd-text-soft); }
body.dash-dark .help-content table.steps td:first-child { color: var(--dd-accent); }
