/* =========================================================
   CHRISTELLE GENIER — RÉFLEXOLOGIE & BIEN-ÊTRE
   Feuille de style partagée (toutes les pages)
   ========================================================= */

:root{
  --lin:#EFE6D5; --blanc:#FBF8F1; --ocre:#CBA486; --brun:#C49480; --anthracite:#3B322B;
  --lin-fonce:#E6DAC5; --creme:#FBF7F0; --ocre-clair:#EACFBC; --brun-fonce:#B07D69;
  --espresso:#B07A66; --texte-doux:#7C6F61; --ligne:#E7DCCA;
  --serif:'Cormorant Garamond',Georgia,serif;
  --sans:'DM Sans',system-ui,-apple-system,sans-serif;
  --section-y:clamp(92px,11vw,160px);
  --container:1480px; --pad-x:clamp(22px,5vw,84px);
  --radius:18px; --radius-lg:26px; --arch:240px;
  --ombre-s:0 8px 24px rgba(80,55,30,.07);
  --ombre-m:0 20px 48px rgba(80,55,30,.13);
  --ombre-l:0 34px 80px rgba(60,40,22,.20);
}

*{ margin:0; padding:0; box-sizing:border-box; }
html{ scroll-behavior:smooth; -webkit-font-smoothing:antialiased; color-scheme:light; }
body{ font-family:var(--sans); font-size:17px; line-height:1.7; color:var(--anthracite); background:var(--lin); overflow-x:hidden; }
img{ display:block; max-width:100%; }
a{ color:inherit; text-decoration:none; }
button{ font-family:inherit; cursor:pointer; border:none; background:none; }
ul{ list-style:none; }

/* ---------- ACCESSIBILITÉ : focus, touch, ancres ---------- */
a, button, input, textarea, select, label, [role="button"], .reflexo-chip, .av-dot, .carousel-dot, .hotspot{ touch-action:manipulation; }
:focus:not(:focus-visible){ outline:none; }
a:focus-visible, button:focus-visible, input:focus-visible, textarea:focus-visible, select:focus-visible, [tabindex]:focus-visible{
  outline:2.5px solid var(--brun); outline-offset:3px; border-radius:4px; }
section[id], main[id], [id].section{ scroll-margin-top:96px; }
.skip-link{ position:fixed; top:10px; left:50%; transform:translate(-50%,-140%); z-index:9700;
  background:var(--brun); color:var(--creme); padding:12px 22px; border-radius:100px; font-size:14px; font-weight:600;
  box-shadow:var(--ombre-m); transition:transform .25s ease; }
.skip-link:focus{ transform:translate(-50%,0); outline:none; }
h1,h2,h3{ font-family:var(--serif); font-weight:500; line-height:1.08; letter-spacing:.005em; }

.eyebrow{ font-family:var(--sans); font-size:13px; font-weight:600; letter-spacing:.24em; text-transform:uppercase; color:var(--brun); }
.section{ padding:var(--section-y) 0; }
.container{ width:100%; max-width:var(--container); margin:0 auto; padding:0 var(--pad-x); }
.accent{ color:var(--brun); font-style:italic; }
.media{ position:relative; overflow:hidden; background:var(--lin-fonce); }
.imgcover{ width:100%; height:100%; object-fit:cover; display:block; }
.center{ text-align:center; }

/* ---------- BOUTONS ---------- */
.btn{ display:inline-flex; align-items:center; gap:10px; font-family:var(--sans); font-size:15px; font-weight:600;
  padding:15px 28px; border-radius:100px; transition:background .35s cubic-bezier(.2,.7,.3,1), color .35s ease, transform .35s cubic-bezier(.2,.7,.3,1), box-shadow .35s ease, border-color .35s ease; white-space:nowrap; }
