/* ---- Variables & base ---- */
:root{
  --sage:#A3B18A;
  --sage-600:#7F8F68;
  --beige:#F5F1E9;
  --charcoal:#333333;
  --white:#ffffff;
  --shadow:0 10px 30px rgba(0,0,0,.08);
  --radius:20px;
  --electrofit:#0A1E3F; --magicfitness:#0a0a0a;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:'Poppins', system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  color:var(--charcoal);
  background:var(--beige);
  line-height:1.6;
}
img{max-width:100%;display:block}
.container{width:min(1120px,92%);margin:0 auto}

.serif{font-family:'Marcellus', serif}

/* ---- Header & Nav ---- */
.site-header{
  background:linear-gradient(180deg, rgba(163,177,138,.18), rgba(245,241,233,1));
  position:relative;
}
.nav{display:flex;align-items:center;justify-content:space-between;padding:1rem 0}
.brand{display:flex;align-items:center;gap:.6rem;font-weight:600;text-decoration:none;color:var(--charcoal)}
nav a{margin-left:1rem;text-decoration:none;color:var(--charcoal);font-weight:500}
nav a.btn{margin-left:1rem}
.burger{display:none;background:none;border:0;padding:.4rem;cursor:pointer}
.burger span{display:block;width:24px;height:2px;background:#333;margin:5px 0}

/* ---- Buttons ---- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;
  padding:.9rem 1.15rem;border-radius:999px;text-decoration:none;border:1px solid transparent;
  box-shadow:var(--shadow);transition:.2s ease;
}
.btn:hover{transform:translateY(-1px)}
.btn-primary{background:var(--sage);color:var(--white)}
.btn-primary:hover{background:var(--sage-600)}
.btn-secondary{background:var(--white)}
.btn-ghost{background:transparent;border-color:#dcdcdc}
.btn-ghost:hover{background:#efefef}
.btn-magicfitness{background:var(--magicfitness); color:#fff; font-weight:800; padding:10px 14px; border-radius:999px}
.btn-electrofit{background:var(--electrofit); color:#fff; font-weight:800; padding:10px 14px; border-radius:999px}

/* ---- Hero ---- */
.hero{display:grid;grid-template-columns:1.1fr .9fr;gap:2rem;align-items:center;padding:2rem 0 2.5rem}
.hero h1{font-size:clamp(2rem,5vw,3.2rem);line-height:1.1;margin:.2rem 0 1rem}
.hero p{font-size:1.05rem}
.cta-row{display:flex;gap:1rem;margin-top:1rem}
.hero-visual img{border-radius:var(--radius);box-shadow:var(--shadow)}

/* ---- Sections ---- */
.section{padding:4rem 0}
.section.soft{background:linear-gradient(180deg, rgba(163,177,138,.10), rgba(245,241,233,0));}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:2rem;align-items:center}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:1.6rem}
.rounded{border-radius:var(--radius)}
.shadow{box-shadow:var(--shadow)}
h2{font-size:clamp(1.6rem,3.2vw,2.2rem);margin:0 0 1rem}
h3{margin:.2rem 0 .4rem;font-size:1.15rem}
.list-check{padding-left:0;list-style:none;margin:1rem 0 0}
.list-check li{position:relative;padding-left:1.8rem;margin:.45rem 0}
.list-check li::before{
  content:"";position:absolute;left:0;top:.32rem;width:1.1rem;height:1.1rem;
  background:url('../images/check.svg') no-repeat center/contain;opacity:.95;
}

/* ---- Cards ---- */
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-top:1.2rem}
.cards-6{grid-template-columns:repeat(3,1fr)}
.card{background:var(--white);border-radius:var(--radius);padding:1.2rem;box-shadow:var(--shadow)}
.card p{margin:.4rem 0 0}

