/* ===========================================================
   ANICHA ESPACE BIEN-ÊTRE
   Feuille de styles — "Clair, Moderne & Contrasté"
   Organisation :
     1.  Tokens
     2.  Reset & base
     3.  Typographie
     4.  Layout
     5.  Boutons
     6.  Header & navigation
     7.  Hero
     8.  Réassurance
     9.  Cartes (soins, formules, témoignages)
     10. Philosophie
     11. Contact rapide
     12. Footer
     13. Pages secondaires
     14. Utilitaires & responsive
     15. Formulaire & FAB WhatsApp
   =========================================================== */

/* ============================================================
   1. TOKENS
   ============================================================ */
:root {
  /* Palette Or temple thaï — safran, teck, ébène */
  --color-bg:           #F5F1E8;   /* crème safranée — soie du temple */
  --color-bg-alt:       #EAE0C8;   /* safran pâle — lin doré */
  --color-bg-surface:   #DDD4B0;   /* surface ocre dorée */
  --color-bg-card:      #FFFFFF;   /* cartes blanches */
  --color-bg-dark:      #1C1000;   /* ébène de teck — nuit du temple */

  --color-primary:      #C8920A;   /* or de temple — boutons, prix, soulignements */
  --color-primary-dark: #9A6E00;   /* or profond — hover */
  --color-primary-light:#E0A820;   /* or lumineux — hero, reflets */

  --color-secondary:    #7A4E00;   /* teck brun — structure */
  --color-accent:       #A06A10;   /* ambre doré — détails décoratifs */

  --color-text:         #1C1000;   /* ébène — texte principal */
  --color-muted:        #5C3E10;   /* teck moyen lisible */
  --color-border:       #D8CC9A;   /* safran bordure */
  --color-border-mid:   #C4B878;   /* safran bordure marquée */
  --color-white:        #FFFFFF;

  /* Typographie */
  --font-serif: 'Cormorant Garamond', 'Playfair Display', Georgia, serif;
  --font-sans:  'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;

  /* Tailles fluides */
  --fs-xs:   0.8125rem;
  --fs-sm:   0.9375rem;
  --fs-base: 1.0625rem;
  --fs-md:   1.1875rem;
  --fs-lg:   clamp(1.25rem, 1.5vw + 0.8rem, 1.75rem);
  --fs-xl:   clamp(1.75rem, 2.5vw + 0.8rem, 2.75rem);
  --fs-2xl:  clamp(2.25rem, 4vw + 0.8rem, 4rem);
  --fs-hero: clamp(2.75rem, 6vw + 1rem, 5.5rem);

  /* Espacements */
  --space-3xs: 0.25rem;
  --space-2xs: 0.5rem;
  --space-xs:  0.75rem;
  --space-sm:  1rem;
  --space-md:  1.5rem;
  --space-lg:  2.5rem;
  --space-xl:  4rem;
  --space-2xl: 6rem;
  --space-3xl: 8rem;

  /* Layout */
  --max-width:      1280px;
  --max-width-text: 720px;
  --header-height:  80px;
  --radius-sm:  4px;
  --radius:     10px;
  --radius-lg:  18px;
  --radius-full: 9999px;

  /* Effets */
  --shadow-sm:   0 1px 4px rgba(28,16,0,.07);
  --shadow:      0 8px 32px rgba(28,16,0,.11);
  --shadow-lg:   0 24px 72px rgba(28,16,0,.18);
  --shadow-gold: 0 0 0 2px rgba(200,146,10,.30), 0 8px 40px rgba(28,16,0,.15);

  --transition:      200ms ease;
  --transition-slow: 400ms ease;
}

/* ============================================================
   2. RESET & BASE
   ============================================================ */
*, *::before, *::after { box-sizing: border-box; }
* { margin: 0; padding: 0; }

html {
  scroll-behavior: smooth;
  scroll-padding-top: var(--header-height);
  overflow-x: hidden; /* Empêche Chrome Android d'élargir le viewport au-delà de l'écran */
}

/* Garantit qu'aucun élément ne dépasse la largeur de l'écran */
body {
  max-width: 100vw;
}

body {
  font-family: var(--font-sans);
  font-size: var(--fs-base);
  line-height: 1.65;
  color: var(--color-text);
  background-color: var(--color-bg);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
}

img, picture, video, canvas { display: block; max-width: 100%; height: auto; }
svg { display: block; overflow: visible; }
input, button, textarea, select { font: inherit; color: inherit; }

a {
  color: var(--color-primary);
  text-decoration: none;
  transition: color var(--transition);
}
a:hover { color: var(--color-primary-dark); }

ul, ol { list-style: none; }
button { background: none; border: 0; cursor: pointer; }

::selection { background-color: var(--color-primary); color: var(--color-white); }

:focus-visible {
  outline: 2px solid var(--color-primary);
  outline-offset: 3px;
  border-radius: var(--radius-sm);
}

/* ============================================================
   3. TYPOGRAPHIE
   ============================================================ */
h1, h2, h3, h4 {
  font-family: var(--font-serif);
  font-weight: 500;
  line-height: 1.12;
  color: var(--color-text);
  letter-spacing: -0.01em;
}

h1 { font-size: var(--fs-hero);  font-weight: 400; }
h2 { font-size: var(--fs-2xl);   font-weight: 400; }
h3 { font-size: var(--fs-xl);    font-weight: 500; }
h4 { font-size: var(--fs-lg);    font-weight: 600; font-family: var(--font-sans); letter-spacing: 0.04em; }

p { max-width: 65ch; }

/* Eyebrow — trait or + texte */
.eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 0.6em;
  font-family: var(--font-sans);
  font-size: var(--fs-xs);
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--color-primary);
  margin-bottom: var(--space-sm);
}
.eyebrow::before {
  content: "";
  display: inline-block;
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background-color: var(--color-primary);
  flex-shrink: 0;
}

.lead {
  font-size: var(--fs-md);
  color: var(--color-muted);
  max-width: 60ch;
}

/* ============================================================
   4. LAYOUT
   ============================================================ */
.container {
  width: 100%;
  max-width: var(--max-width);
  margin: 0 auto;
  padding-left: var(--space-md);
  padding-right: var(--space-md);
}

.section        { padding: var(--space-2xl) 0; }
.section--tight { padding: var(--space-xl) 0; }
.section--alt   { background-color: var(--color-bg-alt); }
.section--dark  {
  background-color: var(--color-bg-dark);
  color: #EDE0CC;
}
.section--dark h2   { color: #F5EEC8; }
.section--dark .lead { color: #8AA89A; }

.section-header {
  text-align: center;
  margin-bottom: var(--space-xl);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-sm);
}
.section-header .eyebrow { justify-content: center; }
.section-header p { margin: 0 auto; }

/* ============================================================
   5. BOUTONS
   ============================================================ */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2xs);
  padding: 0.95rem 1.75rem;
  font-family: var(--font-sans);
  font-size: var(--fs-sm);
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  text-decoration: none;
  border: 1.5px solid transparent;
  border-radius: var(--radius-full);
  cursor: pointer;
  transition: background-color var(--transition), color var(--transition),
              border-color var(--transition), transform var(--transition),
              box-shadow var(--transition);
  white-space: nowrap;
}

/* Primaire : or teck + texte jade sombre */
.btn--primary {
  background-color: var(--color-primary);
  color: var(--color-bg-dark);
  border-color: var(--color-primary);
  font-weight: 700;
}
.btn--primary:hover {
  background-color: var(--color-primary-dark);
  border-color: var(--color-primary-dark);
  color: var(--color-white);
  transform: translateY(-2px);
  box-shadow: 0 8px 28px rgba(200,146,10,.42);
}

/* Ghost sur fond clair : bordure sombre, texte sombre */
.btn--ghost {
  background-color: transparent;
  color: var(--color-text);
  border-color: var(--color-text);
}
.btn--ghost:hover {
  background-color: var(--color-text);
  color: var(--color-bg);
  transform: translateY(-1px);
}

/* Ghost clair (hero photo) */
.btn--ghost-light {
  background-color: transparent;
  color: var(--color-white);
  border-color: rgba(255,255,255,.65);
}
.btn--ghost-light:hover {
  background-color: var(--color-white);
  color: var(--color-text);
}

.btn--small { padding: 0.7rem 1.25rem; font-size: var(--fs-xs); }

/* ============================================================
   6. HEADER & NAVIGATION
   ============================================================ */
.site-header {
  position: sticky;
  top: 0;
  z-index: 100;
  background-color: rgba(247,243,234,.96);
  backdrop-filter: saturate(160%) blur(12px);
  -webkit-backdrop-filter: saturate(160%) blur(12px);
  border-bottom: 1px solid var(--color-border);
  transition: box-shadow var(--transition), border-color var(--transition);
}
.site-header.is-scrolled {
  box-shadow: 0 4px 32px rgba(28,16,0,.10);
  border-bottom-color: var(--color-border-mid);
}

.site-header__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: var(--header-height);
  gap: var(--space-md);
}

.logo {
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: var(--space-xs);
  text-decoration: none;
  color: var(--color-text);
  line-height: 1;
}
.logo__img {
  height: 70px;
  width: auto;
  flex-shrink: 0;
  display: block;
}
.logo__text {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  line-height: 1.1;
}
.logo__name {
  font-family: var(--font-serif);
  font-size: 1.75rem;
  font-weight: 500;
  letter-spacing: 0.18em;
  color: var(--color-text);
}
.logo__tagline {
  font-size: 0.72rem;
  font-weight: 600;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: #4A4035;
  margin-top: 4px;
}
/* Sous-titre "Massage thaï traditionnel" */
.logo__sub {
  font-family: var(--font-serif);
  font-size: 1rem;
  font-style: italic;
  font-weight: 500;
  color: #4A4035;
  margin-top: 1px;
  letter-spacing: 0.04em;
}

/* Mobile : on réduit un peu pour que ça reste lisible */
@media (max-width: 768px) {
  .logo__img      { height: 52px; }
  .logo__name     { font-size: 1.35rem; }
  .logo__tagline  { font-size: 0.62rem; letter-spacing: 0.18em; }
  .logo__sub      { font-size: 0.88rem; }
}

/* Nav est maintenant un sibling du header dans le DOM (hors <header>).
   On le repositionne en fixed pour qu'il apparaisse visuellement dans la bande header. */
.nav {
  display: flex;
  align-items: center;
  gap: var(--space-md);
  position: fixed;
  top: 0;
  right: max(var(--space-md), calc((100vw - var(--max-width)) / 2 + var(--space-md)));
  height: var(--header-height);
  z-index: 101;
}
.nav__list { display: flex; align-items: center; gap: var(--space-md); }

.nav__link {
  font-size: var(--fs-sm);
  font-weight: 500;
  color: var(--color-muted);
  letter-spacing: 0.03em;
  position: relative;
  padding: var(--space-2xs) 0;
  transition: color var(--transition);
}
.nav__link:hover { color: var(--color-text); }
.nav__link::after {
  content: "";
  position: absolute;
  left: 0; bottom: -4px;
  width: 0; height: 1.5px;
  background-color: var(--color-primary);
  transition: width var(--transition);
}
.nav__link:hover::after,
.nav__link[aria-current="page"]::after { width: 100%; }
.nav__link[aria-current="page"] { color: var(--color-text); }

.nav__cta { display: inline-flex; align-items: center; }

/* Burger — caché sur desktop, fixed en haut à droite sur mobile */
.menu-toggle {
  display: none;
  position: fixed;
  top: 0;
  right: var(--space-md);
  width: 48px;
  height: var(--header-height);
  align-items: center; justify-content: center;
  z-index: 999;
  background: transparent;
  border: none;
  padding: 0;
  cursor: pointer;
  touch-action: manipulation;
  -webkit-tap-highlight-color: transparent;
  user-select: none;
  -webkit-user-select: none;
}
.menu-toggle__bar {
  display: block;
  width: 26px; height: 1.5px;
  background-color: var(--color-text);
  position: relative;
  transition: background-color 200ms;
}
.menu-toggle__bar::before,
.menu-toggle__bar::after {
  content: "";
  position: absolute;
  left: 0;
  width: 26px; height: 1.5px;
  background-color: var(--color-text);
  transition: transform 250ms;
}
.menu-toggle__bar::before { top: -8px; }
.menu-toggle__bar::after  { top:  8px; }
.menu-toggle[aria-expanded="true"] .menu-toggle__bar { background: transparent; }
.menu-toggle[aria-expanded="true"] .menu-toggle__bar::before { transform: translateY(8px) rotate(45deg); }
.menu-toggle[aria-expanded="true"] .menu-toggle__bar::after  { transform: translateY(-8px) rotate(-45deg); }

/* ============================================================
   7. HERO
   ============================================================ */
.hero {
  position: relative;
  min-height: clamp(600px, 90vh, 900px);
  display: grid;
  align-items: center;
  overflow: hidden;
  isolation: isolate;
}

/* Extra height pour la course du parallax */
.hero__bg {
  position: absolute;
  top: -25%;
  left: 0; right: 0;
  bottom: -25%;
  z-index: -2;
  overflow: hidden;
  will-change: transform;
  /* Fallback si la vidéo ne charge pas */
  background: url('https://images.unsplash.com/photo-1600334129128-685c5582fd35?auto=format&fit=crop&w=1920&q=80') center/cover no-repeat;
}
.hero__video {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  display: block;
  position: absolute;
  top: 0; left: 0;
}

/* Reduced motion : pause vidéo */
/* Ken Burns vidéo : très doux, on le garde même en reduce-motion */

.hero__overlay {
  position: absolute; inset: 0; z-index: -1;
  background: linear-gradient(
    105deg,
    rgba(28,16,0,.45) 0%,
    rgba(28,16,0,.28) 50%,
    rgba(28,16,0,.05) 100%
  );
}

/* Liseré vertical or — signature graphique */
.hero__decor {
  position: absolute;
  left: 0; top: 0; bottom: 0;
  width: 3px;
  background: linear-gradient(
    to bottom,
    transparent 0%,
    var(--color-primary-light) 25%,
    var(--color-primary-light) 75%,
    transparent 100%
  );
  opacity: 0.7;
  z-index: 1;
}

.hero__inner {
  max-width: 800px;
  color: var(--color-white);
  padding: var(--space-2xl) 0;
  position: relative;
  z-index: 2;
}

.hero h1 { color: var(--color-white); margin-bottom: var(--space-md); }
.hero h1 em { font-style: italic; color: var(--color-primary-light); }
.hero__subtitle {
  color: rgba(255,255,255,.8);
  font-size: var(--fs-md);
  margin-bottom: var(--space-lg);
  max-width: 56ch;
}
.hero__actions { display: flex; flex-wrap: wrap; gap: var(--space-sm); }
.hero .eyebrow { color: var(--color-primary-light); margin-bottom: var(--space-md); }
.hero .eyebrow::before { background-color: var(--color-primary-light); }

/* ============================================================
   8. RÉASSURANCE
   ============================================================ */
.reassurance {
  background-color: var(--color-bg-alt);
  padding: var(--space-xl) 0;
  border-bottom: 1px solid var(--color-border);
}
.reassurance__grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: var(--space-lg);
}
.reassurance__item {
  display: flex; flex-direction: column;
  align-items: flex-start; gap: var(--space-2xs);
}
.reassurance__icon {
  width: 40px; height: 40px;
  color: var(--color-primary);
  margin-bottom: var(--space-2xs);
}
.reassurance__title {
  font-family: var(--font-sans);
  font-weight: 600;
  font-size: var(--fs-md);
  color: var(--color-text);
}
.reassurance__desc { font-size: var(--fs-sm); color: var(--color-muted); margin: 0; }

/* ============================================================
   9. CARTES
   ============================================================ */
.cards-grid { display: grid; gap: var(--space-md); }
.cards-grid--soins    { grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); }
.cards-grid--formules { grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); }

/* Carte soin — tilt 3D géré par JS */
.card {
  background-color: var(--color-bg-card);
  border-radius: var(--radius-lg);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  box-shadow: var(--shadow-sm);
  border: 1px solid var(--color-border);
  position: relative;
  will-change: transform;
  /* transition CSS pour le retour au repos (override par JS en live) */
  transition: box-shadow var(--transition-slow), border-color var(--transition-slow);
}
.card:hover {
  box-shadow: var(--shadow-gold);
  border-color: rgba(200,146,10,.35);
}

.card__image {
  aspect-ratio: 4 / 3;
  background-size: cover;
  background-position: center;
  background-color: var(--color-bg-surface);
  overflow: hidden;
}
/* Zoom léger sur l'image au hover de la carte */
.card:hover .card__image {
  transform: scale(1.04);
  transition: transform 600ms ease;
}

.card__body {
  padding: var(--space-md);
  display: flex; flex-direction: column;
  gap: var(--space-xs);
  flex: 1;
  position: relative;
}

/* Numéro en filigrane — touche éditoriale */
.card__number {
  position: absolute;
  top: var(--space-xs);
  right: var(--space-md);
  font-family: var(--font-serif);
  font-size: 4.5rem;
  font-weight: 400;
  line-height: 1;
  color: rgba(200,146,10,.09);
  pointer-events: none;
  user-select: none;
  transition: color var(--transition-slow);
}
.card:hover .card__number { color: rgba(200,146,10,.18); }