.btn-primary{ background:var(--brun); color:var(--creme); box-shadow:0 10px 24px rgba(196,148,128,.35); }
.btn-primary:hover{ background:var(--brun-fonce); transform:translateY(-3px); box-shadow:0 16px 34px rgba(196,148,128,.45); }
.btn-outline{ background:transparent; color:var(--anthracite); border:1.5px solid var(--ocre); }
.btn-outline:hover{ background:var(--ocre); color:var(--creme); transform:translateY(-3px); }
.btn-light{ background:var(--creme); color:var(--brun); }
.btn-light:hover{ background:#fff; transform:translateY(-3px); }
.btn-arrow{ transition:transform .35s; }
.btn:hover .btn-arrow{ transform:translateX(4px); }

/* ---------- HEADER + NAV ---------- */
.header{ position:fixed; top:0; left:0; right:0; z-index:100; padding:22px 0; transition:padding .4s, box-shadow .4s; }
.header::after{ content:""; position:absolute; inset:0; z-index:-1; opacity:0; background:rgba(250,250,247,.84);
  backdrop-filter:blur(14px) saturate(1.1); border-bottom:1px solid var(--ligne); transition:opacity .4s; }
.header.scrolled{ padding:13px 0; box-shadow:0 6px 24px rgba(80,55,30,.06); }
.header.scrolled::after{ opacity:1; }
.header.solid::after{ opacity:1; } /* pages internes : header opaque d'emblée */

/* ---- HEADER ADAPTATIF : clair sur fond foncé, foncé sur fond clair ---- */
.header{ transition:padding .4s ease, box-shadow .4s ease; }
.logo-name,.logo-sub,.nav a,.burger span,.socials a,.header-right .btn-primary{
  transition:color .45s ease, background .45s ease, border-color .45s ease, box-shadow .45s ease; }
.header::after{ transition:opacity .45s ease, background .45s ease; }
.header.on-dark::after{ opacity:1; background:linear-gradient(180deg, rgba(26,18,12,.5), rgba(26,18,12,0));
  border-bottom:none; -webkit-backdrop-filter:none; backdrop-filter:none; }
.header.on-dark.scrolled::after{ background:linear-gradient(180deg, rgba(26,18,12,.82), rgba(26,18,12,.3)); }
.header.on-dark .logo-name{ color:var(--creme); }
.header.on-dark .logo-sub{ color:rgba(251,247,240,.7); }
.header.on-dark .nav a{ color:rgba(251,247,240,.9); }
.header.on-dark .nav a::after{ background:var(--ocre-clair); }
.header.on-dark .nav a:hover, .header.on-dark .nav a.active{ color:#fff; }
.header.on-dark .burger span{ background:var(--creme); }
.header.on-dark .socials a{ border-color:rgba(251,247,240,.38); color:rgba(251,247,240,.85); }
.header.on-dark .socials a:hover{ background:var(--creme); color:var(--espresso); border-color:var(--creme); }
.header.on-dark .header-right .btn-primary{ background:rgba(251,247,240,.12); color:var(--creme);
  border:1.5px solid rgba(251,247,240,.55); box-shadow:none; -webkit-backdrop-filter:blur(6px); backdrop-filter:blur(6px); }
.header.on-dark .header-right .btn-primary:hover{ background:var(--creme); color:var(--espresso); border-color:var(--creme); }
.header-inner{ display:flex; align-items:center; justify-content:space-between; gap:20px; }

.logo{ display:flex; align-items:center; gap:12px; }
.logo-img{ width:46px; height:46px; flex-shrink:0; object-fit:contain; }
.logo-text{ line-height:1.05; display:flex; flex-direction:column; align-items:flex-start; }
.logo-name{ font-family:var(--serif); font-size:20px; font-weight:600; color:var(--anthracite); white-space:nowrap; display:block; }
.logo-sub{ font-size:10px; letter-spacing:.13em; text-transform:uppercase; color:var(--texte-doux); white-space:nowrap; display:block; padding:4px 0 0 !important; margin:0 !important; text-align:left !important; }

.nav{ display:flex; align-items:center; gap:26px; }
.nav a{ position:relative; font-size:15px; font-weight:500; color:var(--anthracite); padding:6px 2px; white-space:nowrap; transition:color .35s ease; }
.nav a::after{ content:""; position:absolute; left:0; right:0; bottom:0; height:2px; background:var(--brun); border-radius:2px;
  transform:scaleX(0); transform-origin:right; transition:transform .42s cubic-bezier(.2,.7,.3,1); }
.nav a:hover{ color:var(--brun); }
.nav a:hover::after{ transform:scaleX(1); transform-origin:left; }
.nav a.active{ color:var(--brun); }
.nav a.active::after{ transform:scaleX(1); }

.header-right{ display:flex; align-items:center; gap:14px; }
.socials{ display:flex; gap:12px; }
.socials a{ width:34px; height:34px; border-radius:50%; display:grid; place-items:center; border:1px solid var(--ligne); color:var(--texte-doux); transition:background .3s ease, color .3s ease, border-color .3s ease, transform .3s ease; }
.socials a:hover{ background:var(--ocre); color:var(--creme); border-color:var(--ocre); transform:translateY(-2px); }
.socials svg{ width:16px; height:16px; }

.burger{ display:none; width:44px; height:44px; flex-direction:column; justify-content:center; align-items:center; gap:5px; border-radius:12px; }
.burger span{ width:24px; height:2px; background:var(--anthracite); border-radius:2px; transition:transform .35s ease, opacity .35s ease; }
.burger.open span:nth-child(1){ transform:translateY(7px) rotate(45deg); }
.burger.open span:nth-child(2){ opacity:0; }
.burger.open span:nth-child(3){ transform:translateY(-7px) rotate(-45deg); }

.mobile-nav{ position:fixed; inset:0; z-index:99; background:rgba(250,250,247,.98); backdrop-filter:blur(12px);
  display:flex; flex-direction:column; justify-content:center; align-items:center; gap:8px; opacity:0; pointer-events:none; transition:opacity .4s; }
.mobile-nav.open{ opacity:1; pointer-events:auto; }
.mobile-nav a{ font-family:var(--serif); font-size:34px; color:var(--anthracite); padding:10px; opacity:0; transform:translateY(16px); transition:opacity .5s ease, transform .5s ease; }
.mobile-nav.open a{ opacity:1; transform:none; }
.mobile-nav.open a:nth-child(1){ transition-delay:.08s; } .mobile-nav.open a:nth-child(2){ transition-delay:.14s; }
.mobile-nav.open a:nth-child(3){ transition-delay:.2s; } .mobile-nav.open a:nth-child(4){ transition-delay:.26s; }
.mobile-nav.open a:nth-child(5){ transition-delay:.32s; }
.mobile-nav .btn-primary{ margin-top:24px; font-size:16px; opacity:0; transition-delay:.4s; }
.mobile-nav.open .btn-primary{ opacity:1; }

/* ---------- TITRES DE SECTION ---------- */
.sec-head{ max-width:700px; margin-bottom:clamp(48px,6vw,78px); }
.sec-head.center{ margin-left:auto; margin-right:auto; }
.sec-head .eyebrow{ display:block; margin-bottom:18px; }
.sec-head h2{ font-size:clamp(36px,4.6vw,60px); color:var(--anthracite); }
.sec-head p{ margin-top:20px; font-size:clamp(17px,1.7vw,20px); color:var(--texte-doux); line-height:1.75; }

/* ---------- HERO (accueil) ---------- */
.hero{ position:relative; padding:clamp(150px,19vh,210px) 0 clamp(70px,8vw,110px); overflow:hidden; }
.hero::before{ content:""; position:absolute; top:-12%; right:-6%; width:60vw; height:60vw; max-width:780px; max-height:780px;
  background:radial-gradient(circle, rgba(214,180,152,.40), transparent 62%); z-index:0; pointer-events:none; }
.hero .container{ position:relative; z-index:1; }
.hero-grid{ display:grid; grid-template-columns:1.04fr .96fr; gap:clamp(36px,5vw,84px); align-items:center; }
.hero-eyebrow{ display:inline-flex; align-items:center; gap:10px; margin-bottom:28px; }
.hero-eyebrow::before{ content:""; width:32px; height:1px; background:var(--ocre); }
.hero h1{ font-size:clamp(42px,4.9vw,74px); letter-spacing:-.01em; margin-bottom:30px; color:var(--anthracite); max-width:15ch; }
.hero h1 em{ font-style:italic; color:var(--brun); }
.hero-sub{ font-size:clamp(18px,2vw,21px); color:var(--texte-doux); max-width:37ch; margin-bottom:40px; line-height:1.75; }
.hero-cta{ display:flex; flex-wrap:wrap; gap:16px; }
.hero-visual{ position:relative; }
.hero-photo{ aspect-ratio:4/5; border-radius:var(--arch) var(--arch) var(--radius-lg) var(--radius-lg); box-shadow:var(--ombre-l); }
.hero-photo .imgcover{ animation:kenburns 20s ease-in-out infinite alternate; }
@keyframes kenburns{ from{ transform:scale(1.02); } to{ transform:scale(1.13) translateY(-1.5%); } }
.hero-badge{ position:absolute; left:clamp(-10px,-2vw,-34px); bottom:46px; background:var(--creme); border-radius:var(--radius);
  padding:18px 22px; box-shadow:var(--ombre-m); display:flex; align-items:center; gap:14px; z-index:2; }
.hero-badge .num{ font-family:var(--serif); font-size:40px; font-weight:600; color:var(--brun); line-height:1; }
.hero-badge .lbl{ font-size:13px; color:var(--texte-doux); line-height:1.3; max-width:14ch; }
.hero-chip{ position:absolute; right:18px; top:30px; background:rgba(251,247,240,.9); backdrop-filter:blur(6px); border-radius:100px;
  padding:9px 16px; box-shadow:var(--ombre-s); display:flex; align-items:center; gap:8px; font-size:13.5px; font-weight:600; color:var(--anthracite); z-index:2; }
.hero-chip .st{ color:var(--ocre); letter-spacing:1px; }
.scroll-cue{ display:flex; align-items:center; gap:12px; margin-top:54px; color:var(--texte-doux); font-size:13px; letter-spacing:.16em; text-transform:uppercase; }
.scroll-cue .line{ width:46px; height:1px; background:var(--ocre); position:relative; overflow:hidden; }
.scroll-cue .line::after{ content:""; position:absolute; inset:0; background:var(--brun); animation:slide 2.4s ease-in-out infinite; }
@keyframes slide{ 0%{ transform:translateX(-100%); } 60%,100%{ transform:translateX(100%); } }

.hero-strip{ display:grid; grid-template-columns:repeat(5,1fr); gap:14px; margin-top:clamp(48px,5vw,72px); }
.vignette{ position:relative; border-radius:16px; overflow:hidden; aspect-ratio:3/4; box-shadow:var(--ombre-s); transition:transform .5s cubic-bezier(.2,.7,.3,1), box-shadow .5s; }
.vignette:hover{ transform:translateY(-8px); box-shadow:var(--ombre-m); }
.vignette .imgcover{ transition:transform .7s ease; }
.vignette:hover .imgcover{ transform:scale(1.07); }
.vignette .vig-label{ position:absolute; left:0; right:0; bottom:0; padding:16px 15px 14px; color:var(--creme); font-weight:600; font-size:14.5px;
  line-height:1.2; z-index:2; background:linear-gradient(transparent, rgba(40,28,18,.82)); }

/* ---------- CANVAS PAGES INTERNES ---------- */
/* Toile beige homogène : chaque bloc coloré éclot puis se résorbe dans CETTE même
   couleur (var--lin) — aucun bord de couleur différente, donc aucune « bande ». */
.flow-bg{ background:var(--lin); }

/* ---------- BANNIÈRE PAGES INTERNES ---------- */
.page-hero{ position:relative; padding:clamp(150px,20vh,230px) 0 clamp(60px,7vw,96px); overflow:hidden; background:transparent; }
.page-hero::before{ content:""; position:absolute; top:-20%; right:-8%; width:55vw; height:55vw; max-width:680px; max-height:680px;
  background:radial-gradient(circle, rgba(214,180,152,.40), transparent 62%); pointer-events:none; }
.page-hero .container{ position:relative; }
.page-hero .eyebrow{ display:block; margin-bottom:18px; }
.page-hero h1{ font-size:clamp(44px,6vw,86px); color:var(--anthracite); letter-spacing:-.01em; max-width:16ch; }
.page-hero h1 em{ font-style:italic; color:var(--brun); }
.page-hero p{ margin-top:22px; font-size:clamp(18px,2vw,21px); color:var(--texte-doux); max-width:54ch; line-height:1.75; }
.breadcrumb{ display:flex; gap:8px; font-size:13px; color:var(--texte-doux); margin-bottom:24px; letter-spacing:.04em; }
.breadcrumb a:hover{ color:var(--brun); }
.breadcrumb span{ color:var(--ocre); }

/* ---------- TIMELINE / DÉROULÉ ---------- */
.process{ background:linear-gradient(180deg, var(--lin) 0%, var(--blanc) 26%, var(--blanc) 74%, var(--lin) 100%); }
.process-grid{ display:grid; grid-template-columns:.82fr 1.18fr; gap:clamp(44px,6vw,96px); align-items:center; }
.process-photo{ aspect-ratio:4/5; border-radius:0; box-shadow:var(--ombre-m); }
.process-photo .imgcover{ filter:brightness(1.2) saturate(0.88); }
.timeline{ position:relative; padding-left:42px; }
.timeline::before{ content:""; position:absolute; left:11px; top:10px; bottom:10px; width:2px; background:linear-gradient(var(--ocre), var(--lin-fonce)); }
.timeline .eyebrow{ display:block; margin-bottom:16px; }
.timeline > h2{ font-size:clamp(32px,4vw,52px); margin-bottom:40px; }
.step{ position:relative; padding-bottom:42px; }
.step:last-child{ padding-bottom:0; }
.step::before{ content:""; position:absolute; left:-36px; top:7px; width:14px; height:14px; border-radius:50%; background:var(--brun); box-shadow:0 0 0 5px rgba(160,82,45,.16); }
.step .step-num{ font-size:12px; font-weight:600; letter-spacing:.2em; text-transform:uppercase; color:var(--ocre); }
.step h3{ font-size:clamp(24px,2.6vw,31px); margin:6px 0 10px; color:var(--anthracite); }
.step p{ color:var(--texte-doux); max-width:48ch; }

/* ---------- SÉANCES ---------- */
.seances-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(20px,2.4vw,30px); }
.seances-grid.cols-4{ grid-template-columns:repeat(4,1fr); }
.carte{ position:relative; background:var(--creme); border:1px solid var(--ligne); border-radius:var(--radius-lg); padding:38px 34px 30px;
  display:flex; flex-direction:column; transition:transform .45s cubic-bezier(.2,.7,.3,1), box-shadow .45s, border-color .45s; }
.carte:hover{ transform:translateY(-10px); box-shadow:var(--ombre-m); border-color:var(--ocre-clair); }
.carte-num{ font-family:var(--serif); font-size:28px; color:var(--ocre); font-style:italic; }
.carte h3{ font-size:clamp(23px,2.3vw,28px); margin:14px 0 12px; color:var(--anthracite); }
.carte p{ color:var(--texte-doux); font-size:16px; line-height:1.65; flex:1; }
.carte-meta{ display:flex; align-items:baseline; justify-content:space-between; gap:12px; margin:24px 0 22px; padding-top:20px; border-top:1px solid var(--ligne); }
.carte-duree{ font-size:14px; letter-spacing:.04em; color:var(--texte-doux); text-transform:uppercase; }
.carte-prix{ font-family:var(--serif); font-size:34px; font-weight:600; color:var(--brun); }
.carte-prix small{ font-size:18px; }
.carte-btn{ display:inline-flex; align-items:center; justify-content:center; gap:8px; width:100%; padding:13px; border-radius:100px;
  font-weight:600; font-size:15px; border:1.5px solid var(--ocre); color:var(--brun); transition:background .35s ease, color .35s ease, border-color .35s ease; }
.carte:hover .carte-btn{ background:var(--brun); border-color:var(--brun); color:var(--creme); }
.forfait-list{ list-style:none; margin:18px 0 26px; flex:1; display:flex; flex-direction:column; gap:2px; }
.forfait-list li{ display:flex; align-items:baseline; justify-content:space-between; gap:14px; padding:13px 0; border-bottom:1px solid var(--ligne); }
.forfait-list li:last-child{ border-bottom:0; }
.forfait-list span{ color:var(--texte-doux); font-size:16px; }
.forfait-list b{ font-family:var(--serif); font-size:25px; font-weight:600; color:var(--brun); white-space:nowrap; }

/* ---------- POURQUOI (cartes verre) ---------- */
.pourquoi{ position:relative; background:var(--espresso); color:var(--creme); overflow:hidden; }
.pourquoi::before{ content:""; position:absolute; inset:0; background:radial-gradient(60% 60% at 12% 0%, rgba(214,180,152,.22), transparent 60%),
  radial-gradient(50% 70% at 100% 100%, rgba(180,126,100,.28), transparent 60%); }
.pourquoi .container{ position:relative; }
.pourquoi .eyebrow{ color:var(--ocre-clair); }
.pourquoi .sec-head h2{ color:var(--creme); }
.pourquoi .sec-head p{ color:rgba(250,250,247,.7); }
.verre-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:clamp(16px,1.8vw,24px); }
.verre{ background:rgba(255,255,255,.12); border:1px solid rgba(255,255,255,.30); border-radius:var(--radius); padding:32px 26px;
  backdrop-filter:blur(8px); transition:transform .45s, background .45s, border-color .45s; }
