@import url('https://fonts.googleapis.com/css2?family=Luckiest+Guy&family=Poppins:wght@300;400;500;600;700&display=swap');

/* ── TOKENS ──────────────────────────────────────────────── */
:root {
  --bleu:        #1238C7;
  --bleu-dark:   #0c28a0;
  --bleu-light:  #1a46e8;
  --jaune:       #FFC300;
  --jaune-dark:  #e6b000;
  --blanc:       #FFFFFF;
  --fond:        #F8FAFC;
  --texte:       #0F172A;
  --texte-2:     #475569;
  --border:      rgba(18,56,199,.12);
  --glass-bg:    rgba(255,255,255,.10);
  --glass-border:rgba(255,255,255,.22);
  --shadow-sm:   0 2px 12px rgba(18,56,199,.08);
  --shadow-md:   0 8px 32px rgba(18,56,199,.14);
  --shadow-lg:   0 20px 60px rgba(18,56,199,.18);
  --radius:      16px;
  --radius-lg:   24px;
  --transition:  .3s cubic-bezier(.4,0,.2,1);

  /* POLICES */
  --font-display: 'Luckiest Guy', cursive;
  --font-body:    'Poppins', sans-serif;
}

/* ── RESET ───────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; font-size: 16px; }
body {
  font-family: var(--font-body);
  background: var(--fond);
  color: var(--texte);
  overflow-x: hidden;
  line-height: 1.65;
}
img  { display: block; max-width: 100%; }
a    { color: inherit; text-decoration: none; }
button { cursor: pointer; font-family: inherit; }
ul   { list-style: none; }

/* ── CURSOR GLOW ─────────────────────────────────────────── */
#cursor-glow {
  position: fixed; top: 0; left: 0;
  width: 400px; height: 400px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(18,56,199,.07) 0%, transparent 70%);
  pointer-events: none;
  z-index: 0;
  will-change: transform;
}

/* ── PAGE LOADER ─────────────────────────────────────────── */
#page-loader {
  position: fixed; inset: 0;
  background: var(--bleu);
  z-index: 9999;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 24px;
  transition: opacity .6s ease, transform .6s ease;
}
.loader-logo-img {
  height: 80px;
  object-fit: contain;
  animation: loaderPulse 1s ease infinite alternate;
}
@keyframes loaderPulse {
  from { transform: scale(1);    opacity: .9; }
  to   { transform: scale(1.06); opacity: 1;  }
}
#page-loader .loader-bar {
  width: 140px; height: 3px;
  background: rgba(255,255,255,.2);
  border-radius: 99px;
  overflow: hidden;
}
#page-loader .loader-bar::after {
  content: '';
  display: block; height: 100%;
  background: var(--jaune);
  border-radius: 99px;
  animation: loaderProgress 1.1s ease forwards;
}
@keyframes loaderProgress { from { width:0; } to { width:100%; } }
#page-loader.loader-out { opacity: 0; transform: translateY(-100%); }

/* ── NAVBAR ──────────────────────────────────────────────── */
.navbar {
  position: fixed; top: 0; left: 0; right: 0;
  z-index: 100;
  padding: 20px 0;
  transition: var(--transition);
}
.navbar-scrolled {
  background: rgba(248,250,252,.94);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  padding: 10px 0;
  box-shadow: var(--shadow-sm);
  border-bottom: 1px solid var(--border);
}
.navbar-inner {
  max-width: 1200px; margin: 0 auto;
  padding: 0 24px;
  display: flex; align-items: center; justify-content: space-between;
}

/* Logo image dans la navbar */
.nav-logo { display: flex; align-items: center; }
.nav-logo-img { height: 46px; object-fit: contain; transition: var(--transition); }

/* Par défaut : on montre logo clair (sur fond sombre/transparent hero) */
.nav-logo-light    { display: block; }
.nav-logo-scrolled { display: none;  }

/* Quand la navbar est scrollée : fond clair → logo bleu */
.navbar-scrolled .nav-logo-light    { display: none;  }
.navbar-scrolled .nav-logo-scrolled { display: block; }

.nav-links { display: flex; gap: 8px; align-items: center; }
.nav-link {
  font-family: var(--font-body);
  font-size: .9rem;
  font-weight: 500;
  color: rgba(255,255,255,.85);
  padding: 8px 16px;
  border-radius: 99px;
  transition: var(--transition);
}
.nav-link:hover { color: var(--blanc); background: rgba(255,255,255,.12); }
.navbar-scrolled .nav-link { color: var(--texte-2); }
.navbar-scrolled .nav-link:hover { color: var(--bleu); background: rgba(18,56,199,.06); }