.card__name-thai {
  display: block;
  font-family: var(--font-serif);
  font-style: italic;
  font-size: var(--fs-sm);
  color: var(--color-primary);
  letter-spacing: 0.04em;
  margin-bottom: var(--space-xs);
}
.card__title {
  font-family: var(--font-serif);
  font-size: var(--fs-lg);
  font-weight: 500;
  color: var(--color-text);
  line-height: 1.2;
}
.card__desc { font-size: var(--fs-sm); color: var(--color-muted); flex: 1; }

/* CTA "Découvrir" en bas de chaque carte massage */
.card__cta {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.45em;
  margin-top: var(--space-sm);
  align-self: flex-start;
  font-family: var(--font-sans);
  font-size: 0.72rem;
  font-weight: 600;
  letter-spacing: 0.10em;
  text-transform: uppercase;
  color: var(--color-primary, #C49A35);
  text-decoration: none;
  padding: 0.45em 1.1em;
  border: 1.5px solid rgba(200,146,10,.55);
  border-radius: 2em;
  background: transparent;
  transition: background 0.25s ease, color 0.25s ease, border-color 0.25s ease, box-shadow 0.25s ease;
}
.card__cta span {
  display: inline-block;
  transition: transform 0.3s cubic-bezier(0.22, 0.61, 0.36, 1);
}
.card:hover .card__cta {
  background: var(--color-primary);
  color: #fff;
  border-color: var(--color-primary);
  box-shadow: 0 4px 18px rgba(200,146,10,.30);
}
.card:hover .card__cta span { transform: translateX(3px); }
.card__meta {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  font-size: var(--fs-sm);
  color: var(--color-muted);
  border-top: 1px solid var(--color-border);
  padding-top: var(--space-sm);
  margin-top: auto;
}
.card__price { color: var(--color-primary); font-weight: 700; font-size: var(--fs-md); }

/* ============================================================
   CARROUSEL FORMULES (homepage)
   ============================================================ */
.formules-carousel {
  position: relative;
  display: grid;
  grid-template-columns: 48px 1fr 48px;
  gap: var(--space-md);
  align-items: center;
}

.formules-carousel__track {
  grid-column: 2;
  display: flex;
  gap: var(--space-md);
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  scroll-behavior: smooth;
  scrollbar-width: none;        /* Firefox */
  -ms-overflow-style: none;     /* IE / Edge */
  padding: var(--space-xs) 0;   /* Pour ne pas couper les ombres */
}
.formules-carousel__track::-webkit-scrollbar { display: none; }

.formules-carousel .formule-card {
  flex: 0 0 calc((100% - 2 * var(--space-md)) / 3); /* 3 cartes visibles desktop */
  scroll-snap-align: start;
  min-width: 0;
}

/* Flèches */
.carousel-arrow {
  width: 48px; height: 48px;
  border-radius: 50%;
  background-color: var(--color-bg-card);
  border: 1px solid var(--color-border);
  color: var(--color-primary);
  display: flex; align-items: center; justify-content: center;
  cursor: pointer;
  transition: background-color var(--transition), color var(--transition),
              border-color var(--transition), transform var(--transition),
              box-shadow var(--transition);
  z-index: 2;
}
.carousel-arrow svg { width: 22px; height: 22px; }
.carousel-arrow:hover {
  background-color: var(--color-primary);
  color: var(--color-white);
  border-color: var(--color-primary);
  transform: scale(1.06);
  box-shadow: var(--shadow);
}
.carousel-arrow:disabled {
  opacity: 0.35;
  cursor: not-allowed;
  transform: none;
}
.carousel-arrow--prev { grid-column: 1; justify-self: end; }
.carousel-arrow--next { grid-column: 3; justify-self: start; }

/* Dots de pagination */
.carousel-dots {
  grid-column: 2;
  display: flex;
  gap: 10px;
  justify-content: center;
  margin-top: var(--space-md);
}
.carousel-dot {
  width: 10px; height: 10px;
  border-radius: 50%;
  background-color: var(--color-border);
  border: 0;
  padding: 0;
  cursor: pointer;
  transition: background-color var(--transition), transform var(--transition), width var(--transition);
}
.carousel-dot:hover { background-color: var(--color-secondary); }
.carousel-dot[aria-selected="true"] {
  background-color: var(--color-primary);
  width: 28px;
  border-radius: 6px;
}

/* Tablette : 2 cartes visibles + flèches plus petites */
@media (max-width: 1024px) {
  .formules-carousel { grid-template-columns: 40px 1fr 40px; gap: var(--space-sm); }
  .carousel-arrow { width: 40px; height: 40px; }
  .formules-carousel .formule-card {
    flex-basis: calc((100% - var(--space-md)) / 2);
  }
}

/* Mobile : 1 carte + flèches masquées (swipe naturel) */
@media (max-width: 640px) {
  .formules-carousel {
    grid-template-columns: 1fr;
  }
  .carousel-arrow { display: none; }
  .formules-carousel__track {
    grid-column: 1;
    padding-left: var(--space-md);
    padding-right: var(--space-md);
    margin: 0 calc(-1 * var(--space-md));
    scroll-padding-left: var(--space-md);
  }
  .formules-carousel .formule-card {
    flex-basis: 85%;
    scroll-snap-align: center;
  }
  .carousel-dots { grid-column: 1; }
}

/* Carte formule — tilt 3D géré par JS aussi */
.formule-card {
  background-color: var(--color-bg-card);
  border-radius: var(--radius-lg);
  border: 1px solid var(--color-border);
  padding: 0;
  display: flex; flex-direction: column;
  gap: var(--space-xs);
  overflow: hidden;
  will-change: transform;
  transition: box-shadow var(--transition), border-color var(--transition);
}
.formule-card:hover {
  box-shadow: var(--shadow-gold);
  border-color: rgba(200,146,10,.40);
}

/* Image en tête de carte formule (fallback dégradé doré si l'image manque) */
.formule-card__image {
  width: 100%;
  aspect-ratio: 16 / 10;
  background-size: cover;
  background-position: center;
  background-color: #E8DBC7;
  background-image: linear-gradient(135deg, #F4E9D2 0%, #DDC9A6 100%);
  margin-bottom: var(--space-sm);
}
/* Padding rétabli sur le contenu texte */
.formule-card > .formule-card__duration,
.formule-card > .formule-card__name,
.formule-card > .formule-card__list,
.formule-card > .formule-card__price {
  padding-left: var(--space-md);
  padding-right: var(--space-md);
}
.formule-card > .formule-card__duration { padding-top: 0; }
.formule-card > .formule-card__price    { padding-bottom: var(--space-md); }
.formule-card > .formule-card__cta      { padding-bottom: 0; }

/* CTA "Découvrir" en bas de chaque carte formule du carrousel */
.formule-card__cta {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.45em;
  margin-top: auto;
  margin-left: var(--space-md);
  margin-bottom: var(--space-md);
  align-self: flex-start;
  font-family: var(--font-sans);
  font-size: 0.72rem;
  font-weight: 600;
  letter-spacing: 0.10em;
  text-transform: uppercase;
  color: var(--color-primary, #C49A35);
  text-decoration: none;
  padding: 0.45em 1.1em;
  border: 1.5px solid rgba(200,146,10,.55);
  border-radius: 2em;
  background: transparent;
  transition: background 0.25s ease, color 0.25s ease, border-color 0.25s ease, box-shadow 0.25s ease;
}
.formule-card__cta span {
  display: inline-block;
  transition: transform 0.3s cubic-bezier(0.22, 0.61, 0.36, 1);
}
.formule-card:hover .formule-card__cta {
  background: var(--color-primary);
  color: #fff;
  border-color: var(--color-primary);
  box-shadow: 0 4px 18px rgba(200,146,10,.30);
}
.formule-card:hover .formule-card__cta span { transform: translateX(3px); }

/* Featured : fond or nacré */
.formule-card--featured {
  background: linear-gradient(145deg, #FEF8E8 0%, #F9EDCC 100%);
  border-color: rgba(200,146,10,.45);
  box-shadow: 0 0 0 1px rgba(200,146,10,.20);
}
.formule-card--featured .formule-card__name  { color: var(--color-primary); }
.formule-card--featured .formule-card__list  { color: var(--color-muted); }
.formule-card--featured .formule-card__price { color: var(--color-primary); }

.formule-card__name {
  font-family: var(--font-serif);
  font-size: var(--fs-lg);
  font-weight: 500;
  color: var(--color-primary);
  letter-spacing: 0.02em;
}
.formule-card__duration {
  font-size: var(--fs-xs);
  color: var(--color-muted);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  font-weight: 600;
}
.formule-card__list { font-size: var(--fs-sm); color: var(--color-muted); line-height: 1.6; }
.formule-card__price {
  font-family: var(--font-serif);
  font-size: 2.25rem;
  font-weight: 500;
  color: var(--color-primary);
  margin-top: auto;
  padding-top: var(--space-sm);
  border-top: 1px dashed var(--color-border);
}

/* Note agrégée Google */
.google-aggregate {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-lg);
  background-color: var(--color-bg-alt);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  padding: var(--space-md) var(--space-xl);
  margin-bottom: var(--space-xl);
  flex-wrap: wrap;
}
.google-aggregate__score {
  font-family: var(--font-serif);
  font-size: 3.5rem;
  font-weight: 400;
  color: var(--color-text);
  line-height: 1;
}
.google-aggregate__right {
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.google-aggregate__stars {
  color: #FBBC04;
  font-size: 1.4rem;
  letter-spacing: 2px;
}
.google-aggregate__label {
  font-size: var(--fs-sm);
  color: var(--color-muted);
}
.google-aggregate__logo {
  display: flex;
  align-items: center;
  gap: 6px;
  font-family: var(--font-sans);
  font-size: var(--fs-md);
  font-weight: 600;
  color: var(--color-text);
}
.google-aggregate__rating {
  display: flex;
  flex-direction: column;
  gap: 4px;
  align-items: center;
}
.google-aggregate__count {
  font-size: var(--fs-sm);
  color: var(--color-muted);
  margin: 0;
}
.google-aggregate__score span {
  font-size: var(--fs-md);
  color: var(--color-muted);
}
.google-aggregate__cta {
  display: flex;
  gap: var(--space-sm);
  flex-wrap: wrap;
}

/* G coloré façon Google */
.google-g {
  font-size: 1.6rem;
  font-weight: 700;
  background: linear-gradient(135deg, #4285F4 25%, #EA4335 25% 50%, #FBBC04 50% 75%, #34A853 75%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

/* Témoignages */
.testimonials__grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: var(--space-md);
}
.testimonial {
  background-color: var(--color-bg-card);
  border-radius: var(--radius-lg);
  padding: var(--space-md);
  border: 1px solid var(--color-border);
  display: flex; flex-direction: column;
  gap: var(--space-sm);
  transition: transform var(--transition), box-shadow var(--transition), border-color var(--transition);
}
.testimonial:hover {
  transform: translateY(-3px);
  box-shadow: var(--shadow);
  border-color: var(--color-border-mid);
}
/* En-tête d'avis : avatar + nom + source */
.testimonial__header {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
}
.testimonial__avatar {
  width: 40px;
  height: 40px;
  border-radius: var(--radius-full);
  background-color: var(--color-primary);
  color: var(--color-white);
  font-family: var(--font-serif);
  font-size: 1.1rem;
  font-weight: 500;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.testimonial__meta { display: flex; flex-direction: column; gap: 2px; }
.testimonial__name { font-weight: 600; font-size: var(--fs-sm); color: var(--color-text); }
.testimonial__source {
  font-size: var(--fs-xs);
  color: var(--color-muted);
  display: flex;
  align-items: center;
  gap: 4px;
}

.testimonial__stars { display: flex; gap: 2px; color: #FBBC04; }
.testimonial__text {
  font-family: var(--font-serif);
  font-style: italic;
  font-size: var(--fs-md);
  color: var(--color-text);
  line-height: 1.5;
}
.testimonial__text::before { content: "« "; color: var(--color-primary); }
.testimonial__text::after  { content: " »"; color: var(--color-primary); }
.testimonial__author { font-size: var(--fs-sm); color: var(--color-muted); letter-spacing: 0.05em; }
.testimonials__google {
  text-align: center;
  margin-top: var(--space-lg);
  color: var(--color-muted);
  font-size: var(--fs-sm);
}

/* ============================================================
   10. PHILOSOPHIE
   ============================================================ */
/* Grid 2 colonnes uniquement sur la homepage (texte + image), pas sur la page À propos */
div.philosophy {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-2xl);
  align-items: center;
}
.philosophy__text { max-width: 50ch; }
.philosophy__text h2 { margin-bottom: var(--space-md); }
.philosophy__text p + p { margin-top: var(--space-sm); }
.philosophy__text p { color: var(--color-muted); }

.philosophy__image {
  aspect-ratio: 4 / 5;
  background-size: cover;
  background-position: center;
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-lg);
  overflow: hidden;
  will-change: transform;
}

/* Page À propos : section philosophie centrée (sans image) */
.philosophy .philosophy__inner {
  max-width: 70ch;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  gap: var(--space-md);
  text-align: center;
}
.philosophy .philosophy__content {
  display: flex;
  flex-direction: column;
  gap: var(--space-md);
  align-items: center;
}
.philosophy .philosophy__content blockquote {
  margin: 0;
  font-family: var(--font-serif);
  font-style: italic;
  font-size: var(--fs-md);
  color: var(--color-text);
  border-left: 3px solid var(--color-secondary);
  padding: var(--space-sm) var(--space-md);
  text-align: left;
  max-width: 60ch;
}
.philosophy .philosophy__content blockquote cite {
  display: block;
  margin-top: var(--space-xs);
  font-style: normal;
  font-size: var(--fs-sm);
  color: var(--color-muted);
  letter-spacing: 0.05em;
}

/* ============================================================
   12. CONTACT RAPIDE
   ============================================================ */
.contact-quick {
  display: grid;
  grid-template-columns: 1.1fr 1fr;
  gap: var(--space-2xl);
  align-items: center;
}
.contact-quick__details { display: flex; flex-direction: column; gap: var(--space-md); }
.contact-quick__details h2 { margin-bottom: var(--space-sm); }

.contact-info { display: grid; gap: var(--space-md); margin: var(--space-md) 0; }
.contact-info__item { display: flex; gap: var(--space-md); align-items: flex-start; }
.contact-info__icon {
  flex-shrink: 0;
  width: 36px; height: 36px;
  color: var(--color-primary);
  background-color: var(--color-bg-surface);
  padding: 8px;
  border-radius: var(--radius-full);
}
.contact-info__label {
  font-size: var(--fs-xs);
  text-transform: uppercase;
  letter-spacing: 0.12em;
  font-weight: 700;
  color: var(--color-primary);
  margin-bottom: 2px;
}
.contact-info__value {
  font-family: var(--font-serif);
  font-size: var(--fs-md);
  color: var(--color-text);
}
.contact-info__value a { color: var(--color-text); }
.contact-info__value a:hover { color: var(--color-primary); }
.contact-info__value small {
  display: block;
  font-family: var(--font-sans);
  font-size: var(--fs-sm);
  color: var(--color-muted);
  margin-top: 2px;
}

.contact-quick__map {
  height: 540px;
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-lg);
  overflow: hidden;
  border: 1px solid var(--color-border);
}
.contact-quick__map iframe {
  width: 100%;
  height: 100%;
  border: 0;
  display: block;
}

/* ============================================================
   13. FOOTER
   ============================================================ */
.site-footer {
  background-color: var(--color-bg-dark);
  color: #B89840;
  padding: var(--space-2xl) 0 var(--space-md);
  margin-top: var(--space-2xl);
}
.site-footer__grid {
  display: grid;
  grid-template-columns: 1.4fr 1fr 1fr 1fr;
  gap: var(--space-lg);
  margin-bottom: var(--space-xl);
}
.site-footer h4 {
  color: #F5EEC8;
  font-family: var(--font-sans);
  font-size: var(--fs-xs);
  text-transform: uppercase;
  letter-spacing: 0.16em;
  font-weight: 600;
  margin-bottom: var(--space-md);
}
.site-footer ul { display: flex; flex-direction: column; gap: var(--space-2xs); }
.site-footer a { color: #B89840; }
.site-footer a:hover { color: var(--color-primary-light); }
.site-footer__brand p {
  color: rgba(160,152,120,.80);
  font-size: var(--fs-sm);
  margin-top: var(--space-sm);
  max-width: 32ch;
}
.site-footer__logo {
  display: inline-flex;
  align-items: center;
  gap: var(--space-xs);
  font-family: var(--font-serif);
  font-size: 1.6rem;
  font-weight: 500;
  letter-spacing: 0.18em;
  color: #F5EEC8;
  text-decoration: none;
}
.site-footer__logo .logo__img {
  height: 44px;
  width: auto;
  /* logo noir → blanc sur fond sombre */
  filter: brightness(0) invert(1);
  opacity: 0.85;
}
.site-footer__logo-text {
  display: flex;
  flex-direction: column;
}
.site-footer__logo span {
  display: block;
  font-family: var(--font-sans);
  font-size: 0.7rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--color-primary-light);
  margin-top: 4px;
}
.site-footer__notice {
  text-align: center;
  font-size: var(--fs-xs);
  font-style: italic;
  color: rgba(160,152,120,.55);
  margin: 0 auto var(--space-md);
  max-width: 60ch;
  letter-spacing: 0.02em;
}
.site-footer__bottom {
  border-top: 1px solid rgba(200,146,10,.18);
  padding-top: var(--space-md);
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  gap: var(--space-sm);
  font-size: var(--fs-xs);
  color: rgba(160,152,120,.60);
}
.site-footer__bottom-links { display: flex; gap: var(--space-md); flex-wrap: wrap; }

.socials { display: flex; gap: var(--space-xs); }
.socials a {
  display: flex; align-items: center; justify-content: center;
  width: 36px; height: 36px;
  border-radius: var(--radius-full);
  border: 1px solid rgba(200,146,10,.25);
  color: #B89840;
  transition: all var(--transition);
}
.socials a:hover {
  background-color: var(--color-primary);
  color: var(--color-white);
  border-color: var(--color-primary);
}
.socials svg { width: 16px; height: 16px; }

/* ============================================================
   14. PAGES SECONDAIRES
   ============================================================ */
.page-hero {
  position: relative;
  background-color: var(--color-bg-dark);
  padding: var(--space-2xl) 0 var(--space-xl);
  text-align: center;
  border-bottom: 1px solid var(--color-border);
  overflow: hidden;
  isolation: isolate;
  min-height: 360px;
  display: flex;
  align-items: center;
  justify-content: center;
}
.page-hero__bg {
  position: absolute;
  inset: 0;
  z-index: -2;
  pointer-events: none;
}
.page-hero__bg video {
  width: 100%;
  height: 100%;
  object-fit: cover;
  animation: kenburns 28s ease-in-out infinite alternate;
  transform-origin: center center;
}
.page-hero__overlay {
  position: absolute;
  inset: 0;
  z-index: -1;
  background: linear-gradient(
    180deg,
    rgba(42, 36, 30, 0.25) 0%,
    rgba(42, 36, 30, 0.22) 60%,
    rgba(42, 36, 30, 0.38) 100%
  );
  pointer-events: none;
}
.page-hero .container { position: relative; z-index: 1; }
.page-hero .eyebrow { color: var(--color-primary-light, #D4B055); }
.page-hero .eyebrow::before { background-color: var(--color-primary-light, #D4B055); }
.page-hero h1 {
  font-size: var(--fs-2xl);
  margin-bottom: var(--space-sm);
  color: #FFFFFF;
}
.page-hero h1 em { color: var(--color-primary-light, #D4B055); font-style: italic; }
.page-hero p  {
  color: rgba(255,255,255,0.88);
  margin: 0 auto;
  max-width: 56ch;
}
/* Variante compacte (mentions-legales) */
.page-hero--compact {
  min-height: 240px;
  padding: var(--space-xl) 0 var(--space-lg);
}

.placeholder {
  text-align: center;
  padding: var(--space-2xl) 0;
  max-width: 60ch;
  margin: 0 auto;
}
.placeholder h2 { font-size: var(--fs-xl); margin-bottom: var(--space-sm); color: var(--color-primary); }
.placeholder p  { margin: 0 auto var(--space-md); color: var(--color-muted); }

/* ============================================================
   14b. PAGES MASSAGES
   ============================================================ */
.massage-detail {
  position: relative;
  overflow: hidden;
}
.massage-detail__inner {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-2xl);
  align-items: center;
  position: relative;
}

/* Image avec hover-zoom et halo doré */
.massage-detail__image {
  border-radius: var(--radius-lg);
  background-size: cover;
  background-position: center;
  aspect-ratio: 4 / 5;
  box-shadow: var(--shadow-lg);
  overflow: hidden;
  transition: transform 0.7s cubic-bezier(0.22, 0.61, 0.36, 1),
              box-shadow 0.5s ease,
              filter 0.7s ease;
  will-change: transform;
}
.massage-detail__image::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, rgba(200,146,10,0) 0%, rgba(200,146,10,0.18) 100%);
  opacity: 0;
  transition: opacity 0.5s ease;
  pointer-events: none;
  border-radius: var(--radius-lg);
}
.massage-detail:hover .massage-detail__image {
  transform: scale(1.03);
  box-shadow: 0 30px 70px rgba(200,146,10,0.25), 0 12px 30px rgba(42,42,42,0.15);
  filter: saturate(1.08);
}
.massage-detail:hover .massage-detail__image::after { opacity: 1; }

.massage-detail__content {
  display: flex;
  flex-direction: column;
  gap: var(--space-md);
  position: relative;
}
.massage-detail__content h2 {
  font-size: var(--fs-xl);
  margin: 0;
  position: relative;
}
.massage-detail__content h2::after {
  content: "";
  display: block;
  width: 0;
  height: 2px;
  margin-top: var(--space-sm);
  background: linear-gradient(90deg, var(--color-secondary, #B89B72) 0%, transparent 100%);
  transition: width 1s cubic-bezier(0.22, 0.61, 0.36, 1) 0.3s;
}
.massage-detail.is-visible .massage-detail__content h2::after { width: 80px; }

.massage-detail__content p { color: var(--color-muted); margin: 0; }

/* Numéro géant en filigrane derrière le titre */
.massage-detail__content .card__number {
  position: absolute;
  top: -40px;
  left: -10px;
  font-family: var(--font-serif);
  font-size: 9rem;
  font-weight: 500;
  font-style: italic;
  color: rgba(200,146,10,0.10);
  line-height: 1;
  pointer-events: none;
  user-select: none;
  z-index: 0;
  transition: color 0.5s ease, transform 0.7s ease;
}
.massage-detail:hover .massage-detail__content .card__number {
  color: rgba(200,146,10,0.20);
  transform: translateX(-6px);
}
.massage-detail__content > * { position: relative; z-index: 1; }

/* Bénéfices : reveal avec stagger au scroll */
.massage-detail__benefits {
  list-style: none; padding: 0; margin: 0;
  display: flex; flex-direction: column; gap: var(--space-xs);
}
.massage-detail__benefits li {
  padding-left: 1.6em;
  position: relative;
  color: var(--color-text);
  font-size: var(--fs-sm);
  opacity: 0;
  transform: translateX(-12px);
  transition: opacity 600ms ease, transform 600ms ease;
}
.massage-detail.is-visible .massage-detail__benefits li { opacity: 1; transform: translateX(0); }
.massage-detail.is-visible .massage-detail__benefits li:nth-child(1) { transition-delay: 0.1s; }
.massage-detail.is-visible .massage-detail__benefits li:nth-child(2) { transition-delay: 0.2s; }
.massage-detail.is-visible .massage-detail__benefits li:nth-child(3) { transition-delay: 0.3s; }
.massage-detail.is-visible .massage-detail__benefits li:nth-child(4) { transition-delay: 0.4s; }
.massage-detail.is-visible .massage-detail__benefits li:nth-child(5) { transition-delay: 0.5s; }

.massage-detail__benefits li::before {
  content: '';
  position: absolute;
  left: 2px;
  top: 0.55em;
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: radial-gradient(circle at 30% 30%, var(--color-primary-light, #D4B055) 0%, var(--color-primary, #C49A35) 70%);
  box-shadow: 0 0 6px rgba(200,146,10,0.30);
  transition: transform 0.4s ease, box-shadow 0.4s ease;
}
.massage-detail__benefits li:hover::before {
  transform: scale(1.35);
  box-shadow: 0 0 10px rgba(200,146,10,0.55);
}

/* Pricing pills lumineuses */
.massage-detail__pricing {
  display: flex; gap: var(--space-sm); flex-wrap: wrap;
}
.pricing-pill {
  display: flex; align-items: center; gap: var(--space-xs);
  background-color: var(--color-bg-alt);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-full);
  padding: var(--space-xs) var(--space-md);
  position: relative;
  cursor: default;
  transition: transform 0.25s ease, box-shadow 0.3s ease,
              border-color 0.3s ease, background-color 0.3s ease;
  overflow: hidden;
}
.pricing-pill::before {
  content: "";
  position: absolute;
  top: 0; left: -100%;
  width: 60%; height: 100%;
  background: linear-gradient(120deg,
    transparent 0%, rgba(255,235,180,0.55) 50%, transparent 100%);
  transform: skewX(-20deg);
  transition: left 700ms ease;
  pointer-events: none;
}
.pricing-pill:hover {
  transform: translateY(-2px);
  border-color: var(--color-secondary);
  background: linear-gradient(135deg, #FEF8E8 0%, #F9EDCC 100%);
  box-shadow: 0 8px 20px rgba(200,146,10,0.20);
}
.pricing-pill:hover::before { left: 130%; }
.pricing-pill__duration { font-size: var(--fs-sm); color: var(--color-muted); }
.pricing-pill__price {
  font-family: var(--font-serif);
  font-size: var(--fs-md);
  font-weight: 600;
  color: var(--color-primary);
  letter-spacing: 0.01em;
}

/* Bouton "Réserver ce soin" — appel doux à l'action */
.massage-detail .btn--primary {
  align-self: flex-start;
  position: relative;
}
.massage-detail .btn--primary::before {
  content: "";
  position: absolute;
  inset: -4px;
  border-radius: var(--radius-full);
  background: radial-gradient(circle, rgba(200,146,10,0.35) 0%, rgba(200,146,10,0) 65%);
  opacity: 0;
  z-index: -1;
  transition: opacity 0.4s ease;
  pointer-events: none;
}
.massage-detail.is-visible .btn--primary::before { opacity: 1; animation: pulseGlow 2.4s ease-in-out infinite; }
@keyframes pulseGlow {
  0%, 100% { transform: scale(1);    opacity: 0.45; }
  50%      { transform: scale(1.08); opacity: 0.85; }
}

/* Apparition au scroll (alternance gauche / droite) */
.massage-detail__image,
.massage-detail__content {
  opacity: 0;
  transform: translateX(-40px);
  transition: opacity 900ms cubic-bezier(0.22, 0.61, 0.36, 1),
              transform 900ms cubic-bezier(0.22, 0.61, 0.36, 1);
}
.massage-detail--alt .massage-detail__image,
.massage-detail--alt .massage-detail__content { transform: translateX(40px); }
.massage-detail.is-visible .massage-detail__image,
.massage-detail.is-visible .massage-detail__content {
  opacity: 1;
  transform: translateX(0);
}
.massage-detail.is-visible .massage-detail__content { transition-delay: 0.15s; }
.ci-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-xl);
  margin-top: var(--space-xl);
}
.ci-block {
  background-color: var(--color-bg-card);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  padding: var(--space-lg);
}
.ci-block h3 {
  font-family: var(--font-serif);
  font-size: var(--fs-md);
  color: var(--color-primary);
  margin: 0 0 var(--space-sm);
}
.ci-block ul { padding-left: var(--space-md); color: var(--color-muted); }
.ci-block ul li { margin-bottom: var(--space-xs); }

/* ============================================================
   14c. PAGES TARIFS — menu éditorial
   ============================================================ */
.tarifs-table {
  margin-top: var(--space-xl);
  display: flex;
  flex-direction: column;
}
/* En-tête : on le retire visuellement (le visuel "menu" parle de lui-même) */
.tarifs-row--header { display: none; }

.tarifs-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto auto;
  align-items: baseline;
  column-gap: var(--space-xl);
  row-gap: var(--space-2xs);
  padding: var(--space-lg) 0;
  border-bottom: 1px dashed rgba(200,146,10,.30);
  transition: padding var(--transition);
}
.tarifs-row:first-of-type { padding-top: 0; }
.tarifs-row:last-of-type  { border-bottom: none; }

/* Bloc nom + sous-titre */
.tarifs-row__name {
  display: flex;
  flex-direction: column;
  gap: 4px;
  min-width: 0;
}
.tarifs-row__name strong {
  font-family: var(--font-serif);
  font-size: 1.4rem;
  font-weight: 500;
  color: var(--color-text);
  letter-spacing: -0.005em;
  line-height: 1.2;
}
.tarifs-row__name span {
  font-size: var(--fs-sm);
  color: var(--color-muted);
  line-height: 1.4;
  font-style: italic;
}

/* Durée */
.tarifs-row__duration {
  font-family: var(--font-sans);
  font-size: 0.72rem;
  font-weight: 600;
  letter-spacing: 0.10em;
  text-transform: uppercase;
  color: var(--color-text);
  background: rgba(200,146,10,.10);
  border: 1px solid rgba(200,146,10,.25);
  border-radius: 999px;
  padding: 4px 12px;
  white-space: nowrap;
  text-align: center;
  align-self: center;
}

/* Prix */
.tarifs-row__price {
  font-family: var(--font-serif);
  font-size: 1.55rem;
  font-weight: 600;
  font-style: italic;
  color: var(--color-primary-dark);
  letter-spacing: 0.01em;
  white-space: nowrap;
  text-align: right;
  align-self: center;
}

/* Léger highlight au survol (ligne entière) */
.tarifs-row:hover .tarifs-row__name strong { color: var(--color-primary); }
.tarifs-row:hover .tarifs-row__price       { transform: scale(1.04); }
.tarifs-row__price { transition: transform 0.25s ease; }
.formules-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-lg);
  margin-top: var(--space-xl);
}

/* === Carte formule éditoriale (page Tarifs) === */
.formules-grid .formule-card {
  background-color: #FFFFFF;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: var(--space-sm);
  position: relative;
  overflow: visible; /* Annule l'overflow hidden pour laisser le badge dépasser */
  transition: transform var(--transition), box-shadow var(--transition), border-color var(--transition);
}

/* Image en haut de la carte formule (page Tarifs), avec fallback dégradé doré */
.formules-grid .formule-card__image {
  width: 100%;
  aspect-ratio: 16 / 10;
  background-size: cover;
  background-position: center;
  background-color: #E8DBC7;
  background-image: linear-gradient(135deg, #F4E9D2 0%, #DDC9A6 100%);
  border-radius: var(--radius-lg) var(--radius-lg) 0 0;
}

/* Tous les enfants texte reprennent le padding intérieur sauf l'image */
.formules-grid .formule-card > *:not(.formule-card__image):not(.formule-badge) {
  padding-left: var(--space-lg);
  padding-right: var(--space-lg);
}
.formules-grid .formule-card > .formule-card__duration { padding-top: var(--space-md); }
.formules-grid .formule-card > .formule-card__price    { padding-bottom: var(--space-lg); }
/* Si pas d'image : conserve l'ancien padding-top */
.formules-grid .formule-card:not(:has(.formule-card__image)) > .formule-card__duration {
  padding-top: var(--space-lg);
}
.formules-grid .formule-card:hover {
  transform: translateY(-3px);
  box-shadow: var(--shadow-gold);
  border-color: rgba(200,146,10,.45);
}

.formules-grid .formule-card .formule-card__duration {
  display: inline-block;
  font-family: var(--font-sans);
  font-size: var(--fs-xs);
  font-weight: 600;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--color-secondary);
  margin: 0;
}

.formules-grid .formule-card .formule-card__name {
  font-family: var(--font-serif);
  font-size: 1.7rem;
  font-style: italic;
  font-weight: 500;
  color: var(--color-primary);
  line-height: 1.1;
  margin: 0;
  letter-spacing: -0.005em;
}

.formules-grid .formule-card .formule-card__intro {
  font-size: var(--fs-sm);
  color: var(--color-muted);
  margin: var(--space-2xs) 0 0;
  line-height: 1.5;
}

.formules-grid .formule-card .formule-card__items {
  list-style: none;
  padding: 0;
  margin: var(--space-xs) 0 0;
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.formules-grid .formule-card .formule-card__items li {
  position: relative;
  padding-left: 1.1em;
  font-size: var(--fs-sm);
  color: var(--color-text);
  line-height: 1.45;
}
.formules-grid .formule-card .formule-card__items li::before {
  content: '';
  position: absolute;
  left: 0;
  top: 0.55em;
  width: 6px; height: 6px;
  border-radius: 50%;
  background-color: var(--color-primary);
}

.formules-grid .formule-card .formule-card__price {
  font-family: var(--font-serif);
  font-size: 1.6rem;
  font-weight: 500;
  color: var(--color-primary);
  margin-top: auto;
  padding-top: var(--space-md);
  border-top: 1px dashed var(--color-border);
  letter-spacing: 0.01em;
}

/* Featured (Orchidée) — fond or doux + badge en pastille flottante */
.formules-grid .formule-card--featured {
  background: linear-gradient(160deg, #FEF8E8 0%, #F9EDCC 100%);
  border-color: rgba(200,146,10,.55);
  box-shadow: 0 0 0 1px rgba(200,146,10,.20), 0 18px 40px rgba(200,146,10,.10);
}
.formules-grid .formule-card--featured .formule-card__price { color: var(--color-primary); }
.formules-grid .formule-card--featured .formule-card__intro { color: #7A6845; }

.formule-badge {
  position: absolute;
  top: -14px;
  left: 50%;
  transform: translateX(-50%);
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 6px 14px;
  background: var(--color-primary);
  color: #FFFFFF;
  font-family: var(--font-sans);
  font-size: 0.7rem;
  font-weight: 600;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  white-space: nowrap;
  border-radius: var(--radius-full);
  box-shadow: 0 4px 12px rgba(139,94,60,0.30);
  z-index: 2;
}
.formule-badge svg { width: 12px; height: 12px; color: var(--color-secondary); }

/* Tablette */
@media (max-width: 1024px) {
  .formules-grid { grid-template-columns: repeat(2, 1fr); gap: var(--space-md); }
  .formules-grid .formule-card { padding: var(--space-md); }
  .formules-grid .formule-card .formule-card__name { font-size: 1.5rem; }
}
/* Mobile */
@media (max-width: 640px) {
  .formules-grid { grid-template-columns: 1fr; }
}
.services-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-lg);
  margin-top: var(--space-xl);
}
.service-item {
  background-color: var(--color-bg-card);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  padding: var(--space-lg);
}
.service-item svg { width: 32px; height: 32px; flex-shrink: 0; color: var(--color-primary); margin-bottom: var(--space-sm); }
.service-item h3 { font-size: var(--fs-md); margin: 0 0 var(--space-xs); }
.service-item p  { font-size: var(--fs-sm); color: var(--color-muted); margin: 0; }
.tarifs-note {
  text-align: center;
  margin-top: var(--space-xl);
  font-size: var(--fs-sm);
  color: var(--color-muted);
}
.tarifs-disclaimer {
  margin-top: var(--space-md);
  font-size: var(--fs-sm);
  font-style: italic;
  color: var(--color-muted);
}

/* Autres soins (page Massages) — grille compacte */
.autres-soins-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--space-md);
  margin-top: var(--space-xl);
}
.autre-soin-card {
  background-color: #FFFFFF;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  padding: var(--space-lg);
  display: flex;
  flex-direction: column;
  gap: var(--space-sm);
  transition: transform var(--transition), box-shadow var(--transition), border-color var(--transition);
}
.autre-soin-card:hover {
  transform: translateY(-3px);
  box-shadow: var(--shadow-gold);
  border-color: rgba(200,146,10,.45);
}
.autre-soin-card h3 {
  font-family: var(--font-serif);
  font-size: 1.4rem;
  font-style: italic;
  color: var(--color-text);
  margin: 0;
}
.autre-soin-card p {
  font-size: var(--fs-sm);
  color: var(--color-muted);
  margin: 0;
  flex: 1;
}
.autre-soin-card__pricing {
  display: flex;
  margin-top: var(--space-xs);
}
.autre-soin-card .btn {
  align-self: flex-start;
  margin-top: var(--space-xs);
}
@media (max-width: 768px) {
  .autres-soins-grid { grid-template-columns: 1fr; }
}

/* ============================================================
   14d. PAGE À PROPOS
   ============================================================ */
.about-inner {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-2xl);
  align-items: center;
}
.about-image {
  border-radius: var(--radius-lg);
  background-size: cover;
  background-position: center;
  aspect-ratio: 4 / 5;
  box-shadow: var(--shadow-lg);
  overflow: hidden;
}
.about-content { display: flex; flex-direction: column; gap: var(--space-md); }
.about-content h2 { font-size: var(--fs-xl); margin: 0; }
.about-content p  { color: var(--color-muted); margin: 0; }
/* Timeline */
.timeline {
  position: relative;
  margin-top: var(--space-xl);
  padding-left: var(--space-xl);
}
.timeline::before {
  content: '';
  position: absolute;
  left: 0; top: 0; bottom: 0;
  width: 2px;
  background: linear-gradient(to bottom, var(--color-primary), transparent);
}
.timeline-item {
  position: relative;
  display: grid;
  grid-template-columns: 80px 1fr;
  gap: var(--space-lg);
  margin-bottom: var(--space-xl);
}
.timeline-item::before {
  content: '';
  position: absolute;
  left: calc(0px - var(--space-xl) - 4px);
  top: 6px;
  width: 10px; height: 10px;
  border-radius: 50%;
  background-color: var(--color-primary);
  border: 2px solid var(--color-bg);
}
.timeline-item__year {
  font-family: var(--font-serif);
  font-size: var(--fs-lg);
  font-weight: 600;
  color: var(--color-primary);
  line-height: 1;
  padding-top: 2px;
}
.timeline-item__content h3 { font-size: var(--fs-md); margin: 0 0 var(--space-xs); }
.timeline-item__content p  { font-size: var(--fs-sm); color: var(--color-muted); margin: 0 0 var(--space-xs); }
.timeline-item__content p:last-child { margin-bottom: 0; }

.timeline-list {
  list-style: none;
  margin: var(--space-xs) 0 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 0.35em;
}
.timeline-list li {
  font-size: var(--fs-sm);
  color: var(--color-muted);
  padding-left: 1.2em;
  position: relative;
}
.timeline-list li::before {
  content: '';
  position: absolute;
  left: 0;
  top: 0.55em;
  width: 5px; height: 5px;
  border-radius: 50%;
  background-color: var(--color-primary);
}

.about-notice {
  margin-top: var(--space-md);
  padding: var(--space-sm) var(--space-md);
  border-left: 3px solid var(--color-border-mid);
  background: var(--color-bg-alt);
  border-radius: 0 var(--radius-sm) var(--radius-sm) 0;
  font-size: var(--fs-sm);
  color: var(--color-muted);
}

/* ============================================================
   14e. PAGE CONTACT
   ============================================================ */
.contact-page__grid {
  display: grid;
  grid-template-columns: 1fr 1.2fr;
  gap: var(--space-2xl);
  align-items: start;
}
.contact-page__info { display: flex; flex-direction: column; gap: var(--space-lg); }
.contact-block {
  display: grid;
  grid-template-columns: 40px 1fr;
  gap: var(--space-md);
  align-items: start;
}
.contact-block svg { width: 22px; height: 22px; color: var(--color-primary); margin-top: 2px; }
.contact-block h3  { font-size: var(--fs-sm); font-family: var(--font-sans); font-weight: 600; margin: 0 0 4px; text-transform: uppercase; letter-spacing: 0.08em; color: var(--color-muted); }
.contact-block p   { font-size: var(--fs-sm); color: var(--color-muted); margin: 4px 0 0; }
.contact-block__value {
  font-family: var(--font-serif);
  font-size: var(--fs-lg);
  color: var(--color-text);
  text-decoration: none;
  display: block;
}
a.contact-block__value:hover { color: var(--color-primary); }
.contact-page__map {
  height: 600px;
  border-radius: var(--radius-lg);
  overflow: hidden;
  box-shadow: var(--shadow-lg);
  border: 1px solid var(--color-border);
  position: sticky;
  top: calc(var(--header-height) + var(--space-lg));
}
.contact-page__map iframe { width: 100%; height: 100%; border: 0; display: block; }
.hours-table { width: 100%; border-collapse: collapse; margin-top: var(--space-sm); }
.hours-table td {
  padding: 4px 0;
  font-size: var(--fs-sm);
  color: var(--color-text);
}
.hours-table td:first-child { color: var(--color-muted); width: 100px; }
.hours-table__closed { color: var(--color-muted) !important; font-style: italic; }
.acces-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-lg);
  margin-top: var(--space-xl);
}
.acces-item {
  background-color: var(--color-bg-card);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  padding: var(--space-lg);
}
.acces-item h3 { font-size: var(--fs-md); margin: 0 0 var(--space-sm); }
.acces-item p  { font-size: var(--fs-sm); color: var(--color-muted); margin: 0; }

/* ============================================================
   14g. PAGE AVIS
   ============================================================ */
.testimonials-grid--full {
  grid-template-columns: repeat(3, 1fr);
  margin-top: var(--space-xl);
}

/* ============================================================
   14h. PAGES LÉGALES
   ============================================================ */
.page-hero--compact { padding: var(--space-xl) 0 var(--space-lg); }
.legal-section { padding: var(--space-xl) 0 var(--space-3xl); }
.legal-container {
  display: grid;
  grid-template-columns: 220px 1fr;
  gap: var(--space-2xl);
  align-items: start;
}
.legal-nav {
  position: sticky;
  top: calc(var(--header-height) + var(--space-lg));
  background-color: var(--color-bg-alt);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  padding: var(--space-md);
}
.legal-nav ul { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 4px; }
.legal-nav a {
  display: block;
  padding: var(--space-xs) var(--space-sm);
  border-radius: var(--radius);
  font-size: var(--fs-sm);
  color: var(--color-muted);
  text-decoration: none;
  transition: all var(--transition);
}
.legal-nav a:hover {
  background-color: var(--color-bg-card);
  color: var(--color-primary);
}
.legal-block {
  padding-bottom: var(--space-2xl);
  border-bottom: 1px solid var(--color-border);
  margin-bottom: var(--space-2xl);
}
.legal-block:last-child { border-bottom: none; margin-bottom: 0; padding-bottom: 0; }
.legal-block h2 { font-size: var(--fs-xl); margin: 0 0 var(--space-lg); color: var(--color-primary); }
.legal-block h3 { font-size: var(--fs-md); margin: var(--space-lg) 0 var(--space-xs); }
.legal-block p  { color: var(--color-muted); margin: 0 0 var(--space-sm); line-height: 1.7; }

/* ============================================================
   14i. CTA CENTRÉ
   ============================================================ */
.cta-centered {
  text-align: center;
  max-width: 680px;
  margin: 0 auto;
}
.cta-centered h2 { font-size: var(--fs-xl); margin: var(--space-sm) 0; }
.cta-centered p  { color: var(--color-muted); margin: 0 0 var(--space-lg); }
.cta-centered__actions {
  display: flex;
  gap: var(--space-sm);
  justify-content: center;
  flex-wrap: wrap;
}

/* ============================================================
   15. UTILITAIRES & RESPONSIVE
   ============================================================ */
.sr-only {
  position: absolute; width: 1px; height: 1px;
  padding: 0; margin: -1px; overflow: hidden;
  clip: rect(0,0,0,0); white-space: nowrap; border: 0;
}
.flex-center { display: flex; align-items: center; justify-content: center; }
.text-center { text-align: center; }
.mt-md { margin-top: var(--space-md); }
.mt-lg { margin-top: var(--space-lg); }

.skip-link {
  position: absolute; top: -100px; left: 0;
  background-color: var(--color-primary);
  color: var(--color-white);
  padding: var(--space-sm) var(--space-md);
  z-index: 200;
  transition: top var(--transition);
}
.skip-link:focus { top: 0; }

/* ----- Tablette ----- */
@media (max-width: 1024px) {
  .reassurance__grid { grid-template-columns: 1fr; gap: var(--space-md); }
  .reassurance__item { flex-direction: row; align-items: center; gap: var(--space-md); }
  .reassurance__icon { margin-bottom: 0; }

  div.philosophy,
  .contact-quick { grid-template-columns: 1fr; gap: var(--space-lg); }
  .philosophy__image, .contact-quick__map { aspect-ratio: 16 / 9; }

  .site-footer__grid { grid-template-columns: 1fr 1fr; }

  /* Pages secondaires */
  .massage-detail__inner { grid-template-columns: 1fr; gap: var(--space-xl); }
  .massage-detail--alt .massage-detail__content { order: -1; }
  .massage-detail__image { aspect-ratio: 16 / 9; }
  .ci-grid { grid-template-columns: 1fr; }
  .formules-grid { grid-template-columns: 1fr 1fr; }
  .services-grid { grid-template-columns: 1fr; }
  .about-inner { grid-template-columns: 1fr; gap: var(--space-xl); }
  .about-image { aspect-ratio: 16 / 9; }
  .contact-page__grid { grid-template-columns: 1fr; }
  .contact-page__map { height: 380px; position: static; }
  .acces-grid { grid-template-columns: 1fr; }
  .testimonials-grid--full { grid-template-columns: 1fr 1fr; }
  .legal-container { grid-template-columns: 1fr; }
  .legal-nav { position: static; }
}

/* ----- Mobile ----- */
@media (max-width: 768px) {
  :root {
    --header-height: 64px;
    --space-xl:  3rem;
    --space-2xl: 4rem;
    --space-3xl: 5rem;
  }

  /* === Layout de base === */
  .container { padding-left: var(--space-sm); padding-right: var(--space-sm); }
  .section        { padding: var(--space-2xl) 0; }
  .section--tight { padding: var(--space-xl) 0; }
  .section-header { margin-bottom: var(--space-lg); }

  /* === Navigation mobile ===
     Le <nav> est maintenant un sibling du <header> dans le HTML.
     position:fixed est relatif au viewport — aucun containing block parasite. */
  .menu-toggle { display: inline-flex; }

  /* Tiroir plein écran */
  .nav {
    position: fixed;
    top: var(--header-height);
    left: 0; right: 0;
    /* dvh = dynamic viewport height (gère la barre Safari iOS).
       Fallback sur 100vh pour navigateurs plus anciens. */
    height: calc(100vh - var(--header-height));
    height: calc(100dvh - var(--header-height));
    flex-direction: column;
    align-items: stretch;
    gap: 0;
    background-color: var(--color-bg);
    transform: translate3d(100%, 0, 0);
    -webkit-transform: translate3d(100%, 0, 0);
    transition: transform 350ms ease;
    -webkit-transition: -webkit-transform 350ms ease;
    pointer-events: none;
    overflow-x: hidden;
    overflow-y: auto;
    z-index: 998;
    border-top: 1px solid var(--color-border);
    -webkit-overflow-scrolling: touch;
    will-change: transform;
    -webkit-backface-visibility: hidden;
    backface-visibility: hidden;
  }

  /* Ouverture */
  .nav[data-open="true"] {
    transform: translate3d(0, 0, 0);
    -webkit-transform: translate3d(0, 0, 0);
    pointer-events: auto;
  }

  /* Les enfants redeviennent statiques dans le tiroir flex */
  .nav__list,
  .nav__cta {
    position: static;
    transform: none;
    pointer-events: auto;
    background: none;
  }

  /* Liste des liens — remplit l'espace */
  .nav__list {
    flex: 1;
    flex-direction: column;
    align-items: flex-start;
    gap: 0;
    padding: var(--space-xs) var(--space-md) 0;
    overflow-y: auto;
  }
  .nav__list .nav__link {
    display: block;
    padding: var(--space-md) 0;
    width: 100%;
    border-bottom: 1px solid var(--color-border);
    font-size: var(--fs-md);
    color: var(--color-text);
  }

  /* Bouton Réserver — ancré en bas du tiroir */
  .nav__cta {
    flex-shrink: 0;
    background-color: var(--color-bg-alt) !important;
    padding: var(--space-md);
    border-top: 1px solid var(--color-border);
    display: flex;
    align-items: center;
  }
  .nav__cta .btn { width: 100%; justify-content: center; }

  /* === Hero homepage === */
  .hero__decor { display: none; }
  .hero__inner { padding: var(--space-xl) 0 var(--space-2xl); }
  .hero__subtitle { font-size: var(--fs-base); }
  .hero__actions { flex-direction: column; align-items: flex-start; }
  .hero__actions .btn { width: 100%; justify-content: center; }

  /* === Page hero (pages secondaires) === */
  .page-hero { min-height: 260px; padding: var(--space-xl) 0 var(--space-lg); }
  .page-hero h1 { font-size: clamp(1.75rem, 6vw, 2.5rem); }
  .page-hero p  { font-size: var(--fs-sm); }

  /* === Réassurance === */
  .reassurance__item { flex-direction: column; align-items: flex-start; }
  .reassurance__icon { margin-bottom: var(--space-2xs); }

  /* === Cartes soins (homepage) === */
  .cards-grid--soins { grid-template-columns: 1fr; }

  /* === Google aggregate === */
  .google-aggregate {
    flex-direction: column;
    align-items: center;
    text-align: center;
    gap: var(--space-md);
    padding: var(--space-md);
  }
  .google-aggregate__cta { flex-direction: column; width: 100%; }
  .google-aggregate__cta .btn { width: 100%; }

  /* === Footer === */
  .site-footer__grid { grid-template-columns: 1fr; gap: var(--space-md); }
  .site-footer__bottom { flex-direction: column; align-items: flex-start; gap: var(--space-xs); }
  .site-footer__bottom-links { flex-wrap: wrap; gap: var(--space-sm); }

  /* === Pages secondaires : tarifs === */
  .formules-grid { grid-template-columns: 1fr; }
  .formules-grid .formule-card { padding: 0; }
  .formules-grid .formule-card > *:not(.formule-card__image):not(.formule-badge) {
    padding-left: var(--space-md);
    padding-right: var(--space-md);
  }
  .tarifs-row {
    grid-template-columns: 1fr auto;
    column-gap: var(--space-md);
    padding: var(--space-md) 0;
  }
  .tarifs-row__name { grid-column: 1 / -1; margin-bottom: var(--space-2xs); }
  .tarifs-row__name strong { font-size: 1.15rem; }
  .tarifs-row__duration { grid-column: 1; }
  .tarifs-row__price { grid-column: 2; font-size: 1.25rem; }
  .services-grid { grid-template-columns: 1fr; }

  /* === Massage detail === */
  .massage-detail__inner { grid-template-columns: 1fr; gap: var(--space-lg); }
  .massage-detail__image { aspect-ratio: 16 / 9; }
  .massage-detail--alt .massage-detail__content { order: -1; }
  /* Désactive l'animation de reveal sur mobile (évite les éléments bloqués à opacity:0) */
  .massage-detail__image,
  .massage-detail__content {
    opacity: 1 !important;
    transform: none !important;
  }
  .massage-detail__benefits li {
    opacity: 1 !important;
    transform: none !important;
  }
  .ci-grid { grid-template-columns: 1fr; }
  .ci-block { padding: var(--space-md); }
  .massage-detail__pricing { flex-direction: column; }
  .pricing-pill { justify-content: space-between; }

  /* === Contre-indications === */
  .avantapres-grid { grid-template-columns: 1fr; }

  /* === À propos === */
  .about-inner { grid-template-columns: 1fr; gap: var(--space-lg); }
  .about-image { aspect-ratio: 16 / 9; }
  .timeline { padding-left: var(--space-lg); margin-top: var(--space-lg); }
  .timeline-item { grid-template-columns: 56px 1fr; gap: var(--space-sm); margin-bottom: var(--space-lg); }
  .timeline-item__year { font-size: var(--fs-md); }
  .timeline-item__content h3 { font-size: var(--fs-base); }

  /* === Contact === */
  .contact-quick { grid-template-columns: 1fr; gap: var(--space-lg); }
  .contact-quick__map { height: 280px; aspect-ratio: unset; }
  .contact-page__grid { grid-template-columns: 1fr; }
  .contact-page__map { height: 280px; position: static; }
  .acces-grid { grid-template-columns: 1fr; }
  .acces-item { padding: var(--space-md); }

  /* === Avis === */
  .testimonials-grid--full { grid-template-columns: 1fr; }

  /* === Légales === */
  .legal-container { grid-template-columns: 1fr; gap: var(--space-lg); }
  .legal-nav { position: static; }
  .legal-block { padding-bottom: var(--space-xl); margin-bottom: var(--space-xl); }

  /* === CTA centré === */
  .cta-centered__actions { flex-direction: column; align-items: stretch; }
  .cta-centered__actions .btn { width: 100%; justify-content: center; }

  /* === Philosophie (À propos) === */
  .philosophy .philosophy__content blockquote { font-size: var(--fs-base); }
}

/* ----- Très petits écrans (< 480px) ----- */
@media (max-width: 480px) {
  :root {
    --space-xl:  2.5rem;
    --space-2xl: 3.5rem;
  }

  /* Typographie réduite */
  h2 { font-size: clamp(1.5rem, 6vw, 2rem); }
  .page-hero h1 { font-size: clamp(1.5rem, 7vw, 2rem); }
  .hero__inner { padding: var(--space-lg) 0 var(--space-xl); }
  .hero h1 { font-size: clamp(2rem, 10vw, 3.5rem); }

  /* Header logo : on masque la tagline / sous-titre sur très petits écrans */
  .logo__img { height: 44px; }

  /* Section header plus compact */
  .section-header { gap: var(--space-xs); margin-bottom: var(--space-md); }

  /* Tarifs row : tout en colonne */
  .tarifs-row { grid-template-columns: 1fr; gap: var(--space-3xs); }
  .tarifs-row__name,
  .tarifs-row__duration,
  .tarifs-row__price { grid-column: 1 / -1; }
  .tarifs-row__duration { text-align: left; }
  .tarifs-row__price { text-align: left; font-size: 1.4rem; }

  /* Timeline : on masque la colonne année, on la met en badge */
  .timeline { padding-left: var(--space-md); }
  .timeline-item { grid-template-columns: 1fr; gap: var(--space-xs); }
  .timeline-item__year {
    font-size: var(--fs-sm);
    color: var(--color-primary);
    font-weight: 700;
    letter-spacing: 0.06em;
  }

  /* Formule card sur mobile : padding réduit */
  .formules-grid .formule-card > *:not(.formule-card__image):not(.formule-badge) {
    padding-left: var(--space-sm);
    padding-right: var(--space-sm);
  }
  .formules-grid .formule-card .formule-card__name { font-size: 1.4rem; }

  /* Google aggregate */
  .google-aggregate { padding: var(--space-sm); }
  .google-aggregate__score { font-size: 2.8rem; }

  /* Boutons FAB : texte légèrement plus petit */
  .fab-reserve { font-size: var(--fs-xs); padding: 12px var(--space-md); }

  /* Page hero compacte */
  .page-hero { min-height: 220px; }
  .page-hero--compact { min-height: 160px; padding: var(--space-lg) 0; }

  /* Pricing pills en colonne */
  .massage-detail__pricing { flex-direction: column; }

  /* About notice */
  .about-notice { padding: var(--space-xs) var(--space-sm); }

  /* Mentions légales : pas de sidebar */
  .legal-block h2 { font-size: var(--fs-lg); }
}

/* ----- Reduced motion -----
   On désactive seulement les transitions et les animations qui pourraient gêner
   (mouvements brusques, parallax). Les animations très douces (vidéo Ken Burns,
   particules dorées du hero, pulsation note Google) sont conservées : leur
   amplitude et leur lenteur ne posent pas de problème de motion sickness. */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }
}

