/* ===== Couleurs et polices ===== */
:root{
  --rouge: #B5152A;
  --rouge-vif: #D81E32;
  --noir: #0a0a0a;
  --fond: #161412;
  --fond-clair: #1F1B17;
  --texte: #EDE7DD;
  --texte-mute: #B9B2A6;
  --bordure: rgba(237,231,221,.14);

  --titre: 'Bebas Neue', sans-serif;
  --label: 'Barlow Condensed', sans-serif;
  --corps: 'Barlow', sans-serif;
}

*{ margin:0; padding:0; box-sizing:border-box; }
html{ scroll-behavior:smooth; overflow-x:hidden; max-width:100%; }
body{ background:var(--noir); color:var(--texte); font-family:var(--corps); overflow-x:hidden; max-width:100%; }
a{ color:inherit; text-decoration:none; }
ul{ list-style:none; }
img{ max-width:100%; display:block; }

@media (prefers-reduced-motion: reduce){
  *{ animation-duration:0.01ms !important; transition-duration:0.01ms !important; }
}

/* Séparateur simple entre sections */
.separateur{
  height:2px;
  background:linear-gradient(90deg, transparent, var(--rouge), transparent);
  opacity:.6;
}

/* ===== Topbar ===== */
.topbar{
  background:var(--rouge);
  padding:7px 40px;
  display:flex; align-items:center; justify-content:space-between;
  font-family:var(--label); font-size:12px; letter-spacing:.08em; text-transform:uppercase;
  color:rgba(255,255,255,.85);
}
.topbar a{ color:rgba(255,255,255,.85); margin-left:16px; }
.topbar a:hover{ color:#fff; }

/* ===== Header ===== */
header{
  background:var(--noir);
  border-bottom:1px solid var(--rouge);
  position:sticky; top:0; z-index:100;
}
.header-inner{
  max-width:1200px; margin:0 auto; padding:0 40px;
  height:80px;
  display:flex; align-items:center; gap:32px;
}
.logo-wrap{ display:flex; align-items:center; gap:14px; flex-shrink:0; }
.logo-wrap img{
  height:54px; width:54px; border-radius:50%; object-fit:cover;
  border:2px solid var(--bordure);
}
.logo-text{ display:flex; flex-direction:column; line-height:1; }
.logo-text .l1{ font-family:var(--titre); font-size:18px; letter-spacing:.03em; }
.logo-text .l2{ font-family:var(--label); font-size:10px; letter-spacing:.28em; color:var(--rouge-vif); text-transform:uppercase; margin-top:3px; }

nav{ flex:1; display:flex; }
nav ul{ display:flex; gap:8px; margin-left:auto; align-items:center; }
nav ul li a{
  display:block; padding:10px 16px;
  font-family:var(--label); font-weight:600; font-size:14px; letter-spacing:.06em; text-transform:uppercase;
  color:var(--texte-mute);
  border-bottom:2px solid transparent;
  transition:color .2s, border-color .2s;
}
nav ul li a:hover, nav ul li a.actif{ color:var(--texte); border-color:var(--rouge-vif); }

.btn{
  display:inline-flex; align-items:center; justify-content:center;
  font-family:var(--label); font-weight:700; font-size:13px; letter-spacing:.1em; text-transform:uppercase;
  padding:12px 26px; border:none; cursor:pointer;
  transition:transform .2s, background .2s, border-color .2s, color .2s;
}
.btn-plein{ background:var(--rouge); color:#fff; }
.btn-plein:hover{ background:var(--rouge-vif); }

.btn-contour{ background:transparent; color:var(--texte); border:1px solid rgba(237,231,221,.3); }
.btn-contour:hover{ border-color:var(--rouge-vif); color:var(--texte); }

.header-cta{ display:flex; gap:10px; }

.hamburger{
  display:none; flex-direction:column; gap:5px; cursor:pointer;
  background:none; border:none; padding:8px;
}
.hamburger span{ width:24px; height:2px; background:var(--texte); transition:transform .25s, opacity .25s; }

/* ===== Hero ===== */
#accueil{
  min-height:80vh;
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  text-align:center; padding:100px 40px;
  background:radial-gradient(ellipse 60% 50% at 50% 30%, rgba(181,21,42,.18), transparent 65%), var(--noir);
}
.hero-label{
  font-family:var(--label); font-size:13px; font-weight:600; letter-spacing:.32em; text-transform:uppercase;
  color:var(--texte-mute);
}
#accueil h1{
  font-family:var(--titre); font-size:clamp(52px,10vw,120px); line-height:.9; letter-spacing:.01em;
  margin-top:16px;
}
#accueil h1 span{ color:var(--rouge-vif); }
.hero-sub{
  font-size:16px; color:var(--texte-mute); max-width:460px; margin:20px auto 0; line-height:1.6;
}
.hero-btns{ display:flex; gap:14px; margin-top:32px; flex-wrap:wrap; justify-content:center; }
.hero-btns .btn{ padding:15px 32px; }