/* ── CONTAINER ───────────────────────────────────────────── */
.container { max-width: 1200px; margin: 0 auto; padding: 0 24px; }

/* ── SECTION LABEL ───────────────────────────────────────── */
.section-label {
  display: inline-flex; align-items: center; gap: 8px;
  font-family: var(--font-body);
  font-size: .75rem; font-weight: 600;
  letter-spacing: .12em; text-transform: uppercase;
  color: var(--bleu);
  background: rgba(18,56,199,.08);
  border: 1px solid rgba(18,56,199,.15);
  padding: 6px 14px; border-radius: 99px; margin-bottom: 18px;
}
.section-label::before {
  content: ''; width: 6px; height: 6px;
  background: var(--jaune); border-radius: 50%;
}

/* ── TITRES ──────────────────────────────────────────────── */
/* Tous les titres de section utilisent Luckiest Guy */
.section-title {
  font-family: var(--font-display);
  font-size: clamp(2rem, 4vw, 3rem);
  font-weight: 400; /* Luckiest Guy n'a qu'un seul weight */
  line-height: 1.15;
  letter-spacing: 1px;
  color: var(--texte);
}
.section-title em { font-style: normal; color: var(--bleu); }

/* ── BOUTONS ─────────────────────────────────────────────── */
.btn {
  display: inline-flex; align-items: center; gap: 8px;
  font-family: var(--font-body);
  font-size: .9rem; font-weight: 600;
  padding: 13px 28px; border-radius: 99px; border: none;
  transition: var(--transition);
  position: relative; overflow: hidden;
}
.btn::after {
  content: ''; position: absolute; inset: 0;
  background: rgba(255,255,255,.15);
  opacity: 0; transition: var(--transition);
}
.btn:hover::after { opacity: 1; }

.btn-primary {
  background: var(--bleu); color: var(--blanc);
  box-shadow: 0 4px 24px rgba(18,56,199,.35);
}
.btn-primary:hover {
  background: var(--bleu-light);
  box-shadow: 0 8px 32px rgba(18,56,199,.45);
  transform: translateY(-1px);
}
.btn-secondary {
  background: transparent; color: var(--bleu);
  border: 1.5px solid var(--border);
}
.btn-secondary:hover { background: rgba(18,56,199,.05); border-color: var(--bleu); }
.btn-accent {
  background: var(--jaune); color: var(--texte);
  box-shadow: 0 4px 24px rgba(255,195,0,.35);
}
.btn-accent:hover { background: var(--jaune-dark); transform: translateY(-1px); }
.btn-sm { padding: 9px 20px; font-size: .82rem; }
.btn-danger { background: #ef4444; color: #fff; }
.btn-danger:hover { background: #dc2626; }

/* ── SCROLL REVEAL ───────────────────────────────────────── */
[data-reveal] {
  opacity: 0; transform: translateY(30px);
  transition: opacity .65s cubic-bezier(.4,0,.2,1), transform .65s cubic-bezier(.4,0,.2,1);
}
[data-reveal].revealed { opacity: 1; transform: none; }

/* ── GLASSMORPHISM ───────────────────────────────────────── */
.glass-card {
  background: rgba(255,255,255,.85);
  backdrop-filter: blur(20px); -webkit-backdrop-filter: blur(20px);
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm);
  transition: var(--transition);
}
.glass-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-md); }

/* ── SPOTLIGHT CARDS ─────────────────────────────────────── */
.spotlight-card {
  position: relative; overflow: hidden;
  --spotlight-x: 50%; --spotlight-y: 50%; --spotlight-opacity: 0;
}
.spotlight-card::before {
  content: ''; position: absolute; inset: 0;
  background: radial-gradient(
    600px circle at var(--spotlight-x) var(--spotlight-y),
    rgba(255,195,0,.12), transparent 60%
  );
  opacity: var(--spotlight-opacity);
  transition: opacity .3s ease;
  pointer-events: none; z-index: 1; border-radius: inherit;
}