/* ----- Print ----- */
@media print {
  .site-header, .site-footer, .menu-toggle, .nav__cta { display: none; }
  .hero { min-height: auto; }
  .hero__overlay, .hero__decor { display: none; }
  body { background: white; color: black; }
}

/* ============================================================
   16. TYPOGRAPHIE RAFFINÉE
   ============================================================ */
h1, .hero__title { letter-spacing: -0.03em; line-height: 1.05; }
h2 { letter-spacing: -0.02em; }
.page-hero h1 { letter-spacing: -0.025em; }

/* ============================================================
   17. BOUTONS — SHIMMER + MICRO-ÉLÉVATION
   ============================================================ */
.btn {
  position: relative;
  overflow: hidden;
}
.btn::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(
    105deg,
    transparent 35%,
    rgba(255, 255, 255, 0.22) 50%,
    transparent 65%
  );
  transform: translateX(-130%);
  transition: transform 0s;
  pointer-events: none;
}
.btn:hover::after {
  transform: translateX(160%);
  transition: transform 0.55s ease;
}
.btn:hover {
  transform: translateY(-2px) scale(1.015);
}
.btn:active {
  transform: translateY(0) scale(0.99);
  transition-duration: 0.08s;
}

/* ============================================================
   18. VAGUES SVG ENTRE SECTIONS
   ============================================================ */