/* ===== Titres de section ===== */
.section-head{ text-align:center; max-width:600px; margin:0 auto 50px; padding:0 40px; }
.section-head .eyebrow{
  font-family:var(--label); font-size:12px; font-weight:600; letter-spacing:.28em; text-transform:uppercase;
  color:var(--rouge-vif);
}
.section-head h2{
  font-family:var(--titre); font-size:clamp(36px,5vw,56px); letter-spacing:.02em; margin-top:10px;
}
.section-head p{ color:var(--texte-mute); font-size:15px; margin-top:14px; line-height:1.6; }
.section-head strong{ color:var(--texte); }

/* Apparition douce au scroll */
.reveal{ opacity:0; transform:translateY(18px); transition:opacity .5s ease, transform .5s ease; }
.reveal.in{ opacity:1; transform:translateY(0); }

/* ===== Le Club (présentation + photo) ===== */
#club{ background:var(--noir); padding:80px 0; }
.club-wrap{
  max-width:1080px; margin:0 auto; padding:0 40px;
  display:grid; grid-template-columns:1fr 1fr; gap:48px; align-items:center;
}
.club-photo{
  border:1px solid var(--bordure);
  overflow:hidden;
}
.club-photo img{ width:100%; height:100%; object-fit:cover; }
.club-texte .eyebrow{
  font-family:var(--label); font-size:12px; font-weight:600; letter-spacing:.28em; text-transform:uppercase;
  color:var(--rouge-vif);
}
.club-texte h2{
  font-family:var(--titre); font-size:clamp(32px,4.5vw,46px); letter-spacing:.02em; margin-top:10px; margin-bottom:18px;
}
.club-texte p{ font-size:15px; color:var(--texte-mute); line-height:1.7; margin-bottom:14px; }
.club-texte p strong{ color:var(--texte); }
.club-chiffres{ display:flex; gap:32px; margin-top:24px; flex-wrap:wrap; }
.club-chiffre{ display:flex; flex-direction:column; }
.club-chiffre .val{ font-family:var(--titre); font-size:32px; color:var(--rouge-vif); line-height:1; }
.club-chiffre .lbl{ font-family:var(--label); font-size:11.5px; letter-spacing:.06em; text-transform:uppercase; color:var(--texte-mute); margin-top:4px; }

/* ===== Entraînements ===== */
#entrainements{ background:var(--noir); padding:90px 0; }
.entrain-wrap{ max-width:1200px; margin:0 auto; padding:0 40px; }

