:root{
  --pastel-blue: #9999FF;
  --pastel-pink: #EEA4F4;
  --white: #FFFFFF;
  --max-width: 1200px;
  --grad-main: linear-gradient(135deg,var(--pastel-blue),var(--pastel-pink));
  --grad-subtle: linear-gradient(180deg, rgba(153,153,255,0.07), rgba(238,164,244,0.03));
}
*{box-sizing:border-box}
body{margin:0;font-family:'Quicksand',system-ui,Segoe UI,Roboto,Arial;background:var(--white);color:#111;-webkit-font-smoothing:antialiased}
.container{max-width:var(--max-width);margin:0 auto;padding:28px}
.container.small{padding:16px}

.site-header{position:sticky;top:0;z-index:50;background:rgba(255,255,255,0.85);backdrop-filter:blur(6px);border-bottom:1px solid rgba(0,0,0,0.04)}
.nav-inner{max-width:var(--max-width);margin:0 auto;display:flex;align-items:center;justify-content:space-between;padding:12px 24px}
.brand .logo{height:130px;width:auto;display:block;border-radius:8px}
.main-nav ul{list-style:none;margin:0;padding:0;display:flex;gap:8px;align-items:center}
.main-nav a{display:inline-block;padding:8px 12px;border-radius:12px;text-decoration:none;font-weight:600;font-family:'Poppins',sans-serif;color:#222;transition:all .18s ease}
.main-nav a:hover{transform:translateY(-3px)}
.main-nav a.active{background:var(--grad-main);color:var(--white);box-shadow:0 8px 28px rgba(153,153,255,0.12)}

.nav-toggle{display:none;background:none;border:0;padding:8px;cursor:pointer}
.nav-toggle span{display:block;width:22px;height:2px;background:#222;margin:4px 0;transition:transform .18s ease}

/* Hero */
.hero{padding:36px 0}
.hero-inner{display:grid;grid-template-columns:1fr 420px;gap:28px;align-items:center}
.hero-text h1{font-family:'Poppins',sans-serif;font-size:clamp(28px,4vw,44px);margin:0 0 10px}
.lead{font-size:18px;margin:0 0 18px;line-height:1.5}
.hero-ctas{display:flex;gap:12px}

.btn{display:inline-flex;align-items:center;gap:8px;padding:12px 18px;border-radius:12px;font-weight:700;text-decoration:none;transition:transform .18s ease,box-shadow .18s ease}
.btn:hover{transform:translateY(-4px)}
.btn.primary{background:var(--grad-main);color:var(--white);box-shadow:0 12px 40px rgba(153,153,255,0.12)}
.btn.primary.large{padding:14px 22px;font-size:1.05rem}
.btn.outline{background:transparent;border:1px solid rgba(27,27,27,0.06)}

/* hero image */
.hero-image img{width:100%;max-width:420px;border-radius:14px;box-shadow:0 12px 40px rgba(0,0,0,0.06)}

/* features */
.features{padding:36px 0}
.section-title{font-family:'Poppins',sans-serif;font-size:20px;margin-bottom:14px}
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.card{background:var(--white);padding:18px;border-radius:12px;box-shadow:0 8px 26px rgba(11,11,11,0.04);transition:transform .22s ease,box-shadow .22s ease}
.card:hover{transform:translateY(-6px);box-shadow:0 20px 48px rgba(11,11,11,0.06)}

/* news */
.news{padding:24px 0}
.news-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}
.news-card{padding:14px;border-radius:12px;background:var(--grad-subtle);box-shadow:0 6px 20px rgba(0,0,0,0.04)}

/* CTA strip */
.cta-strip{margin:28px 0;padding:22px;border-radius:14px;background:var(--grad-subtle);display:flex;align-items:center;justify-content:space-between}
.cta-inner h3{margin:0;font-family:'Poppins',sans-serif}

/* footer */
.site-footer{border-top:1px solid rgba(0,0,0,0.04);padding:18px 0;margin-top:28px}
.footer-inner{display:flex;justify-content:space-between;align-items:center;font-size:14px}

/* Responsiveness */
@media (max-width:980px){
  .hero-inner{grid-template-columns:1fr;grid-auto-rows:min-content}
  .cards{grid-template-columns:1fr 1fr}
  .news-grid{grid-template-columns:1fr}
}
@media (max-width:560px){
  .main-nav{display:none}
  .nav-toggle{display:block}
  .cards{grid-template-columns:1fr}
}

/* Page Activités */
.intro-activites {
  text-align: center;
  font-family: 'Poppins', sans-serif;
  margin-bottom: 32px;
}

/*
.activites-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 24px;
  margin-bottom: 40px;
}
*/


.activites-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  justify-content: center;
  max-width: 900px;   /* largeur max du bloc */
  margin: 0 auto 40px auto; /* centre horizontalement */
}

@media (max-width: 900px) {
  .activites-grid {
    grid-template-columns: repeat(2, 1fr);
    max-width: 600px;
  }
}

@media (max-width: 600px) {
  .activites-grid {
    grid-template-columns: 1fr;
    max-width: 400px;
  }
}
/*
.activites2-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 24px;
  justify-content: center;
  max-width: 600px;   /* largeur max du bloc */
/*  margin: 0 auto 40px auto; /* centre horizontalement */
/*}*/
/*
@media (max-width: 900px) {
  .activites2-grid {
    grid-template-columns: repeat(2, 1fr);
    max-width: 600px;
  }
}

@media (max-width: 600px) {
  .activites2-grid {
    grid-template-columns: 1fr;
    max-width: 400px;
  }
}
*/

.activite {
  background: var(--white);
  border-radius: 14px;
  box-shadow: 0 8px 20px rgba(0,0,0,0.05);
  text-align: center;
  padding: 18px;
  transition: transform 0.2s ease, box-shadow 0.2s ease;
}
.activite:hover {
  transform: translateY(-4px);
  box-shadow: 0 14px 30px rgba(0,0,0,0.08);
}
.activite img {
  max-width: 100%;
  border-radius: 12px;
  margin-bottom: 12px;
}
.activite h3 {
  font-family: 'Poppins', sans-serif;
  margin: 8px 0 6px;
}

/* Planning table */
.planning-table {
  width: 100%;
  border-collapse: collapse;
  margin: 20px 0;
  font-size: 15px;
}
.planning-table th {
  background: var(--pastel-blue);
  color: var(--white);
  padding: 10px;
  text-align: left;
}
.planning-table td {
  padding: 8px 10px;
  border-bottom: 1px solid rgba(0,0,0,0.08);
}
.infos-salles {
  font-size: 14px;
  margin-top: 16px;
  background: var(--grad-subtle);
  padding: 12px;
  border-radius: 10px;
}
.download-link {
  text-align: center;
  margin-top: 24px;
}


/* --- PAGE ÉQUIPES --- */

.team-section {
  margin-bottom: 50px;
  text-align: center;
}

.team-section h1 {
  font-family: 'Poppins', sans-serif;
  margin-bottom: 28px;
}

/* Grilles centrées */
.team-grid {
  display: grid;
  gap: 24px;
  justify-content: center;
  margin-bottom: 32px;
}

/* 3 personnes sur la première ligne */
.team-grid-3 {
  grid-template-columns: repeat(3, 1fr);
  max-width: 900px;
  margin-left: auto;
  margin-right: auto;
}

/* 2 personnes sur la deuxième ligne */
.team-grid-2 {
  grid-template-columns: repeat(2, 1fr);
  max-width: 600px;
  margin-left: auto;
  margin-right: auto;
}

.member {
  background: var(--white);
  padding: 18px;
  border-radius: 14px;
  box-shadow: 0 8px 20px rgba(0,0,0,0.06);
  transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.member:hover {
  transform: translateY(-6px);
  box-shadow: 0 14px 30px rgba(0,0,0,0.10);
}

.member img {
  width: 100%;
  max-width: 220px;
  border-radius: 12px;
  margin-bottom: 12px;
}

.member h3 {
  font-family: 'Poppins', sans-serif;
  margin: 4px 0 2px;
}

.member .role {
  font-size: 0.9rem;
  color: #666;
}

/* Responsive */
@media (max-width: 900px) {
  .team-grid-3 { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 600px) {
  .team-grid-3,
  .team-grid-2 { grid-template-columns: 1fr; max-width: 400px; }
}


/* --- PAGE TARIFS --- */

.tarifs-page h1,
.tarifs-page h2 {
  font-family: 'Poppins', sans-serif;
  text-align: center;
}

.intro-tarifs {
  text-align: center;
  margin-bottom: 40px;
}

.cotisation-card,
.tarif-card,
.multisport-card {
  background: var(--white);
  padding: 22px;
  border-radius: 14px;
  text-align: center;
  box-shadow: 0 8px 20px rgba(0,0,0,0.06);
  margin: 0 auto 24px auto;
  max-width: 500px;
}

.cotisation-card .prix,
.tarif-card .montant,
.multisport-card .montant {
  font-size: 2rem;
  font-weight: 700;
  background: var(--grad-main);
  -webkit-background-clip: text;
  color: transparent;
  margin: 10px 0;
}

.tarifs-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  max-width: 900px;
  margin: 0 auto 40px auto;
}

.tarif-card .details,
.multisport-card .details {
  font-size: 0.9rem;
  color: #666;
}

/* Table */
.tarif-table {
  width: 60%;               /* largeur réduite */
  margin: 20px auto;        /* centre horizontalement */
  border-collapse: collapse;
  text-align: center;       /* centre le texte dans le tableau */
}

.tarif-table th {
  background: var(--pastel-blue);
  color: var(--white);
  padding: 10px;
  text-align: center;       /* centre cellules */
}

.tarif-table td {
  padding: 10px;
  border-bottom: 1px solid rgba(0,0,0,0.08);
  text-align: center;       /* centre cellules */
}

.cta-inscription {
  text-align: center;
  margin-top: 40px;
}

/* Responsive */
@media (max-width: 900px) {
  .tarifs-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 600px) {
  .tarifs-grid {
    grid-template-columns: 1fr;
    max-width: 400px;
  }
}


/* Widget HelloAsso intégré */
.helloasso-widget {
  max-width: 900px;
  margin: 0 auto 20px auto;
}

.helloasso-widget iframe {
  background: var(--white);
}

/* Bouton temporaire grisé */
.disabled-temp {
  opacity: 0.6;
  cursor: not-allowed;
}

/* Note d’information */
.cta-inscription .note {
  font-size: 0.9rem;
  color: #666;
  margin-top: 12px;
}


/* --- PAGE À PROPOS --- */

.apropos-page h1,
.apropos-page h2 {
  text-align: center;
  font-family: 'Poppins', sans-serif;
}

.apropos-hero {
  text-align: center;
  margin-bottom: 40px;
  max-width: 800px;
  margin-left: auto;
  margin-right: auto;
}

.apropos-hero p {
  font-size: 1.1rem;
  color: #555;
}

/* Mission */
.mission {
  text-align: center;
  margin-bottom: 40px;
}

/* Valeurs */
.valeurs-grid {
  display: grid;
  grid-template-columns: repeat(3,1fr);
  gap: 24px;
  max-width: 1000px;
  margin: 0 auto 40px auto;
}

.valeur-card {
  background: var(--white);
  padding: 22px;
  border-radius: 14px;
  box-shadow: 0 8px 20px rgba(0,0,0,0.06);
  text-align: center;
  transition: transform .2s ease, box-shadow .2s ease;
}

.valeur-card:hover {
  transform: translateY(-6px);
  box-shadow: 0 18px 40px rgba(0,0,0,0.08);
}

/* Histoire */
.histoire {
  max-width: 900px;
  margin: 0 auto 40px auto;
  text-align: center;
}

/* Fonctionnement */
.fonctionnement {
  max-width: 800px;
  margin: 0 auto 40px auto;
}

.fonctionnement ul {
  list-style: none;
  padding: 0;
  text-align: center;
}

.fonctionnement li {
  margin: 6px 0;
}

/* Contact */
.contact-grid {
  display: grid;
  grid-template-columns: repeat(3,1fr);
  gap: 24px;
  max-width: 1000px;
  margin: 0 auto 40px auto;
}

.contact-card {
  background: var(--white);
  padding: 22px;
  border-radius: 14px;
  box-shadow: 0 8px 20px rgba(0,0,0,0.06);
  text-align: center;
}

.contact-card a {
  color: var(--pastel-blue);
  font-weight: 600;
}

/* CTA final */
.cta-apropos {
  text-align: center;
  margin-top: 40px;
}

/* Responsive */
@media (max-width: 900px) {
  .valeurs-grid,
  .contact-grid {
    grid-template-columns: 1fr 1fr;
  }
}

@media (max-width: 600px) {
  .valeurs-grid,
  .contact-grid {
    grid-template-columns: 1fr;
    max-width: 380px;
  }
}

/* Icônes réseaux sociaux */
.social-icons {
  margin-top: 10px;
}

.facebook-icon .icon {
  width: 36px;
  height: 36px;
  fill: #9999FF; /* bleu pastel du site */
  transition: transform 0.2s ease, fill 0.2s ease;
}

.facebook-icon:hover .icon {
  transform: scale(1.12);
  fill: #EEA4F4; /* rose pastel au survol */
}

/* --- PAGE CONTACT --- */

.contact-page h1 {
  text-align: center;
  font-family: 'Poppins', sans-serif;
}

.contact-intro {
  text-align: center;
  margin-bottom: 40px;
}

.contact-form-section {
  max-width: 600px;
  margin: 0 auto 50px auto;
}

.contact-form {
  display: flex;
  flex-direction: column;
  gap: 16px;
  background: var(--white);
  padding: 28px;
  border-radius: 14px;
  box-shadow: 0 8px 20px rgba(0,0,0,0.06);
}

.contact-form label {
  font-weight: 600;
  font-family: 'Poppins', sans-serif;
}

.contact-form input,
.contact-form textarea {
  padding: 10px 14px;
  border: 1px solid #ccc;
  border-radius: 8px;
  font-family: 'Quicksand', sans-serif;
  font-size: 1rem;
}