.verre:hover{ transform:translateY(-8px); background:rgba(255,255,255,.20); border-color:rgba(255,255,255,.50); }
.verre-ico{ width:48px; height:48px; border-radius:13px; display:grid; place-items:center; background:rgba(201,148,90,.18); margin-bottom:22px; }
.verre-ico svg{ width:25px; height:25px; stroke:var(--ocre-clair); fill:none; stroke-width:1.5; }
.verre h3{ font-size:23px; margin-bottom:10px; color:var(--creme); }
.verre p{ font-size:15px; color:rgba(250,250,247,.66); line-height:1.6; }

/* ---------- À PROPOS ---------- */
.apropos{ background:linear-gradient(180deg, var(--lin) 0%, var(--blanc) 26%, var(--blanc) 74%, var(--lin) 100%); }
.apropos-grid{ display:grid; grid-template-columns:.9fr 1.1fr; gap:clamp(40px,5vw,84px); align-items:center; }
.apropos-visual{ position:relative; }
.apropos-photo{ aspect-ratio:4/5; border-radius:0; box-shadow:var(--ombre-l); }
.apropos-tag{ position:absolute; right:clamp(-8px,-2vw,-24px); top:40px; background:var(--creme); padding:16px 20px; border-radius:14px;
  box-shadow:var(--ombre-m); font-size:14px; max-width:200px; line-height:1.4; z-index:2; }