.cours-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:20px; margin-bottom:70px; }
.cours-card{
  background:var(--fond-clair);
  border-left:4px solid var(--rouge);
  padding:26px 24px;
  transition:transform .25s ease, border-color .25s ease;
}
.cours-card:hover{ border-color:var(--rouge-vif); }
.cours-card h3{
  font-family:var(--label); font-weight:700; font-size:18px; text-transform:uppercase; letter-spacing:.01em;
  margin-bottom:6px; line-height:1.2;
}
.cours-badge{
  display:inline-block; background:var(--rouge); color:#fff;
  font-family:var(--label); font-size:11px; font-weight:600; letter-spacing:.08em; text-transform:uppercase;
  padding:3px 10px; margin-bottom:12px;
}
.cours-card p{ color:var(--texte-mute); font-size:14px; line-height:1.6; margin-bottom:14px; }
.horaires{ display:flex; flex-wrap:wrap; gap:7px; }
.horaire{
  font-family:var(--label); font-size:14px; font-weight:600;
  background:rgba(0,0,0,.3); border:1px solid rgba(237,231,221,.1); padding:7px 14px; color:var(--texte-mute);
}

/* ===== Tarifs ===== */
.tarifs-bloc{
  background:var(--noir);
  border:1px solid var(--bordure);
  padding:48px 40px;
}
.tarifs-titre{ text-align:center; font-family:var(--titre); font-size:30px; letter-spacing:.02em; margin-bottom:6px; }
.tarifs-souslegende{ text-align:center; color:var(--texte-mute); font-size:14px; margin-bottom:30px; }

.legende{ display:flex; justify-content:center; gap:26px; margin-bottom:32px; flex-wrap:wrap; }
.legende-item{ display:flex; align-items:center; gap:8px; font-family:var(--label); font-size:13px; letter-spacing:.05em; color:var(--texte-mute); text-transform:uppercase; }
.puce{ width:11px; height:11px; border-radius:50%; }
.puce.r{ background:var(--rouge-vif); }
.puce.g{ background:var(--texte-mute); }

.tarifs-cat{
  font-family:var(--label); font-size:13px; font-weight:600; letter-spacing:.16em; text-transform:uppercase;
  color:var(--texte-mute); margin:32px 0 16px;
}
.tarifs-cat .plus{ color:var(--rouge-vif); }

.tarifs-grille{ display:grid; gap:14px; }
.tarifs-grille.q4{ grid-template-columns:repeat(4,1fr); }
.tarifs-grille.q2{ grid-template-columns:repeat(2,1fr); }

.tarif-carte{
  background:var(--fond-clair);
  border-left:4px solid var(--rouge);
  padding:24px 18px;
  text-align:center;
  transition:border-color .25s ease;
}
.tarif-carte:hover{ border-color:var(--rouge-vif); }
.tarif-carte.vedette{ border-left-color:var(--rouge-vif); border-left-width:6px; }
.tarif-carte h4{
  font-family:var(--label); font-weight:600; font-size:14px; text-transform:uppercase; color:var(--texte-mute);
  min-height:36px; display:flex; align-items:center; justify-content:center; margin-bottom:14px;
}
.duo-prix{ display:flex; align-items:flex-end; justify-content:center; gap:10px; }
.prix-col{ text-align:center; }
.prix-val{ font-family:var(--titre); font-size:36px; line-height:1; }
.prix-val.r{ color:var(--rouge-vif); }
.prix-val.g{ color:var(--texte-mute); }
.prix-val sup{ font-size:15px; }
.prix-tag{ font-family:var(--label); font-size:9.5px; letter-spacing:.08em; text-transform:uppercase; margin-top:4px; }
.prix-tag.r{ color:var(--rouge-vif); }
.prix-tag.g{ color:var(--texte-mute); }
.sep{ color:var(--texte-mute); font-size:17px; padding-bottom:14px; opacity:.5; }
.note{ color:var(--texte-mute); font-size:11.5px; margin-top:8px; font-style:italic; }


