/* ============================================================
   THEME.CSS — Refonte UI/UX « premium SaaS »
   Couche d'habillage chargée APRÈS crm.css / planer.css / etc.
   N'altère aucune structure : ne fait que retravailler les
   couleurs, la typo, le fond animé, le verre dépoli, le dark
   mode, les micro-interactions et les états de boutons.
   ============================================================ */

/* ---- Police SaaS ---- */
@import url('https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@400;500;600;700;800&display=swap');

/* ============================================================
   TOKENS
   ============================================================ */
:root {
  --primary:    #6366f1;
  --primary-dk: #4f46e5;
  --primary-lt: #eef2ff;
  --accent:     #06b6d4;
  --grad:       linear-gradient(135deg, #6366f1, #8b5cf6);
  --bg:         #f4f4fb;
  --card:       #ffffff;
  --border:     #ecebf3;
  --text:       #16152b;
  --muted:      #6c7086;
  --glass:      rgba(255, 255, 255, .72);
  --glass-top:  rgba(255, 255, 255, .62);
  --glass-brd:  rgba(255, 255, 255, .6);
  --score-track:#ecebf3;
  --radius:     14px;
  --radius-sm:  10px;
  --shadow:     0 1px 2px rgba(16,15,40,.05), 0 14px 34px -16px rgba(16,15,40,.18);
  --shadow-lg:  0 24px 60px -20px rgba(16,15,40,.28);
  --aur-1: #818cf8; --aur-2: #c4b5fd; --aur-3: #7dd3fc; --aur-op: .30;
}

/* ---- Dark mode ---- */
html[data-theme="dark"] {
  color-scheme: dark;
  --primary:    #818cf8;
  --primary-dk: #6366f1;
  --primary-lt: rgba(129,140,248,.16);
  --accent:     #22d3ee;
  --grad:       linear-gradient(135deg, #818cf8, #a78bfa);
  --bg:         #0b0a14;
  --card:       #17152a;
  --border:     rgba(255,255,255,.09);
  --text:       #f2f1fa;
  --muted:      #9a97b5;
  --glass:      rgba(23,21,42,.62);
  --glass-top:  rgba(12,11,22,.55);
  --glass-brd:  rgba(255,255,255,.09);
  --score-track:#241f3d;
  --shadow:     0 1px 2px rgba(0,0,0,.4), 0 20px 48px -18px rgba(0,0,0,.7);
  --shadow-lg:  0 24px 60px -20px rgba(0,0,0,.75);
  --aur-1: #6366f1; --aur-2: #a78bfa; --aur-3: #22d3ee; --aur-op: .42;
}

/* ============================================================
   BASE + TYPO
   ============================================================ */
body {
  font-family: 'Plus Jakarta Sans', system-ui, -apple-system, sans-serif !important;
  background: var(--bg);
  color: var(--text);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
.btn, input, select, textarea, button {
  font-family: 'Plus Jakarta Sans', system-ui, sans-serif;
}
h1, h2, h3, .stat-value, .sidebar-logo {
  letter-spacing: -0.4px;
}

/* ============================================================
   FOND VIVANT (aurore) + GRAIN — fixés derrière toute l'app
   ============================================================ */
body::before {
  content: "";
  position: fixed;
  inset: -10%;
  z-index: 0;
  pointer-events: none;
  background:
    radial-gradient(38% 40% at 14% 8%,  var(--aur-1) 0%, transparent 60%),
    radial-gradient(42% 44% at 88% 92%, var(--aur-2) 0%, transparent 60%),
    radial-gradient(36% 38% at 70% 30%, var(--aur-3) 0%, transparent 62%);
  opacity: var(--aur-op);
  filter: blur(72px) saturate(1.05);
  animation: aurora-drift 26s ease-in-out infinite;
}
body::after {
  content: "";
  position: fixed;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  opacity: .05;
  mix-blend-mode: overlay;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.8' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}
@keyframes aurora-drift {
  0%   { transform: translate3d(0,0,0) scale(1); }
  33%  { transform: translate3d(3%,-2%,0) scale(1.08); }
  66%  { transform: translate3d(-2%,2%,0) scale(0.96); }
  100% { transform: translate3d(0,0,0) scale(1); }
}
/* Le contenu passe au-dessus du fond */
.layout { position: relative; z-index: 1; }
.content { background: transparent !important; }

/* ============================================================
   SIDEBAR
   ============================================================ */
.sidebar {
  background:
    radial-gradient(120% 60% at 0% 0%, rgba(129,140,248,.35), transparent 60%),
    linear-gradient(185deg, #1f1b47 0%, #17143a 55%, #120f2e 100%) !important;
  border-right: 1px solid rgba(255,255,255,.06);
  box-shadow: 4px 0 40px -20px rgba(0,0,0,.5);
}
.sidebar-logo { border-bottom-color: rgba(255,255,255,.08); }
.sidebar-logo span { color: #a5b4fc !important; }
.nav-item {
  border-radius: var(--radius-sm);
  margin: 3px 10px;
  transition: background .18s ease, color .18s ease, transform .12s ease;
}
.nav-item:hover  { transform: translateX(2px); }
.nav-item.active {
  background: rgba(129,140,248,.18) !important;
  border-left-color: transparent !important;
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.08);
  position: relative;
}
.nav-item.active::before {
  content: "";
  position: absolute; left: -10px; top: 50%; transform: translateY(-50%);
  width: 3px; height: 20px; border-radius: 0 3px 3px 0;
  background: #a5b4fc; box-shadow: 0 0 10px #818cf8;
}

/* ============================================================
   TOPBAR — verre dépoli
   ============================================================ */
.topbar {
  background: var(--glass-top) !important;
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  border-bottom: 1px solid var(--border) !important;
  box-shadow: 0 1px 0 var(--border);
}
.topbar h1 { color: var(--text) !important; font-weight: 800; }

/* ============================================================
   STAT CARDS + CARDS — verre dépoli, apparition en cascade
   ============================================================ */
.stat-card,
.table-wrap,
.planner-card,
.import-zone,
.toolbar {
  background: var(--glass) !important;
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  border: 1px solid var(--border) !important;
  box-shadow: var(--shadow) !important;
}
.stat-card { border-radius: var(--radius); transition: transform .16s ease, box-shadow .16s ease; }
.stat-card:hover { transform: translateY(-2px); box-shadow: var(--shadow-lg) !important; }
.stat-card, .stat-value { color: var(--text); }
.stat-label { color: var(--muted) !important; text-transform: uppercase; letter-spacing: .05em; font-weight: 700; font-size: .68rem; }

.stats .stat-card { animation: fade-up .5s ease both; }
.stats .stat-card:nth-child(1){ animation-delay:.00s; }
.stats .stat-card:nth-child(2){ animation-delay:.06s; }
.stats .stat-card:nth-child(3){ animation-delay:.12s; }
.stats .stat-card:nth-child(4){ animation-delay:.18s; }
@keyframes fade-up { from { opacity:0; transform: translateY(12px); } to { opacity:1; transform:none; } }

/* Couleurs des valeurs de stats */
.stat-value.blue   { color: var(--primary) !important; }
.stat-value.green  { color: #22c55e !important; }
.stat-value.orange { color: #f59e0b !important; }
.stat-value.gray   { color: var(--muted) !important; }

/* ============================================================
   TABLE
   ============================================================ */
.table-wrap { border-radius: var(--radius); overflow: hidden; }
#crmTable thead th {
  background: color-mix(in srgb, var(--card) 70%, transparent) !important;
  color: var(--muted) !important;
  text-transform: uppercase;
  letter-spacing: .05em;
  font-size: .68rem;
  font-weight: 700;
  border-bottom: 1px solid var(--border) !important;
}
#crmTable tbody td { border-bottom: 1px solid var(--border) !important; color: var(--text); }
#crmTable tbody tr { transition: background .14s ease; }
#crmTable tbody tr:hover { background: color-mix(in srgb, var(--primary) 7%, transparent) !important; }

/* Colonne score */
.score-wrap { display: flex; align-items: center; gap: 8px; }
.score-track { width: 52px; height: 6px; border-radius: 99px; background: var(--score-track); overflow: hidden; flex-shrink: 0; }
.score-fill  { height: 100%; border-radius: 99px; transition: width .5s cubic-bezier(.4,0,.2,1); }
.score-num   { font-size: 12px; font-weight: 800; }

/* ============================================================
   BADGES — statut CRM (Prospect · Lead · Inactif)
   ============================================================ */
.badge { border-radius: 99px; font-weight: 700; letter-spacing: .01em; }
.badge-orange { background: #fef3c7; color: #b45309; }         /* Prospect */
.badge-blue   { background: var(--primary-lt); color: var(--primary-dk); } /* Lead */
.badge-gray   { background: #eef1f6; color: #64748b; }         /* Inactif */
.badge-green  { background: #dcfce7; color: #15803d; }
html[data-theme="dark"] .badge-orange { background: rgba(245,158,11,.15); color: #fbbf24; }
html[data-theme="dark"] .badge-blue   { background: rgba(129,140,248,.18); color: #c7d2fe; }
html[data-theme="dark"] .badge-gray   { background: rgba(255,255,255,.07); color: #9a97b5; }
html[data-theme="dark"] .badge-green  { background: rgba(34,197,94,.15); color: #4ade80; }

/* ============================================================
   BOUTONS — micro-interactions
   ============================================================ */
.btn {
  border-radius: var(--radius-sm);
  font-weight: 700;
  transition: transform .12s ease, box-shadow .16s ease, background .16s ease, color .16s ease, filter .16s ease;
}
.btn:active { transform: scale(.97); }
.btn-primary {
  background: var(--grad) !important;
  border: none !important;
  box-shadow: 0 6px 16px -6px var(--primary);
}
.btn-primary:hover { filter: brightness(1.06); transform: translateY(-1px); box-shadow: 0 10px 22px -6px var(--primary); }
.btn-outline {
  background: var(--glass) !important;
  border: 1px solid var(--border) !important;
  color: var(--text) !important;
  backdrop-filter: blur(8px);
}
.btn-outline:hover { border-color: var(--primary) !important; color: var(--primary) !important; }
.btn-sm img { border-radius: 3px; }

/* — Bouton Sirène (alimentation) — */
html[data-theme="dark"] .btn-sirene { background: rgba(129,140,248,.16); color: #c7d2fe; }

/* ============================================================
   BOUTONS À ÉTAT — changent UNIQUEMENT de couleur (largeur figée)
   ============================================================ */
/* Pages Jaunes : gris → jaune quand validé, même gabarit */
.btn-pj-toggle {
  min-width: 58px;
  justify-content: center;
  background: var(--score-track);
  color: var(--muted);
  border: 1px solid var(--border);
  transition: background .18s ease, color .18s ease, border-color .18s ease;
}
.btn-pj-toggle:hover { border-color: #FFCC00; }
.btn-pj-toggle.btn-pj-active {
  background: #FFCC00 !important;
  color: #1a1a1a !important;
  border-color: #FFCC00 !important;
}

/* Bot Google : largeur figée, seule la couleur change selon l'état */
button[data-gbot-id] {
  min-width: 34px;
  justify-content: center;
  font-weight: 800;
  transition: background .18s ease, color .18s ease, border-color .18s ease;
}

/* ============================================================
   TOOLBAR / INPUTS
   ============================================================ */
.toolbar { border-radius: var(--radius); }
#searchInput, .toolbar select, .modal input, .modal select, .modal textarea {
  background: color-mix(in srgb, var(--card) 60%, transparent);
  border: 1px solid var(--border);
  color: var(--text);
  border-radius: var(--radius-sm);
  transition: border-color .16s ease, box-shadow .16s ease;
}
#searchInput:focus, .toolbar select:focus, .modal input:focus, .modal select:focus, .modal textarea:focus {
  border-color: var(--primary);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--primary) 18%, transparent);
  outline: none;
}

/* ============================================================
   MODAL — verre + dark
   ============================================================ */
.modal { background: var(--card) !important; color: var(--text); border: 1px solid var(--border); box-shadow: var(--shadow-lg) !important; border-radius: 18px; }
.modal-overlay { backdrop-filter: blur(3px); }
.modal h2, .modal .section-title { color: var(--text); }
.modal label { color: var(--muted); }
html[data-theme="dark"] #f-secteur { background: rgba(255,255,255,.04) !important; color: var(--muted) !important; }

/* ============================================================
   PAGINATION
   ============================================================ */
.page-btn { border-radius: var(--radius-sm); border: 1px solid var(--border); background: var(--glass); color: var(--text); transition: all .14s ease; }
.page-btn:hover:not(:disabled) { border-color: var(--primary); color: var(--primary); }
.page-btn.active { background: var(--grad); color: #fff; border-color: transparent; }

/* ============================================================
   BASCULE DE THÈME (clair / sombre)
   ============================================================ */
.theme-toggle {
  display: flex;
  background: rgba(255,255,255,.08);
  border-radius: var(--radius-sm);
  padding: 3px;
  margin: 0 14px 12px;
  gap: 3px;
}
.theme-toggle button {
  flex: 1;
  display: flex; align-items: center; justify-content: center; gap: 6px;
  padding: 7px 6px;
  border: none;
  background: transparent;
  color: rgba(255,255,255,.55);
  font-size: .78rem; font-weight: 700;
  border-radius: 7px;
  cursor: pointer;
  transition: background .16s ease, color .16s ease;
}
.theme-toggle button svg { width: 14px; height: 14px; }
.theme-toggle button.active { background: rgba(255,255,255,.16); color: #fff; }

/* ============================================================
   SKELETON (utilitaire de chargement)
   ============================================================ */
.sk {
  background: linear-gradient(90deg, var(--score-track) 25%, color-mix(in srgb, var(--muted) 22%, transparent) 37%, var(--score-track) 63%);
  background-size: 200% 100%;
  animation: sk-shimmer 1.4s linear infinite;
  border-radius: 6px;
}
@keyframes sk-shimmer { 0% { background-position: 200% 0; } 100% { background-position: -200% 0; } }

/* ============================================================
   DARK — surfaces secondaires (planner / scanner / relance)
   ============================================================ */
html[data-theme="dark"] .planner-card,
html[data-theme="dark"] .import-zone { color: var(--text); }
html[data-theme="dark"] .stat-value.green  { color: #4ade80 !important; }
html[data-theme="dark"] .stat-value.orange { color: #fbbf24 !important; }

/* ============================================================
   ÉCRANS SECONDAIRES — polish commun
   ============================================================ */
.relance-stat-card, .relance-toolbar, .relance-table-wrap,
.relance-calendar-wrap, .relance-agenda, .relance-view-tabs,
.scanner-preview-grid, .scanner-results-list {
  background: var(--glass) !important;
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  border: 1px solid var(--border) !important;
  box-shadow: var(--shadow) !important;
}
.relance-agenda-societe, .relance-cal-count { color: var(--primary) !important; }

/* Barres de progression → dégradé de marque */
.kpi-global-bar-fill, .scanner-progress-bar-fill { background: var(--grad) !important; }

/* ============================================================
   DARK MODE — exceptions codées en dur (planner / scanner / relance)
   ============================================================ */
html[data-theme="dark"] {

  /* — Champs de saisie clairs → surface sombre — */
  --field-dark: rgba(255,255,255,.05);
}
html[data-theme="dark"] .relance-form-group input,
html[data-theme="dark"] .relance-form-group select,
html[data-theme="dark"] .relance-form-group textarea,
html[data-theme="dark"] .kpi-input,
html[data-theme="dark"] .kpi-target-input,
html[data-theme="dark"] .kpi-name-input,
html[data-theme="dark"] .outlook-input,
html[data-theme="dark"] .scanner-field-input,
html[data-theme="dark"] .planner-card input,
html[data-theme="dark"] .planner-card select {
  background: rgba(255,255,255,.05) !important;
  color: var(--text) !important;
  border-color: var(--border) !important;
}
html[data-theme="dark"] .scanner-field-input[readonly],
html[data-theme="dark"] #f-secteur { background: rgba(255,255,255,.03) !important; }

/* Hovers clairs (#f8faff / #f8fafc) → tint indigo discret */
html[data-theme="dark"] .schedule-slot:hover,
html[data-theme="dark"] .relance-agenda-item:hover,
html[data-theme="dark"] .scanner-history-row:hover,
html[data-theme="dark"] .relance-cal-day:hover {
  background: rgba(129,140,248,.10) !important;
}
html[data-theme="dark"] .relance-agenda-item { border-bottom-color: var(--border) !important; }

/* Modales secondaires */
html[data-theme="dark"] .relance-modal { background: var(--card) !important; color: var(--text); }
html[data-theme="dark"] .relance-modal-overlay { background: rgba(0,0,0,.6); }

/* Bannières / cartes d'état pastel → tints translucides */
html[data-theme="dark"] .kpi-ahead,
html[data-theme="dark"] .kpi-notif-ahead,
html[data-theme="dark"] .scanner-conf-high,
html[data-theme="dark"] .scanner-api-configured,
html[data-theme="dark"] .scanner-import-ok,
html[data-theme="dark"] .scanner-imported-badge,
html[data-theme="dark"] .outlook-connected { background: rgba(34,197,94,.15) !important; color: #4ade80 !important; }

html[data-theme="dark"] .kpi-ontrack { background: rgba(129,140,248,.16) !important; color: #c7d2fe !important; }

html[data-theme="dark"] .kpi-behind,
html[data-theme="dark"] .kpi-notif-behind,
html[data-theme="dark"] .scanner-conf-mid,
html[data-theme="dark"] .scanner-api-not-configured,
html[data-theme="dark"] .scanner-import-warn { background: rgba(245,158,11,.15) !important; color: #fbbf24 !important; }

html[data-theme="dark"] .kpi-danger,
html[data-theme="dark"] .kpi-notif-danger,
html[data-theme="dark"] .scanner-conf-low { background: rgba(239,68,68,.15) !important; color: #f87171 !important; }

html[data-theme="dark"] .outlook-disconnected,
html[data-theme="dark"] .scanner-history-badge,
html[data-theme="dark"] .scanner-thumb,
html[data-theme="dark"] .scanner-preview-item { background: rgba(255,255,255,.05) !important; color: var(--muted) !important; }

/* Zone de dépôt scanner */
html[data-theme="dark"] .scanner-drop-zone { background: rgba(129,140,248,.08) !important; }
html[data-theme="dark"] .scanner-drop-zone:hover,
html[data-theme="dark"] .scanner-drop-zone.scanner-drop-active { background: rgba(129,140,248,.16) !important; }

/* Bannière IA planner + événements Outlook */
html[data-theme="dark"] .planner-ai-banner { background: linear-gradient(135deg, rgba(129,140,248,.14), rgba(34,211,238,.10)) !important; border-color: rgba(129,140,248,.25) !important; }
html[data-theme="dark"] .outlook-event-item { background: rgba(129,140,248,.12) !important; }
html[data-theme="dark"] .scanner-tag { background: rgba(129,140,248,.16) !important; color: #c7d2fe !important; }

/* Créneaux de planning teintés */
html[data-theme="dark"] .slot-type-pause   { background: rgba(34,197,94,.08) !important; }
html[data-theme="dark"] .slot-type-admin    { background: rgba(255,255,255,.03) !important; }
html[data-theme="dark"] .slot-type-rdv      { background: rgba(245,158,11,.08) !important; }
html[data-theme="dark"] .slot-type-focus    { background: rgba(236,72,153,.08) !important; }
html[data-theme="dark"] .slot-type-outlook  { background: rgba(14,165,233,.08) !important; }
html[data-theme="dark"] .slot-check         { background: rgba(255,255,255,.05) !important; }
html[data-theme="dark"] .kpi-badge          { color: inherit; }

/* Badges relance en sombre */
html[data-theme="dark"] .badge-relance-urgent    { background: rgba(239,68,68,.16); color: #fca5a5; }
html[data-theme="dark"] .badge-relance-today     { background: rgba(245,158,11,.16); color: #fbbf24; }
html[data-theme="dark"] .badge-relance-soon      { background: rgba(129,140,248,.16); color: #c7d2fe; }
html[data-theme="dark"] .badge-relance-scheduled,
html[data-theme="dark"] .badge-relance-postponed { background: rgba(255,255,255,.07); color: #9a97b5; }
html[data-theme="dark"] .badge-relance-done      { background: rgba(34,197,94,.15); color: #4ade80; }
html[data-theme="dark"] .badge-relance-converted { background: rgba(167,139,250,.18); color: #c4b5fd; }
html[data-theme="dark"] .relance-quick-banner    { background: linear-gradient(135deg, rgba(245,158,11,.12), rgba(129,140,248,.10)) !important; border-color: rgba(251,191,36,.3) !important; }
html[data-theme="dark"] .relance-quick-banner-text { color: #fcd34d !important; }
html[data-theme="dark"] .relance-quick-banner-text strong { color: #fde68a !important; }

/* — Agent Téléphone : panneaux inline clairs neutralisés en sombre — */
html[data-theme="dark"] #view-phone-agent [style*="#f8fafc"] { background: rgba(255,255,255,.04) !important; }
html[data-theme="dark"] #view-phone-agent [style*="#f1f5f9"] { background: rgba(255,255,255,.06) !important; }
html[data-theme="dark"] #view-phone-agent [style*="#faf5ff"] { background: rgba(167,139,250,.16) !important; color: #c4b5fd !important; }

/* ============================================================
   ACCESSIBILITÉ — respect du « mouvement réduit »
   ============================================================ */
@media (prefers-reduced-motion: reduce) {
  body::before { animation: none !important; }
  * { animation-duration: .001ms !important; animation-iteration-count: 1 !important; }
}

/* ============================================================
   LIGNE CONTACT — mise en page maquette (avatar + société/gérant)
   ============================================================ */
#crmTable { table-layout: fixed; width: 100%; }
#crmTable tbody td { padding: 11px 14px; vertical-align: middle; }

.row-main { display: flex; align-items: center; gap: 12px; min-width: 0; }
.avatar {
  width: 38px; height: 38px; border-radius: 10px; flex-shrink: 0;
  display: flex; align-items: center; justify-content: center;
  color: #fff; font-weight: 800; font-size: 13px; letter-spacing: .02em;
  box-shadow: 0 2px 6px rgba(16,15,40,.20); user-select: none;
}
.row-titles { min-width: 0; }
.row-title {
  font-weight: 700; color: var(--text); font-size: 14px;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.row-sub {
  font-size: 12px; color: var(--muted); margin-top: 1px;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.cell-status .forme-sub {
  font-size: 11px; color: var(--muted); margin-top: 4px;
  text-transform: uppercase; letter-spacing: .03em;
}
#crmTable .actions-cell {
  display: flex; flex-wrap: wrap; gap: 4px; align-items: center;
  white-space: normal;
}
/* Carte mobile : avatar plus compact */
.contact-card__head .avatar { width: 34px; height: 34px; border-radius: 9px; font-size: 12px; }

/* ============================================================
   EN-TÊTE — fil d'ariane + bloc titre Contacts (style maquette)
   ============================================================ */
.crumb { display: flex; align-items: center; gap: 8px; font-weight: 600; }
.crumb-root { color: var(--muted); font-size: .95rem; }
.crumb-sep  { color: var(--muted); opacity: .6; }
.crumb-leaf { color: var(--text); font-size: .95rem; font-weight: 800; }

.contacts-hero {
  display: flex; align-items: flex-end; justify-content: space-between;
  gap: 16px; margin: 2px 0 18px; flex-wrap: wrap;
}
.hero-title {
  font-size: 1.9rem; font-weight: 800; color: var(--text);
  display: flex; align-items: center; gap: 12px; line-height: 1.1;
}
.hero-count {
  font-size: .95rem; font-weight: 800; color: var(--primary-dk);
  background: var(--primary-lt); border-radius: 99px; padding: 4px 12px;
}
html[data-theme="dark"] .hero-count { color: #c7d2fe; }
.hero-sub { margin-top: 6px; font-size: .95rem; color: var(--muted); font-weight: 500; }
.hero-relance { color: #b45309; font-weight: 700; }
html[data-theme="dark"] .hero-relance { color: #fbbf24; }

.hero-view {
  display: flex; gap: 4px; background: var(--card); border: 1px solid var(--border);
  border-radius: 12px; padding: 4px; box-shadow: var(--shadow);
}
.hero-view-tab {
  font-size: .85rem; font-weight: 700; color: var(--muted);
  padding: 7px 14px; border-radius: 9px; cursor: default;
}
.hero-view-tab.active { background: var(--primary-lt); color: var(--primary-dk); }
html[data-theme="dark"] .hero-view-tab.active { color: #c7d2fe; }

/* Cartes stats : ligne label + pastille icône, et puce contextuelle */
.stat-top { display: flex; align-items: center; justify-content: space-between; gap: 8px; margin-bottom: 6px; }
.stat-ic {
  width: 30px; height: 30px; border-radius: 9px; flex-shrink: 0;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 15px; background: var(--primary-lt); color: var(--primary-dk);
}
.ic-leads     { background: rgba(34,197,94,.14);  }
.ic-prospects { background: rgba(245,158,11,.16); }
.ic-inactifs  { background: rgba(100,116,139,.16); color: var(--muted); }
.stat-chip {
  margin-top: 10px; display: inline-block; font-size: .72rem; font-weight: 700;
  padding: 3px 10px; border-radius: 99px; background: rgba(245,158,11,.16); color: #b45309;
}
html[data-theme="dark"] .stat-chip { color: #fbbf24; }
