:root{
  /* Couleurs (tokens) */
  --bg-base:#F7F6F4; 
  --bg-section:#EDEBE7; 
  --text:#2B2B2E; 
  --text-muted:#5A5A5F;
  --brand:#2B2B2E; 
  --accent:#5CB85C; 
  --border:#E6E4E1; 
  --shadow:0 8px 24px rgba(20,18,18,.08);
  
  /* Typo */
  --h1-m:32px; 
  --h1-d:56px; 
  --h2-m:24px;
  --h2-d:32px; 
  --h3-m:18px;
  --h3-d:24px; 
  --body-m:16px; 
  --body-d:18px;
  
  /* Spacing (8pt) */
  --s4:4px; 
  --s8:8px; 
  --s12:12px; 
  --s16:16px; 
  --s24:24px; 
  --s32:32px; 
  --s48:48px; 
  --s64:64px; 
  --s96:96px;
  
  /* Layout */
  --container:1024px; 
  --radius:12px; 
  --radius-btn:8px;
}

/* Reset de base */
*{
  box-sizing:border-box;
  margin:0;
  padding:0;
}

html,body{
  margin:0;
  background:var(--bg-base);
  color:var(--text);
  font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  font-size:var(--body-m);
  line-height:1.6;
}

img{
  max-width:100%;
  height:auto;
  display:block;
}

a{
  color:inherit;
  text-decoration:none;
}

/* Container & Wrap */
.wrap{
  max-width:1000px;
  margin:0 auto;
  padding:0 var(--s16);
}

.container{
  max-width:var(--container);
  margin:auto;
  padding:0 var(--s16);
  position:relative; 
  z-index:1;
}

.section{
  padding:var(--s48) 0;
}

.section.alt{
  background:var(--bg-section);
}

/* Header - Mobile First */
.header{
  position:sticky;
  top:0;
  z-index:50;
  background:#fff;
  border-bottom:1px solid var(--border);
}

.header .bar{
  display:flex;
  align-items:center;
  justify-content:space-between;
  height:64px;
  padding:0 var(--s16);
}

.logo{
  font-family:Spectral,serif;
  font-weight:700;
  font-size:18px;
  letter-spacing:.3px;
  display:flex;
  align-items:center;
}

.logo img{
  max-height:40px;
  width:auto;
}

/* Navigation mobile */
.nav{
  display:none;
  flex-direction:column;
  gap:var(--s16);
  position:absolute;
  top:64px;
  right:var(--s16);
  left:var(--s16);
  background:#fff;
  padding:var(--s16);
  border:1px solid var(--border);
  border-radius:var(--radius);
  box-shadow:var(--shadow);
}

.nav a{
  opacity:.9;
  padding:var(--s8) 0;
  display:block;
}

.nav a:hover{
  opacity:1;
}

.burger{
  background:none;
  border:0;
  font-size:24px;
  cursor:pointer;
  padding:var(--s8);
}

/* Boutons */
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  border-radius:var(--radius-btn);
  font-weight:600;
  padding:12px 20px;
  text-align:center;
  transition:all 0.3s ease;
  cursor:pointer;
}

.btn-primary{
  background:var(--brand);
  color:#fff;
  border:none;
  box-shadow:var(--shadow);
}

.btn-primary:hover{
  transform:translateY(-2px);
  box-shadow:0 12px 32px rgba(20,18,18,.12);
}

.btn-secondary{
  border:1px solid var(--brand);
  background:transparent;
}

.btn-ghost{
  background:transparent;
  border:1px solid var(--brand);
}

/* Hero Section - Mobile First */
.hero--bg{
  min-height:60vh;
  display:grid;
  align-items:center;
  overflow:hidden;
  background-image:
    linear-gradient(to bottom, rgba(0, 0, 0, 0.555), rgba(0, 0, 0, 0.178)),
    url("../img/header-hero-hedorenov.png");
  background-size:cover;
  background-position:center;
  background-repeat:no-repeat;
  position:relative;
  color:#F7F6F4;
  padding:var(--s32) 0;
}

.hero--bg .container{
  z-index:2;
}

.hero--bg h1{
  font-family:"Playfair Display",serif;
  font-weight:700;
  font-size:var(--h1-m);
  line-height:1.2;
  margin:0 0 var(--s16);
}

.hero--bg p{
  font-size:var(--body-m);
  margin:0 0 var(--s24);
  opacity:0.95;
}

.usp{
  list-style:none;
  margin:var(--s24) 0;
  padding:0;
}

.usp li{
  padding:var(--s8) 0;
  padding-left:var(--s24);
  position:relative;
}