/* ===== Contact ===== */
#contact{ background:var(--noir); padding:90px 0; }
.contact-wrap{
  max-width:980px; margin:0 auto; padding:0 40px;
  display:grid; grid-template-columns:.85fr 1.15fr; gap:56px;
}
.carte-acces{
  max-width:980px; margin:48px auto 0; padding:0 40px;
}
.carte-acces h3{ font-family:var(--titre); font-size:24px; letter-spacing:.02em; margin-bottom:18px; }
.carte-wrap{
  border:1px solid var(--bordure);
  overflow:hidden;
}
.carte-wrap iframe{ width:100%; height:340px; border:0; display:block; }
.carte-lien{
  display:inline-flex; align-items:center; gap:8px;
  margin-top:16px;
  font-family:var(--label); font-weight:600; font-size:13px; letter-spacing:.06em; text-transform:uppercase;
  color:var(--texte-mute);
  border-bottom:1px solid var(--bordure);
  padding-bottom:2px;
  transition:color .2s, border-color .2s;
}
.carte-lien:hover{ color:var(--texte); border-color:var(--rouge-vif); }
.contact-info h3{ font-family:var(--titre); font-size:24px; letter-spacing:.02em; margin-bottom:24px; }
.ligne-info{ display:flex; gap:14px; margin-bottom:20px; align-items:flex-start; }
.ligne-info .ic{
  width:36px; height:36px; flex-shrink:0; border-radius:50%;
  background:rgba(181,21,42,.14); border:1px solid rgba(181,21,42,.3);
  display:flex; align-items:center; justify-content:center; font-size:14px;
}
.ligne-info .txt{ font-size:14px; color:var(--texte-mute); line-height:1.5; padding-top:6px; }
.ligne-info .txt strong{ color:var(--texte); display:block; font-family:var(--label); font-weight:600; letter-spacing:.02em; }

.champ{ margin-bottom:16px; }
.champ input, .champ textarea{
  width:100%; background:var(--fond); border:1px solid rgba(237,231,221,.12); color:var(--texte);
  font-family:var(--corps); font-size:14px; padding:14px 16px; outline:none;
  transition:border-color .2s;
}
.champ textarea{ height:120px; resize:vertical; }
.champ input:focus, .champ textarea:focus{ border-color:var(--rouge-vif); }
.contact-form .btn{ width:100%; padding:15px; margin-top:4px; }

