/* =====================================================================
   Mille Frames — Version 2 « Studio » (refonte premium)
   DA : crème / doré / anthracite. Carrousel galeries, multilingue,
   animations, desktop ultra-propre, mobile en défilement.
   ===================================================================== */

:root{
  --cream:      #f5f2ed;
  --cream-soft: #faf8f4;
  --ink:        #161616;
  --ink-soft:   #2c2c2c;
  --muted:      #6a645e;
  --gold:       #c2a57b;
  --gold-deep:  #a9895f;
  --card:       #ffffff;
  --line:       rgba(28,28,28,.10);
  --shadow-sm:  0 4px 16px rgba(0,0,0,.07);
  --shadow:     0 14px 40px rgba(0,0,0,.13);
  --shadow-lg:  0 24px 60px rgba(0,0,0,.22);
  --radius:     18px;
  --radius-lg:  26px;
  --ease:       cubic-bezier(.22,.61,.36,1);
  --maxw:       1240px;
  --pad:        clamp(20px, 4vw, 40px);
  --sec:        clamp(64px, 9vw, 116px);
}

*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; }
body{
  margin:0;
  background:var(--cream);
  color:var(--ink);
  font-family:"DM Sans", system-ui, -apple-system, "Segoe UI", Arial, sans-serif;
  font-size:16px; line-height:1.6;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{ max-width:100%; display:block; }
a{ color:inherit; }
::selection{ background:var(--gold); color:#fff; }

/* ---------- Barre de progression de défilement ---------- */
.scroll-progress{
  position:fixed; top:0; left:0; height:3px; width:0;
  background:linear-gradient(90deg, var(--gold), var(--gold-deep));
  z-index:1000; transition:width .1s linear;
}

/* ---------- Titres ---------- */
h3{
  font-size:13px; font-weight:700; text-transform:uppercase;
  letter-spacing:4px; color:var(--gold-deep);
  margin:0 0 14px; text-align:center;
}
.eyebrow{
  text-transform:uppercase; letter-spacing:5px;
  font-size:12px; font-weight:700; color:var(--gold);
}
.kicker{
  display:inline-flex; align-items:center; gap:12px;
  text-transform:uppercase; letter-spacing:4px;
  font-size:12px; font-weight:700; color:var(--gold-deep);
  margin-bottom:14px;
}
.kicker::before{ content:""; width:34px; height:2px; background:var(--gold); }
p{ font-size:17px; }

.section-head{ text-align:center; margin-bottom:clamp(40px,5vw,60px); }
.section-head h2{
  font-family:"Lora", Georgia, serif; font-weight:600;
  font-size:clamp(30px,4.4vw,46px); margin:6px 0 0; color:var(--ink);
  letter-spacing:-.5px;
}

/* ---------- Header / Nav ---------- */
header{
  position:sticky; top:0; z-index:200;
  display:flex; justify-content:space-between; align-items:center;
  gap:20px;
  padding:14px clamp(18px,4vw,44px);
  background:rgba(250,248,244,.72);
  backdrop-filter:blur(18px) saturate(140%);
  -webkit-backdrop-filter:blur(18px) saturate(140%);
  border-bottom:1px solid transparent;
  transition:border-color .35s ease, box-shadow .35s ease, background .35s ease, padding .35s ease;
}
header.scrolled{
  border-bottom-color:var(--line);
  box-shadow:0 6px 24px rgba(0,0,0,.06);
  padding-top:10px; padding-bottom:10px;
}
.main{ display:flex; align-items:center; }
.icon-rond{ width:82px; transition:transform .4s var(--ease); }
.logo-link{ display:inline-flex; align-items:center; line-height:0; }
.logo-link:hover .icon-rond{ transform:scale(1.05) rotate(-2deg); }

nav .nav-list{ list-style:none; display:flex; gap:4px; margin:0; padding:0; }
.nav-list a{
  position:relative; display:block; padding:9px 16px;
  text-decoration:none; border-radius:8px;
  font-size:12px; font-weight:600; letter-spacing:1px; text-transform:uppercase;
  color:var(--ink); transition:color .3s ease;
}
.nav-list a::after{
  content:""; position:absolute; left:16px; right:16px; bottom:4px;
  height:2px; background:var(--gold); transform:scaleX(0); transform-origin:left;
  transition:transform .35s var(--ease);
}
.nav-list a:hover{ color:var(--gold-deep); }
.nav-list a:hover::after{ transform:scaleX(1); }

/* ---------- Sélecteur multilingue ---------- */
.lang-switch{ position:relative; }
.lang-current{
  display:inline-flex; align-items:center; gap:7px;
  padding:8px 12px; border:1px solid var(--line); border-radius:999px;
  background:rgba(255,255,255,.6); cursor:pointer;
  font-size:12px; font-weight:700; letter-spacing:.5px; text-transform:uppercase;
  color:var(--ink); transition:all .3s var(--ease);
}
.lang-current:hover{ border-color:var(--gold); color:var(--gold-deep); }
.lang-current svg{ width:15px; height:15px; }
.lang-current .chev{ transition:transform .3s var(--ease); }
.lang-switch.open .lang-current .chev{ transform:rotate(180deg); }
.lang-menu{
  position:absolute; right:0; top:calc(100% + 8px);
  background:#fff; border:1px solid var(--line); border-radius:14px;
  box-shadow:var(--shadow); padding:6px; min-width:148px;
  opacity:0; visibility:hidden; transform:translateY(-6px);
  transition:opacity .25s var(--ease), transform .25s var(--ease), visibility .25s;
  z-index:300;
}
.lang-switch.open .lang-menu{ opacity:1; visibility:visible; transform:translateY(0); }
.lang-menu button{
  display:flex; width:100%; align-items:center; gap:10px;
  padding:9px 12px; border:none; background:transparent; cursor:pointer;
  border-radius:9px; font:inherit; font-size:13px; color:var(--ink); text-align:left;
  transition:background .2s ease;
}
.lang-menu button:hover{ background:var(--cream); }
.lang-menu button.active{ color:var(--gold-deep); font-weight:700; }
.lang-menu button .flag{ font-size:16px; line-height:1; }

/* ---------- Hero ---------- */
.hero{
  position:relative; text-align:center; overflow:hidden;
  padding:clamp(86px,13vw,150px) var(--pad) clamp(96px,14vw,150px);
  background:radial-gradient(1100px 540px at 50% -8%, #242424, #131313);
  color:#fff;
}
.hero::before{
  content:""; position:absolute; inset:0;
  background:radial-gradient(620px 320px at 78% 16%, rgba(194,165,123,.16), transparent 60%);
  pointer-events:none;
}
.hero::after{
  content:""; position:absolute; left:50%; bottom:-2px; transform:translateX(-50%);
  width:130px; height:4px; background:var(--gold); border-radius:999px;
}
.hero>*{ position:relative; }
.hero .eyebrow{ display:block; margin-bottom:22px; }
.hero h1{
  font-family:"Lora", Georgia, serif; font-weight:600;
  font-size:clamp(40px,7.4vw,82px); line-height:1.05; letter-spacing:-1px;
  margin:0 0 22px;
}
.hero h1 em{ font-style:italic; color:var(--gold); }
.hero .lead{
  max-width:600px; margin:0 auto 36px;
  color:rgba(255,255,255,.78); font-size:clamp(16px,2vw,19px);
}
.hero-cta{ display:inline-flex; gap:14px; flex-wrap:wrap; justify-content:center; }
.btn-primary,.btn-ghost{
  position:relative; overflow:hidden;
  padding:15px 34px; border-radius:999px; text-decoration:none;
  font-weight:700; font-size:13px; letter-spacing:1px; text-transform:uppercase;
  transition:transform .35s var(--ease), background .35s var(--ease), color .35s var(--ease), border-color .35s var(--ease);
}
.btn-primary{ background:var(--gold); color:#161616; }
.btn-primary:hover{ background:#fff; transform:translateY(-3px); }
.btn-ghost{ background:transparent; color:#fff; border:1.5px solid rgba(255,255,255,.5); }
.btn-ghost:hover{ border-color:#fff; background:rgba(255,255,255,.1); transform:translateY(-3px); }
/* reflet animé sur les boutons */
.btn-primary::after,.btn-ghost::after{
  content:""; position:absolute; top:0; left:-120%; width:60%; height:100%;
  background:linear-gradient(120deg, transparent, rgba(255,255,255,.35), transparent);
  transform:skewX(-20deg); transition:left .6s var(--ease);
}
.btn-primary:hover::after,.btn-ghost:hover::after{ left:130%; }

.scroll-hint{
  position:absolute; left:50%; bottom:26px; transform:translateX(-50%);
  width:24px; height:38px; border:2px solid rgba(255,255,255,.45); border-radius:14px;
  z-index:2;
}
.scroll-hint::after{
  content:""; position:absolute; left:50%; top:7px; transform:translateX(-50%);
  width:4px; height:7px; border-radius:2px; background:#fff;
  animation:scrollDot 1.7s var(--ease) infinite;
}
@keyframes scrollDot{ 0%{ opacity:0; top:7px; } 40%{ opacity:1; } 80%{ opacity:0; top:18px; } 100%{ opacity:0; } }

/* ---------- Sections ---------- */
.gallery-section,.corps-cont,#reservation{ max-width:var(--maxw); margin:0 auto; }
.gallery-section{ padding:var(--sec) var(--pad); }

/* Galerie d'accueil : cartes avec légende en surimpression */
.album-cont{
  display:grid; grid-template-columns:repeat(5,1fr); gap:16px;
}
.album{
  position:relative; display:block; text-decoration:none;
  border-radius:var(--radius); overflow:hidden;
  box-shadow:var(--shadow-sm); aspect-ratio:3/4;
  transition:box-shadow .45s var(--ease), transform .45s var(--ease);
}
.album .fond{ width:100%; height:100%; object-fit:cover; transition:transform .7s var(--ease); }
.album::after{
  content:""; position:absolute; inset:0;
  background:linear-gradient(180deg, rgba(0,0,0,0) 42%, rgba(0,0,0,.74));
}
.album-info{
  position:absolute; left:0; right:0; bottom:0; z-index:2;
  padding:16px 18px; display:flex; align-items:center; justify-content:space-between;
}
.album-info span{ color:#fff; font-family:"Lora", serif; font-size:1.1rem; font-weight:500; }
.album-info::after{
  content:"→"; color:var(--gold); font-size:18px;
  transform:translateX(-6px); opacity:0; transition:all .4s var(--ease);
}
.album:hover{ transform:translateY(-6px); box-shadow:var(--shadow-lg); }
.album:hover .fond{ transform:scale(1.07); }
.album:hover .album-info::after{ transform:translateX(0); opacity:1; }

/* ---------- Tarifs ---------- */
#corps{ background:var(--cream-soft); border-top:1px solid var(--line); border-bottom:1px solid var(--line); }
.corps-cont{ padding:var(--sec) var(--pad); }
.seances-grid{
  display:grid; grid-template-columns:repeat(2,1fr); gap:16px; margin-bottom:clamp(44px,6vw,68px);
}
.seance{
  background:var(--card); border:1px solid var(--line); border-radius:var(--radius);
  display:flex; align-items:center; justify-content:space-between; gap:14px;
  padding:18px 20px; box-shadow:var(--shadow-sm);
  transition:transform .35s var(--ease), box-shadow .35s var(--ease), border-color .35s ease;
}
.seance:hover{ transform:translateY(-4px); box-shadow:var(--shadow); border-color:var(--gold); }
.left{ display:flex; align-items:center; gap:16px; min-width:0; }
.img{ width:40px; flex:none; }
.texte{ text-align:left; min-width:0; }
.titre{ font-weight:700; font-size:16px; margin-bottom:3px; }
.description{ font-size:13.5px; color:var(--muted); line-height:1.5; }
.price-color{ color:var(--gold-deep); font-weight:700; }
.button{
  flex:none; background:var(--ink); color:#fff; border:none; border-radius:999px;
  padding:11px 18px; white-space:nowrap; text-decoration:none;
  font-size:12px; font-weight:700; letter-spacing:.5px; text-transform:uppercase;
  transition:all .35s var(--ease);
}
.button:hover{ background:var(--gold); transform:translateY(-2px); }

.inclus ul{
  list-style:none; padding:0; margin:0;
  display:grid; grid-template-columns:repeat(4,1fr); gap:16px;
}
.liste{
  display:flex; align-items:center; gap:14px; padding:20px;
  background:var(--card); border:1px solid var(--line); border-radius:var(--radius);
  box-shadow:var(--shadow-sm); font-weight:500; font-size:15px;
  transition:transform .35s var(--ease), box-shadow .35s var(--ease);
}
.liste:hover{ transform:translateY(-3px); box-shadow:var(--shadow); }
.logo-liste{ width:30px; flex:none; }

/* ---------- Réservation ---------- */
#reservation{
  display:grid; grid-template-columns:1.1fr .9fr;
  border-radius:var(--radius-lg); overflow:hidden;
  width:min(var(--maxw), calc(100% - 2 * var(--pad)));
  margin:var(--sec) auto;
  box-shadow:var(--shadow); border:1px solid var(--line);
}
.gauche{ background:linear-gradient(160deg, #1d1d1d, #121212); color:#fff; padding:clamp(40px,5vw,64px); }
.droite{
  position:relative; overflow:hidden; color:#fff;
  padding:clamp(40px,5vw,64px); display:flex; flex-direction:column; justify-content:center;
}
.droite .background{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; z-index:0; }
.droite::before{ content:""; position:absolute; inset:0; background:linear-gradient(160deg, rgba(20,20,20,.58), rgba(20,20,20,.84)); z-index:0; }
.droite>*{ position:relative; z-index:1; }
.gauche .form-title,.droite .bio-title{
  font-family:"Lora", serif; font-size:clamp(26px,3.2vw,36px); font-weight:600;
  margin:6px 0 28px; color:#fff; letter-spacing:-.3px;
}
.me p{ font-size:16px; color:rgba(255,255,255,.9); line-height:1.85; }

.formulaire{ display:grid; grid-template-columns:1fr 1fr; gap:14px; }
.formulaire>*{ min-width:0; }
.field{
  background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.16);
  border-radius:12px; display:flex; flex-direction:column; padding:10px 14px;
  transition:border-color .3s ease, background .3s ease;
}
.field:focus-within{ border-color:var(--gold); background:rgba(255,255,255,.12); }
.field label{ font-size:11px; letter-spacing:1px; text-transform:uppercase; color:rgba(255,255,255,.6); margin-bottom:3px; }
.field.full{ grid-column:1/-1; }
.field input,.field textarea,.field select{
  width:100%; background:transparent; border:none; outline:none;
  color:#fff; font-family:"DM Sans", sans-serif; font-size:14px; padding:3px 0;
}
.field textarea{ resize:none; min-height:60px; }
.field input::placeholder,.field textarea::placeholder{ color:rgba(255,255,255,.4); }
.field select{ color:rgba(255,255,255,.5); }
.field select:valid{ color:#fff; }
.field select option{ background-color:#1e1e1e; color:#fff; }
.field select option:checked{ background-color:#2a2a2a; }
.field select option:disabled{ color:rgba(255,255,255,.45); }

/* Menu déroulant personnalisé (coins arrondis, style formulaire) */
.field.has-custom > select{ position:absolute; width:1px; height:1px; opacity:0; pointer-events:none; }
.field:has(.cs.open){ border-color:var(--gold); background:rgba(255,255,255,.12); }
.cs{ position:relative; }
.cs-trigger{
  display:flex; align-items:center; justify-content:space-between; gap:8px;
  width:100%; padding:3px 0; background:transparent; border:none; cursor:pointer;
  color:#fff; font-family:"DM Sans", sans-serif; font-size:14px; text-align:left;
}
.cs-label.placeholder{ color:rgba(255,255,255,.5); }
.cs-chev{ width:14px; height:14px; flex:none; color:rgba(255,255,255,.6); transition:transform .3s var(--ease); }
.cs.open .cs-chev{ transform:rotate(180deg); }
.cs-panel{
  position:absolute; left:-14px; right:-14px; top:calc(100% + 12px); z-index:60;
  background:#1e1e1e; border:1px solid rgba(255,255,255,.16); border-radius:16px;
  box-shadow:0 20px 44px rgba(0,0,0,.45); padding:6px;
  max-height:264px; overflow:auto;
  opacity:0; visibility:hidden; transform:translateY(-6px);
  transition:opacity .22s var(--ease), transform .22s var(--ease), visibility .22s;
}
.cs.open .cs-panel{ opacity:1; visibility:visible; transform:translateY(0); }
.cs-option{
  display:block; width:100%; text-align:left; background:transparent; border:none;
  color:rgba(255,255,255,.85); font-family:"DM Sans", sans-serif; font-size:14px;
  padding:11px 14px; border-radius:11px; cursor:pointer;
  transition:background .2s ease, color .2s ease;
}
.cs-option:hover{ background:rgba(255,255,255,.08); color:#fff; }
.cs-option.sel{ background:var(--gold); color:#161616; }
.field input[type="date"]::-webkit-calendar-picker-indicator{ filter:invert(1); opacity:.6; cursor:pointer; }
.required{ color:var(--gold); }
.btn-reservation{
  grid-column:1/-1; justify-self:start; margin-top:6px;
  position:relative; overflow:hidden;
  background:var(--gold); color:#161616; border:none; border-radius:999px;
  padding:14px 40px; font-size:13px; font-weight:700; letter-spacing:1px; text-transform:uppercase;
  cursor:pointer; transition:all .35s var(--ease);
}
.btn-reservation:hover{ background:#fff; transform:translateY(-3px); }

/* ---------- Footer ---------- */
footer{ background:#121212; padding:clamp(44px,6vw,64px) var(--pad); }
footer h5{ font-family:"Lora", serif; font-size:26px; color:#fff; text-align:center; margin:0 0 36px; }
#contact{ display:flex; justify-content:center; align-items:center; gap:clamp(28px,6vw,64px); flex-wrap:wrap; }
#contact .email,#contact .whatsapp,#contact .insta{ display:flex; align-items:center; gap:12px; }
#contact p,#contact a{ color:rgba(255,255,255,.9); font-size:15px; text-decoration:none; transition:color .3s ease; }
#contact a:hover{ color:var(--gold); }
.logo-email,.logo-whatsapp,.logo-insta{ filter:invert(1); width:30px; transition:transform .3s var(--ease); }
#contact > div:hover img{ transform:translateY(-3px); }
.copyright{
  text-align:center; color:rgba(255,255,255,.5); font-size:12.5px; letter-spacing:.4px;
  max-width:var(--maxw); margin:clamp(26px,4vw,40px) auto 0; padding-top:22px;
  border-top:1px solid rgba(255,255,255,.1);
}
.credit{ text-align:center; color:rgba(255,255,255,.4); font-size:12px; margin:8px 0 0; }
.credit a{ color:rgba(255,255,255,.7); text-decoration:none; border-bottom:1px solid rgba(194,165,123,.5); transition:color .25s ease, border-color .25s ease; }
.credit a:hover{ color:var(--gold); border-color:var(--gold); }

/* =====================================================================
   PAGES GALERIE — Carrousel défilant
   ===================================================================== */
.gal-header{
  position:sticky; top:0; z-index:200;
  display:flex; justify-content:space-between; align-items:center;
  padding:14px clamp(18px,4vw,44px);
  background:rgba(250,248,244,.8);
  backdrop-filter:blur(18px) saturate(140%);
  -webkit-backdrop-filter:blur(18px) saturate(140%);
  border-bottom:1px solid var(--line);
}
.icon-gallery,.icon-gallery-merci{ width:78px; }
.retour{
  text-decoration:none; color:var(--ink); border:1.5px solid var(--ink);
  border-radius:999px; padding:10px 22px; font-size:12px; font-weight:700;
  letter-spacing:1px; text-transform:uppercase; transition:all .35s var(--ease);
}
.retour:hover{ background:var(--ink); color:#fff; }

.gal-title{
  text-align:center; font-family:"Lora", serif; font-weight:600;
  font-size:clamp(30px,5vw,52px); color:var(--ink); margin:clamp(30px,5vw,52px) auto 6px;
  letter-spacing:-.5px;
}
.gal-title-line{ display:block; width:70px; height:3px; margin:16px auto 0; background:var(--gold); border-radius:999px; }
.gal-count{ text-align:center; color:var(--muted); font-size:13px; letter-spacing:2px; text-transform:uppercase; margin:14px 0 6px; }

.carousel-wrap{
  position:relative; max-width:1400px; margin:clamp(18px,3vw,30px) auto clamp(40px,6vw,70px);
  padding:0 clamp(12px,3vw,28px);
}
.carousel{
  display:flex; gap:clamp(14px,2.2vw,26px);
  overflow-x:auto; overflow-y:hidden;
  scroll-snap-type:x mandatory; scroll-behavior:smooth;
  -webkit-overflow-scrolling:touch;
  padding:8px 4px 22px;
  cursor:grab;
}
.carousel.dragging{ cursor:grabbing; scroll-behavior:auto; }
.carousel::-webkit-scrollbar{ height:0; }
.carousel{ scrollbar-width:none; }
.slide{
  flex:0 0 100%; scroll-snap-align:center;
  width:100%; height:min(74vh, 760px);
  border-radius:14px; overflow:hidden;
  background:#0e0e0e;
  position:relative;
}
.slide .galerie-img{
  width:100%; height:100%; object-fit:cover; background:#0e0e0e;
  cursor:inherit; user-select:none; -webkit-user-drag:none;
  transition:transform .6s var(--ease);
}
.slide:hover .galerie-img{ transform:scale(1.015); }

.car-btn{ display:none; }
.car-btn:hover{ background:var(--gold); color:#fff; border-color:var(--gold); }
.car-prev{ left:clamp(6px,2vw,26px); }
.car-next{ right:clamp(6px,2vw,26px); }
.car-prev:hover{ transform:translateY(-50%) translateX(-3px); }
.car-next:hover{ transform:translateY(-50%) translateX(3px); }

.car-controls{ display:flex; align-items:center; justify-content:center; gap:20px; margin-top:10px; }
.car-arrow{
  width:42px; height:42px; border-radius:50%; cursor:pointer; flex:none;
  background:transparent; border:1.5px solid var(--ink); color:var(--ink);
  font-size:20px; line-height:1; display:flex; align-items:center; justify-content:center;
  transition:all .3s var(--ease);
}
.car-arrow:hover{ background:var(--gold); border-color:var(--gold); color:#fff; transform:translateY(-2px); }
.car-dots{ display:flex; justify-content:center; gap:9px; }
.car-dot{
  width:8px; height:8px; border-radius:50%; border:none; padding:0; cursor:pointer;
  background:rgba(28,28,28,.18); transition:all .3s var(--ease);
}
.car-dot.active{ background:var(--gold); width:26px; border-radius:999px; }

/* ---------- Page Merci ---------- */
.merci{
  display:flex; flex-direction:column; justify-content:center; align-items:center;
  background:var(--cream-soft); border:1px solid var(--line);
  box-shadow:var(--shadow); border-radius:var(--radius-lg);
  margin:clamp(40px,7vw,80px) auto; max-width:700px; padding:clamp(40px,6vw,60px) var(--pad);
  text-align:center;
}
.titre-merci{ font-family:"Lora", serif; font-size:clamp(28px,5vw,44px); color:var(--ink); margin:0 0 22px; }
.corps-merci p{ font-size:18px; color:var(--muted); margin:6px 0; }
.retour-merci{
  display:inline-block; color:#161616; background:var(--gold);
  font-size:13px; font-weight:700; letter-spacing:1px; text-transform:uppercase;
  padding:14px 34px; text-decoration:none; border-radius:999px; margin-top:34px;
  transition:all .35s var(--ease);
}
.retour-merci:hover{ background:var(--ink); color:#fff; transform:translateY(-3px); }

/* ---------- Lightbox (plein écran depuis le carrousel) ---------- */
.lightbox{
  position:fixed; inset:0; z-index:9999;
  display:flex; justify-content:center; align-items:center; padding:5vh 6vw;
  background:radial-gradient(circle at 50% 38%, rgba(22,22,24,.74), rgba(8,8,10,.95));
  backdrop-filter:blur(24px) saturate(115%);
  -webkit-backdrop-filter:blur(24px) saturate(115%);
  opacity:0; visibility:hidden; pointer-events:none;
  transition:opacity .4s var(--ease), visibility .4s var(--ease);
}
.lightbox.active{ opacity:1; visibility:visible; pointer-events:auto; }
#lightboxImg{
  max-width:100%; max-height:88vh; object-fit:contain; border-radius:6px;
  box-shadow:0 30px 90px rgba(0,0,0,.65);
  outline:1px solid rgba(255,255,255,.08); outline-offset:-1px;
}
#lightboxImg.swap{ animation:lbIn .5s var(--ease); }
@keyframes lbIn{ from{ opacity:0; transform:scale(.96); } to{ opacity:1; transform:scale(1); } }
.close{
  position:fixed; top:24px; right:28px; width:50px; height:50px;
  display:flex; align-items:center; justify-content:center; font-size:24px;
  color:#fff; cursor:pointer; line-height:1;
  background:rgba(255,255,255,.08); border:1px solid rgba(255,255,255,.18);
  border-radius:50%; backdrop-filter:blur(6px);
  transition:all .35s var(--ease); z-index:10002;
}
.close:hover{ background:var(--gold); color:#161616; border-color:var(--gold); transform:rotate(90deg); }
.lb-nav{
  position:fixed; top:50%; transform:translateY(-50%); z-index:10001;
  width:58px; height:58px; border-radius:50%;
  background:rgba(255,255,255,.08); border:1px solid rgba(255,255,255,.18);
  color:#fff; font-size:26px; line-height:1; cursor:pointer;
  display:none; align-items:center; justify-content:center; backdrop-filter:blur(6px);
  transition:background .3s var(--ease), color .3s var(--ease), border-color .3s var(--ease);
}
.lb-nav:hover{ background:var(--gold); color:#161616; border-color:var(--gold); }
.lb-nav.actif{ display:flex; }
.lb-prev{ left:24px; } .lb-next{ right:24px; }
.lb-compteur{
  position:fixed; bottom:28px; left:50%; transform:translateX(-50%); z-index:10001;
  color:#fff; background:rgba(255,255,255,.08); border:1px solid rgba(255,255,255,.18);
  backdrop-filter:blur(6px); letter-spacing:2px; font-size:13px; font-weight:600;
  padding:9px 20px; border-radius:999px; display:none;
}
.lb-compteur.actif{ display:block; }

/* ---------- Animations reveal ---------- */
[data-rev]{ opacity:0; transform:translateY(28px); transition:opacity .8s var(--ease), transform .8s var(--ease); }
[data-rev].vu{ opacity:1; transform:none; }
[data-rev].d1{ transition-delay:.08s; } [data-rev].d2{ transition-delay:.16s; }
[data-rev].d3{ transition-delay:.24s; } [data-rev].d4{ transition-delay:.32s; }
img[loading="lazy"]{ opacity:0; transition:opacity .6s ease; }
img[loading="lazy"].chargee{ opacity:1; }
/* entrée hero */
.hero .eyebrow,.hero h1,.hero .lead,.hero-cta{ opacity:0; transform:translateY(22px); animation:heroUp .9s var(--ease) forwards; }
.hero h1{ animation-delay:.12s; } .hero .lead{ animation-delay:.24s; } .hero-cta{ animation-delay:.36s; }
@keyframes heroUp{ to{ opacity:1; transform:none; } }

/* ---------- Bouton retour haut ---------- */
#scrollTop{
  position:fixed; right:20px; bottom:20px; z-index:900; width:48px; height:48px;
  border-radius:50%; border:none; background:var(--ink); color:#fff; font-size:20px;
  cursor:pointer; opacity:0; pointer-events:none;
  transition:opacity .3s ease, background .3s ease, transform .3s var(--ease); box-shadow:var(--shadow);
}
#scrollTop.visible{ opacity:.95; pointer-events:auto; }
#scrollTop:hover{ background:var(--gold); transform:translateY(-3px); }

/* =====================================================================
   RESPONSIVE
   ===================================================================== */
@media (max-width:1024px){
  .album-cont{ grid-template-columns:repeat(3,1fr); }
}
@media (max-width:900px){
  #reservation{ grid-template-columns:1fr; }
}
@media (max-width:768px){
  header{ flex-direction:column; align-items:center; gap:8px; padding:10px 14px; }
  .icon-rond{ width:60px; }
  nav .nav-list{ justify-content:center; flex-wrap:wrap; gap:4px; }
  .nav-list a{ padding:8px 11px; font-size:11px; letter-spacing:.5px; }
  .lang-current{ padding:7px 10px; font-size:11px; }
  .lang-switch{ position:relative; }
  .lang-menu{ left:50%; right:auto; transform:translateX(-50%) translateY(-6px); }
  .lang-switch.open .lang-menu{ transform:translateX(-50%) translateY(0); }

  /* Galerie d'accueil : défilement horizontal */
  .album-cont{
    display:flex; gap:14px; overflow-x:auto; -webkit-overflow-scrolling:touch;
    scroll-snap-type:x mandatory; padding-bottom:10px;
    grid-template-columns:none;
  }
  .album-cont::-webkit-scrollbar{ display:none; }
  .album-cont{ scrollbar-width:none; }
  .album{ flex:0 0 70%; scroll-snap-align:center; aspect-ratio:3/4; }

  .seances-grid{ grid-template-columns:1fr; }
  .inclus ul{ grid-template-columns:1fr 1fr; }
  .formulaire{ grid-template-columns:1fr; }
  #contact{ flex-direction:column; gap:18px; }

  /* Carrousel galerie en plein défilement tactile */
  .carousel-wrap{ padding:0; }
  .slide{ flex:0 0 100%; width:100%; height:64vh; }
  .car-btn{ display:none; }   /* on navigue au doigt sur mobile */
  .scroll-hint{ display:none; }
  .close{ top:14px; right:14px; width:44px; height:44px; font-size:22px; }
  .lb-nav{ width:48px; height:48px; }
  .lb-prev{ left:10px; } .lb-next{ right:10px; }
}
@media (max-width:480px){
  .album{ flex:0 0 82%; }
  .slide{ flex:0 0 100%; width:100%; height:58vh; }
}

/* =====================================================================
   COMPOSANTS — pages dédiées (Tarifs / Réservation) + accueil enrichi
   ===================================================================== */
.page-hero{
  text-align:center; position:relative; color:#fff;
  padding:clamp(72px,11vw,124px) var(--pad) clamp(64px,8vw,96px);
  background:radial-gradient(900px 460px at 50% -10%, #232323, #141414);
}
.page-hero::after{ content:""; position:absolute; left:50%; bottom:-2px; transform:translateX(-50%); width:120px; height:4px; background:var(--gold); border-radius:999px; }
.page-hero .kicker{ justify-content:center; color:var(--gold); }
.page-hero h1{ font-family:"Lora",serif; font-weight:600; font-size:clamp(34px,6vw,60px); margin:6px 0 16px; letter-spacing:-.5px; }
.page-hero p{ max-width:600px; margin:0 auto; color:rgba(255,255,255,.78); font-size:clamp(15px,2vw,18px); }

.tarifs-wrap{ max-width:var(--maxw); margin:0 auto; padding:var(--sec) var(--pad); }
.tarifs-wrap .inclus-cont{ margin-top:clamp(40px,6vw,64px); }
.tarifs-cta{ text-align:center; margin-top:clamp(40px,6vw,60px); }

/* À propos (accueil) */
.about{ max-width:var(--maxw); margin:0 auto; padding:var(--sec) var(--pad);
  display:grid; grid-template-columns:1fr 1.1fr; gap:clamp(28px,5vw,64px); align-items:center; }
.about-media{ border-radius:var(--radius-lg); overflow:hidden; box-shadow:var(--shadow); aspect-ratio:4/5; }
.about-media img{ width:100%; height:100%; object-fit:cover; }
.about-body h2{ font-family:"Lora",serif; font-weight:600; font-size:clamp(28px,4vw,44px); margin:8px 0 18px; letter-spacing:-.5px; }
.about-body p{ color:var(--muted); font-size:17px; line-height:1.85; margin:0; }

/* Bandeau d'appel à l'action */
.cta-band{ background:linear-gradient(160deg,#1d1d1d,#121212); color:#fff; text-align:center; padding:clamp(56px,8vw,92px) var(--pad); }
.cta-band h2{ font-family:"Lora",serif; font-weight:600; font-size:clamp(28px,4.4vw,46px); margin:10px 0 14px; }
.cta-band p{ max-width:560px; margin:0 auto 30px; color:rgba(255,255,255,.78); font-size:17px; }
.cta-band .hero-cta{ display:inline-flex; gap:14px; flex-wrap:wrap; justify-content:center; }

/* Réservation — panneau droit */
.me-intro{ color:rgba(255,255,255,.9); font-size:16px; line-height:1.8; margin:0 0 24px; }
.resv-points{ list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:14px; }
.resv-points li{ display:flex; align-items:center; gap:12px; color:#fff; font-size:15px; }
.resv-points li::before{ content:"✓"; flex:none; width:26px; height:26px; border-radius:50%;
  background:var(--gold); color:#161616; font-size:14px; font-weight:700;
  display:flex; align-items:center; justify-content:center; }

@media (max-width:900px){
  .about{ grid-template-columns:1fr; }
  .about-media{ width:100%; max-width:420px; margin:0 auto; }
}

/* =====================================================================
   FORMULAIRE DE RÉSERVATION — carte claire premium
   ===================================================================== */
.cs-native{ position:absolute !important; width:1px; height:1px; opacity:0; pointer-events:none; clip:rect(0 0 0 0); }

.booking{ background:var(--cream); padding:0 var(--pad) var(--sec); }
.bk-card{
  max-width:720px; margin:clamp(-44px,-4vw,-28px) auto 0; position:relative; z-index:2;
  background:#fff; border:1px solid var(--line); border-radius:24px;
  box-shadow:var(--shadow-lg); padding:clamp(26px,4vw,46px);
}
.bk-grid{ display:grid; grid-template-columns:1fr 1fr; gap:18px 20px; }
.bk-field{ display:flex; flex-direction:column; gap:7px; min-width:0; }
.bk-field.full{ grid-column:1/-1; }
.bk-field > label{ font-size:11px; letter-spacing:1.4px; text-transform:uppercase; font-weight:700; color:var(--muted); }
.bk-field .req{ color:var(--gold-deep); }
.bk-input,
.bk-field textarea{
  width:100%; padding:13px 15px; border:1px solid var(--line); border-radius:12px;
  background:var(--cream-soft); color:var(--ink);
  font-family:"DM Sans", sans-serif; font-size:15px;
  transition:border-color .25s ease, box-shadow .25s ease, background .25s ease;
}
.bk-field textarea{ resize:vertical; min-height:96px; }
.bk-input:focus,
.bk-field textarea:focus{
  outline:none; border-color:var(--gold); background:#fff;
  box-shadow:0 0 0 3px rgba(194,165,123,.18);
}
.bk-input::placeholder,
.bk-field textarea::placeholder{ color:#b3ada5; }
.bk-input[type="date"]::-webkit-calendar-picker-indicator,
.bk-input[type="time"]::-webkit-calendar-picker-indicator{ opacity:.55; cursor:pointer; }

.bk-submit{
  grid-column:1/-1; margin-top:6px;
  background:var(--ink); color:#fff; border:none; border-radius:999px;
  padding:16px 28px; font-size:14px; font-weight:700; letter-spacing:1px; text-transform:uppercase;
  cursor:pointer; transition:all .35s var(--ease);
}
.bk-submit:hover{ background:var(--gold); color:#161616; transform:translateY(-2px); }
.bk-required{ grid-column:1/-1; text-align:center; font-size:12px; color:var(--muted); margin-top:-2px; }

/* Menu personnalisé adapté au formulaire clair */
.bk-field .cs-trigger{
  padding:13px 15px; border:1px solid var(--line); border-radius:12px;
  background:var(--cream-soft); color:var(--ink); font-size:15px;
  transition:border-color .25s ease, box-shadow .25s ease, background .25s ease;
}
.bk-field .cs.open .cs-trigger,
.bk-field .cs-trigger:hover{ border-color:var(--gold); }
.bk-field .cs.open .cs-trigger{ background:#fff; box-shadow:0 0 0 3px rgba(194,165,123,.18); }
.bk-field .cs-label.placeholder{ color:#b3ada5; }
.bk-field .cs-chev{ color:var(--muted); }
.bk-field .cs-panel{ left:0; right:0; top:calc(100% + 8px); background:#fff; border-color:var(--line); box-shadow:var(--shadow); }
.bk-field .cs-option{ color:var(--ink); }
.bk-field .cs-option:hover{ background:var(--cream); color:var(--ink); }
.bk-field .cs-option.sel{ background:var(--gold); color:#161616; }

.bk-trust{ max-width:720px; margin:26px auto 0; display:flex; justify-content:center; gap:30px; flex-wrap:wrap; }
.bk-trust span{ display:flex; align-items:center; gap:8px; color:var(--muted); font-size:13px; font-weight:500; }
.bk-trust span::before{
  content:"✓"; flex:none; width:20px; height:20px; border-radius:50%;
  background:var(--gold); color:#fff; font-size:11px; font-weight:700;
  display:flex; align-items:center; justify-content:center;
}

@media (max-width:600px){
  .bk-grid{ grid-template-columns:1fr; }
  .bk-trust{ flex-direction:column; align-items:center; gap:12px; }
}

@media (prefers-reduced-motion:reduce){
  html{ scroll-behavior:auto; }
  *{ transition:none !important; animation:none !important; }
  [data-rev]{ opacity:1; transform:none; }
  .hero .eyebrow,.hero h1,.hero .lead,.hero-cta{ opacity:1; transform:none; }
  img[loading="lazy"]{ opacity:1; }
}
