/* ===== RESET ===== */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
:root{
  --cream:#FFEDA8;
  --cream-dark:#F5E09A;
  --brown-dark:#3E2723;
  --brown:#523D2D;
  --brown-medium:#6B5545;
  --brown-light:#8A7262;
  --gold:#FFD948;
  --gold-light:#FFEDA8;
  --gold-shimmer:linear-gradient(135deg, #FFD948, #FFEDA8, #FFD948);
  --beige:#FAF6F0;
  --white:#FFFFFF;
  --text-dark:#3E2723;
  --text-body:#523D2D;
  --shadow-sm:0 2px 8px rgba(62,39,35,0.06);
  --shadow-md:0 4px 16px rgba(62,39,35,0.08);
  --shadow-lg:0 8px 32px rgba(62,39,35,0.1);
  --shadow-gold:0 4px 20px rgba(255,217,72,0.15);
  --radius:0px;--radius-lg:0px;
  --ease:cubic-bezier(0.4,0,0.2,1);--ease-out:cubic-bezier(0.16,1,0.3,1);
}
html{scroll-behavior:smooth;font-size:16px}
body{font-family: 'Pangram', sans-serif;background:var(--white);color:var(--text-body);line-height:1.7;overflow-x:hidden;-webkit-font-smoothing:antialiased}
img{max-width:100%;height:auto;display:block}
a{text-decoration:none;color:inherit}
ul{list-style:none}
button{border:none;cursor:pointer;font-family:inherit}
.container{width:100%;max-width:1240px;margin:0 auto;padding:0 24px}

/* ===== TYPOGRAPHY ===== */
h1,h2,h3,h4{font-family: 'Pangram', sans-serif;color:var(--brown);line-height:1.12;font-weight: 500}
h1{font-size:clamp(2.4rem,9vw,5rem);letter-spacing:0.02em;text-transform:uppercase}
h2{font-size:clamp(1.6rem,5vw,3.2rem);letter-spacing:0.02em;text-transform:uppercase}
h3{font-size:clamp(1.05rem,2.5vw,1.3rem);font-weight: 500}
.subtitle{font-family: 'Pangram', sans-serif;font-size:clamp(1rem,2.5vw,1.2rem);font-style:italic;color:var(--brown-light);letter-spacing:0.02em}
.section-label{font-size:0.65rem;text-transform:uppercase;letter-spacing:0.3em;color:var(--gold);font-weight: 500;margin-bottom:16px;display:flex;align-items:center;justify-content:center;gap:16px}
.section-label::before,.section-label::after{content:'';width:28px;height:1px;background:var(--gold);opacity:0.5}
.section-label--left{justify-content:flex-start}

/* ===== GOLD ORNAMENT ===== */
.ornament{display:none !important;}

/* ===== BUTTONS ===== */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:15px 36px;font-size:0.75rem;font-weight: 500;letter-spacing:0.1em;text-transform:uppercase;border-radius:0;transition:all 0.4s var(--ease);position:relative;overflow:hidden;font-family: 'Pangram', sans-serif;color:var(--white);border:1px solid var(--brown-dark)}
.btn-primary:hover{background:transparent;color:var(--brown-dark)}
.btn-outline{background:transparent;color:var(--brown-dark);border:1px solid var(--brown-dark)}
.btn-outline:hover{background:var(--brown-dark);color:var(--white)}
.btn-gold{background:var(--white);color:var(--brown-dark);border:1px solid var(--white)}
.btn-gold:hover{background:transparent;color:var(--white)}
.btn-luxe{background:transparent;border:1px solid var(--brown-dark);color:var(--brown-dark)}
.btn-luxe:hover{background:var(--brown-dark);color:var(--white)}

