/* ============================================================
   FEU DE CAMP NUMÉRIQUE — Thème V80 "Night Cyan"
   Palette : bleu nuit + cyan néon + Gardien flamme bleue
   Charge après style.css → surcharge les variables existantes
   ============================================================ */

:root {
  /* ====== NOUVELLE PALETTE NIGHT-CYAN ====== */
  --night-deep:   #050b1c;
  --night-mid:    #0a1428;
  --night-soft:   #0f1d33;
  --night-card:   #131f3a;
  --night-edge:   #1c2c4a;

  --cyan-neon:    #3DA9FC;
  --cyan-soft:    #5BC0EB;
  --cyan-pale:    #A6D8F5;
  --cyan-deep:    #1B6FB8;
  --cyan-glow:    rgba(61, 169, 252, 0.35);
  --cyan-glow-strong: rgba(61, 169, 252, 0.6);

  --violet-accent: #7B68EE;
  --magenta-accent: #C77DFF;

  --ivory:        #FFFFFF;
  --ivory-soft:   #EAF1FB;
  --ivory-dim:    #C9D6E8;

  --success:      #4ADE80;
  --warning:      #FBBF24;
  --danger:       #F87171;
  --info:         #60A5FA;

  /* ====== OVERRIDE DES VARIABLES style.css ====== */
  --black:        var(--night-deep);
  --ink:          var(--ivory);
  --ink-soft:     var(--ivory-soft);

  --gold:         var(--cyan-neon);
  --gold-deep:    var(--cyan-deep);
  --gold-soft:    var(--cyan-soft);
  --gold-pale:    var(--cyan-pale);

  --navy-deep:    var(--night-deep);
  --navy-mid:     var(--night-mid);
  --navy-soft:    var(--night-soft);
  --navy-pale:    var(--cyan-pale);

  --orange:       var(--cyan-neon);
  --orange-soft:  var(--cyan-soft);
  --orange-pale:  var(--cyan-pale);

  --cream:        var(--night-mid);
  --cream-warm:   var(--night-soft);

  --text:         var(--ivory);
  --text-soft:    var(--ivory-soft);

  --pink:         var(--violet-accent);
  --purple:       var(--magenta-accent);

  --line:         var(--night-edge);
  --line-soft:    var(--night-soft);

  /* ====== OMBRES & GLOW ====== */
  --shadow:       0 4px 18px rgba(0, 0, 0, 0.35);
  --shadow-lg:    0 14px 44px rgba(0, 0, 0, 0.55);
  --shadow-glow:  0 0 32px var(--cyan-glow);
  --shadow-glow-strong: 0 0 48px var(--cyan-glow-strong);
  --glow-border:  0 0 0 1px rgba(61,169,252,0.25), 0 0 22px rgba(61,169,252,0.18);

  /* ====== GARDIEN DU FEU (couleurs éditables admin) ====== */
  --gardien-primary:   var(--cyan-neon);
  --gardien-secondary: var(--cyan-soft);
  --gardien-halo:      var(--cyan-glow);
  --gardien-intensity: 1;
  --gardien-eyes:      #FFFFFF;

  /* ====== TYPO ====== */
  --font-display: 'Inter', -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
  --font-body:    'Inter', -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
}

/* ============================================================
   BODY GLOBAL
============================================================ */
html, body {
  background: var(--night-deep);
  color: var(--ivory);
}

body {
  background:
    radial-gradient(ellipse at top, rgba(61,169,252,0.10) 0%, transparent 50%),
    radial-gradient(ellipse at bottom right, rgba(123,104,238,0.08) 0%, transparent 60%),
    var(--night-deep);
  min-height: 100vh;
  background-attachment: fixed;
}

h1, h2, h3, h4, h5, h6,
.page-title, .display-serif {
  color: var(--ivory);
  font-family: var(--font-display);
  letter-spacing: -0.01em;
}
h1 { font-weight: 700; }
h2 { font-weight: 600; }
h3, h4 { font-weight: 600; }