/* ══════════════════════════════════════════════════════════
   HERO
══════════════════════════════════════════════════════════ */
.hero {
  min-height: 100vh;
  display: flex; align-items: center;
  position: relative; overflow: hidden;
  padding: 100px 0 60px;
}

/* Couche image de fond (uploadable) */
.hero-bg { position: absolute; inset: 0; z-index: 0; }

.hero-bg-image {
  position: absolute; inset: 0;
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  transition: opacity .4s ease;
}
/* Overlay sombre si image présente */
.hero-bg-overlay {
  position: absolute; inset: 0;
  background: linear-gradient(
    135deg,
    rgba(12, 40, 160, 0.78) 0%,
    rgba(18, 56, 199, 0.55) 50%,
    rgba(0,0,0,.35) 100%
  );
}
/* Sans image : gradient bleu par défaut */
.hero:not([style]) .hero-bg-overlay,
.hero-bg-image:not([style]) ~ .hero-bg-overlay {
  background: linear-gradient(135deg, var(--bleu) 0%, var(--bleu-dark) 60%, #071580 100%);
}

.hero-blob {
  position: absolute; border-radius: 50%;
  filter: blur(80px); opacity: .45;
}
.hero-blob-1 {
  width: 700px; height: 700px;
  background: radial-gradient(circle, rgba(255,195,0,.22), transparent 70%);
  top: -200px; right: -200px;
}
.hero-blob-2 {
  width: 500px; height: 500px;
  background: radial-gradient(circle, rgba(18,56,199,.35), transparent 70%);
  bottom: -100px; left: -150px;
}
.hero-grid-pattern {
  position: absolute; inset: 0;
  background-image:
    linear-gradient(rgba(255,255,255,.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.04) 1px, transparent 1px);
  background-size: 60px 60px;
}

.hero-content { position: relative; z-index: 2; max-width: 720px; }

.hero-badge {
  display: inline-flex; align-items: center; gap: 8px;
  background: rgba(255,255,255,.15);
  border: 1px solid rgba(255,255,255,.25);
  color: var(--blanc);
  font-family: var(--font-body);
  font-size: .8rem; font-weight: 600;
  letter-spacing: .08em; text-transform: uppercase;
  padding: 7px 16px; border-radius: 99px; margin-bottom: 24px;
}

.hero-title {
  font-family: var(--font-display);
  font-size: clamp(2.8rem, 6vw, 5rem);
  font-weight: 400;           /* Luckiest Guy est déjà très bold */
  line-height: 1.08;
  letter-spacing: 2px;
  color: var(--blanc);
  margin-bottom: 24px;
  text-shadow: 0 2px 20px rgba(0,0,0,.2);
}
.hero-title .accent    { color: var(--jaune); }
.hero-title .highlight { position: relative; display: inline-block; }
.hero-title .highlight::after {
  content: ''; position: absolute;
  left: 0; bottom: 4px;
  width: 100%; height: 6px;
  background: var(--jaune); border-radius: 99px;
  z-index: -1; opacity: .5;
}

.hero-subtitle {
  font-family: var(--font-body);
  font-size: 1.1rem; font-weight: 300;
  color: rgba(255,255,255,.82);
  line-height: 1.75;
  max-width: 540px; margin-bottom: 40px;
}

.hero-cta { display: flex; gap: 14px; flex-wrap: wrap; }

/* Sur hero (fond sombre), btn-secondary en blanc */
.hero .btn-secondary {
  color: var(--blanc);
  border-color: rgba(255,255,255,.35);
  background: rgba(255,255,255,.08);
}
.hero .btn-secondary:hover {
  background: rgba(255,255,255,.18);
  border-color: rgba(255,255,255,.6);
}

.hero-stats {
  display: flex; gap: 32px;
  margin-top: 64px; padding-top: 40px;
  border-top: 1px solid rgba(255,255,255,.18);
}
.hero-stat-value {
  font-family: var(--font-display);
  font-size: 2rem; font-weight: 400;
  color: var(--jaune); letter-spacing: 1px;
}
.hero-stat-label {
  font-family: var(--font-body);
  font-size: .82rem;
  color: rgba(255,255,255,.65);
  margin-top: 2px;
}

/* ══════════════════════════════════════════════════════════
   SECTION ABOUT
══════════════════════════════════════════════════════════ */
.section-about { padding: 100px 0; position: relative; }

.about-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(250px,1fr));
  gap: 20px; margin-top: 48px;
}
.about-card {
  padding: 32px; border-radius: var(--radius-lg);
  background: var(--blanc);
  border: 1px solid var(--border);
  transition: var(--transition);
  position: relative; overflow: hidden;
}
.about-card::before {
  content: ''; position: absolute;
  top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--bleu), var(--jaune));
  transform: scaleX(0); transform-origin: left;
  transition: transform .4s ease;
}
.about-card:hover { box-shadow: var(--shadow-md); transform: translateY(-4px); }
.about-card:hover::before { transform: scaleX(1); }