.section--alt {
  position: relative;
}
.section--alt::before {
  content: '';
  position: absolute;
  top: -48px;
  left: 0; right: 0;
  height: 50px;
  background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 1440 50' preserveAspectRatio='none'%3E%3Cpath fill='%23EAE0C8' d='M0,20 C320,50 760,0 1440,28 L1440,50 L0,50 Z'/%3E%3C/svg%3E") no-repeat center / 100% 100%;
  pointer-events: none;
  z-index: 0;
}

/* ============================================================
   19. BOUTON FLOTTANT « RÉSERVER » (FAB – mobile)
   ============================================================ */
.fab-reserve {
  display: none;
  position: fixed;
  bottom: var(--space-lg);
  right: var(--space-md);
  z-index: 90;
  background-color: var(--color-primary);
  color: var(--color-white);
  font-family: var(--font-sans);
  font-size: var(--fs-sm);
  font-weight: 600;
  padding: 14px var(--space-lg);
  border-radius: var(--radius-full);
  text-decoration: none;
  box-shadow: 0 4px 20px rgba(200,146,10, 0.50);
  align-items: center;
  gap: 8px;
  transition: transform 0.3s ease, box-shadow 0.3s ease, opacity 0.3s ease;
}
.fab-reserve svg { width: 18px; height: 18px; flex-shrink: 0; }
.fab-reserve:hover {
  background-color: var(--color-primary-dark);
  transform: translateY(-3px) !important;
  box-shadow: 0 8px 28px rgba(200,146,10, 0.60);
}
.fab-reserve.fab-hidden {
  opacity: 0;
  transform: translateY(16px);
  pointer-events: none;
}
@media (max-width: 768px) {
  .fab-reserve { display: flex; }
  /* Eviter chevauchement avec footer */
  .site-footer { padding-bottom: 80px; }
}