.usp li::before{
  content:"✓";
  position:absolute;
  left:0;
  color:var(--accent);
  font-weight:700;
}

.hero-ctas{
  display:flex;
  flex-direction:column;
  gap:var(--s12);
  margin-top:var(--s32);
}

/* Grid systems - Mobile First */
.grid-2{
  display:grid;
  grid-template-columns:1fr;
  gap:var(--s24);
}

.grid-3{
  display:grid;
  grid-template-columns:1fr;
  gap:var(--s24);
  padding:0;
}

.sixetape{
  padding:var(--s24);
  background:#fff;
  border:1px solid var(--border);
  border-radius:var(--radius);
  height:auto;
  width:100%;
}

.sixetape img{
  width:100%;
  height:auto;
  max-width:200px;
  margin:0 auto var(--s16);
}

.sixetape h3{
  font-size:var(--h3-m);
  margin:0 0 var(--s12);
  text-align:center;
}

.sixetape p{
  text-align:center;
  font-size:14px;
}

/* Cards */
.cards{
  display:grid;
  gap:var(--s16);
  grid-template-columns:1fr;
}

.card{
  background:#fff;
  border:1px solid var(--border);
  border-radius:var(--radius);
  padding:var(--s24);
  box-shadow:var(--shadow);
}

.card h3{
  font-size:var(--h3-m);
  margin:0 0 var(--s12);
  font-weight:600;
}

.card img{
  width:100%;
  border-radius:var(--radius);
}

/* Before/After slider */
.ba{
  position:relative;
  border:1px solid var(--border);
  border-radius:var(--radius);
  overflow:hidden;
  box-shadow:var(--shadow);
  margin:var(--s24) 0;
}

.ba .frame{
  position:relative;
  aspect-ratio:16/9;
  background:#ddd;
}

.ba img{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
}

.ba .after{
  clip-path:inset(0 0 0 50%);
}

.ba input[type="range"]{
  position:absolute;
  inset:auto 0 10px 0;
  width:100%;
  z-index:10;
}

.ba .handle{
  position:absolute;
  inset:0 auto 0 calc(50% - 1px);
  width:2px;
  background:#fff;
  box-shadow:var(--shadow);
  pointer-events:none;
}

.ba .knob{
  position:absolute;
  top:50%;
  left:50%;
  transform:translate(-50%,-50%);
  width:32px;
  height:32px;
  border-radius:50%;
  background:#fff;
  border:1px solid var(--border);
  box-shadow:var(--shadow);
  pointer-events:none;
}

/* FAQ - Mobile First */
.container-faq{
  width:100%;
  max-width:900px;
  margin:var(--s32) auto 0;
  padding:0 var(--s16);
  display:flex;
  flex-direction:column;
  gap:var(--s12);
}

.questions{
  width:100%;
  margin:var(--s8) 0;
}

.visible-pannel{
  display:flex;
  justify-content:space-between;
  align-items:center;
  background:#f1f1f1;
  border-radius:10px;
  padding:var(--s12) var(--s16);
  cursor:pointer;
}

.visible-pannel h3{
  font-size:16px;
  font-weight:600;
  margin:0;
  padding-right:var(--s12);
}

.visible-pannel img{
  width:20px;
  height:20px;
  flex-shrink:0;
}

.toggle-pannel{
  padding:0 var(--s16);
  height:0;
  opacity:0;
  overflow:hidden;
}

.toggle-pannel h4{
  font-size:16px;
  margin:var(--s12) 0;
}

.toggle-pannel p{
  line-height:1.6;
  margin-bottom:var(--s12);
}

/* Typography */
h1{
  font-family:"Playfair Display",serif;
  font-weight:700;
  font-size:var(--h1-m);
  line-height:1.2;
  margin:0 0 var(--s16);
}

h2, .titre-section{
  font-family:Spectral,serif;
  font-weight:700;
  font-size:var(--h2-m);
  margin:0 0 var(--s24);
  text-align:center;
}

h3{
  font-size:var(--h3-m);
  font-weight:600;
  margin:0 0 var(--s12);
}

p{
  margin:0 0 var(--s16);
}

.muted{
  color:var(--text-muted);
}

/* Utilities */
.center{
  text-align:center;
}

.mt12{margin-top:var(--s12)}
.mt24{margin-top:var(--s24)}
.mt32{margin-top:var(--s32)}
.mt48{margin-top:var(--s48)}

.tag{
  display:inline-block;
  padding:6px 12px;
  border:1px solid var(--border);
  border-radius:999px;
  background:#fff;
  margin:4px;
  font-size:14px;
}