a { color: var(--cyan-soft); transition: color .18s, text-shadow .18s; }
a:hover { color: var(--cyan-neon); text-shadow: 0 0 8px var(--cyan-glow); }

/* ============================================================
   TOPBAR / HEADER
============================================================ */
.topbar {
  background: linear-gradient(180deg, rgba(10,20,40,0.95) 0%, rgba(5,11,28,0.92) 100%);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  border-bottom: 1px solid var(--night-edge);
  box-shadow: 0 6px 24px rgba(0,0,0,0.4);
  color: var(--ivory);
}

.brand { color: var(--ivory); }
.brand:hover { color: var(--cyan-neon); }

.brand-mark {
  background: radial-gradient(circle at 30% 30%, var(--cyan-soft) 0%, var(--cyan-neon) 50%, var(--cyan-deep) 100%);
  box-shadow:
    0 0 16px var(--cyan-glow-strong),
    inset 0 0 8px rgba(255,255,255,0.3);
  color: #fff;
}

.nav-main a {
  color: var(--ivory-soft);
  transition: color .2s, text-shadow .2s;
}
.nav-main a:hover,
.nav-main a.active {
  color: var(--cyan-neon);
  text-shadow: 0 0 12px var(--cyan-glow);
}

/* ============================================================
   CARDS GLASSMORPHISM
============================================================ */
.card,
.panel,
.box,
.mc-feature,
.mc-dash,
.admin-card,
.section-card {
  background: linear-gradient(145deg, rgba(19,31,58,0.85) 0%, rgba(15,29,51,0.75) 100%);
  border: 1px solid rgba(61,169,252,0.15);
  border-radius: 16px;
  box-shadow:
    0 4px 24px rgba(0,0,0,0.4),
    inset 0 1px 0 rgba(255,255,255,0.04);
  color: var(--ivory);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  transition: transform .25s, box-shadow .25s, border-color .25s;
}

.card:hover,
.panel:hover,
.admin-card:hover {
  border-color: rgba(61,169,252,0.35);
  box-shadow:
    0 8px 32px rgba(0,0,0,0.5),
    0 0 24px var(--cyan-glow),
    inset 0 1px 0 rgba(255,255,255,0.06);
  transform: translateY(-2px);
}

/* ============================================================
   BOUTONS
============================================================ */
.btn,
button.primary,
.btn-primary,
input[type="submit"],
button[type="submit"]:not(.btn-ghost):not(.btn-secondary) {
  background: linear-gradient(135deg, var(--cyan-neon) 0%, var(--cyan-deep) 100%);
  color: #fff;
  border: 1px solid rgba(255,255,255,0.18);
  border-radius: 12px;
  padding: 10px 22px;
  font-weight: 600;
  font-size: 14px;
  letter-spacing: 0.02em;
  cursor: pointer;
  box-shadow:
    0 4px 16px rgba(27,111,184,0.4),
    inset 0 1px 0 rgba(255,255,255,0.2);
  transition: transform .15s, box-shadow .2s, filter .2s;
}

.btn:hover,
button.primary:hover,
.btn-primary:hover,
input[type="submit"]:hover,
button[type="submit"]:hover {
  filter: brightness(1.12);
  box-shadow:
    0 6px 24px rgba(27,111,184,0.55),
    0 0 24px var(--cyan-glow),
    inset 0 1px 0 rgba(255,255,255,0.25);
  transform: translateY(-1px);
}

.btn:active,
button.primary:active { transform: translateY(0); }

.btn-ghost,
.btn-secondary {
  background: rgba(61,169,252,0.08);
  color: var(--cyan-soft);
  border: 1px solid rgba(61,169,252,0.3);
  border-radius: 12px;
  padding: 9px 20px;
  font-weight: 500;
  transition: all .2s;
}
.btn-ghost:hover,
.btn-secondary:hover {
  background: rgba(61,169,252,0.15);
  border-color: var(--cyan-neon);
  color: var(--cyan-neon);
}