/* ---- Pricing ---- */
.pricing-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;margin-top:1rem}
.price-card{background:var(--white);border-radius:var(--radius);padding:1.2rem;box-shadow:var(--shadow);display:flex;flex-direction:column}
.price-card .lead{color:#666;margin:.1rem 0 .6rem}
.price-card .price{font-size:1.8rem;font-weight:700;margin:.6rem 0 1rem}
.price-card ul{list-style:none;padding:0;margin:0}
.price-card li{padding:.35rem 0;border-bottom:1px dashed #eee}

/* ---- Info blocks ---- */
.info-block{background:var(--white);padding:1.2rem;border-radius:var(--radius);box-shadow:var(--shadow)}
.schedule{list-style:none;padding:0;margin:.2rem 0 0}
.schedule li{padding:.45rem 0;border-bottom:1px dashed #eee}

/* ---- Gallery ---- */
.gallery{display:grid;grid-template-columns:repeat(4,1fr);gap:.8rem;margin-top:1rem}
.gallery img{box-shadow:var(--shadow)}

/* ---- Testimonials ---- */
.testimonials{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-top:.6rem}
blockquote{background:var(--white);border-radius:var(--radius);padding:1rem;box-shadow:var(--shadow);margin:0}
blockquote cite{display:block;margin-top:.6rem;color:#666;font-style:normal}

/* ---- Contact ---- */
.contact-grid{align-items:stretch}
.contact-card{background:var(--white);padding:1.2rem;border-radius:var(--radius);box-shadow:var(--shadow)}
.coach{display:flex;align-items:center;gap:.8rem;margin-bottom:1rem}
.contact-list{list-style:none;padding:0;margin:0 0 1rem}
.contact-list li{display:flex;align-items:center;justify-content:space-between;padding:.4rem 0;border-bottom:1px dashed #eee}
.form-row{display:flex;flex-direction:column;margin:.6rem 0}
input, textarea{padding:.9rem 1rem;border-radius:12px;border:1px solid #ddd;background:#fff;outline:none}
input:focus, textarea:focus{border-color:var(--sage);box-shadow:0 0 0 4px rgba(163,177,138,.18)}
.form-actions{display:flex;gap:.8rem;align-items:center;margin-top:.6rem;flex-wrap:wrap}
.map-wrap{position:relative;padding-top:62%;border-radius:12px;overflow:hidden;margin-top:.6rem}
.map-wrap iframe{position:absolute;inset:0;width:100%;height:100%;border:0}

/* ---- Footer ---- */
.site-footer {
  background: #f5f5f5;
  color: #333;
  padding: 3rem 1.5rem;
  margin-top: 3rem;
  border-top: 1px solid #ddd;
}

.footer-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 2rem;
  margin-bottom: 2rem;
}

.footer-col h3 {
  margin-bottom: 0.75rem;
  font-size: 1.1rem;
  color: #222;
}

.footer-links {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}

.footer-links a {
  text-decoration: none;
  color: #555;
  transition: color 0.2s;
}

.footer-links a:hover {
  color: #c25b37; /* petite touche zen/orangé */
}

.footer-credit {
  text-align: center;
  font-size: 0.9rem;
  border-top: 1px solid #ddd;
  padding-top: 1rem;
  color: #777;
}

/* ---- Animations ---- */
.fade{opacity:0;transform:translateY(14px);transition:opacity .6s ease, transform .6s ease}
.fade.visible{opacity:1;transform:translateY(0)}

/* ---- Responsive ---- */

@media (max-width: 1024px){ 
.pricing-grid{grid-template-columns:repeat(2,1fr)} 
.testimonials{grid-template-columns:1fr 1fr} } 

@media (max-width: 920px){ 
.hero{grid-template-columns:1fr;gap:1rem} 
.grid-2{grid-template-columns:1fr} 
.grid-3{grid-template-columns:1fr} 
.cards, .cards-6{grid-template-columns:1fr 1fr} 
.gallery{grid-template-columns:1fr 1fr} 
.footer-grid{grid-template-columns:1fr} 
nav.site-nav {
    display: none;
    flex-direction: column;
    background: var(--beige);
    position: absolute;
    top: 70px; /* ajuster si nécessaire selon header */
    left: 0;
    right: 0;
    padding: 1rem 0;
    gap: 0.8rem;
    box-shadow: 0 4px 12px rgba(0,0,0,0.15);
    text-align: center;
    z-index: 999;
  }

  nav.site-nav.active {
    display: flex;
  }

  nav.site-nav a {
    margin: 0.5rem 0;
    font-size: 1.1rem;
    display: block;
  }

  .burger {
    display: flex;
    flex-direction: column;
    justify-content: center;
    gap: 5px;
    background: none;
    border: none;
    cursor: pointer;
  }

  .burger span {
    display: block;
    width: 24px;
    height: 2px;
    background: var(--charcoal);
    border-radius: 2px;
  }
 } 



@media (max-width: 520px){ 
.cards, .cards-6{grid-template-columns:1fr} 
.gallery{grid-template-columns:1fr} 
.testimonials{grid-template-columns:1fr} }