.vsl-blc{
  display:flex;
  align-items:center;
  justify-content:center;
  margin:var(--s24) 0;
}

.vsl-blc img{
  max-width:100%;
  height:auto;
}

/* Forms */
.contact{
  display:flex;
  flex-direction:column;
  gap:var(--s16);
  max-width:600px;
  margin:var(--s32) auto;
}

.contact input,
.contact textarea{
  width:100%;
  padding:12px;
  border:1px solid var(--border);
  border-radius:var(--radius-btn);
  background:#fff;
  font-family:inherit;
  font-size:16px;
}

.contact textarea{
  min-height:120px;
  resize:vertical;
}

.contact label{
  display:flex;
  gap:var(--s8);
  align-items:flex-start;
  font-size:14px;
}

/* Embed Calendly */
.embed{
  margin:var(--s32) 0;
  border-radius:var(--radius);
  overflow:hidden;
}

/* Footer */
footer{
  background:#fff;
  border-top:1px solid var(--border);
  padding:var(--s32) 0;
  text-align:center;
}

footer .container{
  font-size:14px;
  opacity:0.8;
}

/* ========================================
   RESPONSIVE - TABLET (768px+)
   ======================================== */
@media(min-width:768px){
  .section{
    padding:var(--s64) 0;
  }

  .header .bar{
    height:72px;
  }

  .logo{
    font-size:20px;
  }

  .logo img{
    max-height:48px;
  }

  .hero--bg h1{
    font-size:40px;
  }

  .hero-ctas{
    flex-direction:row;
    gap:var(--s16);
  }

  .grid-2{
    grid-template-columns:repeat(2,1fr);
    gap:var(--s32);
  }

  .grid-3{
    grid-template-columns:repeat(2,1fr);
    gap:var(--s24);
  }

  .cards.cols-2{
    grid-template-columns:repeat(2,1fr);
  }

  .visible-pannel h3{
    font-size:18px;
  }

  .visible-pannel img{
    width:25px;
    height:25px;
  }

  h2, .titre-section{
    font-size:var(--h2-d);
  }
}

/* ========================================
   RESPONSIVE - DESKTOP (1024px+)
   ======================================== */
@media(min-width:1024px){
  .section{
    padding:var(--s96) 0;
  }

  .burger{
    display:none;
  }

  .nav{
    display:flex;
    flex-direction:row;
    position:static;
    background:transparent;
    padding:0;
    border:none;
    box-shadow:none;
    gap:var(--s24);
  }

  .nav a{
    padding:0;
  }

  .hero--bg{
    min-height:70vh;
  }

  .hero--bg h1{
    font-size:var(--h1-d);
    max-width:800px;
  }

  .hero--bg p{
    font-size:var(--body-d);
    max-width:700px;
  }

  .grid-3{
    grid-template-columns:repeat(3,1fr);
    padding-left:var(--s32);
  }

  .sixetape{
    height:450px;
    padding:var(--s32);
  }

  .sixetape h3{
    text-align:left;
  }

  .sixetape p{
    text-align:left;
  }

  .cards.cols-3{
    grid-template-columns:repeat(3,1fr);
  }

  .cards.cols-4{
    grid-template-columns:repeat(4,1fr);
  }

  .cards.cols-6{
    grid-template-columns:repeat(6,1fr);
  }

  .container-faq{
    width:70%;
    min-width:400px;
  }
}

/* ========================================
   RESPONSIVE - LARGE DESKTOP (1280px+)
   ======================================== */
@media(min-width:1280px){
  .grid-3{
    grid-template-columns:repeat(4,1fr);
  }
}

/* ========================================
   FIXES SPÉCIFIQUES MOBILE
   ======================================== */
@media(max-width:767px){
  /* Hero responsive */
  .hero--bg{
    min-height:80vh;
    padding:var(--s48) 0;
  }

  /* Boutons pleine largeur sur mobile */
  .btn{
    width:100%;
  }

  .hero-ctas .btn{
    width:100%;
  }

  /* Images des étapes centrées */
  .sixetape img{
    margin:0 auto var(--s12);
  }

  /* Tags qui wrappent bien */
  .tag{
    display:inline-block;
    margin:4px 4px 4px 0;
  }

  /* Calendly responsive */
  .calendly-inline-widget{
    min-width:100% !important;
    height:600px !important;
  }

  /* Espacement réduit sur mobile */
  .section{
    padding:var(--s32) 0;
  }
}

/* Print styles */
@media print{
  .header,
  .burger,
  .btn,
  .embed,
  footer{
    display:none;
  }
}