.apropos-tag b{ font-family:var(--serif); font-size:17px; color:var(--brun); }
.apropos-text h2{ font-size:clamp(32px,4vw,54px); margin-bottom:22px; }
.apropos-text p{ color:var(--texte-doux); margin-bottom:18px; }
.signature{ font-family:var(--serif); font-style:italic; font-size:27px; color:var(--brun); margin-top:26px; }
.chiffres{ display:grid; grid-template-columns:repeat(3,1fr); gap:20px; margin-top:40px; padding-top:36px; border-top:1px solid var(--ligne); }
.chiffre .n{ font-family:var(--serif); font-size:clamp(40px,4.4vw,54px); font-weight:600; color:var(--brun); line-height:1; }
.chiffre .l{ font-size:14px; color:var(--texte-doux); margin-top:8px; line-height:1.35; }

/* ---------- TÉMOIGNAGES (statique + carrousel) ---------- */
.temoins-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(20px,2.4vw,30px); }
.avis{ background:var(--creme); border:1px solid var(--ligne); border-radius:var(--radius-lg); padding:36px 32px; transition:transform .45s, box-shadow .45s; }
.avis:hover{ transform:translateY(-6px); box-shadow:var(--ombre-m); }
.stars{ color:var(--ocre); letter-spacing:3px; font-size:16px; margin-bottom:18px; }
.avis-txt{ font-family:var(--serif); font-size:21px; line-height:1.5; color:var(--anthracite); font-style:italic; }
.avis-pers{ display:flex; align-items:center; gap:14px; margin-top:26px; }
.avatar{ width:50px; height:50px; border-radius:50%; display:grid; place-items:center; font-family:var(--serif); font-size:19px; font-weight:600; color:var(--creme); flex-shrink:0; }
.avis-nom{ font-weight:600; font-size:15.5px; }
.avis-meta{ font-size:13px; color:var(--texte-doux); }