/* ============================================================
   20. SCROLL INDICATOR (hero)
   ============================================================ */
.scroll-indicator {
  position: absolute;
  bottom: var(--space-xl);
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  color: rgba(255, 255, 255, 0.75);
  font-size: 10px;
  font-family: var(--font-sans);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  text-decoration: none;
  animation: scrollBounce 2.2s ease-in-out infinite;
  transition: opacity 0.4s;
  z-index: 2;
}
.scroll-indicator__ring {
  width: 32px; height: 32px;
  border: 1.5px solid rgba(255, 255, 255, 0.55);
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.scroll-indicator__ring svg { width: 14px; height: 14px; }
@keyframes scrollBounce {
  0%, 100% { transform: translateX(-50%) translateY(0); }
  50%       { transform: translateX(-50%) translateY(8px); }
}
.scroll-indicator.is-hidden { opacity: 0; pointer-events: none; }
@media (max-width: 768px) { .scroll-indicator { bottom: var(--space-2xl); } }

/* ============================================================
   21. GALERIE PHOTOS
   ============================================================ */
.gallery-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 10px;
  margin-top: var(--space-xl);
}
.gallery-item {
  border-radius: var(--radius);
  overflow: hidden;
  aspect-ratio: 1;
  position: relative;
  background-color: var(--color-bg-surface);
}
.gallery-item:first-child {
  grid-column: span 2;
  grid-row: span 2;
  aspect-ratio: auto;
}
.gallery-item img {
  width: 100%; height: 100%;
  object-fit: cover;
  object-position: center;
  transition: transform 0.55s ease;
  display: block;
}
.gallery-item:hover img { transform: scale(1.06); }
.gallery-item__caption {
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(28,16,0, 0.65) 0%, transparent 55%);
  opacity: 0;
  transition: opacity 0.35s;
  display: flex; align-items: flex-end;
  padding: var(--space-sm);
}
.gallery-item:hover .gallery-item__caption { opacity: 1; }
.gallery-item__caption span {
  color: #fff;
  font-size: var(--fs-xs);
  font-family: var(--font-sans);
  letter-spacing: 0.06em;
}
@media (max-width: 1024px) {
  .gallery-grid { grid-template-columns: repeat(3, 1fr); }
  .gallery-item:first-child { grid-column: span 2; }
}
@media (max-width: 768px) {
  .gallery-grid { grid-template-columns: repeat(2, 1fr); gap: 6px; }
  .gallery-item:first-child { grid-column: span 2; grid-row: span 1; aspect-ratio: 16/9; }
}

/* ============================================================
   22. SECTION AVANT / APRÈS LA SÉANCE
   ============================================================ */
.avantapres-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-xl);
  margin-top: var(--space-xl);
}
.avantapres-card {
  background-color: var(--color-bg-card);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  padding: var(--space-xl);
}
.avantapres-card__icon {
  width: 52px; height: 52px;
  border-radius: var(--radius-full);
  background-color: var(--color-bg-alt);
  display: flex; align-items: center; justify-content: center;
  margin-bottom: var(--space-md);
}
.avantapres-card__icon svg { width: 26px; height: 26px; color: var(--color-primary); }
.avantapres-card h3 {
  font-family: var(--font-serif);
  font-size: var(--fs-lg);
  color: var(--color-primary);
  margin: 0 0 var(--space-md);
}
.avantapres-list {
  list-style: none;
  padding: 0; margin: 0;
  display: flex; flex-direction: column;
  gap: var(--space-sm);
}
.avantapres-list li {
  display: flex;
  gap: var(--space-sm);
  font-size: var(--fs-sm);
  color: var(--color-muted);
  align-items: flex-start;
  line-height: 1.5;
}
.avantapres-list li::before {
  content: '✓';
  color: var(--color-primary);
  font-weight: 700;
  flex-shrink: 0;
  margin-top: 1px;
}
@media (max-width: 768px) { .avantapres-grid { grid-template-columns: 1fr; } }

/* ============================================================
   23. BADGE « LE PLUS CHOISI »
   ============================================================ */
.formule-card--featured {
  border: 2px solid var(--color-primary);
  box-shadow: 0 0 0 4px rgba(200,146,10, 0.12), var(--shadow-lg);
  position: relative;
}
.formule-badge {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  background-color: var(--color-primary);
  color: var(--color-white);
  font-family: var(--font-sans);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  padding: 4px 10px;
  border-radius: var(--radius-full);
  margin-bottom: var(--space-sm);
}
.formule-badge svg { width: 11px; height: 11px; }

/* ============================================================
   24. FORMULAIRE DE CONTACT
   ============================================================ */
.contact-form-section {
  background-color: var(--color-bg-alt);
  padding: var(--space-2xl) 0;
}
.contact-form {
  background-color: var(--color-bg-card);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  padding: var(--space-xl);
  max-width: 760px;
  margin: 0 auto;
}
.contact-form__header {
  text-align: center;
  margin-bottom: var(--space-xl);
}
.contact-form__header h2 {
  font-family: var(--font-serif);
  font-size: var(--fs-xl);
  color: var(--color-primary);
  margin: var(--space-xs) 0 var(--space-sm);
  letter-spacing: -0.02em;
}
.contact-form__header p {
  color: var(--color-muted);
  font-size: var(--fs-sm);
  margin: 0;
}
.form-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-md);
}
.form-group {
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.form-group--full { grid-column: 1 / -1; }
.form-group label {
  font-size: 11px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--color-muted);
}
.form-group input,
.form-group select,
.form-group textarea {
  width: 100%;
  padding: 11px var(--space-md);
  border: 1px solid var(--color-border);
  border-radius: var(--radius);
  background-color: var(--color-bg);
  font-family: var(--font-sans);
  font-size: var(--fs-sm);
  color: var(--color-text);
  transition: border-color var(--transition), box-shadow var(--transition);
  outline: none;
  box-sizing: border-box;
  appearance: none;
}
.form-group input::placeholder,
.form-group textarea::placeholder { color: var(--color-border-mid); }
.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus {
  border-color: var(--color-primary);
  box-shadow: 0 0 0 3px rgba(58, 102, 71, 0.12);
}
.form-group textarea { resize: vertical; min-height: 120px; }
.form-group select {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%234A6B52' stroke-width='2'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 12px center;
  background-size: 16px;
  padding-right: 40px;
}
.form-submit {
  margin-top: var(--space-lg);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-md);
  flex-wrap: wrap;
}
.form-note {
  font-size: var(--fs-xs);
  color: var(--color-muted);
}
@media (max-width: 768px) {
  .form-grid { grid-template-columns: 1fr; }
  .form-submit { flex-direction: column; align-items: stretch; }
  .form-submit .btn { text-align: center; }
}