/* ===== HEADER & NAVBAR ===== */
.site-header{position:fixed;top:0;left:0;width:100%;z-index:1000;box-shadow:0 1px 0 rgba(0,0,0,0.05)}
.top-bar-announcement{display:block;background:var(--cream);color:var(--brown-dark);text-align:center;padding:12px 24px;font-size:0.8rem;letter-spacing:0.03em;font-family: 'Pangram', sans-serif;font-weight: 500;text-decoration:none;transition:background 0.3s var(--ease)}
.top-bar-announcement:hover{background:#f7e6b8}
.top-bar-announcement .underline{text-decoration:underline;text-underline-offset:4px;font-weight: 500}
.navbar{padding:10px 0;background:var(--white);transition:all 0.3s var(--ease)}
.navbar .container{display:grid;grid-template-columns:1fr auto 1fr;align-items:center}
.nav-left{display:flex;align-items:center;justify-self:flex-start}
.nav-center{justify-self:center}
.nav-right{display:flex;align-items:center;justify-self:flex-end}
.nav-logo{font-family: 'Pangram', sans-serif;font-size:1.6rem;color:var(--brown);letter-spacing:0.05em;font-weight: 500;transition:all 0.5s var(--ease);text-align:center;line-height:1;text-transform:uppercase}
.nav-links{display:none}
.hamburger{display:flex;flex-direction:column;gap:6px;background:none;padding:8px 0;z-index:1001;cursor:pointer}
.hamburger span{width:26px;height:1px;background:var(--brown);transition:all 0.4s var(--ease);transform-origin:center}
.hamburger.active span{background:var(--cream)!important}
.hamburger.active span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}
.hamburger.active span:nth-child(2){opacity:0;transform:scaleX(0)}
.hamburger.active span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}
.nav-reserve{font-family: 'Pangram', sans-serif;font-size:0.7rem;font-weight: 500;letter-spacing:0.1em;text-transform:uppercase;color:var(--brown);display:flex;align-items:center;gap:8px}

.mobile-menu{position:fixed;top:0;left:0;width:100%;height:100dvh;background:var(--brown-dark);z-index:999;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:36px;opacity:0;pointer-events:none;transition:0.5s var(--ease)}
.mobile-menu::before{content:'';position:absolute;top:50%;left:50%;width:300px;height:300px;background:radial-gradient(circle,rgba(196,162,101,0.08) 0%,transparent 70%);transform:translate(-50%,-50%);border-radius:50%}
.mobile-menu.active{opacity:1;pointer-events:all}
.mobile-menu a{font-family: 'Pangram', sans-serif;font-size:2rem;font-weight: 500;color:var(--cream);letter-spacing:0.08em;transition:all 0.4s var(--ease);opacity:0;transform:translateY(24px);position:relative}
.mobile-menu a::after{content:'';position:absolute;bottom:-4px;left:50%;width:0;height:1px;background:var(--gold);transition:all 0.4s var(--ease);transform:translateX(-50%)}
.mobile-menu a:hover::after{width:100%}
.mobile-menu.active a{opacity:1;transform:translateY(0)}
.mobile-menu.active a:nth-child(1){transition-delay:0.1s}
.mobile-menu.active a:nth-child(2){transition-delay:0.15s}
.mobile-menu.active a:nth-child(3){transition-delay:0.2s}
.mobile-menu.active a:nth-child(4){transition-delay:0.25s}
.mobile-menu.active a:nth-child(5){transition-delay:0.3s}
.mobile-menu a:hover{color:var(--gold)}

/* ===== HERO ===== */
.hero{position:relative;min-height:100dvh;display:flex;align-items:center;justify-content:center;text-align:center;overflow:hidden;padding-top:100px}
.hero-bg{position:absolute;inset:0;z-index:0}
.hero-bg img{width:100%;height:100%;object-fit:cover;transform:scale(1.05);animation:heroZoom 20s ease-in-out infinite alternate;object-position:center}
@keyframes heroZoom{0%{transform:scale(1.05)}100%{transform:scale(1.12)}}
.hero-bg::after{content:'';position:absolute;inset:0;background:rgba(60,60,60,0.75)}
.hero-content{position:relative;z-index:2;padding:0 24px;max-width:720px;width:100%}
.hero-content .section-label{color:var(--white);margin-bottom:12px;font-family: 'Pangram', sans-serif;text-transform:none;letter-spacing:0.02em;font-size:0.95rem;font-weight:400;display:block}
.hero-content .section-label::before,.hero-content .section-label::after{display:none}
.hero-content h1{color:var(--white);margin-bottom:24px;font-family: 'Pangram', sans-serif;font-weight:400;text-transform:none;font-size:clamp(2rem,6vw,3.2rem);letter-spacing:0;text-shadow:none}
.hero-link{color:var(--white);text-decoration:underline;text-underline-offset:6px;font-size:1rem;font-weight:400;letter-spacing:0.02em;transition:all 0.3s;display:inline-block}
.hero-link:hover{color:var(--cream)}
.hero-scroll{position:absolute;bottom:32px;left:50%;transform:translateX(-50%);z-index:2;display:flex;flex-direction:column;align-items:center;gap:10px;color:rgba(255,255,255,0.5);font-size:0.6rem;letter-spacing:0.2em;text-transform:uppercase}
.hero-scroll .scroll-line{width:1px;height:48px;background:rgba(255,255,255,0.2);position:relative;overflow:hidden}
.hero-scroll .scroll-line::after{content:'';position:absolute;top:-100%;left:0;width:100%;height:100%;background:var(--gold);animation:scrollDown 2s var(--ease) infinite}
@keyframes scrollDown{0%{top:-100%}100%{top:100%}}