.about-icon {
  width: 52px; height: 52px;
  background: rgba(18,56,199,.08); border-radius: 14px;
  display: flex; align-items: center; justify-content: center;
  margin-bottom: 20px;
}
.about-card h3 {
  font-family: var(--font-display);
  font-size: 1.05rem; font-weight: 400;
  letter-spacing: .5px;
  margin-bottom: 10px; color: var(--texte);
}
.about-card p {
  font-family: var(--font-body);
  font-size: .9rem; color: var(--texte-2); line-height: 1.6;
}

/* ══════════════════════════════════════════════════════════
   SECTION MEMBRES
══════════════════════════════════════════════════════════ */
.section-membres { padding: 100px 0; background: var(--fond); }

.membres-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(270px,1fr));
  gap: 24px; margin-top: 48px;
}
.membre-card {
  background: var(--blanc);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  overflow: hidden;
  transition: var(--transition);
}
.membre-card:hover { box-shadow: var(--shadow-md); transform: translateY(-6px); }

.membre-card-img {
  position: relative; height: 220px; overflow: hidden;
  background: linear-gradient(135deg, rgba(18,56,199,.08), rgba(255,195,0,.08));
}
.membre-card-img img {
  width: 100%; height: 100%; object-fit: cover;
  transition: transform .5s ease;
}
.membre-card:hover .membre-card-img img { transform: scale(1.06); }

.poste-badge {
  position: absolute; top: 14px; left: 14px;
  background: var(--bleu); color: var(--blanc);
  font-family: var(--font-body);
  font-size: .72rem; font-weight: 600;
  letter-spacing: .06em; text-transform: uppercase;
  padding: 5px 12px; border-radius: 99px;
}
.membre-card-body { padding: 24px; }
.membre-card-name {
  font-family: var(--font-display);
  font-size: 1.1rem; font-weight: 400;
  letter-spacing: .5px;
  margin-bottom: 6px;
}
.membre-card-bio {
  font-family: var(--font-body);
  font-size: .85rem; color: var(--texte-2);
  margin-bottom: 20px; line-height: 1.55;
}
.membre-card-footer {
  display: flex; align-items: center; justify-content: space-between;
}
.social-mini { display: flex; gap: 8px; }
.social-mini a {
  width: 32px; height: 32px;
  display: flex; align-items: center; justify-content: center;
  border-radius: 8px; background: var(--fond);
  border: 1px solid var(--border); color: var(--texte-2);
  transition: var(--transition);
}
.social-mini a:hover { background: var(--bleu); color: var(--blanc); border-color: var(--bleu); }

/* ══════════════════════════════════════════════════════════
   FOOTER
══════════════════════════════════════════════════════════ */
.footer {
  background: var(--texte);
  color: rgba(255,255,255,.65);
  padding: 56px 0 32px;
}
.footer-grid {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr;
  gap: 40px;
  padding-bottom: 40px;
  border-bottom: 1px solid rgba(255,255,255,.08);
  margin-bottom: 32px;
}
.footer-brand-name {
  font-family: var(--font-display);
  font-size: 1.4rem; font-weight: 400;
  color: var(--blanc); margin-bottom: 12px;
}
.footer-brand-name span { color: var(--jaune); }
.footer-col h4 {
  font-family: var(--font-body);
  font-size: .78rem; font-weight: 700;
  letter-spacing: .1em; text-transform: uppercase;
  color: var(--blanc); margin-bottom: 16px;
}
.footer-col ul { display: flex; flex-direction: column; gap: 10px; }
.footer-col a {
  font-family: var(--font-body);
  font-size: .88rem; transition: color .2s;
}
.footer-col a:hover { color: var(--jaune); }
.footer-bottom {
  display: flex; align-items: center; justify-content: space-between;
  font-family: var(--font-body); font-size: .82rem;
}