.btn-danger {
  background: linear-gradient(135deg, #EF4444 0%, #B91C1C 100%);
  color: #fff;
}
.btn-success {
  background: linear-gradient(135deg, #22C55E 0%, #15803D 100%);
  color: #fff;
}

/* ============================================================
   INPUTS / FORMS
============================================================ */
input[type="text"],
input[type="email"],
input[type="password"],
input[type="number"],
input[type="search"],
input[type="url"],
input[type="tel"],
input[type="date"],
input[type="time"],
textarea,
select {
  /* FIX visibilité : fond opaque (anti-conflit thème navigateur/OS) */
  background: #0a1428 !important;
  color: #FAF7F0 !important;
  -webkit-text-fill-color: #FAF7F0 !important;
  color-scheme: dark;
  border: 1px solid var(--night-edge);
  border-radius: 10px;
  padding: 10px 14px;
  font-family: var(--font-body);
  font-size: 14px;
  transition: border-color .2s, box-shadow .2s;
}

input:focus,
textarea:focus,
select:focus {
  outline: none;
  border-color: var(--cyan-neon);
  box-shadow: 0 0 0 3px rgba(61,169,252,0.15), 0 0 18px var(--cyan-glow);
  background: #0f1d33 !important;
  color: #FFFFFF !important;
  -webkit-text-fill-color: #FFFFFF !important;
}

input::placeholder,
textarea::placeholder { color: rgba(250,247,240,0.50) !important; opacity: 1; }

/* Autofill Chrome (fond bleu/jaune par défaut + texte invisible) */
input:-webkit-autofill,
textarea:-webkit-autofill,
select:-webkit-autofill {
  -webkit-box-shadow: 0 0 0 1000px #0a1428 inset !important;
  -webkit-text-fill-color: #FAF7F0 !important;
  caret-color: #FAF7F0;
  transition: background-color 5000s ease-in-out 0s;
}

label { color: var(--ivory-soft); font-weight: 500; font-size: 13px; }

/* ============================================================
   TABLES
============================================================ */
table {
  background: rgba(15,29,51,0.5);
  color: var(--ivory);
  border-radius: 14px;
  overflow: hidden;
  border-collapse: separate;
  border-spacing: 0;
}
th {
  background: rgba(27,111,184,0.15);
  color: var(--cyan-soft);
  padding: 12px 16px;
  text-align: left;
  font-weight: 600;
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  border-bottom: 1px solid var(--night-edge);
}
td {
  padding: 12px 16px;
  border-bottom: 1px solid var(--night-edge);
  color: var(--ivory);
}
tr:hover td { background: rgba(61,169,252,0.05); }

/* ============================================================
   BADGES / TAGS / PILLS
============================================================ */
.badge, .tag, .pill {
  display: inline-block;
  padding: 4px 12px;
  border-radius: 999px;
  font-size: 12px;
  font-weight: 600;
  background: rgba(61,169,252,0.15);
  color: var(--cyan-soft);
  border: 1px solid rgba(61,169,252,0.3);
}
.badge-success { background: rgba(74,222,128,0.15); color: var(--success); border-color: rgba(74,222,128,0.3); }
.badge-warning { background: rgba(251,191,36,0.15); color: var(--warning); border-color: rgba(251,191,36,0.3); }
.badge-danger  { background: rgba(248,113,113,0.15); color: var(--danger);  border-color: rgba(248,113,113,0.3); }

/* ============================================================
   SIDEBAR ADMIN
============================================================ */
.a-sidebar,
.admin-sidebar,
aside.sidebar {
  background: linear-gradient(180deg, rgba(10,20,40,0.95) 0%, rgba(5,11,28,0.98) 100%);
  border-right: 1px solid var(--night-edge);
  color: var(--ivory);
}

.a-nav-item,
.admin-sidebar a {
  color: var(--ivory-soft);
  border-radius: 10px;
  padding: 9px 14px;
  margin: 2px 8px;
  transition: all .18s;
  display: flex;
  align-items: center;
  gap: 10px;
}

.a-nav-item:hover,
.admin-sidebar a:hover {
  background: rgba(61,169,252,0.08);
  color: var(--cyan-neon);
}

.a-nav-item.active,
.admin-sidebar a.active {
  background: linear-gradient(90deg, rgba(61,169,252,0.18) 0%, rgba(61,169,252,0.05) 100%);
  color: var(--cyan-neon);
  border-left: 3px solid var(--cyan-neon);
  box-shadow: inset 0 0 18px rgba(61,169,252,0.08);
}

/* ============================================================
   FOOTER
============================================================ */
.site-footer, footer {
  background: linear-gradient(180deg, var(--night-mid) 0%, var(--night-deep) 100%);
  color: var(--ivory-soft);
  border-top: 1px solid var(--night-edge);
}
.site-footer a, footer a { color: var(--ivory-soft); }
.site-footer a:hover, footer a:hover { color: var(--cyan-neon); }

/* ============================================================
   LE GARDIEN DU FEU — Mascotte
============================================================ */
.gardien-orb {
  width: 220px; height: 220px;
  position: relative;
  display: inline-block;
}

.gardien-orb video,
.gardien-orb img {
  width: 100%; height: 100%;
  object-fit: contain;
  filter:
    drop-shadow(0 0 24px var(--gardien-halo))
    drop-shadow(0 0 48px var(--gardien-halo));
  /* Filtre teinte si vidéo bleue de base, pour permettre recoloration */
  /* Surchargé par variable --gardien-hue-rotate depuis admin */
}

.gardien-orb::before {
  content: "";
  position: absolute;
  inset: -20%;
  background: radial-gradient(circle, var(--gardien-halo) 0%, transparent 65%);
  pointer-events: none;
  z-index: -1;
  animation: gardien-pulse 4s ease-in-out infinite;
}

@keyframes gardien-pulse {
  0%, 100% { opacity: 0.5; transform: scale(1); }
  50%      { opacity: 0.85; transform: scale(1.08); }
}

.gardien-name {
  color: var(--cyan-neon);
  font-weight: 600;
  text-shadow: 0 0 12px var(--cyan-glow);
}

/* ============================================================
   STATS / KPI CARDS
============================================================ */
.kpi-card {
  background: linear-gradient(145deg, rgba(27,111,184,0.18) 0%, rgba(15,29,51,0.6) 100%);
  border: 1px solid rgba(61,169,252,0.2);
  border-radius: 16px;
  padding: 18px 22px;
  position: relative;
  overflow: hidden;
}
.kpi-card::after {
  content: "";
  position: absolute;
  top: -50%; right: -20%;
  width: 80%; height: 200%;
  background: radial-gradient(ellipse, var(--cyan-glow) 0%, transparent 60%);
  pointer-events: none;
}
.kpi-value {
  color: var(--cyan-neon);
  font-size: 28px;
  font-weight: 700;
  text-shadow: 0 0 16px var(--cyan-glow);
  position: relative; z-index: 1;
}
.kpi-label {
  color: var(--ivory-soft);
  font-size: 12px;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

/* ============================================================
   MODALES / OVERLAYS
============================================================ */
.modal,
.feature-modal {
  background: linear-gradient(145deg, rgba(15,29,51,0.98) 0%, rgba(10,20,40,0.98) 100%);
  border: 1px solid rgba(61,169,252,0.3);
  border-radius: 18px;
  color: var(--ivory);
  box-shadow:
    0 24px 80px rgba(0,0,0,0.7),
    0 0 60px rgba(61,169,252,0.15);
}
.modal-backdrop,
.overlay {
  background: rgba(5,11,28,0.85);
  backdrop-filter: blur(6px);
}

/* ============================================================
   SCROLLBAR
============================================================ */
::-webkit-scrollbar { width: 10px; height: 10px; }
::-webkit-scrollbar-track { background: var(--night-deep); }
::-webkit-scrollbar-thumb {
  background: linear-gradient(180deg, var(--night-edge) 0%, var(--night-soft) 100%);
  border-radius: 8px;
  border: 2px solid var(--night-deep);
}
::-webkit-scrollbar-thumb:hover { background: var(--cyan-deep); }

/* ============================================================
   SECTION TITLES / DIVIDERS
============================================================ */
.section-title {
  color: var(--ivory);
  font-size: 20px;
  font-weight: 600;
  margin-bottom: 16px;
  position: relative;
  padding-left: 14px;
}
.section-title::before {
  content: "";
  position: absolute;
  left: 0; top: 4px; bottom: 4px;
  width: 3px;
  background: linear-gradient(180deg, var(--cyan-neon) 0%, var(--cyan-deep) 100%);
  border-radius: 2px;
  box-shadow: 0 0 8px var(--cyan-glow);
}

hr {
  border: none;
  height: 1px;
  background: linear-gradient(90deg, transparent 0%, var(--night-edge) 50%, transparent 100%);
  margin: 24px 0;
}

/* ============================================================
   UTILS
============================================================ */
.text-muted, .muted, small { color: var(--ivory-dim); }
.text-cyan { color: var(--cyan-neon); }
.text-glow { text-shadow: 0 0 12px var(--cyan-glow); }
.bg-night { background: var(--night-mid); }
.glow-border { box-shadow: var(--glow-border); }

/* ============================================================
   ANIMATIONS UTILES
============================================================ */
@keyframes shimmer {
  0%, 100% { opacity: 0.3; }
  50%      { opacity: 1; }
}
@keyframes float {
  0%, 100% { transform: translateY(0); }
  50%      { transform: translateY(-6px); }
}
@keyframes glow-pulse {
  0%, 100% { box-shadow: 0 0 24px var(--cyan-glow); }
  50%      { box-shadow: 0 0 48px var(--cyan-glow-strong); }
}

.float-anim { animation: float 3.5s ease-in-out infinite; }
.glow-pulse { animation: glow-pulse 3s ease-in-out infinite; }

/* ============================================================
   RESPONSIVE
============================================================ */
@media (max-width: 768px) {
  .kpi-card { padding: 14px 16px; }
  .kpi-value { font-size: 22px; }
  .section-title { font-size: 17px; }
}

/* ============================================================
   ACCESSIBILITÉ
============================================================ */
@media (prefers-reduced-motion: reduce) {
  .gardien-orb::before,
  .float-anim,
  .glow-pulse {
    animation: none !important;
  }
  * { transition: none !important; }
}

/* ============================================================
   OVERRIDES : HOME HERO (home-hero.css)
   Re-déclare les variables locales --hh-* en couleurs night-cyan
============================================================ */
.hh-hero {
  --hh-cream:        var(--night-mid) !important;
  --hh-cream-deep:   var(--night-soft) !important;
  --hh-ink:          var(--ivory) !important;
  --hh-ink-soft:     var(--ivory-soft) !important;
  --hh-text-muted:   var(--ivory-dim) !important;
  --hh-gold:         var(--cyan-neon) !important;
  --hh-gold-soft:    var(--cyan-soft) !important;
  --hh-gold-deep:    var(--cyan-deep) !important;
  --hh-shadow-card:  0 18px 40px -22px rgba(0,0,0,0.6) !important;
  --hh-shadow-cta:   0 14px 32px -10px rgba(61,169,252,0.55) !important;

  background:
    radial-gradient(ellipse at top, rgba(61,169,252,0.12) 0%, transparent 50%),
    radial-gradient(ellipse at bottom right, rgba(123,104,238,0.10) 0%, transparent 60%),
    linear-gradient(135deg, var(--night-deep) 0%, var(--night-mid) 60%, var(--night-soft) 100%) !important;
  color: var(--ivory) !important;
}

.hh-headline { color: var(--ivory) !important; }
.hh-headline .hh-accent,
.hh-accent {
  color: var(--cyan-neon) !important;
  text-shadow: 0 0 20px var(--cyan-glow);
}
.hh-text { color: var(--ivory-soft) !important; }
.hh-text-intro { color: var(--ivory) !important; }
.hh-divider-line {
  background: linear-gradient(90deg, transparent, var(--cyan-glow), transparent) !important;
}

.hh-cta {
  background: linear-gradient(135deg, var(--cyan-deep) 0%, var(--cyan-neon) 100%) !important;
  color: #fff !important;
  box-shadow: 0 14px 32px -10px var(--cyan-glow-strong), 0 0 24px var(--cyan-glow) !important;
}
.hh-cta:hover {
  filter: brightness(1.15);
  transform: translateY(-2px);
}

.hh-card {
  background: linear-gradient(145deg, rgba(19,31,58,0.85) 0%, rgba(15,29,51,0.75) 100%) !important;
  border: 1px solid rgba(61,169,252,0.18) !important;
  color: var(--ivory) !important;
}
.hh-card:hover {
  border-color: rgba(61,169,252,0.4) !important;
  box-shadow: 0 12px 32px rgba(0,0,0,0.5), 0 0 24px var(--cyan-glow) !important;
}
.hh-card * { color: var(--ivory); }
.hh-card .hh-card-meta,
.hh-card small { color: var(--ivory-dim) !important; }

/* ============================================================
   OVERRIDES : MON CERCLE (mon-cercle.css / mc-theme.css)
============================================================ */
.page-mon-cercle, body.page-mon-cercle {
  background:
    radial-gradient(ellipse at top, rgba(61,169,252,0.12) 0%, transparent 55%),
    radial-gradient(ellipse at bottom left, rgba(123,104,238,0.10) 0%, transparent 60%),
    var(--night-deep);
  color: var(--ivory);
}

.mc-stage, .mc-frame, .mc-wrapper {
  background: transparent !important;
}

.mc-center {
  background: radial-gradient(circle at 30% 30%,
    var(--cyan-soft) 0%,
    var(--cyan-neon) 35%,
    var(--cyan-deep) 60%,
    transparent 85%) !important;
  box-shadow:
    0 0 60px var(--cyan-glow-strong),
    0 0 120px var(--cyan-glow),
    inset 0 0 40px rgba(255,255,255,0.15) !important;
  border: 1px solid rgba(255,255,255,0.2) !important;
}
.mc-center::before,
.mc-center::after { filter: hue-rotate(180deg); }

.mc-center-title,
.mc-title {
  color: var(--ivory) !important;
  text-shadow: 0 0 18px rgba(0,0,0,0.6), 0 0 30px var(--cyan-glow) !important;
}

.mc-feature {
  background: linear-gradient(145deg, rgba(19,31,58,0.9) 0%, rgba(15,29,51,0.85) 100%) !important;
  border: 1px solid rgba(61,169,252,0.2) !important;
  color: var(--ivory) !important;
  box-shadow:
    0 6px 24px rgba(0,0,0,0.45),
    0 0 0 1px rgba(255,255,255,0.04) inset !important;
}
.mc-feature:hover {
  border-color: var(--cyan-neon) !important;
  box-shadow:
    0 10px 32px rgba(0,0,0,0.55),
    0 0 28px var(--cyan-glow) !important;
  transform: translateY(-3px);
}
.mc-feature .mc-f-label,
.mc-feature .mc-f-title {
  color: var(--ivory) !important;
}

.mc-dash {
  color: var(--ivory) !important;
}
.mc-dash-line, .mc-dash-stat {
  color: var(--ivory-soft) !important;
}
.mc-dash-hl {
  color: var(--cyan-neon) !important;
  text-shadow: 0 0 12px var(--cyan-glow);
}

/* ============================================================
   OVERRIDES : ADMIN (admin.css)
============================================================ */
body.admin-layout,
body.admin-body,
.admin-wrap {
  background:
    radial-gradient(ellipse at top, rgba(61,169,252,0.08) 0%, transparent 50%),
    radial-gradient(ellipse at bottom right, rgba(123,104,238,0.06) 0%, transparent 60%),
    var(--night-deep) !important;
  color: var(--ivory) !important;
}

/* Variables admin de admin.css : on les recolorise complètement */
body.admin-layout {
  --a-sidebar-bg:    var(--night-mid) !important;
  --a-sidebar-bg2:   var(--night-soft) !important;
  --a-sidebar-line:  rgba(61,169,252,0.15) !important;
  --a-sidebar-text:  var(--ivory-soft) !important;
  --a-sidebar-hover: rgba(61,169,252,0.08) !important;
  --a-sidebar-active-bg: rgba(61,169,252,0.18) !important;
  --a-sidebar-active-bord: var(--cyan-neon) !important;
  --orange:          var(--cyan-neon) !important;
  --orange-soft:     var(--cyan-soft) !important;
  --a-bg:            var(--night-deep) !important;
  --a-card:          rgba(19,31,58,0.85) !important;
  --a-line:          var(--night-edge) !important;
  --a-text:          var(--ivory) !important;
  --a-text-soft:     var(--ivory-soft) !important;
  --a-blue-pale:     rgba(61,169,252,0.15) !important;
  --a-green-pale:    rgba(74,222,128,0.15) !important;
  --a-orange-pale:   rgba(251,191,36,0.15) !important;
  --a-red-pale:      rgba(248,113,113,0.15) !important;
  --a-purple-pale:   rgba(123,104,238,0.15) !important;
  --a-shadow:        0 4px 16px rgba(0,0,0,0.4) !important;
  --a-shadow-h:      0 8px 24px rgba(0,0,0,0.5), 0 0 24px var(--cyan-glow) !important;
}

.a-shell, .a-layout, .admin-shell {
  background: transparent !important;
  color: var(--ivory) !important;
}

.a-sidebar-brand .mark {
  background: radial-gradient(circle at 30% 30%, var(--cyan-soft), var(--cyan-neon) 50%, var(--cyan-deep)) !important;
  box-shadow: 0 4px 12px var(--cyan-glow-strong), 0 0 20px var(--cyan-glow) !important;
}
.a-sidebar-brand .name { color: var(--ivory) !important; }
.a-sidebar-brand .sub { color: var(--ivory-dim) !important; }

/* Boutons groupes pliables sidebar */
.a-nav-group > button,
.a-nav-group-title {
  color: var(--cyan-soft) !important;
  background: transparent !important;
}

.a-sidebar {
  background: linear-gradient(180deg, rgba(10,20,40,0.96) 0%, rgba(5,11,28,0.98) 100%) !important;
  border-right: 1px solid var(--night-edge) !important;
  color: var(--ivory) !important;
}

.a-sidebar h2,
.a-sidebar h3,
.a-sidebar .a-group-title {
  color: var(--cyan-soft) !important;
  text-transform: uppercase;
  font-size: 11px;
  letter-spacing: 0.1em;
  font-weight: 600;
}

.a-main, .a-content {
  background: transparent !important;
  color: var(--ivory) !important;
}

.a-page-title {
  color: var(--ivory) !important;
  font-size: clamp(24px, 3vw, 32px);
  font-weight: 700;
}
.a-page-subtitle {
  color: var(--ivory-soft) !important;
}

.a-stat-card, .a-card, .a-panel {
  background: linear-gradient(145deg, rgba(19,31,58,0.85) 0%, rgba(15,29,51,0.75) 100%) !important;
  border: 1px solid rgba(61,169,252,0.18) !important;
  border-radius: 16px !important;
  color: var(--ivory) !important;
  box-shadow:
    0 4px 24px rgba(0,0,0,0.4),
    inset 0 1px 0 rgba(255,255,255,0.04) !important;
}

.a-stat-card:hover, .a-card:hover {
  border-color: rgba(61,169,252,0.35) !important;
  box-shadow:
    0 8px 32px rgba(0,0,0,0.5),
    0 0 24px var(--cyan-glow),
    inset 0 1px 0 rgba(255,255,255,0.06) !important;
}

.a-stat-label, .a-card-label { color: var(--ivory-soft) !important; }
.a-stat-value, .a-card-value, .a-kpi-value {
  color: var(--cyan-neon) !important;
  text-shadow: 0 0 18px var(--cyan-glow);
  font-weight: 700;
}
.a-stat-footer, .a-card-footer { color: var(--ivory-dim) !important; }

.a-stat-icon {
  background: rgba(61,169,252,0.15) !important;
  border: 1px solid rgba(61,169,252,0.3) !important;
  color: var(--cyan-neon) !important;
  box-shadow: 0 0 16px var(--cyan-glow);
}
.a-stat-icon.blue   { background: rgba(61,169,252,0.18) !important; color: var(--cyan-neon) !important; }
.a-stat-icon.green  { background: rgba(74,222,128,0.15) !important; color: var(--success) !important; border-color: rgba(74,222,128,0.3) !important; }
.a-stat-icon.orange { background: rgba(251,191,36,0.15) !important; color: var(--warning) !important; border-color: rgba(251,191,36,0.3) !important; }
.a-stat-icon.red    { background: rgba(248,113,113,0.15) !important; color: var(--danger) !important; border-color: rgba(248,113,113,0.3) !important; }
.a-stat-icon.purple { background: rgba(123,104,238,0.18) !important; color: var(--violet-accent) !important; border-color: rgba(123,104,238,0.3) !important; }

.a-stat-delta.up { color: var(--success) !important; }
.a-stat-delta.down { color: var(--danger) !important; }

/* Nav admin (boutons icônes 3D rondes) */
.a-nav-item .a-nav-img {
  border: 1px solid rgba(61,169,252,0.4) !important;
  box-shadow: 0 0 0 2px rgba(0,0,0,0.3), 0 0 12px var(--cyan-glow) !important;
  background: var(--night-soft) !important;
}
.a-nav-item.active .a-nav-img {
  border-color: var(--cyan-neon) !important;
  box-shadow: 0 0 0 2px var(--night-deep), 0 0 20px var(--cyan-glow-strong) !important;
}

/* ============================================================
   OVERRIDES : PREMIUM IA (premium-ia.css — Gemma chat)
============================================================ */
.gemma-bubble, .gemma-orb, .ag-orb {
  filter: hue-rotate(180deg) saturate(1.3);
}
.gemma-name, .ag-name, .gardien-name {
  color: var(--cyan-neon) !important;
  text-shadow: 0 0 12px var(--cyan-glow);
}

/* ============================================================
   PHRASE TYPO HELPER
============================================================ */
.lead { color: var(--ivory-soft); font-size: 17px; line-height: 1.6; }
.eyebrow {
  color: var(--cyan-neon);
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  font-weight: 600;
  margin-bottom: 8px;
}

/* ============================================================
   LISIBILITÉ (07/06) — texte forcé en blanc : on ré-assombrit
   les vieilles cartes restées CLAIRES (sinon blanc sur blanc).
   Ne s'applique PAS au thème clair « Phare allumé » (body.phare-light,
   chargé après et en !important → il garde la priorité).
   ============================================================ */
.card-pro,
.premium-card,
.moment-hero,
.organizer-card,
.moderation-notice,
.circle-info,
.flash {
  background: var(--night-card) !important;
  border: 1px solid rgba(61,169,252,.18) !important;
  color: var(--ivory) !important;
}
.radio-card {
  background: var(--night-soft) !important;
  color: var(--ivory) !important;
  border-color: rgba(61,169,252,.20) !important;
}
/* Enfants au texte codé SOMBRE → ré-éclaircis pour rester lisibles */
.moment-hero-title,
.premium-card .pr-title,
.premium-card .pr-content,
.organizer-card .organizer-name,
.page-head h1 {
  color: var(--ivory) !important;
}
.page-head .subtitle,
.moment-hero-msg,
.organizer-desc {
  color: var(--ivory-soft) !important;
}
/* Bandeaux flash : teintes sombres translucides (texte blanc lisible) */
.flash-success { background: rgba(74,222,128,.14) !important; }
.flash-error   { background: rgba(246,104,94,.14) !important; }
.flash-info    { background: rgba(61,169,252,.14) !important; }