/* ===== PAGE HERO (subpages) ===== */
.page-hero{padding:180px 0 80px;background:var(--white);text-align:center;position:relative;border-bottom:1px solid #EEE}
.page-hero h1{color:var(--brown-dark);font-size:clamp(1.8rem,6vw,3.5rem)}
.page-hero .section-label{color:var(--brown-medium)}
.page-hero .subtitle{color:var(--brown-medium);display:block;margin-top:16px}
.page-hero .ornament{display:none}

/* ===== UNIVERS CARDS ===== */
.univers-grid{display:grid;grid-template-columns:1fr;gap:24px;margin-top:48px}
.univers-card{background:transparent;border:none;transition:all 0.5s var(--ease)}
.univers-img{aspect-ratio:16/9;overflow:hidden;background:#EEE}
.univers-img img{width:100%;height:100%;object-fit:cover;transition:all 0.8s var(--ease-out)}
.univers-card:hover .univers-img img{transform:scale(1.05)}
.univers-body{padding:24px 0}
.univers-body h3{font-size:1.3rem;margin-bottom:14px}
.univers-body p{font-size:0.88rem;color:var(--text-body);font-weight:300;line-height:1.7;margin-bottom:20px}
/* ===== SALON ===== */
.salon{padding:100px 0;background:var(--white);position:relative;border-top:1px solid #EEE}
.salon-grid{display:flex;flex-direction:column;gap:40px}
.salon-images{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.salon-images .img-wrap{border-radius:4px;overflow:hidden;aspect-ratio:3/4;position:relative}
.salon-images .img-wrap::after{content:'';position:absolute;inset:0;border:1px solid rgba(196,162,101,0.1);border-radius:4px;pointer-events:none;transition:all 0.6s}
.salon-images .img-wrap:hover::after{border-color:rgba(196,162,101,0.3)}
.salon-images .img-wrap img{width:100%;height:100%;object-fit:cover;transition:all 0.8s var(--ease-out)}
.salon-images .img-wrap:hover img{transform:scale(1.04)}
.salon-images .img-wrap:first-child{grid-column:1/-1;aspect-ratio:16/10}
.salon-text{display:flex;flex-direction:column;justify-content:center}
.salon-text h2{margin-bottom:20px}
.salon-text p{margin-bottom:20px;color:var(--text-body);font-weight:300;font-size:0.92rem}
.salon-text p strong{color:var(--brown-dark);font-weight: 500}
.salon-text .btn{margin-top:8px;align-self:flex-start}

/* ===== PRESTATIONS ===== */
.prestations{padding:100px 0;background:var(--white);text-align:center;position:relative}
.prestations h2{margin-bottom:48px}
.prestations .ornament{display:none}
.prestations-grid{display:flex;flex-direction:column;gap:32px;max-width:800px;margin:0 auto}
.prestation-card{
  position:sticky;
  top:80px;
  background:var(--brown-dark);
  border-radius:12px;
  padding:0;
  box-shadow:0 -10px 40px rgba(0,0,0,0.15);
  transition:all 0.5s var(--ease);
  text-align:left;
  overflow:hidden;
  border:none;
  height:75vh;
  min-height:380px;
  max-height:700px;
  display:flex;
  align-items:flex-end;
}
.prestation-img{position:absolute;inset:0;z-index:1;background:#000}
.prestation-img img{width:100%;height:100%;object-fit:cover;transition:all 0.8s var(--ease-out)}
.prestation-card:hover .prestation-img img{transform:scale(1.04)}
.prestation-img::after{
  content:'';
  position:absolute;
  inset:0;
  background:linear-gradient(to top, rgba(30,18,11,0.95) 0%, rgba(30,18,11,0.5) 50%, rgba(30,18,11,0.1) 100%);
}
.prestation-body{position:relative;z-index:2;padding:32px 24px;width:100%}
.prestation-body h3{margin-bottom:10px;font-size:1.5rem;color:var(--cream);font-weight:400;text-transform:uppercase}
.prestation-body p{font-size:0.9rem;color:rgba(252,235,182,0.8);font-weight:300;line-height:1.6;margin-bottom:20px;max-width:500px}
.prestation-body .link-decouvrir{color:var(--cream);text-decoration:underline;text-underline-offset:6px;font-size:0.8rem;text-transform:uppercase;letter-spacing:0.1em;transition:all 0.3s;display:inline-block}
.prestation-body .link-decouvrir:hover{color:var(--white)}
/* ===== ACADEMIE BANNER ===== */
.academie-banner{width:100%;background:var(--white);border-top:1px solid #EEE}
.academie-split{display:flex;flex-direction:column}
.academie-image{flex:1;aspect-ratio:4/5;overflow:hidden;min-height:300px}
.academie-image img{width:100%;height:100%;object-fit:cover;transition:transform 1s var(--ease-out)}
.academie-split:hover .academie-image img{transform:scale(1.03)}
.academie-content{flex:1;padding:48px 24px;text-align:center;display:flex;flex-direction:column;justify-content:center;align-items:center}
.academie-content .section-label{color:var(--brown-medium);margin-bottom:16px;letter-spacing:0.2em}
.academie-content h2{font-family: 'Pangram', sans-serif;font-size:clamp(1.8rem,8vw,3.2rem);color:var(--brown-dark);margin-bottom:20px;text-transform:uppercase;font-weight:400;line-height:1.15;letter-spacing:0.02em}
.academie-content p{color:var(--brown-medium);font-size:0.9rem;max-width:400px;margin:0 auto 32px;line-height:1.6;font-weight:300}
.link-decouvrir-dark{color:var(--brown-dark);text-decoration:underline;text-underline-offset:6px;font-size:0.8rem;text-transform:uppercase;letter-spacing:0.1em;transition:all 0.3s;display:inline-block}
.link-decouvrir-dark:hover{color:var(--brown-light)}

@media(min-width:768px){
  .academie-split{flex-direction:row;align-items:stretch;height:85vh;min-height:500px;max-height:800px}
  .academie-image{aspect-ratio:auto;height:100%}
  .academie-content{padding:0 80px}
}

/* ===== POURQUOI (Simple Minimalist) ===== */
.pourquoi {
  padding: 80px 0;
  background: var(--cream);
}
.pourquoi-grid {
  display: flex;
  flex-direction: row;
  gap: 16px;
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  padding-bottom: 24px;
  -ms-overflow-style: none; /* IE and Edge */
  scrollbar-width: none; /* Firefox */
}
.pourquoi-grid::-webkit-scrollbar {
  display: none;
}
.pourquoi-card {
  background: var(--white);
  text-align: left;
  border: 1px solid #EFEFEF;
  transition: all 0.4s var(--ease);
  flex: 0 0 85%;
  scroll-snap-align: center;
  position: relative;
  overflow: hidden;
  display: flex;
  flex-direction: column;
}
.pourquoi-card:hover {
  border-color: var(--brown-dark);
  box-shadow: 0 10px 30px rgba(0,0,0,0.05);
}

.card-graphic {
  position: relative;
  height: 220px;
  background: #faeab1; /* Yellow pastel matching the moodboard */
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: center;
  border-bottom: 1px solid #EFEFEF;
}
.card-bg-text {
  position: absolute;
  font-family: 'Pangram', sans-serif;
  font-size: 5rem;
  font-weight: 800;
  color: var(--brown-dark);
  white-space: nowrap;
  line-height: 0.85;
}
.card-bg-text:not(.bottom) {
  top: -5px;
  left: 50%;
  transform: translateX(-50%);
}
.card-bg-text.bottom {
  bottom: -15px;
  left: 50%;
  transform: translateX(-50%);
}

.card-sticker {
  position: relative;
  z-index: 10;
  width: 140px;
  height: auto;
  filter: drop-shadow(4px 4px 0px rgba(0,0,0,0.05));
  transition: transform 0.4s var(--ease);
}
.pourquoi-card:hover .card-sticker {
  transform: scale(1.1) rotate(-3deg);
}

.card-content {
  padding: 32px 24px;
  flex-grow: 1;
}
.pourquoi-num {
  font-family: 'Pangram', sans-serif;
  font-size: 1.8rem;
  color: var(--brown-medium);
  display: block;
  margin-bottom: 16px;
  font-weight: 300;
  opacity: 0.7;
}
.pourquoi-card h3 {
  font-size: 1.2rem;
  color: var(--brown-dark);
  margin-bottom: 12px;
  text-transform: uppercase;
  font-weight: 400;
  letter-spacing: 0.05em;
}
.pourquoi-card p {
  font-size: 0.95rem;
  color: var(--text-body);
  line-height: 1.6;
  font-weight: 300;
}
@media(min-width: 768px) {
  .pourquoi { padding: 120px 0; }
  .pourquoi-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 32px;
    overflow-x: visible;
    padding-bottom: 0;
  }
  .pourquoi-card { 
    flex: auto;
  }
  .card-content {
    padding: 40px;
  }
  .card-graphic {
    height: 260px;
  }
  .card-bg-text {
    font-size: 6rem;
  }
  .card-sticker {
    width: 170px;
  }
  
  .prestation-card{top:120px}
  .prestations-grid{gap:60px}
  .prestation-body{padding:40px}
  .prestation-body h3{font-size:1.8rem}
  .prestation-body p{font-size:0.95rem}
}

/* ===== FORMATIONS ===== */
.formations{padding:100px 0;background:var(--white);position:relative}
.formations-header{margin-bottom:48px;text-align:center}
.formations-header h2{margin-bottom:8px}
.formations-header .ornament{display:none}
.formations-cards{display:grid;grid-template-columns:1fr;gap:24px}
.formation-card{background:transparent;border:none;border-bottom:1px solid #EEE;transition:all 0.5s var(--ease)}
.formation-img{aspect-ratio:16/10;overflow:hidden;background:#EEE}
.formation-img img{width:100%;height:100%;object-fit:cover;transition:all 0.8s var(--ease-out)}
.formation-card:hover .formation-img img{transform:scale(1.02)}
.formation-body{padding:24px 0}
.formation-tag{font-size:0.65rem;text-transform:uppercase;letter-spacing:0.16em;color:var(--brown-dark);font-weight: 500;display:inline-block;padding:4px 0;margin-bottom:12px}
.formation-body h3{margin-bottom:12px;font-size:1.1rem}
.formation-body p{font-size:0.85rem;color:var(--text-body);font-weight:300;line-height:1.65;margin-bottom:16px}
.formation-points{display:grid;grid-template-columns:1fr 1fr;gap:6px;margin-bottom:18px}
.formation-points li{font-size:0.78rem;color:var(--brown-medium);font-weight:400}
.formation-body .price{font-family: 'Pangram', sans-serif;font-size:1.2rem;color:var(--brown-dark);display:block;padding-top:14px;border-top:1px solid #EEE}

/* ===== GALERIE ===== */
.galerie{padding:100px 0;background:var(--white);text-align:center;position:relative;border-top:1px solid #EEE}
.galerie h2{margin-bottom:48px}
.galerie .ornament{display:none}
.galerie-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.gallery-item{overflow:hidden;position:relative;aspect-ratio:1;background:#EEE}
.gallery-item.wide{grid-column:1/-1;aspect-ratio:16/9}
.gallery-item img{width:100%;height:100%;object-fit:cover;transition:all 0.8s var(--ease-out)}
.gallery-item:hover img{transform:scale(1.02)}
.gallery-item .overlay{position:absolute;inset:0;background:rgba(0,0,0,0.4);display:flex;align-items:flex-end;padding:20px;opacity:0;transition:all 0.5s var(--ease)}
.gallery-item:hover .overlay{opacity:1}
.gallery-item .overlay span{color:var(--white);font-size:0.78rem;font-weight: 500;letter-spacing:0.12em;text-transform:uppercase;padding-top:8px;border-top:1px solid var(--white);display:inline-block}

/* ===== FAQ ===== */
.faq{padding:100px 0;background:var(--white);text-align:center;border-top:1px solid #EEE}
.faq h2{margin-bottom:48px}
.faq .ornament{display:none}
.faq-list{max-width:760px;margin:0 auto;text-align:left}
.faq-item{border-bottom:1px solid #EEE;overflow:hidden}
.faq-item summary{padding:20px 0;font-family: 'Pangram', sans-serif;font-size:1rem;font-weight: 500;cursor:pointer;list-style:none;display:flex;justify-content:space-between;align-items:center;color:var(--brown-dark);transition:color 0.3s}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::after{content:'+';font-size:1.4rem;color:var(--brown-dark);transition:transform 0.3s;font-weight:300}
.faq-item[open] summary::after{transform:rotate(45deg)}
.faq-item[open] summary{color:var(--brown-medium)}
.faq-item p{padding:0 0 20px;font-size:0.88rem;color:var(--text-body);line-height:1.7;font-weight:300}

/* ===== TEMOIGNAGES ===== */
.temoignages{padding:100px 0;background:var(--white);text-align:center;position:relative;border-top:1px solid #EEE}
.temoignages h2{margin-bottom:48px}
.temoignages .ornament{display:none}
.temoignages-grid{display:grid;grid-template-columns:1fr;gap:20px}
.temoignage-card{background:transparent;padding:32px 24px;text-align:left;border:1px solid #EEE;transition:all 0.5s var(--ease);position:relative}
.temoignage-card::before{content:'\201C';position:absolute;top:16px;right:24px;font-family: 'Pangram', sans-serif;font-size:4rem;color:#EEE;line-height:1}
.temoignage-card .stars{color:var(--brown-dark);font-size:0.75rem;margin-bottom:16px;letter-spacing:3px}
.temoignage-card p{font-family: 'Pangram', sans-serif;font-style:italic;margin-bottom:20px;font-size:0.95rem;line-height:1.7;color:var(--text-body)}
.temoignage-card .author{display:flex;align-items:center;gap:14px;padding-top:16px;border-top:1px solid #EEE}
.temoignage-card .author img{width:48px;height:48px;border-radius:50%;object-fit:cover;border:1px solid #EEE}
.temoignage-card .author-info strong{font-size:0.85rem;color:var(--brown-dark);display:block;font-weight: 500;letter-spacing:0.02em}
.temoignage-card .author-info span{font-size:0.72rem;color:var(--brown-light);letter-spacing:0.04em;text-transform:uppercase}

/* ===== CTA FINAL ===== */
.cta-final {
  padding: 100px 16px;
  background: url('images/cta-bg.png') center/cover no-repeat;
  text-align: center;
  position: relative;
  overflow: hidden;
}
.cta-final::before {
  content: '';
  position: absolute;
  inset: 0;
  background: rgba(255,255,255,0.78);
  backdrop-filter: blur(3px);
  pointer-events: none;
}
.cta-inner {
  position: relative;
  z-index: 1;
  max-width: 480px;
  margin: 0 auto;
}

/* Eyebrow */
.cta-eyebrow {
  display: block;
  font-family: 'Pangram', sans-serif;
  font-size: 0.68rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: #523D2D;
  margin-bottom: 20px;
  font-weight: 500;
}

/* Title */
.cta-final h2 {
  font-family: 'Pangram', sans-serif;
  font-size: 2.8rem;
  font-weight: 700;
  color: #3E2723;
  line-height: 1.1;
  margin-bottom: 20px;
  letter-spacing: -0.02em;
}
.cta-final h2 em {
  font-style: italic;
  font-family: 'Pangram', sans-serif;
  font-weight: 400;
  color: #523D2D;
}

/* Stars */
.cta-stars {
  font-size: 0.85rem;
  color: #FFD948;
  margin-bottom: 36px;
  letter-spacing: 2px;
}
.cta-stars span {
  color: #8A7262;
  font-size: 0.72rem;
  letter-spacing: 0.05em;
  margin-left: 6px;
}

/* CTA Button */
.cta-button {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  padding: 18px 44px;
  background: #3E2723;
  color: #FFEDA8;
  font-family: 'Pangram', sans-serif;
  font-size: 0.82rem;
  font-weight: 500;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  text-decoration: none;
  position: relative;
  overflow: hidden;
  transition: all 0.4s cubic-bezier(0.25,0.46,0.45,0.94);
}
.cta-button svg {
  width: 18px;
  height: 18px;
  stroke: #FFEDA8;
  transition: transform 0.3s ease;
}
.cta-button:hover svg {
  transform: translateX(5px);
}
.cta-button::after {
  content: '';
  position: absolute;
  top: 0; left: -100%;
  width: 100%; height: 100%;
  background: linear-gradient(90deg, transparent, rgba(255,237,168,0.12), transparent);
  transition: left 0.6s ease;
}
.cta-button:hover::after { left: 100%; }
.cta-button:hover {
  transform: translateY(-2px);
  box-shadow: 0 10px 35px rgba(62,39,35,0.2);
  background: #523D2D;
}

/* Reassurance */
.cta-reassurance {
  margin-top: 16px;
  font-size: 0.7rem;
  color: #8A7262;
  letter-spacing: 0.06em;
}

/* Separator */
.cta-separator {
  width: 40px;
  height: 1px;
  background: #3E2723;
  opacity: 0.15;
  margin: 36px auto;
}

/* Info blocks */
.cta-infos {
  display: flex;
  justify-content: center;
  gap: 40px;
}
.cta-info {
  text-align: left;
}
.cta-info strong {
  display: block;
  font-family: 'Pangram', sans-serif;
  font-size: 0.65rem;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: #3E2723;
  margin-bottom: 6px;
  font-weight: 500;
}
.cta-info span {
  font-size: 0.8rem;
  color: #6B5545;
  line-height: 1.5;
}

/* ===== LEGAL PAGES ===== */
.legal-content {
  background: var(--white);
}
.legal-content h2 {
  font-family: 'Pangram', sans-serif;
  font-size: 1.1rem;
  font-weight: 500;
  color: var(--brown-dark);
  margin: 36px 0 12px;
  letter-spacing: 0.02em;
}
.legal-content h2:first-child { margin-top: 0; }
.legal-content p {
  font-size: 0.88rem;
  color: var(--text-body);
  line-height: 1.75;
  margin-bottom: 12px;
}
.legal-content ul {
  padding-left: 20px;
  margin-bottom: 16px;
}
.legal-content ul li {
  font-size: 0.88rem;
  color: var(--text-body);
  line-height: 1.75;
  margin-bottom: 4px;
}

/* ===== FOOTER ===== */
.footer-wrapper {
  background: #EAE6DE;
  padding: 40px 16px;
}
.footer-dior {
  background: var(--white);
  border-radius: 6px;
  max-width: 600px;
  margin: 0 auto;
  box-shadow: 0 4px 30px rgba(0,0,0,0.05);
}

/* Advantages */
.footer-advantages {
  padding: 24px;
}
.advantage-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 24px 0;
  border-bottom: 1px solid #EAEAEA;
  color: var(--brown-dark);
  text-decoration: none;
  transition: opacity 0.3s var(--ease);
}
.advantage-item:last-child { border-bottom: none; }
.advantage-item:hover { opacity: 0.7; }
.adv-text strong {
  display: block;
  font-size: 0.95rem;
  font-weight: 500;
  margin-bottom: 4px;
}
.adv-text p {
  font-size: 0.85rem;
  color: var(--brown-medium);
  margin: 0;
  line-height: 1.4;
}
.advantage-item svg {
  width: 20px;
  height: 20px;
  flex-shrink: 0;
  color: var(--brown-dark);
}

/* Footer columns */
.footer-cols {
  padding: 32px 24px;
  display: flex;
  flex-direction: column;
  gap: 28px;
  border-top: 1px solid #EAEAEA;
}
.footer-col h4 {
  font-family: 'Pangram', sans-serif;
  font-size: 0.68rem;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: var(--brown-dark);
  margin-bottom: 14px;
  font-weight: 500;
}
.footer-col a {
  display: block;
  font-size: 0.82rem;
  color: var(--brown-medium);
  margin-bottom: 10px;
  text-decoration: none;
  transition: color 0.3s ease;
}
.footer-col a:hover {
  color: var(--brown-dark);
}

/* Social */
.footer-social {
  display: flex;
  gap: 16px;
}
.footer-social a {
  display: block;
  color: var(--brown-dark);
  margin-bottom: 0;
}
.footer-social svg {
  width: 22px;
  height: 22px;
}

/* Legal links */
.footer-legal {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 16px;
  margin-top: 12px;
}
.footer-legal a {
  font-size: 0.65rem;
  color: var(--brown-light);
  text-decoration: none;
  letter-spacing: 0.05em;
  transition: color 0.3s ease;
  text-transform: uppercase;
}
.footer-legal a:hover { color: var(--brown-dark); }

/* Bottom */
.footer-bottom-dior {
  text-align: center;
  padding: 28px 24px;
  border-top: 1px solid #EAEAEA;
}
.footer-logo-dior {
  font-family: 'Pangram', sans-serif;
  font-size: 1.5rem;
  font-weight: 700;
  letter-spacing: 0.2em;
  color: var(--brown-dark);
  margin-bottom: 8px;
}
.footer-bottom-dior p {
  font-size: 0.7rem;
  color: var(--brown-light);
}

/* ===== ANIMATIONS ===== */
.fade-up{opacity:0;transform:translateY(28px);transition:0.8s var(--ease-out)}
.fade-up.visible{opacity:1;transform:translateY(0)}
.fade-up:nth-child(2){transition-delay:0.08s}
.fade-up:nth-child(3){transition-delay:0.16s}
.fade-up:nth-child(4){transition-delay:0.24s}

/* ===== DESKTOP ===== */
@media(min-width:768px){
  .hero{padding-bottom:0}
  .univers-grid{grid-template-columns:repeat(2,1fr);gap:32px}
  .salon-grid{flex-direction:row;gap:60px;align-items:center}
  .salon-images{flex:1.1}
  .salon-text{flex:1}
  .formations-cards{grid-template-columns:repeat(3,1fr);gap:24px}
  .galerie-grid{grid-template-columns:repeat(3,1fr);gap:10px}
  .gallery-item.wide{grid-column:span 2;aspect-ratio:16/10}
  .temoignages-grid{grid-template-columns:repeat(3,1fr);gap:20px}
  .contact-grid{flex-direction:row;align-items:flex-start;gap:48px}
  .contact-info{flex:0.8}
  .contact-form{flex:1}
  .footer-grid {
    flex-direction: row;
    justify-content: space-between;
  }
  /* Desktop Footer */
  .footer-dior {
    max-width: 900px;
  }
  .footer-advantages {
    display: flex;
    justify-content: space-between;
    padding: 32px 48px;
    gap: 40px;
  }
  .advantage-item {
    flex: 1;
    border-bottom: none;
    border-right: 1px solid #EAEAEA;
    padding: 0 32px 0 0;
  }
  .advantage-item:last-child {
    border-right: none;
    padding-right: 0;
  }
  .footer-cols {
    flex-direction: row;
    justify-content: space-around;
    padding: 48px;
  }
  .footer-legal {
    justify-content: center;
    gap: 40px;
  }
}
@media(min-width:1024px){
  .container{padding:0 48px}
  .salon,.prestations,.pourquoi,.formations,.galerie,.temoignages,.faq,.contact{padding:140px 0}
  .contact-form{padding:44px 40px}
  .section-label::before,.section-label::after{width:48px}
}