/* ══════════════════════════════════════════════════════════
   PAGE PROFIL MEMBRE
══════════════════════════════════════════════════════════ */
.profil-hero {
  min-height: 55vh;
  background: linear-gradient(135deg, var(--bleu) 0%, var(--bleu-dark) 100%);
  display: flex; align-items: flex-end;
  padding: 120px 0 0;
  position: relative; overflow: hidden;
}
.profil-hero-bg {
  position: absolute; inset: 0;
  background-image:
    linear-gradient(rgba(255,255,255,.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.04) 1px, transparent 1px);
  background-size: 50px 50px;
}
.profil-hero-blob {
  position: absolute;
  width: 500px; height: 500px;
  background: radial-gradient(circle, rgba(255,195,0,.22), transparent 70%);
  top: -100px; right: -100px;
  border-radius: 50%; filter: blur(60px);
}
.profil-hero-inner {
  position: relative; z-index: 2;
  display: flex; align-items: flex-end; gap: 40px;
  padding-bottom: 0;
}
.profil-avatar-wrap {
  flex-shrink: 0;
  width: 180px; height: 180px;
  border-radius: 24px; overflow: hidden;
  border: 4px solid rgba(255,255,255,.3);
  box-shadow: 0 20px 60px rgba(0,0,0,.25);
  transform: translateY(40px);
}
.profil-avatar-wrap img { width: 100%; height: 100%; object-fit: cover; }
.profil-hero-meta { padding-bottom: 24px; color: var(--blanc); }
.profil-poste-badge {
  display: inline-block;
  background: var(--jaune); color: var(--texte);
  font-family: var(--font-body);
  font-size: .75rem; font-weight: 700;
  text-transform: uppercase; letter-spacing: .08em;
  padding: 5px 14px; border-radius: 99px; margin-bottom: 14px;
}
.profil-name {
  font-family: var(--font-display);
  font-size: clamp(2rem, 4vw, 3rem);
  font-weight: 400;
  letter-spacing: 1px; line-height: 1.05; margin-bottom: 12px;
}
.profil-bio-fun {
  font-family: var(--font-body);
  font-size: 1rem; opacity: .8; font-style: italic;
}

/* Lien retour */
.back-link {
  display: inline-flex; align-items: center; gap: 6px;
  font-family: var(--font-body);
  font-size: .85rem; color: var(--texte-2);
  margin-bottom: 36px;
  transition: color .2s;
}
.back-link:hover { color: var(--bleu); }

/* Corps profil */
.profil-body { padding: 80px 0; }
.profil-grid {
  display: grid;
  grid-template-columns: 1fr 380px;
  gap: 40px; align-items: start;
}
.profil-section { margin-bottom: 40px; }
.profil-section-title {
  font-family: var(--font-display);
  font-size: 1rem; font-weight: 400;
  letter-spacing: .5px;
  color: var(--texte);
  margin-bottom: 16px; padding-bottom: 12px;
  border-bottom: 2px solid var(--border);
  display: flex; align-items: center; gap: 10px;
}
.profil-text {
  font-family: var(--font-body);
  font-size: .95rem; color: var(--texte-2); line-height: 1.8;
}
.profil-citation {
  margin: 0;
  padding: 24px 28px;
  border-left: 3px solid var(--jaune);
  border-radius: 0 var(--radius) var(--radius) 0;
  background: rgba(255,195,0,.05);
  font-family: var(--font-body);
  font-size: 1.05rem; font-style: italic;
  color: var(--texte); line-height: 1.7;
}

/* Réseaux profil */
.social-profil { display: flex; gap: 12px; flex-wrap: wrap; margin-top: 8px; }
.social-profil a {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 10px 20px; border-radius: 99px;
  border: 1.5px solid var(--border);
  font-family: var(--font-body);
  font-size: .85rem; font-weight: 500;
  color: var(--texte-2); transition: var(--transition);
}
.social-profil a:hover { background: var(--bleu); color: var(--blanc); border-color: var(--bleu); }