.notif{ display:none; margin-top:14px; padding:12px 16px; font-family:var(--label); font-size:13px; text-align:center; border:1px solid; }
.notif.succes{ display:block; background:rgba(40,180,99,.08); border-color:rgba(40,180,99,.4); color:#5fd98c; }
.notif.erreur{ display:block; background:rgba(216,30,50,.08); border-color:rgba(216,30,50,.4); color:#ff8d96; }

/* ===== Inscription ===== */
#inscription{ background:var(--noir); padding:90px 0; }
.inscription-wrap{ max-width:1000px; margin:0 auto; padding:0 40px; }

.etapes{
  display:grid; grid-template-columns:repeat(3,1fr); gap:20px;
  margin-bottom:56px;
}
.etape{
  background:var(--fond-clair);
  border-left:4px solid var(--rouge);
  padding:26px 24px;
  transition:border-color .2s ease;
}
.etape:hover{ border-color:var(--rouge-vif); }
.etape-num{
  font-family:var(--titre); font-size:34px; color:var(--rouge-vif); line-height:1;
  margin-bottom:10px; display:block;
}
.etape h4{
  font-family:var(--label); font-weight:700; font-size:15.5px; letter-spacing:.02em;
  text-transform:uppercase; color:var(--texte); margin-bottom:8px;
}
.etape p{ font-size:13.5px; color:var(--texte-mute); line-height:1.55; }

.doc-bloc{
  background:var(--fond-clair);
  border:1px solid var(--bordure);
  padding:44px;
  display:flex;
  align-items:center;
  gap:36px;
  flex-wrap:wrap;
}
.doc-apercu{
  flex-shrink:0;
  width:120px; height:160px;
  background:#fff;
  border-radius:4px;
  box-shadow:0 4px 14px rgba(0,0,0,.3);
  position:relative;
  overflow:hidden;
  display:flex; align-items:center; justify-content:center;
}
.doc-apercu::before{
  content:"";
  position:absolute; top:0; left:0; right:0; height:10px;
  background:var(--rouge);
}
.doc-apercu .doc-lignes{
  width:80%; display:flex; flex-direction:column; gap:7px; margin-top:14px;
}
.doc-apercu .doc-lignes span{ display:block; height:3px; background:#ddd; border-radius:2px; }
.doc-apercu .doc-lignes span:nth-child(1){ width:70%; }
.doc-apercu .doc-lignes span:nth-child(2){ width:90%; }
.doc-apercu .doc-lignes span:nth-child(3){ width:55%; }
.doc-apercu .doc-lignes span:nth-child(4){ width:85%; margin-top:8px; }
.doc-apercu .doc-lignes span:nth-child(5){ width:65%; }
.doc-apercu .doc-icone{
  position:absolute; bottom:14px; right:14px; font-size:20px; opacity:.5;
}

.doc-texte{ flex:1; min-width:240px; }
.doc-texte h3{
  font-family:var(--titre); font-size:28px; letter-spacing:.02em; margin-bottom:10px;
}
.doc-texte p{ font-size:14.5px; color:var(--texte-mute); line-height:1.6; margin-bottom:18px; }
.doc-texte p strong{ color:var(--texte); }

.alerte-papier{
  display:flex; align-items:flex-start; gap:12px;
  background:var(--fond);
  border:1px solid var(--bordure);
  border-left:3px solid var(--rouge);
  padding:14px 18px;
  margin-bottom:22px;
}
.alerte-papier .ic{ font-size:18px; flex-shrink:0; }
.alerte-papier p{
  font-family:var(--label); font-weight:600; font-size:13px; letter-spacing:.02em;
  text-transform:uppercase; color:var(--texte-mute); margin:0; line-height:1.5;
}

.doc-cta{ display:flex; gap:10px; flex-wrap:wrap; }

/* ===== Footer ===== */
footer{
  background:var(--noir); border-top:1px solid var(--rouge);
  padding:30px 40px; display:flex; align-items:center; justify-content:space-between; flex-wrap:wrap; gap:12px;
  font-family:var(--label); font-size:12px; letter-spacing:.06em; text-transform:uppercase; color:var(--texte-mute);
}
footer a{ color:var(--rouge-vif); }
footer a:hover{ color:var(--texte); }

/* ===== Responsive ===== */
@media (max-width:900px){
  .topbar, .header-cta{ display:none; }
  .hamburger{ display:flex; }
  .header-inner{ padding:0 20px; }
  nav{
    position:fixed; top:80px; left:0; right:0; bottom:0;
    background:var(--noir); flex-direction:column; padding:16px;
    display:none;
  }
  nav.ouvert{ display:flex; }
  nav ul{ flex-direction:column; width:100%; margin-left:0; gap:0; }
  nav ul li a{ padding:16px 12px; font-size:16px; border-bottom:1px solid rgba(237,231,221,.06); }

  .cours-grid{ grid-template-columns:1fr; }
  .club-wrap{ grid-template-columns:1fr; gap:32px; }
  .etapes{ grid-template-columns:1fr; }
  .tarifs-grille.q4{ grid-template-columns:repeat(2,1fr); }
  .tarifs-grille.q2{ grid-template-columns:1fr; }
  .tarifs-bloc{ padding:36px 20px; }
  .contact-wrap{ grid-template-columns:1fr; gap:44px; }
  footer{ justify-content:center; text-align:center; }
}

@media (max-width:560px){
  .tarifs-grille.q4{ grid-template-columns:1fr; }
  .tarif-carte{ padding:20px 16px; }
  .duo-prix{ gap:6px; }
  .prix-val{ font-size:30px; }

  .doc-bloc{ padding:28px 20px; flex-direction:column; text-align:center; }
  .doc-apercu{ margin:0 auto; }
  .doc-texte{ min-width:0; width:100%; }
  .doc-cta{ justify-content:center; }
  .doc-cta .btn{ width:100%; }

  .etape{ padding:20px 18px; }
}