/* ---------- RÉSERVATION / FORMULAIRE ---------- */
.reserve{ position:relative; background:var(--espresso); color:var(--creme); overflow:hidden; }
.reserve-bg{ position:absolute; inset:0; z-index:0; }
.reserve-bg .imgcover{ opacity:.55; filter:brightness(1.15) saturate(0.85); }
/* Formulaire : bloc net, sans fondu (volontaire — demande client) */
.reserve::after{ content:""; position:absolute; inset:0; z-index:1; pointer-events:none;
  background:linear-gradient(115deg, rgba(50,35,25,.78) 36%, rgba(50,35,25,.42)); }
.reserve .container{ position:relative; z-index:2; }
.reserve-grid{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(40px,6vw,90px); align-items:center; }
.reserve .eyebrow{ color:var(--ocre-clair); }
.reserve h2{ font-size:clamp(34px,4.4vw,58px); color:var(--creme); margin:16px 0 22px; }
.reserve-info p{ color:rgba(250,250,247,.74); font-size:18px; line-height:1.7; max-width:42ch; }
.reserve-points{ margin-top:30px; display:flex; flex-direction:column; gap:14px; }
.reserve-points li{ display:flex; align-items:center; gap:14px; color:rgba(250,250,247,.85); font-size:16px; }
.reserve-points li::before{ content:""; width:9px; height:9px; border-radius:50%; background:var(--ocre); flex-shrink:0; box-shadow:0 0 0 4px rgba(201,148,90,.2); }