/* Fun card */
.fun-card {
  background: var(--blanc);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 28px;
  position: sticky; top: 100px;
}
.fun-card-title {
  font-family: var(--font-display);
  font-size: 1rem; font-weight: 400;
  letter-spacing: .5px;
  margin-bottom: 24px;
  display: flex; align-items: center; gap: 8px;
}
.fun-item {
  display: flex; align-items: flex-start; gap: 14px;
  padding: 16px 0; border-bottom: 1px solid var(--border);
}
.fun-item:last-child { border-bottom: none; }
.fun-item-icon {
  width: 40px; height: 40px; flex-shrink: 0;
  background: rgba(18,56,199,.07); border-radius: 12px;
  display: flex; align-items: center; justify-content: center;
}
.fun-item-label {
  font-family: var(--font-body);
  font-size: .72rem; font-weight: 600;
  text-transform: uppercase; letter-spacing: .08em;
  color: var(--texte-2); margin-bottom: 4px;
}
.fun-item-value {
  font-family: var(--font-body);
  font-size: .9rem; font-weight: 500; color: var(--texte);
}

/* Jauge caféine */
.cafeine-bar { display: flex; gap: 6px; margin-top: 6px; }
.cafeine-dot {
  width: 18px; height: 18px; border-radius: 50%;
  background: var(--border); border: 2px solid var(--border);
  transition: all .3s ease; opacity: 0; transform: scale(0);
}
.cafeine-dot.animated  { opacity: 1; transform: scale(1); }
.cafeine-dot.active    { background: var(--jaune); border-color: var(--jaune-dark); box-shadow: 0 0 8px rgba(255,195,0,.5); }

/* 404 */
.error-page {
  min-height: 100vh;
  display: flex; align-items: center; justify-content: center;
  text-align: center;
}
.error-code {
  font-family: var(--font-display);
  font-size: 8rem; font-weight: 400;
  color: var(--bleu); opacity: .1; line-height: 1;
}

/* ══════════════════════════════════════════════════════════
   ADMIN
══════════════════════════════════════════════════════════ */
.admin-body {
  min-height: 100vh;
  background: #0f172a;
  color: var(--blanc);
  font-family: var(--font-body);
}

/* Login */
.admin-login-wrap {
  min-height: 100vh;
  display: flex; align-items: center; justify-content: center;
  padding: 24px;
  background: linear-gradient(135deg, #0f172a 0%, #1e293b 100%);
  position: relative; overflow: hidden;
}
.admin-login-wrap::before {
  content: ''; position: absolute;
  width: 600px; height: 600px;
  background: radial-gradient(circle, rgba(18,56,199,.2), transparent 70%);
  top: -200px; right: -200px; border-radius: 50%;
}
.admin-login-card {
  width: 100%; max-width: 440px;
  background: rgba(255,255,255,.05);
  border: 1px solid rgba(255,255,255,.1);
  border-radius: var(--radius-lg);
  padding: 48px 40px;
  backdrop-filter: blur(20px);
  position: relative; z-index: 2;
}
.admin-login-sub {
  text-align: center; font-size: .85rem;
  color: rgba(255,255,255,.4); margin-bottom: 36px;
  font-family: var(--font-body);
}

/* Champs formulaire (dark) */
.form-group { margin-bottom: 20px; }
.form-label {
  display: block; font-family: var(--font-body);
  font-size: .78rem; font-weight: 600;
  text-transform: uppercase; letter-spacing: .08em;
  color: rgba(255,255,255,.55); margin-bottom: 8px;
}
.form-control {
  width: 100%; padding: 13px 16px;
  border-radius: 12px;
  border: 1.5px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.07);
  color: var(--blanc);
  font-family: var(--font-body); font-size: .92rem;
  transition: var(--transition); outline: none;
}
.form-control::placeholder { color: rgba(255,255,255,.25); }
.form-control:focus {
  border-color: var(--bleu);
  background: rgba(255,255,255,.1);
  box-shadow: 0 0 0 3px rgba(18,56,199,.25);
}
.error-msg {
  background: rgba(239,68,68,.15);
  border: 1px solid rgba(239,68,68,.3);
  color: #fca5a5;
  padding: 12px 16px; border-radius: 10px;
  font-family: var(--font-body); font-size: .85rem;
  margin-bottom: 20px;
}