/* Bandeau de confirmation après envoi du formulaire */
.form-success {
  background-color: #ECF6EE;
  border: 1px solid #B7DBC1;
  border-left: 4px solid var(--color-accent, #7E8C76);
  border-radius: var(--radius);
  padding: var(--space-md) var(--space-lg);
  margin-bottom: var(--space-lg);
  color: #2C5A3A;
  font-size: var(--fs-base);
  line-height: 1.6;
}
.form-success strong {
  display: block;
  font-family: var(--font-serif);
  font-size: var(--fs-md);
  font-weight: 500;
  color: #1F4429;
  margin-bottom: var(--space-2xs);
}
.form-success a { color: #1F4429; text-decoration: underline; }

/* ============================================================
   16. FAB WHATSAPP
   ============================================================ */
.fab-stack {
  position: fixed;
  right: var(--space-md);
  bottom: var(--space-md);
  display: flex;
  flex-direction: column;
  gap: var(--space-xs);
  z-index: 90;
}
.fab-stack .fab-reserve { position: static; right: auto; bottom: auto; }
.fab-whatsapp {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 56px;
  height: 56px;
  border-radius: var(--radius-full);
  background-color: #25D366;
  color: #FFFFFF;
  box-shadow: var(--shadow-lg);
  transition: transform var(--transition), box-shadow var(--transition), background-color var(--transition);
  /* Positionné en bas à GAUCHE, indépendamment du fab-stack */
  position: fixed;
  left: var(--space-md);
  bottom: var(--space-md);
  right: auto;
}
.fab-whatsapp:hover {
  transform: translateY(-2px) scale(1.05);
  background-color: #128C7E;
  color: #FFFFFF;
}
.fab-whatsapp svg { width: 28px; height: 28px; }
.fab-whatsapp.fab-hidden { transform: translateY(120%); pointer-events: none; }

/* ============================================================
   17. EFFETS DÉCORATIFS
   ============================================================ */

/* 17a. Barre de progression du scroll (haut de page) — visible et dorée */
.scroll-progress {
  position: fixed;
  top: 0; left: 0; right: 0;
  height: 5px;
  z-index: 200;
  background-color: rgba(200,146,10,0.10);
  pointer-events: none;
}
.scroll-progress__bar {
  height: 100%;
  width: 0%;
  background: linear-gradient(90deg, var(--color-secondary, #B89B72) 0%, var(--color-primary, #8B5E3C) 50%, var(--color-secondary, #B89B72) 100%);
  transition: width 80ms linear;
  box-shadow: 0 0 12px rgba(200,146,10,0.65);
}

/* 17b. Vidéo hero — léger Ken Burns (zoom et pan très lents) */
.hero__video {
  animation: kenburns 28s ease-in-out infinite alternate;
  transform-origin: center center;
}
@keyframes kenburns {
  0%   { transform: scale(1.00) translate(0, 0); }
  50%  { transform: scale(1.07) translate(-1.5%, -1%); }
  100% { transform: scale(1.10) translate(1%, 1.5%); }
}

/* 17c. Particules dorées flottantes dans le hero */
.hero__particles {
  position: absolute;
  inset: 0;
  pointer-events: none;
  overflow: hidden;
  z-index: 0;
}
.hero__particles span {
  position: absolute;
  bottom: -30px;
  width: 10px; height: 10px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(255,235,180,1) 0%, rgba(255,205,120,0.7) 35%, rgba(200,146,10,0) 75%);
  filter: blur(0.3px);
  opacity: 0;
  animation: floatUp 11s linear infinite;
  box-shadow: 0 0 8px rgba(255,215,140,0.5);
}
.hero__particles span:nth-child(1) { left:  6%; width:  9px; height:  9px; animation-delay: 0s;   animation-duration: 11s; }
.hero__particles span:nth-child(2) { left: 17%; width: 14px; height: 14px; animation-delay: 1.5s; animation-duration: 13s; }
.hero__particles span:nth-child(3) { left: 26%; width:  7px; height:  7px; animation-delay: 4s;   animation-duration: 10s; }
.hero__particles span:nth-child(4) { left: 38%; width: 12px; height: 12px; animation-delay: 0.5s; animation-duration: 12s; }
.hero__particles span:nth-child(5) { left: 50%; width:  9px; height:  9px; animation-delay: 3s;   animation-duration: 14s; }
.hero__particles span:nth-child(6) { left: 62%; width: 15px; height: 15px; animation-delay: 5.5s; animation-duration: 11s; }
.hero__particles span:nth-child(7) { left: 74%; width:  8px; height:  8px; animation-delay: 6s;   animation-duration: 10s; }
.hero__particles span:nth-child(8) { left: 84%; width: 11px; height: 11px; animation-delay: 2s;   animation-duration: 13s; }
.hero__particles span:nth-child(9) { left: 93%; width:  9px; height:  9px; animation-delay: 4.5s; animation-duration: 12s; }

@keyframes floatUp {
  0%   { transform: translateY(0)      translateX(0);     opacity: 0; }
  10%  {                                                  opacity: 1; }
  50%  { transform: translateY(-50vh)  translateX(30px);  opacity: 0.85; }
  90%  {                                                  opacity: 0.7; }
  100% { transform: translateY(-100vh) translateX(-15px); opacity: 0; }
}

/* 17d. Effet "shine" sur les CTA primaires */
.btn--primary {
  position: relative;
  overflow: hidden;
  isolation: isolate;
}
.btn--primary::after {
  content: "";
  position: absolute;
  top: 0; left: -120%;
  width: 60%;
  height: 100%;
  background: linear-gradient(120deg,
    transparent 0%,
    rgba(255,255,255,0.28) 50%,
    transparent 100%);
  transform: skewX(-20deg);
  transition: left 700ms ease;
  z-index: -1;
  pointer-events: none;
}
.btn--primary:hover::after { left: 130%; }

/* 17e. Pulsation dorée sur la note Google 5,0 */
.google-aggregate__score {
  position: relative;
  display: inline-block;
}
.google-aggregate__score::before {
  content: "";
  position: absolute;
  inset: -10px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(200,146,10,0.30) 0%, rgba(200,146,10,0) 70%);
  z-index: -1;
  animation: glowPulse 3.5s ease-in-out infinite;
}
@keyframes glowPulse {
  0%, 100% { transform: scale(0.9); opacity: 0.5; }
  50%      { transform: scale(1.15); opacity: 0.95; }
}

/* 17f. Reveal du H1 du hero — mots qui apparaissent successivement (rempli par le JS) */
.hero h1 .word {
  display: inline-block;
  opacity: 0;
  transform: translateY(20px);
  filter: blur(6px);
  animation: wordIn 900ms cubic-bezier(0.22, 0.61, 0.36, 1) forwards;
}
.hero h1 .word + .word { margin-left: 0.25em; }
@keyframes wordIn {
  0%   { opacity: 0; transform: translateY(20px); filter: blur(6px); }
  100% { opacity: 1; transform: translateY(0);    filter: blur(0); }
}

/* 17g. Underline doré progressif sous les H2 de section au scroll */
.section-header h2 {
  position: relative;
  display: inline-block;
  padding-bottom: 0.4em;
}
.section-header h2::after {
  content: "";
  position: absolute;
  left: 50%;
  bottom: 0;
  width: 0;
  height: 2px;
  background: linear-gradient(90deg, transparent 0%, var(--color-secondary, #B89B72) 50%, transparent 100%);
  transform: translateX(-50%);
  transition: width 1200ms cubic-bezier(0.22, 0.61, 0.36, 1);
}
.section-header h2.is-visible::after { width: 80px; }

/* Désactivation des animations marquées pour utilisateurs sensibles.
   On laisse vivre les effets très doux (vidéo Ken Burns, particules, pulse note Google) :
   leur lenteur et faible amplitude ne posent pas de problème de motion sickness. */
@media (prefers-reduced-motion: reduce) {
  .hero h1 .word,
  .scroll-progress__bar,
  .section-header h2::after {
    animation: none !important;
    transition: none !important;
  }
  .hero h1 .word { opacity: 1; transform: none; filter: none; }
  .section-header h2.is-visible::after { width: 80px; }
}

/* ============================================================
   18. SECTIONS HOMEPAGE — Objectifs, Ingrédients, Merci
   ============================================================ */

/* Objectifs de la pression — liste centrée élégante */
/* Liste éditoriale "objectifs de la pression" — type magazine wellness */
.objectifs-rituel {
  list-style: none;
  padding: 0;
  margin: 0 auto;
  max-width: 820px;
  display: flex;
  flex-direction: column;
}
.objectif-item {
  display: grid;
  grid-template-columns: 96px 44px 1fr;
  align-items: center;
  gap: var(--space-md);
  padding: var(--space-lg) var(--space-md);
  border-bottom: 1px dashed rgba(200,146,10,.30);
  transition: background-color 0.3s ease, padding-left 0.4s ease;
  position: relative;
}
.objectif-item:last-child { border-bottom: none; }
.objectif-item::before {
  content: "";
  position: absolute;
  left: 0; top: 50%;
  transform: translateY(-50%) scaleY(0);
  width: 3px; height: 60%;
  background: linear-gradient(180deg, var(--color-primary-light, #D4B055) 0%, var(--color-primary, #C49A35) 100%);
  border-radius: 2px;
  transition: transform 0.4s cubic-bezier(0.22, 0.61, 0.36, 1);
  transform-origin: center;
}
.objectif-item:hover {
  background-color: rgba(255,255,255,0.6);
  padding-left: calc(var(--space-md) + 12px);
}
.objectif-item:hover::before { transform: translateY(-50%) scaleY(1); }

.objectif-item__num {
  font-family: var(--font-serif);
  font-style: italic;
  font-size: 4.2rem;
  font-weight: 500;
  color: var(--color-primary-light, #D4B055);
  opacity: 0.35;
  line-height: 1;
  letter-spacing: -0.02em;
  text-align: center;
  transition: opacity 0.3s ease, transform 0.3s ease;
}
.objectif-item:hover .objectif-item__num {
  opacity: 0.85;
  transform: translateX(-2px);
}

.objectif-item__icon {
  width: 36px;
  height: 36px;
  color: var(--color-primary, #C49A35);
  flex-shrink: 0;
  transition: transform 0.4s ease;
}
.objectif-item:hover .objectif-item__icon {
  transform: scale(1.1) rotate(-3deg);
}

.objectif-item__text { min-width: 0; }
.objectif-item__text h3 {
  font-family: var(--font-serif);
  font-size: var(--fs-lg);
  font-weight: 500;
  font-style: italic;
  color: var(--color-text);
  margin: 0 0 4px;
  line-height: 1.2;
}
.objectif-item__text p {
  font-size: var(--fs-sm);
  color: var(--color-muted);
  margin: 0;
  line-height: 1.5;
}

/* Tablette */
@media (max-width: 768px) {
  .objectif-item {
    grid-template-columns: 60px 36px 1fr;
    gap: var(--space-sm);
    padding: var(--space-md) var(--space-2xs);
  }
  .objectif-item__num { font-size: 2.8rem; }
  .objectif-item__icon { width: 28px; height: 28px; }
  .objectif-item__text h3 { font-size: var(--fs-md); }
}

/* Ingrédients (huiles de coco, pochon d'herbes) */
.ingredients-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-xl);
  margin-top: var(--space-lg);
}
.ingredient-card {
  background-color: #FFFFFF;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  transition: transform var(--transition), box-shadow var(--transition);
}
.ingredient-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 18px 40px rgba(42,36,30,0.12);
}
.ingredient-card__image {
  aspect-ratio: 16 / 9;
  background-size: cover;
  background-position: center;
}
.ingredient-card__body {
  padding: var(--space-lg);
  display: flex;
  flex-direction: column;
  gap: var(--space-sm);
}
.ingredient-card__body h3 {
  font-family: var(--font-serif);
  font-size: var(--fs-lg);
  font-style: italic;
  color: var(--color-text);
  margin: 0;
  line-height: 1.2;
}
.ingredient-card__body p {
  font-size: var(--fs-base);
  color: var(--color-muted);
  line-height: 1.65;
  margin: 0;
}

/* Bannière "Merci pour votre visite" — séparateur narratif élégant */
.merci-banner {
  text-align: center;
  padding: var(--space-2xl) var(--space-md);
  background: linear-gradient(135deg, #2A241E 0%, #3D342B 100%);
  position: relative;
  overflow: hidden;
}
.merci-banner::before,
.merci-banner::after {
  content: "";
  position: absolute;
  top: 50%;
  height: 1px;
  background: linear-gradient(90deg, transparent 0%, var(--color-primary-light) 50%, transparent 100%);
  width: 30%;
  pointer-events: none;
}
.merci-banner::before { left: 0; }
.merci-banner::after  { right: 0; }
.merci-banner__deco {
  display: inline-block;
  color: var(--color-primary-light);
  font-size: 1.4rem;
  margin-bottom: var(--space-sm);
  animation: floatGently 4s ease-in-out infinite;
}
.merci-banner h2 {
  font-family: var(--font-serif);
  font-style: italic;
  font-weight: 400;
  font-size: clamp(1.4rem, 2.5vw, 2.1rem);
  line-height: 1.4;
  color: #F8E9C7;
  max-width: 38ch;
  margin: 0 auto;
  letter-spacing: 0.005em;
}
@keyframes floatGently {
  0%, 100% { transform: translateY(0); opacity: 0.8; }
  50%      { transform: translateY(-4px); opacity: 1; }
}

@media (max-width: 1024px) {
  .ingredients-grid { grid-template-columns: 1fr; gap: var(--space-md); }
  .merci-banner::before, .merci-banner::after { width: 18%; }
}

/* Petite note sous la grille des 4 cartes massages homepage */
.cards-grid__note {
  text-align: center;
  margin-top: var(--space-lg);
  font-family: var(--font-serif);
  font-style: italic;
  font-size: var(--fs-base);
  color: var(--color-muted);
  max-width: 60ch;
  margin-left: auto;
  margin-right: auto;
}

/* ============================================================
   19. SECTION BIENVENUE (homepage, après le hero)
   ============================================================ */
.welcome {
  padding: var(--space-3xl) 0 var(--space-2xl);
  background: linear-gradient(180deg, var(--color-bg, #FAF6F0) 0%, var(--color-bg-alt, #F1E8D9) 100%);
  position: relative;
  overflow: hidden;
}
.welcome::before,
.welcome::after {
  content: "";
  position: absolute;
  width: 320px;
  height: 320px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(212,176,85,0.12) 0%, rgba(212,176,85,0) 70%);
  pointer-events: none;
}
.welcome::before { top: -100px; left: -100px; }
.welcome::after  { bottom: -100px; right: -100px; }

.welcome__inner {
  display: grid;
  grid-template-columns: 1fr 420px;
  gap: var(--space-3xl);
  align-items: center;
  text-align: left;
  position: relative;
  z-index: 1;
}

.welcome h2 {
  font-size: clamp(2rem, 3vw + 0.8rem, 3rem);
  margin: 0;
  line-height: 1.15;
  color: var(--color-text);
}
.welcome h2 em {
  font-style: italic;
  color: var(--color-primary-light, #D4B055);
}

/* Ornement central entre le titre et le texte */
.welcome__ornament {
  display: inline-block;
  font-size: 1.4rem;
  color: var(--color-primary-light, #D4B055);
  position: relative;
  padding: 0 var(--space-md);
  margin: var(--space-xs) 0 var(--space-md);
}
.welcome__ornament::before,
.welcome__ornament::after {
  content: "";
  position: absolute;
  top: 50%;
  width: 80px;
  height: 1px;
  background: linear-gradient(90deg, transparent 0%, var(--color-primary-light, #D4B055) 100%);
}
.welcome__ornament::before { right: 100%; }
.welcome__ornament::after  {
  left: 100%;
  background: linear-gradient(90deg, var(--color-primary-light, #D4B055) 0%, transparent 100%);
}

.welcome__content {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: var(--space-md);
}
.welcome__content .eyebrow { text-align: left; }
.welcome__content .eyebrow::before { margin-left: 0; }

.welcome__text {
  display: flex;
  flex-direction: column;
  gap: var(--space-md);
}
.welcome__text p {
  font-size: var(--fs-md);
  line-height: 1.75;
  color: var(--color-text);
  margin: 0;
  text-align: left;
}
.welcome__text strong {
  color: var(--color-primary, #C49A35);
  font-weight: 600;
}

/* Photo + animations d'entrée */
.welcome__content,
.welcome__visual {
  opacity: 0;
  transition: opacity 0.7s ease, transform 0.7s ease;
}
.welcome__content { transform: translateX(-30px); }
.welcome__visual  { transform: translateX(30px); }
.welcome.is-visible .welcome__content { opacity: 1; transform: translateX(0); }
.welcome.is-visible .welcome__visual  { opacity: 1; transform: translateX(0); transition-delay: 0.15s; }

.welcome__visual { position: relative; }
.welcome__img-frame {
  position: relative;
  border-radius: var(--radius-lg);
  overflow: hidden;
  box-shadow: var(--shadow-lg);
}
.welcome__img-frame::after {
  content: "";
  position: absolute;
  inset: 14px -14px -14px 14px;
  border: 2px solid rgba(200,146,10,.40);
  border-radius: var(--radius-lg);
  pointer-events: none;
  z-index: -1;
}
.welcome__img {
  width: 100%;
  height: 520px;
  object-fit: cover;
  display: block;
  transition: transform 0.6s ease;
}
.welcome__img-frame:hover .welcome__img { transform: scale(1.04); }

.welcome__call {
  font-family: var(--font-serif);
  font-style: italic;
  font-size: var(--fs-lg);
  line-height: 1.5;
  color: var(--color-text);
  margin: var(--space-md) 0 var(--space-sm);
  max-width: 50ch;
  text-align: left;
}
.welcome__call em {
  color: #4A4035;
  font-style: italic;
}
.welcome__call strong {
  display: inline-block;
  margin-top: var(--space-2xs);
  color: #4A4035;
  font-weight: 600;
}

/* Mobile */
@media (max-width: 768px) {
  .welcome { padding: var(--space-2xl) 0; }
  .welcome__inner { grid-template-columns: 1fr; gap: var(--space-xl); }
  .welcome__visual { display: none; }
  .welcome__ornament::before,
  .welcome__ornament::after { width: 50px; }
  .welcome__content { align-items: center; text-align: center; }
  .welcome__content .eyebrow { text-align: center; }
  .welcome__text p { font-size: var(--fs-base); text-align: center; }
  .welcome__call { text-align: center; }
}

/* ============================================================
   25. AMÉLIORATIONS MOBILES — POLISH VISUEL
   ============================================================ */

/* ── Hero homepage : plein écran sur mobile ─────────────────── */
@media (max-width: 768px) {
  .hero {
    min-height: 100dvh;
    min-height: 100vh;
    align-items: flex-end;
  }

  /* Supprime le débordement 25% prévu pour le parallax desktop
     → la vidéo occupe exactement le cadre, sans crop forcé       */
  .hero__bg {
    top: 0;
    bottom: 0;
    transform: none !important;
  }

  /* Ken Burns très discret sur mobile : dézoome au lieu de zoomer */
  .hero__video {
    animation: kenburns-mobile 32s ease-in-out infinite alternate;
    object-position: center 30%; /* cadre la zone intéressante */
  }

  /* Overlay : pente depuis le bas (texte ancré en bas) */
  .hero__overlay {
    background: linear-gradient(
      to top,
      rgba(12, 6, 0, 0.65) 0%,
      rgba(12, 6, 0, 0.32) 45%,
      rgba(12, 6, 0, 0.05) 100%
    );
  }

  /* Contenu texte — padding-bottom suffisant pour passer au-dessus des FABs fixes */
  .hero__inner {
    padding-bottom: calc(var(--space-2xl) + 80px); /* 80px = hauteur FAB + marge */
    padding-top: calc(var(--header-height) + var(--space-md));
    max-width: 100%;
  }

  /* Eyebrow + titre */
  .hero .eyebrow { margin-bottom: var(--space-sm); }
  .hero h1 {
    font-size: clamp(2.1rem, 8.5vw, 3rem);
    line-height: 1.1;
    margin-bottom: var(--space-sm);
  }
  .hero h1 br { display: none; } /* Coupe naturelle sur petits écrans */

  /* Sous-titre */
  .hero__subtitle {
    font-size: var(--fs-sm);
    line-height: 1.6;
    margin-bottom: var(--space-lg);
    opacity: .88;
    max-width: 100%;
  }

  /* Boutons plein-largeur, bien espacés */
  .hero__actions {
    flex-direction: column;
    gap: var(--space-xs);
  }
  .hero__actions .btn {
    width: 100%;
    justify-content: center;
    min-height: 52px;
    font-size: var(--fs-sm);
  }

  /* Liseré doré : masqué sur mobile */
  .hero__decor { display: none; }

  /* Scroll indicator : masqué sur mobile (superposition avec les FABs) */
  .scroll-indicator { display: none; }
}

/* Animation Ken Burns version mobile — très subtile, sans zoom */
@keyframes kenburns-mobile {
  0%   { transform: scale(1.00) translate(0,    0);    }
  100% { transform: scale(1.03) translate(0.5%, 0.5%); }
}

/* ── Burger : barres plus épaisses et plus visibles ─────────── */
@media (max-width: 768px) {
  .menu-toggle__bar,
  .menu-toggle__bar::before,
  .menu-toggle__bar::after {
    height: 2px;
    width: 22px;
  }
  .menu-toggle__bar::before { top: -7px; }
  .menu-toggle__bar::after  { top:  7px; }
}

/* ── Drawer : liens touch-friendly & page courante ──────────── */
@media (max-width: 768px) {
  .nav__list .nav__link {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 16px var(--space-md);
    min-height: 56px;
    font-size: 1rem;
    font-weight: 500;
    letter-spacing: 0.01em;
    border-bottom: 1px solid var(--color-border);
    transition: background-color 0.15s;
  }
  .nav__list .nav__link::after {
    content: "";
    display: block;
    width: 6px; height: 6px;
    border-right: 1.5px solid var(--color-primary);
    border-top: 1.5px solid var(--color-primary);
    transform: rotate(45deg);
    opacity: 0.5;
    flex-shrink: 0;
  }
  .nav__list .nav__link:active,
  .nav__list .nav__link[aria-current="page"] {
    background-color: rgba(200,146,10,.07);
    color: var(--color-primary);
  }
  .nav__list .nav__link[aria-current="page"]::after { opacity: 1; }

  .nav__cta { padding: var(--space-md) var(--space-md) var(--space-lg); }
  .nav__cta .btn { min-height: 52px; font-size: var(--fs-sm); }
}

/* ── Page hero secondaire : fond sombre bien contrasté ──────── */
@media (max-width: 768px) {
  .page-hero {
    min-height: 52dvh;
    min-height: 52vh;
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    padding: var(--space-xl) 0 var(--space-xl);
    padding-top: calc(var(--header-height) + var(--space-lg));
  }
  .page-hero__overlay {
    background: linear-gradient(
      to bottom,
      rgba(10,5,0,.15) 0%,
      rgba(10,5,0,.40) 100%
    ) !important;
  }
  .page-hero h1 {
    font-size: clamp(1.8rem, 7.5vw, 2.8rem);
    line-height: 1.1;
    margin-bottom: var(--space-sm);
  }
  .page-hero p { max-width: 90%; }
  .page-hero .eyebrow { margin-bottom: var(--space-xs); }
}

/* ── Boutons : cibles de 48 px minimum partout ──────────────── */
@media (max-width: 768px) {
  .btn {
    min-height: 48px;
    padding: 13px var(--space-md);
    font-size: var(--fs-sm);
  }
  .btn--small { min-height: 40px; padding: 10px var(--space-sm); }

  /* Feedback tactile */
  .btn:active { opacity: .82; transform: scale(.97); }
}

/* ── Inputs et select : cibles 48 px ───────────────────────── */
@media (max-width: 768px) {
  .form-group input,
  .form-group select,
  .form-group textarea {
    padding: 14px var(--space-md);
    font-size: 16px; /* évite le zoom auto iOS */
    min-height: 48px;
    border-radius: var(--radius);
  }
  .form-group textarea { min-height: 110px; }

  /* Formulaire de contact : moins de padding sur petits écrans */
  .contact-form {
    padding: var(--space-md);
    border-radius: var(--radius);
    border-left: none;
    border-right: none;
    border-radius: 0;
    margin: 0 calc(-1 * var(--space-sm));
    max-width: calc(100% + var(--space-sm) * 2);
  }
  .contact-form__header { margin-bottom: var(--space-lg); }
  .contact-form__header h2 { font-size: var(--fs-lg); }

  .form-submit .btn { min-height: 52px; }
}

/* ── Section header : eyebrow + trait dorés ─────────────────── */
@media (max-width: 768px) {
  .section-header { text-align: center; }
  .eyebrow {
    font-size: 10px;
    letter-spacing: 0.18em;
  }
  .section-header h2 { font-size: clamp(1.6rem, 6.5vw, 2.2rem); }
  .section-header .lead {
    font-size: var(--fs-sm);
    max-width: 92%;
    margin-left: auto;
    margin-right: auto;
  }
}

/* ── Cards : feedback tactile ───────────────────────────────── */
@media (max-width: 768px) {
  .card:active,
  .formule-card:active {
    transform: scale(.98);
    box-shadow: none;
  }
  .card { border-radius: var(--radius); }
}

/* ── Tarifs : rangées plus aérées et colorées ───────────────── */
@media (max-width: 768px) {
  .tarifs-row {
    padding: var(--space-md) 0;
    row-gap: var(--space-3xs);
  }
  .tarifs-row__name strong { font-size: 1.1rem; }
  .tarifs-row__name span  { font-size: var(--fs-xs); }
  .tarifs-row__duration   { font-size: 10px; letter-spacing: 0.12em; }
  .tarifs-row__price      { font-size: 1.15rem; color: var(--color-primary); }

  .tarifs-disclaimer,
  .tarifs-note {
    font-size: var(--fs-xs);
    text-align: center;
    padding: var(--space-sm) var(--space-md);
    background: rgba(200,146,10,.06);
    border-radius: var(--radius);
    margin-top: var(--space-lg);
  }

  /* Formule card image plus haute */
  .formule-card__image { aspect-ratio: 16 / 7; }
  .formule-card__name { font-size: 1.3rem; }
  .formule-card__price {
    font-size: 1.5rem;
    color: var(--color-primary);
    font-weight: 600;
  }
}

/* ── Services grid (tarifs) : items avec icône ──────────────── */
@media (max-width: 768px) {
  .service-item {
    display: flex;
    gap: var(--space-md);
    align-items: flex-start;
    text-align: left;
    padding: var(--space-md) 0;
    border-bottom: 1px solid var(--color-border);
  }
  .service-item:last-child { border-bottom: none; }
  .service-item svg {
    width: 28px; height: 28px;
    flex-shrink: 0;
    margin-top: 2px;
    color: var(--color-primary);
  }
  .service-item h3 { font-size: var(--fs-base); margin: 0 0 var(--space-3xs); }
  .service-item p  { font-size: var(--fs-sm); margin: 0; color: var(--color-muted); }
}

/* ── À propos : image plein-cadre ───────────────────────────── */
@media (max-width: 768px) {
  .about-image { aspect-ratio: 4 / 3; border-radius: var(--radius); }
  .about-content blockquote {
    font-size: var(--fs-base);
    padding-left: var(--space-md);
    border-left-width: 2px;
  }
  .certif-list { gap: var(--space-xs); }
  .certif-item { padding: var(--space-xs) var(--space-sm); font-size: var(--fs-xs); }
}

/* ── Footer mobile raffiné ──────────────────────────────────── */
@media (max-width: 768px) {
  .site-footer {
    padding-top: var(--space-xl);
  }
  .site-footer__brand p {
    font-size: var(--fs-sm);
    max-width: 28ch;
  }
  .site-footer__grid h4 {
    font-size: var(--fs-sm);
    margin-bottom: var(--space-xs);
  }
  .site-footer__grid ul li {
    font-size: var(--fs-sm);
    margin-bottom: var(--space-3xs);
  }
  .site-footer__bottom {
    padding-top: var(--space-md);
    font-size: var(--fs-xs);
  }
  .site-footer__notice {
    font-size: 11px;
    text-align: center;
    padding: var(--space-xs) 0;
  }
  .socials { gap: var(--space-sm); }
  .socials a {
    width: 40px; height: 40px;
    display: flex; align-items: center; justify-content: center;
  }
}

/* ── CTA centré : boutons plein-largeur ─────────────────────── */
@media (max-width: 768px) {
  .cta-centered { text-align: center; }
  .cta-centered p { font-size: var(--fs-sm); max-width: 88%; margin: 0 auto var(--space-md); }
  .cta-centered__actions { gap: var(--space-sm); }
  .cta-centered__actions .btn { min-height: 52px; }
}

/* ── FAB stack (Réserver) + WhatsApp séparés ────────────────── */
@media (max-width: 768px) {
  .fab-stack {
    bottom: var(--space-md);
    right: var(--space-sm);
  }
  .fab-whatsapp {
    width: 50px; height: 50px;
    left: var(--space-sm);
    bottom: var(--space-md);
  }
  .fab-whatsapp svg { width: 24px; height: 24px; }
}

/* ── Avis & galerie ─────────────────────────────────────────── */
@media (max-width: 768px) {
  .testimonial {
    padding: var(--space-md);
    border-radius: var(--radius);
  }
  .testimonial__text {
    font-size: var(--fs-sm);
    line-height: 1.6;
  }
}

/* ── Drawer : liens touch-friendly & page courante */
@media (max-width: 768px) {
  .nav__list .nav__link {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 16px var(--space-md);
    min-height: 56px;
    font-size: 1rem;
    font-weight: 500;
    border-bottom: 1px solid var(--color-border);
    transition: background-color 0.15s;
  }
  .nav__list .nav__link::after {
    content: "";
    display: block;
    width: 6px; height: 6px;
    border-right: 1.5px solid var(--color-primary);
    border-top: 1.5px solid var(--color-primary);
    transform: rotate(45deg);
    opacity: 0.5;
    flex-shrink: 0;
  }
  .nav__list .nav__link:active,
  .nav__list .nav__link[aria-current="page"] {
    background-color: rgba(200,146,10,.07);
    color: var(--color-primary);
  }
  .nav__list .nav__link[aria-current="page"]::after { opacity: 1; }
  .nav__cta { padding: var(--space-md) var(--space-md) var(--space-lg); }
  .nav__cta .btn { min-height: 52px; }
}

/* Page hero secondaire */
@media (max-width: 768px) {
  .page-hero {
    min-height: 52dvh;
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    padding-top: calc(var(--header-height) + var(--space-lg));
  }
  .page-hero h1 { font-size: clamp(1.8rem, 7.5vw, 2.8rem); line-height: 1.1; }
  .page-hero p  { max-width: 90%; }
}

/* Boutons 48px minimum */
@media (max-width: 768px) {
  .btn { min-height: 48px; padding: 13px var(--space-md); font-size: var(--fs-sm); }
  .btn--small { min-height: 40px; padding: 10px var(--space-sm); }
  .btn:active { opacity: .82; transform: scale(.97); }
}

/* Inputs : font-size 16px evite le zoom iOS */
@media (max-width: 768px) {
  .form-group input,
  .form-group select,
  .form-group textarea {
    padding: 14px var(--space-md);
    font-size: 16px;
    min-height: 48px;
  }
  .form-group textarea { min-height: 110px; }
  .contact-form {
    padding: var(--space-md);
    border-radius: var(--radius);
    margin: 0 calc(-1 * var(--space-sm));
  }
  .contact-form__header { margin-bottom: var(--space-md); }
  .contact-form__header h2 { font-size: var(--fs-lg); }
  .form-submit .btn { min-height: 52px; }
}

/* Section header */
@media (max-width: 768px) {
  .section-header { text-align: center; }
  .section-header h2 { font-size: clamp(1.6rem, 6.5vw, 2.2rem); }
  .section-header .lead {
    font-size: var(--fs-sm);
    max-width: 92%;
    margin-left: auto;
    margin-right: auto;
  }
}

/* Cards feedback tactile */
@media (max-width: 768px) {
  .card:active, .formule-card:active { transform: scale(.98); }
}

/* Tarifs */
@media (max-width: 768px) {
  .tarifs-row { padding: var(--space-md) 0; }
  .tarifs-row__name strong { font-size: 1.1rem; }
  .tarifs-row__name span   { font-size: var(--fs-xs); }
  .tarifs-row__price       { font-size: 1.15rem; color: var(--color-primary); }
  .tarifs-disclaimer, .tarifs-note {
    font-size: var(--fs-xs);
    text-align: center;
    padding: var(--space-sm) var(--space-md);
    background: rgba(200,146,10,.06);
    border-radius: var(--radius);
    margin-top: var(--space-lg);
  }
  .formule-card__image { aspect-ratio: 16 / 7; }
  .formule-card__name  { font-size: 1.3rem; }
  .formule-card__price { font-size: 1.5rem; color: var(--color-primary); }
}

/* Services grid - tarifs - layout row sur mobile */
/* Services grid - tarifs */
@media (max-width: 768px) {
  .service-item {
    display: flex;
    gap: var(--space-md);
    align-items: flex-start;
    text-align: left;
    padding: var(--space-md) 0;
    border-bottom: 1px solid var(--color-border);
  }
  .service-item:last-child { border-bottom: none; }
  .service-item svg { width: 28px; height: 28px; flex-shrink: 0; color: var(--color-primary); }
  .service-item h3  { font-size: var(--fs-base); margin: 0 0 2px; }
  .service-item p   { font-size: var(--fs-sm); margin: 0; }
}

/* A propos */
@media (max-width: 768px) {
  .about-image { aspect-ratio: 4 / 3; border-radius: var(--radius); }
}

/* Footer */
@media (max-width: 768px) {
  .site-footer { padding-top: var(--space-xl); }
  .site-footer__brand p    { font-size: var(--fs-sm); }
  .site-footer__grid h4    { font-size: var(--fs-sm); margin-bottom: var(--space-xs); }
  .site-footer__grid ul li { font-size: var(--fs-sm); }
  .site-footer__notice     { font-size: 11px; text-align: center; }
  .socials a { width: 40px; height: 40px; display: inline-flex; align-items: center; justify-content: center; }
}

/* CTA centree */
@media (max-width: 768px) {
  .cta-centered p { font-size: var(--fs-sm); max-width: 88%; margin: 0 auto var(--space-md); }
  .cta-centered__actions .btn { min-height: 52px; }
}

/* FAB WhatsApp - bas gauche sur mobile */
@media (max-width: 768px) {
  .fab-whatsapp {
    width: 50px; height: 50px;
    left: var(--space-sm);
    right: auto;
    bottom: var(--space-md);
  }
  .fab-whatsapp svg { width: 24px; height: 24px; }
}

/* Avis */
@media (max-width: 768px) {
  .testimonial { padding: var(--space-md); }
  .testimonial__text { font-size: var(--fs-sm); line-height: 1.6; }
}

/* Safe area iPhone X+ */
@supports (padding: env(safe-area-inset-top)) {
  @media (max-width: 768px) {
    .site-header  { padding-top: env(safe-area-inset-top); }
    .menu-toggle  { top: env(safe-area-inset-top); }
    .nav          { top: calc(var(--header-height) + env(safe-area-inset-top)); }
    .fab-stack    { bottom: max(var(--space-md), env(safe-area-inset-bottom)); }
    .fab-whatsapp { bottom: max(var(--space-md), env(safe-area-inset-bottom)); left: var(--space-sm); }
  }
}


/* ============================================================
   26. POLISH MOBILE — TOUTES PAGES
   ============================================================ */

/* ──────────────────────────────────────────────────────────────
   INDEX — sections sous le hero
   ────────────────────────────────────────────────────────────── */

/* Réassurance : scroll horizontal sur mobile au lieu d'empiler */
@media (max-width: 768px) {
  .reassurance { padding: var(--space-lg) 0; }
  .reassurance__grid {
    grid-template-columns: 1fr;
    gap: 0;
  }
  .reassurance__item {
    flex-direction: row;
    align-items: center;
    gap: var(--space-md);
    padding: var(--space-md) 0;
    border-bottom: 1px solid var(--color-border);
  }
  .reassurance__item:last-child { border-bottom: none; }
  .reassurance__icon {
    flex-shrink: 0;
    width: 36px; height: 36px;
    margin-bottom: 0;
  }
  .reassurance__title { font-size: var(--fs-base); }
  .reassurance__desc  { font-size: var(--fs-sm); }
}

/* Section Bienvenue : texte centré, visuel masqué */
@media (max-width: 768px) {
  .welcome { padding: var(--space-xl) 0; }
  .welcome__inner { gap: var(--space-lg); }
  .welcome h2 {
    font-size: clamp(1.8rem, 7vw, 2.4rem);
    text-align: center;
  }
  .welcome__ornament { margin: var(--space-xs) auto; }
  .welcome__text p { font-size: var(--fs-sm); }
  .welcome__call {
    display: flex;
    flex-direction: column;
    gap: var(--space-sm);
    align-items: stretch;
  }
  .welcome__call .btn { width: 100%; justify-content: center; min-height: 50px; }
}

/* Google note : compact et lisible */
@media (max-width: 768px) {
  .google-aggregate {
    padding: var(--space-md);
    gap: var(--space-md);
    border-radius: var(--radius);
    margin-bottom: var(--space-lg);
  }
  .google-aggregate__score { font-size: 2.8rem; }
  .google-aggregate__stars { font-size: 1.2rem; }
  .google-aggregate__label { font-size: var(--fs-xs); }
  .google-aggregate__cta { width: 100%; }
  .google-aggregate__cta .btn { width: 100%; min-height: 48px; }
}

/* Objectifs : grid simplifié */
@media (max-width: 768px) {
  .objectif-item {
    grid-template-columns: 48px 1fr;
    padding: var(--space-md) 0;
    gap: var(--space-sm);
  }
  .objectif-item__num { font-size: 2rem; }
  .objectif-item__icon { display: none; }
  .objectif-item__text h3 { font-size: var(--fs-base); margin-bottom: 4px; }
  .objectif-item__text p  { font-size: var(--fs-sm); }
}

/* Cartes soins : image plus haute, meilleur visuel */
@media (max-width: 768px) {
  .card__image { aspect-ratio: 16 / 9; }
  .card__body  { padding: var(--space-md); }
  .card__title { font-size: var(--fs-lg); }
  .card__desc  { font-size: var(--fs-sm); }
  .card__number {
    font-size: 4rem;
    bottom: var(--space-sm);
    right: var(--space-sm);
  }
}

/* ──────────────────────────────────────────────────────────────
   MASSAGES — détail de chaque soin
   ────────────────────────────────────────────────────────────── */

@media (max-width: 768px) {
  /* En-tête de chaque soin */
  .massage-detail__content h2 {
    font-size: clamp(1.6rem, 6vw, 2rem);
    margin-bottom: var(--space-sm);
  }
  .massage-detail__desc {
    font-size: var(--fs-sm);
    line-height: 1.7;
  }

  /* Pills de prix : colonne lisible */
  .massage-detail__pricing {
    flex-direction: column;
    gap: var(--space-xs);
  }
  .pricing-pill {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: var(--space-sm) var(--space-md);
    font-size: var(--fs-sm);
  }

  /* Bénéfices : plus compact */
  .massage-detail__benefits { margin-top: var(--space-md); }
  .massage-detail__benefits li {
    font-size: var(--fs-sm);
    padding: var(--space-xs) 0;
  }

  /* Contre-indications */
  .ci-block {
    padding: var(--space-sm) var(--space-md);
    border-radius: var(--radius);
  }
  .ci-block h3 { font-size: var(--fs-base); }
  .ci-block ul { font-size: var(--fs-sm); }

  /* Avant / Après */
  .avantapres-grid { gap: var(--space-md); }
  .avantapres-item {
    padding: var(--space-md);
    border-radius: var(--radius);
  }
  .avantapres-item h3 { font-size: var(--fs-base); }
  .avantapres-item li { font-size: var(--fs-sm); }

  /* Bouton réserver soin */
  .massage-detail__cta { margin-top: var(--space-md); }
  .massage-detail__cta .btn {
    width: 100%;
    justify-content: center;
    min-height: 52px;
  }
}

/* ──────────────────────────────────────────────────────────────
   À PROPOS
   ────────────────────────────────────────────────────────────── */

@media (max-width: 768px) {
  /* Intro : texte centré */
  .about-intro { text-align: center; }
  .about-intro h1 {
    font-size: clamp(1.8rem, 7vw, 2.4rem);
    line-height: 1.15;
  }
  .about-intro .lead { font-size: var(--fs-sm); }

  /* Bloc portrait + texte */
  .about-image {
    aspect-ratio: 3 / 2;
    border-radius: var(--radius);
  }
  .about-content h2 { font-size: clamp(1.5rem, 6vw, 1.9rem); }
  .about-content p  { font-size: var(--fs-sm); }
  .about-content blockquote {
    padding: var(--space-sm) var(--space-md);
    font-size: var(--fs-base);
    border-left: 2px solid var(--color-secondary);
    margin: var(--space-md) 0;
  }

  /* Notice */
  .about-notice {
    font-size: var(--fs-xs);
    padding: var(--space-xs) var(--space-sm);
    border-radius: var(--radius);
    text-align: center;
  }

  /* Certifications : chips en wrap */
  .certif-list {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-xs);
    justify-content: center;
    margin-top: var(--space-md);
  }
  .certif-item {
    font-size: var(--fs-xs);
    padding: 6px var(--space-sm);
    border-radius: var(--radius-full);
    text-align: center;
    flex: 0 0 auto;
  }

  /* Timeline */
  .timeline { margin-top: var(--space-lg); }
  .timeline-item__content p { font-size: var(--fs-sm); }

  /* Philosophie */
  .philosophy .philosophy__content blockquote {
    font-size: var(--fs-sm);
    padding: var(--space-sm) var(--space-md);
  }

  /* CTA final */
  .about-cta .btn {
    width: 100%;
    justify-content: center;
    min-height: 52px;
  }
}

/* ──────────────────────────────────────────────────────────────
   AVIS & GALERIE
   ────────────────────────────────────────────────────────────── */

@media (max-width: 768px) {
  /* Note Google en haut */
  .google-banner {
    flex-direction: column;
    text-align: center;
    gap: var(--space-sm);
    padding: var(--space-md);
    border-radius: var(--radius);
  }

  /* Témoignages */
  .testimonial {
    padding: var(--space-md);
    border-radius: var(--radius);
  }
  .testimonial__text {
    font-size: var(--fs-sm);
    line-height: 1.65;
  }
  .testimonial__text::before { font-size: 2.5rem; }
  .testimonial__author { font-size: var(--fs-sm); }
  .testimonial__date   { font-size: var(--fs-xs); }

  /* Galerie : 2 colonnes sur mobile */
  .gallery-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 6px;
  }
  .gallery-item:first-child {
    grid-column: span 2;
    aspect-ratio: 16 / 9;
  }
  .gallery-item { aspect-ratio: 1; }
  .gallery-item img { border-radius: 0; }

  /* CTA galerie */
  .gallery-cta {
    flex-direction: column;
    align-items: stretch;
    gap: var(--space-sm);
  }
  .gallery-cta .btn {
    width: 100%;
    justify-content: center;
    min-height: 50px;
  }
}

/* ──────────────────────────────────────────────────────────────
   CONTACT
   ────────────────────────────────────────────────────────────── */

@media (max-width: 768px) {
  /* Cartes infos de contact */
  .contact-page__info { gap: var(--space-md); }
  .contact-info-card {
    padding: var(--space-md);
    border-radius: var(--radius);
  }
  .contact-info-card h3 { font-size: var(--fs-base); margin-bottom: var(--space-xs); }
  .contact-info-card p,
  .contact-info-card a { font-size: var(--fs-sm); }

  /* Horaires */
  .horaires-grid {
    grid-template-columns: 1fr;
    gap: var(--space-xs);
  }
  .horaires-row { font-size: var(--fs-sm); }

  /* Carte Google Maps */
  .contact-page__map { height: 240px; border-radius: var(--radius); overflow: hidden; }

  /* Accès transport */
  .acces-grid { gap: var(--space-md); }
  .acces-item {
    padding: var(--space-md);
    border-radius: var(--radius);
  }
  .acces-item h3 { font-size: var(--fs-base); margin-bottom: var(--space-xs); }
  .acces-item p  { font-size: var(--fs-sm); }
}

/* ──────────────────────────────────────────────────────────────
   MENTIONS LÉGALES — lecture confortable
   ────────────────────────────────────────────────────────────── */

@media (max-width: 768px) {
  .legal-section { padding: var(--space-xl) 0; }
  .legal-container { gap: var(--space-lg); }
  .legal-body      { font-size: var(--fs-sm); line-height: 1.8; }
  .legal-block     { padding-bottom: var(--space-lg); margin-bottom: var(--space-lg); }
  .legal-block h2  { font-size: var(--fs-md); margin-bottom: var(--space-sm); }
  .legal-block h3  { font-size: var(--fs-base); margin-bottom: var(--space-xs); }
  .legal-block p,
  .legal-block li  { font-size: var(--fs-sm); line-height: 1.75; }
}

/* ──────────────────────────────────────────────────────────────
   GLOBAL — finitions communes à toutes les pages
   ────────────────────────────────────────────────────────────── */

@media (max-width: 768px) {
  /* Section header uniforme */
  .section-header h2    { font-size: clamp(1.55rem, 6vw, 2rem); }
  .section-header .lead { font-size: var(--fs-sm); line-height: 1.65; }

  /* Sections : espacement vertical réduit */
  .section       { padding: var(--space-xl) 0; }
  .section--alt  { padding: var(--space-xl) 0; }
  .section--tight{ padding: var(--space-lg) 0; }
  .section-header{ margin-bottom: var(--space-md); }

  /* Container légèrement plus serré */
  .container { padding-left: 18px; padding-right: 18px; }

  /* Page hero secondaire : hauteur raisonnable */
  .page-hero {
    min-height: 44dvh;
    padding-bottom: var(--space-xl);
  }

  /* Paragraphes : max-width libéré sur mobile */
  p { max-width: 100%; }

  /* Tables responsive */
  table { font-size: var(--fs-sm); }
}

/* Très petits écrans */

/* Très petits écrans */
@media (max-width: 390px) {
  .section-header h2 { font-size: clamp(1.4rem, 7vw, 1.8rem); }
  .hero h1           { font-size: clamp(1.9rem, 8.5vw, 2.5rem); }
  .page-hero h1      { font-size: clamp(1.5rem, 8vw, 2rem); }
  .btn               { font-size: var(--fs-xs); padding: 12px var(--space-sm); }
}

/* =============================================
   AUTO-HÉBERGEMENT DES POLICES (RGPD)
   ============================================= */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url('../fonts/inter-latin-400-normal.woff2') format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+2000-206F, U+2074, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url('../fonts/inter-latin-500-normal.woff2') format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+2000-206F, U+2074, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url('../fonts/inter-latin-600-normal.woff2') format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+2000-206F, U+2074, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url('../fonts/inter-latin-700-normal.woff2') format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+2000-206F, U+2074, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
  font-family: 'Cormorant Garamond';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url('../fonts/cormorant-garamond-latin-400-normal.woff2') format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+2000-206F, U+2074, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
  font-family: 'Cormorant Garamond';
  font-style: italic;
  font-weight: 400;
  font-display: swap;
  src: url('../fonts/cormorant-garamond-latin-400-italic.woff2') format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+2000-206F, U+2074, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
  font-family: 'Cormorant Garamond';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url('../fonts/cormorant-garamond-latin-500-normal.woff2') format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+2000-206F, U+2074, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
  font-family: 'Cormorant Garamond';
  font-style: italic;
  font-weight: 500;
  font-display: swap;
  src: url('../fonts/cormorant-garamond-latin-500-italic.woff2') format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+2000-206F, U+2074, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
  font-family: 'Cormorant Garamond';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url('../fonts/cormorant-garamond-latin-600-normal.woff2') format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+2000-206F, U+2074, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
  font-family: 'Cormorant Garamond';
  font-style: italic;
  font-weight: 600;
  font-display: swap;
  src: url('../fonts/cormorant-garamond-latin-600-italic.woff2') format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+2000-206F, U+2074, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

/* =============================================
   MAP CONSENT PLACEHOLDER
   ============================================= */
.map-consent {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--color-bg-alt, #f5f0eb);
  z-index: 2;
}
.map-consent__inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-sm);
  padding: var(--space-lg);
  text-align: center;
  max-width: 320px;
}
.map-consent__inner svg {
  color: var(--color-primary);
  flex-shrink: 0;
}
.map-consent__inner p {
  font-size: 0.875rem;
  color: var(--color-text-light);
  line-height: 1.5;
  margin: 0;
}
.contact-page__map {
  position: relative;
}
.contact-page__map iframe {
  width: 100%;
  height: 100%;
  border: 0;
  display: block;
}

/* =============================================
   BANDEAU COOKIES RGPD
   ============================================= */
.cookie-banner {
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  z-index: 9999;
  background: rgba(28, 20, 12, 0.97);
  color: #f0ebe4;
  padding: var(--space-md) var(--space-lg);
  display: flex;
  align-items: center;
  gap: var(--space-md);
  flex-wrap: wrap;
  justify-content: space-between;
  box-shadow: 0 -4px 24px rgba(0,0,0,0.25);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  transform: translateY(100%);
  transition: transform 0.4s cubic-bezier(0.4, 0, 0.2, 1);
}
.cookie-banner.is-visible {
  transform: translateY(0);
}
.cookie-banner__text {
  flex: 1;
  min-width: 220px;
  font-size: 0.82rem;
  line-height: 1.55;
  color: #d4c8b8;
}
.cookie-banner__text strong {
  color: #f0ebe4;
  font-weight: 600;
}
.cookie-banner__text a {
  color: var(--color-primary-light, #D4B055);
  text-decoration: underline;
  text-underline-offset: 3px;
}
.cookie-banner__actions {
  display: flex;
  gap: var(--space-sm);
  flex-shrink: 0;
}
.cookie-btn {
  padding: 0.45rem 1.1rem;
  border-radius: 4px;
  font-size: 0.8rem;
  font-weight: 600;
  cursor: pointer;
  border: none;
  transition: opacity 0.2s;
  letter-spacing: 0.03em;
}
.cookie-btn:hover { opacity: 0.85; }
.cookie-btn--accept {
  background: var(--color-primary, #B8922A);
  color: #fff;
}
.cookie-btn--refuse {
  background: transparent;
  color: #c8bfb0;
  border: 1px solid rgba(200,191,176,0.35);
}

@media (max-width: 600px) {
  .cookie-banner {
    flex-direction: column;
    align-items: flex-start;
    padding: var(--space-md);
    gap: var(--space-sm);
  }
  .cookie-banner__actions {
    width: 100%;
  }
  .cookie-btn {
    flex: 1;
    text-align: center;
  }
}

/* =============================================
   FORMULE CARD — label & tagline
   ============================================= */
.formule-card__label {
  display: block;
  font-family: var(--font-sans);
  font-size: 0.85rem;
  font-weight: 700;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--color-primary);
  padding-left: var(--space-md);
  padding-right: var(--space-md);
  padding-top: var(--space-md);
  margin-bottom: 4px;
}
.formule-card__tagline {
  font-family: var(--font-serif);
  font-size: 1.05rem;
  font-style: italic;
  font-weight: 700;
  color: var(--color-primary-dark);
  margin: 0 0 var(--space-xs);
  line-height: 1.5;
  padding-left: var(--space-md);
  padding-right: var(--space-md);
  text-wrap: balance;
}
.formule-card > .formule-card__name {
  padding-top: var(--space-md);
  font-size: 2.4rem;
}

/* =============================================
   SOINS À LA CARTE (formules en liste)
   ============================================= */
.soins-carte {
  display: flex;
  flex-direction: column;
  gap: 0;
  max-width: 860px;
  margin: 0 auto;
  border-radius: var(--radius-lg);
  overflow: hidden;
  border: 1px solid var(--color-border);
}
.soin-carte-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-lg);
  padding: var(--space-md) var(--space-lg);
  background: var(--color-bg-card);
  border-bottom: 1px solid var(--color-border);
  flex-wrap: wrap;
}
.soin-carte-item:last-child { border-bottom: none; }
.soin-carte-item--featured {
  background: linear-gradient(135deg, #FEF8E8 0%, #F9EDCC 100%);
}
.soin-carte-item__info {
  flex: 1;
  min-width: 200px;
}
.soin-carte-item__name {
  font-family: var(--font-serif);
  font-size: 1.25rem;
  font-weight: 500;
  color: var(--color-text);
  margin: 0 0 4px;
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  flex-wrap: wrap;
}
.soin-carte-badge {
  font-family: var(--font-sans);
  font-size: 0.65rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  background: var(--color-primary);
  color: #fff;
  padding: 2px 8px;
  border-radius: 2em;
}
.soin-carte-item__desc {
  font-size: var(--fs-sm);
  color: var(--color-muted);
  margin: 0;
  line-height: 1.5;
}
.soin-carte-item .massage-detail__pricing {
  flex-shrink: 0;
}

@media (max-width: 600px) {
  .soin-carte-item {
    flex-direction: column;
    align-items: flex-start;
    gap: var(--space-sm);
    padding: var(--space-md);
  }
}

/* ── Tarifs subheadings ───────────────────────── */
.tarifs-subheading {
  margin-bottom: var(--space-md);
  text-align: center;
}
.tarifs-subheading .eyebrow {
  font-size: 0.8rem;
  letter-spacing: 0.12em;
}
.tarifs-row--featured {
  background: linear-gradient(135deg, #FEF8E8 0%, #F9EDCC 100%);
}