.form-card{ background:rgba(255,255,255,.16); border:1px solid rgba(255,255,255,.30); border-radius:var(--radius-lg); padding:clamp(28px,3.2vw,44px); backdrop-filter:blur(10px); }
.form-card h3{ font-size:28px; color:var(--creme); margin-bottom:6px; }
.form-card .fc-sub{ font-size:14.5px; color:rgba(250,250,247,.6); margin-bottom:26px; }
.form-row{ display:grid; grid-template-columns:1fr 1fr; gap:18px; }
.field{ position:relative; margin-bottom:20px; }
.field label{ display:block; font-size:12.5px; letter-spacing:.12em; text-transform:uppercase; color:var(--ocre-clair); margin-bottom:8px; }
.field input, .field textarea, .field select{ width:100%; background:transparent; border:none; border-bottom:1.5px solid rgba(255,255,255,.45);
  color:var(--creme); font-family:var(--sans); font-size:16px; padding:8px 2px; transition:border-color .3s; }
.field select option{ color:var(--anthracite); }
.field input::placeholder, .field textarea::placeholder{ color:rgba(250,250,247,.35); }
.field input:focus, .field textarea:focus, .field select:focus{ border-color:var(--ocre); }
.field textarea{ resize:vertical; min-height:60px; }
.field.invalid input, .field.invalid textarea{ border-color:#d98b6a; }
.field .err{ font-size:12px; color:#e7a98f; margin-top:6px; display:none; }
.field.invalid .err{ display:block; }
.form-card .btn-primary{ width:100%; justify-content:center; margin-top:6px; }
.form-card .btn-primary[disabled]{ opacity:.6; cursor:not-allowed; transform:none; }
.form-note{ font-size:12.5px; color:rgba(250,250,247,.5); margin-top:16px; text-align:center; }
.form-ok{ margin-top:18px; padding:16px 18px; border-radius:12px; background:rgba(201,148,90,.18); border:1px solid rgba(226,193,154,.4); color:var(--ocre-clair); font-size:14.5px; text-align:center; }
.form-success{ text-align:center; padding:20px 6px; }
.form-success .ico{ width:64px; height:64px; border-radius:50%; background:rgba(201,148,90,.2); display:grid; place-items:center; margin:0 auto 18px; font-size:30px; color:var(--ocre-clair); }
.form-success h3{ margin-bottom:10px; }
.form-success p{ color:rgba(250,250,247,.7); font-size:15px; }

/* ---------- CARTE INTERACTIVE DES ZONES RÉFLEXES ---------- */
.reflexo{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(36px,5vw,72px); align-items:center; }
.reflexo-map{ position:relative; aspect-ratio:4/5; border-radius:var(--arch) var(--arch) var(--radius-lg) var(--radius-lg); overflow:hidden; box-shadow:var(--ombre-l); background:var(--lin-fonce); }
.reflexo-map .imgcover{ filter:saturate(1.02); }
.reflexo-map::after{ content:""; position:absolute; inset:0; background:linear-gradient(transparent 55%, rgba(40,28,18,.35)); pointer-events:none; }
.hotspot{ position:absolute; width:30px; height:30px; transform:translate(-50%,-50%); border-radius:50%; border:2px solid var(--creme);
  background:rgba(160,82,45,.7); cursor:pointer; z-index:3; transition:transform .3s, background .3s; }
.hotspot::after{ content:""; position:absolute; inset:-8px; border-radius:50%; border:1px solid rgba(251,247,240,.6); animation:pulse 2.4s ease-out infinite; }
@keyframes pulse{ 0%{ transform:scale(.6); opacity:.9; } 100%{ transform:scale(1.5); opacity:0; } }
.hotspot:hover, .hotspot.active{ background:var(--ocre); transform:translate(-50%,-50%) scale(1.18); }
.reflexo-info{ }
.reflexo-info .zone-num{ font-family:var(--serif); font-style:italic; font-size:24px; color:var(--ocre); }
.reflexo-info h3{ font-size:clamp(28px,3.2vw,40px); margin:6px 0 16px; color:var(--anthracite); }
.reflexo-info p{ color:var(--texte-doux); font-size:18px; line-height:1.7; max-width:46ch; }
.reflexo-chips{ display:flex; flex-wrap:wrap; gap:10px; margin-top:28px; }
.reflexo-chip{ padding:10px 18px; border-radius:100px; border:1.5px solid var(--ligne); background:var(--creme); font-size:14.5px; font-weight:500;
  color:var(--texte-doux); cursor:pointer; transition:background .3s ease, color .3s ease, border-color .3s ease; }
.reflexo-chip:hover{ border-color:var(--ocre); color:var(--brun); }
.reflexo-chip.active{ background:var(--brun); border-color:var(--brun); color:var(--creme); }

/* ---------- CARROUSEL AVIS ---------- */
.carousel{ position:relative; max-width:860px; margin:0 auto; }
.carousel-track{ overflow:hidden; }
.carousel-slide{ text-align:center; padding:10px clamp(10px,4vw,50px); }
.carousel-slide .stars{ justify-content:center; display:flex; margin-bottom:24px; }
.carousel-quote{ font-family:var(--serif); font-style:italic; font-size:clamp(24px,3vw,34px); line-height:1.45; color:var(--anthracite); }
.carousel-pers{ display:flex; align-items:center; justify-content:center; gap:14px; margin-top:34px; }
.carousel-ctrl{ display:flex; align-items:center; justify-content:center; gap:10px; margin-top:38px; }
.carousel-dot{ width:9px; height:9px; border-radius:50%; background:var(--lin-fonce); transition:background .3s ease, width .3s ease, border-radius .3s ease; cursor:pointer; }
.carousel-dot.active{ background:var(--brun); width:28px; border-radius:6px; }
.carousel-arrow{ width:48px; height:48px; border-radius:50%; border:1.5px solid var(--ligne); display:grid; place-items:center; color:var(--brun); transition:background .3s ease, color .3s ease, border-color .3s ease; }
.carousel-arrow:hover{ background:var(--brun); color:var(--creme); border-color:var(--brun); }

/* ---------- BANDE CTA ---------- */
.cta-band{ background:var(--brun); color:var(--creme); text-align:center; }
.cta-band h2{ font-size:clamp(32px,4.4vw,56px); color:var(--creme); margin-bottom:18px; }
.cta-band p{ color:rgba(251,247,240,.85); font-size:19px; max-width:48ch; margin:0 auto 34px; }

/* ---------- ADMIN ---------- */
.admin{ padding-top:140px; min-height:100vh; }
.admin-head{ display:flex; flex-wrap:wrap; align-items:flex-end; justify-content:space-between; gap:18px; margin-bottom:34px; }
.admin-head h1{ font-size:clamp(34px,4vw,52px); }
.admin-stats{ display:flex; gap:14px; flex-wrap:wrap; margin-bottom:30px; }
.admin-stat{ background:var(--creme); border:1px solid var(--ligne); border-radius:16px; padding:20px 26px; min-width:150px; }
.admin-stat .n{ font-family:var(--serif); font-size:36px; font-weight:600; color:var(--brun); line-height:1; }
.admin-stat .l{ font-size:13px; color:var(--texte-doux); margin-top:6px; }
.admin-table{ width:100%; border-collapse:collapse; background:var(--creme); border-radius:16px; overflow:hidden; box-shadow:var(--ombre-s); }
.admin-table th, .admin-table td{ text-align:left; padding:16px 20px; font-size:15px; border-bottom:1px solid var(--ligne); vertical-align:top; }
.admin-table th{ background:var(--lin-fonce); font-size:12px; letter-spacing:.1em; text-transform:uppercase; color:var(--texte-doux); font-weight:600; }
.admin-table tr:last-child td{ border-bottom:none; }
.admin-table .pill{ display:inline-block; padding:4px 12px; border-radius:100px; font-size:12px; font-weight:600; background:rgba(201,148,90,.18); color:var(--brun-fonce); }
.admin-empty{ text-align:center; padding:70px 20px; color:var(--texte-doux); }
.admin-empty .ico{ font-size:40px; margin-bottom:14px; }
.admin-tools{ display:flex; gap:12px; }
.btn-ghost{ font-size:14px; font-weight:600; color:var(--texte-doux); padding:10px 18px; border-radius:100px; border:1px solid var(--ligne); transition:color .3s ease, border-color .3s ease; }
.btn-ghost:hover{ border-color:var(--brun); color:var(--brun); }

/* ---------- FOOTER ---------- */
.footer{ background:var(--lin); padding:clamp(64px,7vw,96px) 0 32px; }
.footer-top{ display:grid; grid-template-columns:1.4fr 1fr 1fr; gap:40px; padding-bottom:46px; border-bottom:1px solid var(--ligne); }
.footer-brand .logo{ margin-bottom:18px; }
.footer-brand p{ color:var(--texte-doux); font-size:15px; max-width:34ch; }
.footer-col h4{ font-family:var(--sans); font-size:13px; letter-spacing:.18em; text-transform:uppercase; color:var(--brun); margin-bottom:18px; font-weight:600; }
.footer-col ul{ display:flex; flex-direction:column; gap:11px; }
.footer-col a, .footer-col li{ font-size:15px; color:var(--texte-doux); transition:color .3s; }
.footer-col a:hover{ color:var(--brun); }
.footer-legal{ margin-top:30px; padding-top:22px; }
.footer-disclaimer{ font-size:13px; color:var(--texte-doux); max-width:70ch; line-height:1.6; margin-bottom:18px; font-style:italic; }
.footer-bottom{ display:flex; flex-wrap:wrap; align-items:center; justify-content:space-between; gap:14px; font-size:13px; color:var(--texte-doux); }
.footer-bottom .socials a{ border-color:var(--ligne); }

/* ---------- LENIS (scroll fluide) — CSS requis sur toutes les pages ---------- */
html.lenis, html.lenis body{ height:auto; }
.lenis.lenis-smooth{ scroll-behavior:auto !important; }
.lenis.lenis-smooth [data-lenis-prevent]{ overscroll-behavior:contain; }
.lenis.lenis-stopped{ overflow:hidden; }
.lenis.lenis-smooth iframe{ pointer-events:none; }

/* ---------- RIDEAU DE TRANSITION DE PAGE (partagé) ---------- */
.scroll-prog{ position:fixed; top:0; left:0; height:3px; width:100%; transform:scaleX(0); transform-origin:0 50%;
  background:linear-gradient(90deg, var(--ocre-clair), var(--ocre), var(--brun)); z-index:130; pointer-events:none; }
.page-curtain{ position:fixed; inset:0; z-index:9600; background:var(--espresso); display:grid; place-items:center;
  pointer-events:none; transform:translateY(0);
  animation:curtainLift 1s cubic-bezier(.76,0,.24,1) 1.05s forwards; }
.page-curtain__inner{ overflow:hidden; padding-bottom:.14em; }
.page-curtain__name{ display:block; font-family:var(--serif); font-weight:500; font-size:clamp(28px,4.6vw,52px);
  color:var(--creme); letter-spacing:.01em; transform:translateY(112%); animation:curtainName .95s cubic-bezier(.2,.7,.3,1) .12s forwards; }
.page-curtain__sub{ display:block; text-align:center; margin-top:11px; font-family:var(--sans); font-size:11.5px;
  letter-spacing:.34em; text-transform:uppercase; color:rgba(251,247,240,.80); opacity:0; animation:curtainSub .8s ease .52s forwards; }
.page-curtain .dotsep{ display:inline-block; width:5px; height:5px; border-radius:50%; background:var(--ocre); margin:0 9px 3px; }
@keyframes curtainName{ to{ transform:none; } }
@keyframes curtainSub{ to{ opacity:1; } }
@keyframes curtainLift{ to{ transform:translateY(-101%); } }
/* recouvre l'écran au clic d'un lien interne, avant la navigation */
.page-curtain.lifted{ animation:none; transform:translateY(-101%); }
.page-curtain.covering{ animation:none; transform:translateY(0); transition:transform .55s cubic-bezier(.76,0,.24,1); }
.page-curtain.instant{ animation:none !important; transform:translateY(-101%); }
/* intro déjà vue dans la session → rideau retiré, aucune animation au rechargement */
html.no-intro .page-curtain{ display:none !important; }

/* ---------- MOTS QUI S'ILLUMINENT AU SCROLL ---------- */
html.js [data-words]{ --w-dim:.16; }
html.js [data-words] .rv-w{ opacity:var(--w-dim); }
html.no-gsap [data-words] .rv-w{ opacity:1 !important; }

/* ---------- ANIMATIONS ---------- */
.reveal{ opacity:0; transform:translateY(34px); transition:opacity .9s ease, transform .9s cubic-bezier(.2,.7,.3,1); }
.reveal.is-visible{ opacity:1; transform:none; }
@keyframes heroIn{ from{ opacity:0; transform:translateY(28px); } to{ opacity:1; transform:none; } }
.hero-anim{ opacity:0; animation:heroIn .85s ease forwards; }
.d1{ animation-delay:.05s; } .d2{ animation-delay:.2s; } .d3{ animation-delay:.35s; } .d4{ animation-delay:.5s; } .d5{ animation-delay:.64s; }
@media (prefers-reduced-motion:reduce){
  .reveal,.hero-anim{ opacity:1!important; transform:none!important; animation:none!important; }
  .hero-photo .imgcover, .scroll-cue .line::after, .hotspot::after{ animation:none!important; }
  .page-curtain{ display:none !important; }
  html.js [data-words] .rv-w{ opacity:1 !important; }
  html{ scroll-behavior:auto; }
}

/* ---------- RESPONSIVE ---------- */
/* Le menu passe en burger AVANT que le layout ne se replie, pour ne jamais
   laisser le header se tasser/se chevaucher sur les laptops & fenêtres réduites. */
@media (max-width:1120px){
  .nav, .header-right .socials{ display:none; }
  .burger{ display:flex; }
}
@media (max-width:980px){
  .hero-grid, .process-grid, .apropos-grid, .reserve-grid, .reflexo{ grid-template-columns:1fr; }
  .hero-visual, .process-photo, .apropos-visual, .reflexo-map{ max-width:460px; margin-left:auto; margin-right:auto; }
  .timeline > h2{ margin-left:0; }
  .seances-grid, .seances-grid.cols-4, .verre-grid, .temoins-grid{ grid-template-columns:repeat(2,1fr); }
  .footer-top{ grid-template-columns:1fr 1fr; }
  .admin-table{ display:block; overflow-x:auto; white-space:nowrap; }
}
@media (max-width:620px){
  body{ font-size:16px; }
  :root{ --arch:150px; }
  .header-right .btn-primary{ display:none; } /* la CTA reste dans le menu burger */
  .hero-strip{ grid-template-columns:repeat(3,1fr); }
  .hero-strip .vignette:nth-child(4), .hero-strip .vignette:nth-child(5){ display:none; }
  .seances-grid, .seances-grid.cols-4, .verre-grid, .temoins-grid, .chiffres, .form-row{ grid-template-columns:1fr; }
  .chiffres{ gap:26px; }
  .apropos-tag{ right:0; }
}