/* Layout admin */
.admin-layout { display: flex; min-height: 100vh; }
.admin-sidebar {
  width: 260px; flex-shrink: 0;
  background: #1e293b;
  border-right: 1px solid rgba(255,255,255,.06);
  padding: 28px 16px;
  display: flex; flex-direction: column;
  position: fixed; top: 0; left: 0; bottom: 0;
  overflow-y: auto;
}
.admin-sidebar-logo {
  display: flex; align-items: center;
  padding: 0 8px; margin-bottom: 32px;
}
.admin-nav { flex: 1; }
.admin-nav-label {
  font-family: var(--font-body);
  font-size: .68rem; font-weight: 700;
  text-transform: uppercase; letter-spacing: .12em;
  color: rgba(255,255,255,.3);
  padding: 0 12px; margin-bottom: 8px; margin-top: 24px;
}
.admin-nav a {
  display: flex; align-items: center; gap: 10px;
  padding: 11px 12px; border-radius: 10px;
  color: rgba(255,255,255,.55);
  font-family: var(--font-body); font-size: .88rem; font-weight: 500;
  margin-bottom: 2px; transition: var(--transition);
}
.admin-nav a:hover { background: rgba(255,255,255,.07); color: var(--blanc); }
.admin-nav a.active {
  background: rgba(18,56,199,.35);
  color: #93bbff;
}
.admin-sidebar-footer {
  padding: 0 12px;
  border-top: 1px solid rgba(255,255,255,.06);
  padding-top: 20px;
}
.admin-main {
  margin-left: 260px; flex: 1;
  padding: 32px; background: #0f172a;
}
.admin-topbar {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: 36px;
}
.admin-page-title {
  font-family: var(--font-display);
  font-size: 1.6rem; font-weight: 400;
  color: var(--blanc); letter-spacing: 1px;
}
.admin-page-title span { color: var(--jaune); }

/* Stats admin */
.admin-stats-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px,1fr));
  gap: 16px; margin-bottom: 32px;
}
.admin-stat-card {
  background: #1e293b;
  border: 1px solid rgba(255,255,255,.06);
  border-radius: var(--radius); padding: 24px;
}
.admin-stat-value {
  font-family: var(--font-display);
  font-size: 2rem; font-weight: 400;
  color: var(--bleu-light); letter-spacing: 1px;
}
.admin-stat-label {
  font-family: var(--font-body);
  font-size: .8rem; color: rgba(255,255,255,.45); margin-top: 4px;
}

/* Table admin */
.admin-panel {
  background: #1e293b;
  border: 1px solid rgba(255,255,255,.06);
  border-radius: var(--radius-lg); overflow: hidden;
}
.admin-panel-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: 20px 24px;
  border-bottom: 1px solid rgba(255,255,255,.06);
}
.admin-panel-header h3 {
  font-family: var(--font-display);
  font-size: 1rem; font-weight: 400;
  letter-spacing: .5px; color: var(--blanc);
}
.admin-table { width: 100%; border-collapse: collapse; }
.admin-table th {
  text-align: left;
  font-family: var(--font-body);
  font-size: .72rem; font-weight: 700;
  text-transform: uppercase; letter-spacing: .1em;
  color: rgba(255,255,255,.35);
  padding: 12px 20px;
  border-bottom: 1px solid rgba(255,255,255,.06);
}
.admin-table td {
  padding: 16px 20px;
  border-bottom: 1px solid rgba(255,255,255,.04);
  font-family: var(--font-body); font-size: .88rem;
  color: rgba(255,255,255,.8); vertical-align: middle;
}
.admin-table tr:last-child td { border-bottom: none; }
.admin-table tr:hover td { background: rgba(255,255,255,.02); }
.admin-membre-avatar {
  width: 40px; height: 40px;
  border-radius: 10px; object-fit: cover;
  background: rgba(255,255,255,.1);
}
.badge-poste {
  display: inline-block;
  font-family: var(--font-body);
  font-size: .72rem; font-weight: 600;
  padding: 3px 10px; border-radius: 99px;
  background: rgba(18,56,199,.3);
  color: #93bbff; border: 1px solid rgba(18,56,199,.4);
}
.actions-group { display: flex; gap: 8px; }
.btn-edit {
  display: inline-flex; align-items: center;
  padding: 7px 14px; border-radius: 8px;
  background: rgba(255,195,0,.12);
  border: 1px solid rgba(255,195,0,.25);
  color: #fcd34d;
  font-family: var(--font-body); font-size: .78rem; font-weight: 600;
  transition: var(--transition); cursor: pointer;
}
.btn-edit:hover { background: rgba(255,195,0,.22); }
.btn-delete {
  display: inline-flex; align-items: center;
  padding: 7px 14px; border-radius: 8px;
  background: rgba(239,68,68,.12);
  border: 1px solid rgba(239,68,68,.25);
  color: #fca5a5;
  font-family: var(--font-body); font-size: .78rem; font-weight: 600;
  transition: var(--transition); cursor: pointer;
}
.btn-delete:hover { background: rgba(239,68,68,.22); }

/* Formulaire admin */
.admin-form-grid {
  display: grid; grid-template-columns: 1fr 1fr; gap: 20px;
}
.admin-form-grid .full-width { grid-column: 1 / -1; }

.admin-form-section {
  background: #1e293b;
  border: 1px solid rgba(255,255,255,.06);
  border-radius: var(--radius-lg);
  padding: 28px; margin-bottom: 24px;
}
.admin-form-section-title {
  font-family: var(--font-display);
  font-size: .95rem; font-weight: 400;
  letter-spacing: .5px;
  color: rgba(255,255,255,.9);
  margin-bottom: 24px; padding-bottom: 14px;
  border-bottom: 1px solid rgba(255,255,255,.06);
  display: flex; align-items: center; gap: 8px;
}
.form-control-admin {
  width: 100%; padding: 11px 14px;
  border-radius: 10px;
  border: 1.5px solid rgba(255,255,255,.1);
  background: rgba(255,255,255,.05);
  color: var(--blanc);
  font-family: var(--font-body); font-size: .88rem;
  outline: none; transition: var(--transition);
}
.form-control-admin::placeholder { color: rgba(255,255,255,.25); }
.form-control-admin:focus {
  border-color: var(--bleu);
  background: rgba(255,255,255,.07);
  box-shadow: 0 0 0 3px rgba(18,56,199,.2);
}
textarea.form-control-admin { resize: vertical; min-height: 100px; }
.form-label-admin {
  display: block;
  font-family: var(--font-body);
  font-size: .78rem; font-weight: 600;
  text-transform: uppercase; letter-spacing: .08em;
  color: rgba(255,255,255,.45); margin-bottom: 8px;
}

/* Range */
.range-group { display: flex; align-items: center; gap: 12px;
  font-family: var(--font-body); font-size: .85rem; color: rgba(255,255,255,.4);
}
.range-group input[type=range] { flex: 1; accent-color: var(--jaune); }
.range-value {
  font-family: var(--font-display);
  font-size: 1.2rem; font-weight: 400;
  color: var(--jaune); min-width: 24px; text-align: center;
}

/* Upload zone */
.upload-zone {
  border: 2px dashed rgba(255,255,255,.15);
  border-radius: 14px; padding: 32px;
  text-align: center; cursor: pointer;
  transition: var(--transition);
  position: relative; display: block;
}
.upload-zone:hover { border-color: var(--bleu); background: rgba(18,56,199,.05); }
.upload-zone input[type=file] { display: none; }
.upload-preview {
  width: 100px; height: 100px; border-radius: 16px;
  object-fit: cover; margin: 0 auto 16px; display: none;
  border: 2px solid rgba(255,255,255,.15);
}
.upload-preview.visible { display: block; }

/* Flash */
.flash-message {
  position: fixed; top: 24px; right: 24px; z-index: 999;
  background: #22c55e; color: #fff;
  padding: 14px 24px; border-radius: 12px;
  font-family: var(--font-body); font-size: .88rem; font-weight: 600;
  box-shadow: 0 8px 32px rgba(34,197,94,.25);
  transition: opacity .3s ease, transform .3s ease;
}
.flash-message.error { background: #ef4444; }

/* ── RESPONSIVE ──────────────────────────────────────────── */
@media (max-width: 1024px) {
  .profil-grid { grid-template-columns: 1fr; }
  .fun-card { position: static; }
  .footer-grid { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 900px) {
  .footer-grid { grid-template-columns: 1fr; }
  .admin-sidebar { display: none; }
  .admin-main { margin-left: 0; }
  .admin-form-grid { grid-template-columns: 1fr; }
  .admin-form-grid .full-width { grid-column: 1; }
}
@media (max-width: 640px) {
  .hero-stats { flex-wrap: wrap; gap: 20px; }
  .profil-hero-inner { flex-direction: column; align-items: flex-start; }
  .profil-avatar-wrap { transform: none; width: 120px; height: 120px; }
  .nav-links .nav-link { display: none; }
  .hero-title { font-size: 2.4rem; }
  .section-title { font-size: 1.8rem; }
}