@font-face {
  font-family: 'Tan Pearl';
  src: url('fonts/tan-pearl.otf') format('opentype');
  font-weight: normal;
  font-style: normal;
  font-display: swap;
}

:root {
  --ink:      #3B1408;
  --ink-soft: #5E3528;
  --muted:    #8C8070;
  --cream:    #F8F4EE;
  --linen:    #EDE8DF;
  --stone:    #D9D2C5;
  --ochre:    #C4882A;
  --ochre-lt: #E8B865;
  --terra:    #B85C35;
  --white:    #FDFCFA;
  --serif:    'Cormorant Garamond', Georgia, serif;
  --display:  'Tan Pearl', 'Cormorant Garamond', Georgia, serif;
  --body:     'EB Garamond', Georgia, serif;
  --sans:     'Inter', system-ui, sans-serif;
  --ease:     cubic-bezier(0.16, 1, 0.3, 1);
}
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; overflow-x: hidden; }
/* Visually hidden — readable by Google & screen readers */
.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; }
body { font-family: var(--body); background: var(--cream); color: var(--ink); overflow-x: hidden; cursor: none; font-size: 1.3rem; line-height: 1.8; }
img  { display: block; width: 100%; height: 100%; object-fit: cover; }
a    { text-decoration: none; }

/* ════════════════════════════════════════
   PROGRESS BAR
════════════════════════════════════════ */
#progress { position:fixed;top:env(safe-area-inset-top, 0px);left:0;width:0%;height:2px;background:linear-gradient(90deg,var(--ochre),var(--ochre-lt));z-index:100000;pointer-events:none; }

/* ════════════════════════════════════════
   LOADER
════════════════════════════════════════ */
#loader {
  position:fixed;inset:0;z-index:999999;
  background:#ffffff;
  display:flex;align-items:center;justify-content:center;
  opacity:1;
  transform-origin: 50% 52%;
  will-change:opacity,transform,background;
}

/*
  Transition en 3 actes :
  ① 0 → 30 %  — fond blanc → encre de la hero, opacité 1
  ② 30 → 46 % — amorce du zoom, opacité toujours 1
  ③ 46 → 78 % — zoom accéléré, fond reste plein (l'image de fond fade IN derrière)
  ④ 78 → 100% — fond transite vers transparent : l'image hero saigne à travers
                 (opacity reste 1 — seul le background disparaît)
*/
@keyframes loader-fade-reveal {
  0%   { background:#ffffff;              transform:scale(1);    opacity:1; }
  30%  { background:#3B1408;              transform:scale(1);    opacity:1; }
  46%  { background:#3B1408;              transform:scale(1.18); opacity:1; }
  78%  { background:#3B1408;              transform:scale(7);    opacity:1; }
  100% { background:rgba(59,20,8,0);      transform:scale(18);   opacity:1; }
}
#loader.door-zoom {
  animation: loader-fade-reveal 1.65s cubic-bezier(0.22, 0, 0.58, 1) forwards;
  pointer-events: none;
}
#loaderSvg {
  display: block;
  max-width: min(80vw, 900px);
  width: 100%;
  height: auto;
  overflow: visible;
}
/* Contre-formes : blanc → encre, puis fade out avec le SVG */
@keyframes fill-to-dark {
  0%   { fill: #ffffff; }
  30%  { fill: #3B1408; }
  100% { fill: #3B1408; }
}
#loader.door-zoom #loaderSvg .wf {
  animation: fill-to-dark 1.75s linear 1 forwards;
}
/* Le SVG lui-même fade out en fin d'animation pour ne pas laisser de traces */
@keyframes svg-fade-out {
  0%, 72% { opacity:1; }
  100%    { opacity:0; }
}
#loader.door-zoom #loaderSvg {
  animation: svg-fade-out 1.75s ease-in forwards;
}

/* ════════════════════════════════════════
   CURSOR
════════════════════════════════════════ */
#cur   { position:fixed;z-index:9999;pointer-events:none;width:8px;height:8px;background:#1A1410;border-radius:50%;transform:translate(-50%,-50%);transition:width .25s var(--ease),height .25s var(--ease),background .2s; }
#cur-r { position:fixed;z-index:9998;pointer-events:none;width:34px;height:34px;border:1.5px solid rgba(26,20,16,.45);border-radius:50%;transform:translate(-50%,-50%);transition:width .4s var(--ease),height .4s var(--ease),opacity .4s,border-color .2s; }
#cur.cur--light   { background:#FDFCFA; }
#cur-r.cur--light { border-color:rgba(253,252,250,.55); }
body:has(a:hover) #cur, body:has(button:hover) #cur { width:18px;height:18px; }
body:has(a:hover) #cur-r, body:has(button:hover) #cur-r { width:52px;height:52px; }

/* Curseur personnalisé masqué sur appareils tactiles */
@media (pointer:coarse) {
  body { cursor:auto; }
  #cur, #cur-r { display:none; }
}

/* ── Hero words : taille adaptée mobile (le JS gère le positionnement) ── */
@media(max-width:640px) {
  .hero-word { font-size: clamp(1.3rem, 6vw, 2.2rem); }
  /* Tagline autorise le retour à la ligne sur mobile */
  #hero-tagline-exp {
    white-space:normal !important;
    word-break:break-word;
    overflow-wrap:anywhere;
    text-align:center;
    max-width:88vw;
    line-height:1.7;
    font-size:.58rem;
    letter-spacing:.1em;
  }
  #hero-text-bottom { width:90%; left:50%; transform:translateX(-50%); }
}

/* ════════════════════════════════════════
   NAV
════════════════════════════════════════ */
nav {
  position:fixed;top:0;left:0;right:0;z-index:1000;
  display:grid;
  grid-template-columns:1fr auto 1fr;
  align-items:center;
  padding:2rem 4rem;
  padding-top:max(2rem, calc(env(safe-area-inset-top) + .75rem));
  transition:padding .5s var(--ease),background .5s,border-color .5s,transform .45s var(--ease);
  border-bottom:1px solid transparent;
  background:linear-gradient(to bottom,rgba(26,20,16,.45) 0%,transparent 100%);
}
/* Nav solidifiée au scroll — clairement séparée des sections */
nav.nav-solid {
  background:rgba(26,20,16,.92);
  backdrop-filter:blur(16px);
  -webkit-backdrop-filter:blur(16px);
  border-bottom-color:rgba(255,255,255,.06);
}
/* Logo à gauche, liens au centre, groupe droit à droite */
nav > a:first-child { justify-self:start; }
.nav-links          { justify-self:center; }
.nav-right          { justify-self:end; display:flex; align-items:center; gap:.75rem; }
/* Auto-hide: slides up out of view when scrolling down */
nav.nav-hidden { transform:translateY(-110%); }
.nav-logo-img { height:48px;width:auto;transition:filter .4s; }
.nav-links { display:flex;gap:2.5rem;list-style:none; }
.nav-links a { font-size:.68rem;letter-spacing:.22em;text-transform:uppercase;color:rgba(253,252,250,.7);transition:color .3s;position:relative; }
.nav-links a::after { content:'';position:absolute;bottom:-3px;left:0;width:0;height:1px;background:var(--ochre);transition:width .4s var(--ease); }
.nav-links a:hover { color:var(--white); }
.nav-links a:hover::after { width:100%; }
.nav-cta { font-family:var(--sans);font-size:.54rem;letter-spacing:.18em;text-transform:uppercase;padding:.42rem .7rem;border:1px solid rgba(253,252,250,.22);border-radius:3px;background:transparent;color:rgba(253,252,250,.65);cursor:pointer;transition:background .3s,color .3s,border-color .3s;white-space:nowrap; }
.nav-cta:hover { border-color:rgba(253,252,250,.55);color:var(--white); }

/* ── Hamburger button ── */
.nav-ham {
  display:none;
  flex-direction:column;justify-content:center;align-items:center;
  gap:5px;
  width:42px;height:42px;
  background:transparent;border:none;padding:6px;
  cursor:pointer;z-index:1100;flex-shrink:0;
}
.nav-ham span {
  display:block;width:22px;height:1.5px;
  background:var(--white);
  transition:transform .35s var(--ease),opacity .25s,width .35s var(--ease);
  transform-origin:center;
}
.nav-ham.open span:nth-child(1) { transform:translateY(6.5px) rotate(45deg); }
.nav-ham.open span:nth-child(2) { opacity:0;width:0; }
.nav-ham.open span:nth-child(3) { transform:translateY(-6.5px) rotate(-45deg); }

/* ── Mobile nav overlay ── */
#nav-mob {
  display:none;
  position:fixed;inset:0;z-index:999;
  background:var(--ink);
  flex-direction:column;justify-content:center;align-items:center;gap:2.5rem;
  opacity:0;transform:translateY(-12px);
  transition:opacity .35s var(--ease),transform .35s var(--ease);
  pointer-events:none;
}
#nav-mob.open {
  opacity:1;transform:translateY(0);
  pointer-events:auto;
}
#nav-mob ul { list-style:none;display:flex;flex-direction:column;align-items:center;gap:2rem;padding:0; }
#nav-mob ul a {
  font-family:var(--serif);font-size:clamp(1.6rem,5vw,2.4rem);font-weight:400;
  color:rgba(253,252,250,.7);letter-spacing:0;
  transition:color .3s;
}
#nav-mob ul a:hover { color:var(--white); }
.nav-mob-cta {
  font-family:var(--sans);font-size:.65rem;letter-spacing:.22em;text-transform:uppercase;
  padding:.85rem 2.2rem;border:1px solid rgba(253,252,250,.35);color:var(--white);
  transition:background .3s,color .3s;
}
.nav-mob-cta:hover { background:var(--white);color:var(--ink); }
/* Prevent body scroll when mobile nav is open */
body.nav-mob-open { overflow:hidden; }

/* ════════════════════════════════════════
   HERO — SCROLL MEDIA EXPANSION
════════════════════════════════════════ */
#hero {
  position:relative;
  height:100vh;min-height:600px;
  overflow:hidden;
  background:var(--ink);
  display:flex;align-items:center;justify-content:center;
}
#hero-bg-tint {
  position:absolute;inset:0;
  background:var(--ink);
  z-index:1;pointer-events:none;
}
#hero-media-box {
  position:absolute;
  top:50%;left:50%;
  transform:translate(-50%,-50%);
  z-index:2;
  overflow:hidden;
  border-radius:16px;
  will-change:width,height,border-radius;
}
#hero-media-box img { width:100%;height:100%;object-fit:cover;object-position:center 30%; }
#hero-media-dim {
  position:absolute;inset:0;
  background:rgba(0,0,0,.18);
}
.hero-word {
  position:absolute;
  top:50%;
  z-index:3;
  font-family: var(--display);
  font-size:clamp(2rem,4.5vw,4.8rem);
  text-transform:uppercase;
  font-weight:400;
  letter-spacing:0.06em;
  color: var(--white);
  white-space:nowrap;
  pointer-events:none;
  will-change:transform;
  line-height:1;
}
#hero-word-left  { right:50%;padding-right:.6rem;transform:translateY(-50%); }
#hero-word-right { left:50%;padding-left:.6rem;transform:translateY(-50%); }
#hero-text-bottom {
  position:absolute;bottom:20%;left:50%;
  transform:translateX(-50%);
  z-index:4;
  display:flex;flex-direction:column;align-items:center;gap:.75rem;
  pointer-events:none;
}
#hero-eyebrow-exp {
  display:flex;align-items:center;gap:1.2rem;
  opacity:0;will-change:opacity;
}
.hee-dot  { width:3px;height:3px;border-radius:50%;background:var(--ochre);flex-shrink:0; }
.hee-text { font-size:.58rem;letter-spacing:.5em;text-transform:uppercase;color:rgba(253,252,250,.5); }
#hero-tagline-exp {
  font-family:var(--sans);font-size:.78rem;letter-spacing:.18em;text-transform:uppercase;
  color:rgba(253,252,250,.82);white-space:nowrap;
  opacity:0;will-change:opacity;
}
#heroScroll {
  position:absolute;bottom:2.5rem;left:50%;
  transform:translateX(-50%);
  z-index:20;
  display:flex;flex-direction:column;align-items:center;gap:.6rem;
  color:rgba(253,252,250,.45);font-size:.5rem;letter-spacing:.32em;text-transform:uppercase;
  pointer-events:none;white-space:nowrap;
}
.hero-scroll-mouse {
  width:24px;height:38px;
  border:1.5px solid rgba(253,252,250,.35);border-radius:12px;
  display:flex;align-items:flex-start;justify-content:center;
  padding-top:5px;
}
.hero-scroll-dot {
  width:3px;height:7px;
  background:rgba(253,252,250,.6);border-radius:2px;
  animation:scrollDotDrop 2s ease-in-out infinite;
}
@keyframes scrollDotDrop {
  0%,100% { transform:translateY(0);opacity:1; }
  60%      { transform:translateY(8px);opacity:.15; }
}
.hero-book-bar {
  position:absolute;bottom:0;left:0;right:0;z-index:10;
  opacity:0;will-change:opacity;pointer-events:none;
}
.hero-book-bar.active { pointer-events:auto; }
.hbb-inner {
  display:flex;align-items:stretch;
  background:rgba(253,252,250,.94);backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);
  border-top:1px solid rgba(217,210,197,.6);
}
.hbb-field { flex:1;padding:1.4rem 2rem;border-right:1px solid var(--linen);min-width:0; }
.hbb-field label {
  display:block;font-size:.52rem;letter-spacing:.32em;text-transform:uppercase;
  color:var(--ochre);margin-bottom:.45rem;
}
.hbb-in,.hbb-sel {
  width:100%;background:transparent;border:none;outline:none;
  font-family:var(--serif);font-size:1.05rem;color:var(--ink);
  -webkit-appearance:none;cursor:pointer;
}
.hbb-btn {
  flex-shrink:0;padding:0 3rem;
  background:var(--ink);color:var(--white);border:none;cursor:pointer;
  font-family:var(--sans);font-size:.6rem;letter-spacing:.25em;text-transform:uppercase;
  transition:background .3s;display:inline-flex;align-items:center;justify-content:center;
}
.hbb-btn:hover { background:var(--ochre); }
.hbb-inner--simple { justify-content:center; padding:1.6rem 2rem; }
.hbb-inner--simple .hbb-btn { padding:1.1rem 3.5rem; font-size:.65rem; }

/* ════════════════════════════════════════
   TICKER
════════════════════════════════════════ */
.ticker { background:var(--ink);overflow:hidden;padding:.9rem 0; }
.ticker-track { display:flex;width:max-content;animation:ticker 25s linear infinite;white-space:nowrap; }
.ticker-track:hover { animation-play-state:paused; }
.ticker-item { font-size:.62rem;letter-spacing:.3em;text-transform:uppercase;color:rgba(253,252,250,.4);padding:0 3rem; }
.ticker-item b { color:var(--ochre-lt); }

/* ════════════════════════════════════════
   SHARED SECTION STYLES
════════════════════════════════════════ */
.s-head { margin-bottom:4.5rem; }
.s-eyebrow { display:inline-flex;align-items:center;gap:.75rem;font-size:.6rem;letter-spacing:.5em;text-transform:uppercase;color:var(--ochre);margin-bottom:1.25rem;opacity:0;transform:translateY(14px);transition:opacity .7s var(--ease),transform .7s var(--ease); }
.s-eyebrow::before { content:'';width:22px;height:1px;background:var(--ochre); }
.s-eyebrow.vis { opacity:1;transform:translateY(0); }
.s-title { font-family:var(--display);font-size:clamp(1.6rem,2.6vw,2.6rem);font-weight:400;line-height:1.3;color:var(--ink);opacity:0;transform:translateY(24px);transition:opacity .9s var(--ease) .1s,transform .9s var(--ease) .1s; }
.s-title.vis { opacity:1;transform:translateY(0); }
.s-title em { font-style:italic;color:var(--ochre); }
.s-rule { margin-top:1.75rem;width:0;height:1px;background:linear-gradient(90deg,var(--ochre),transparent);transition:width 1s var(--ease) .3s; }
.s-rule.vis { width:60px; }

/* ════════════════════════════════════════
   CLIP REVEAL
════════════════════════════════════════ */
.cr { overflow:hidden; }
.cr > * { transform:translateY(6%) scale(1.06);transition:transform 1.4s var(--ease); }
.cr.vis > * { transform:translateY(0) scale(1); }

/* ════════════════════════════════════════
   INTRO
════════════════════════════════════════ */
#intro { padding:4rem 4rem;background:var(--white);display:grid;grid-template-columns:1fr 1fr;gap:7rem;align-items:center; }
.intro-copy { opacity:0;transform:translateY(28px);transition:opacity .9s var(--ease),transform .9s var(--ease); }
.intro-copy.vis { opacity:1;transform:translateY(0); }
.intro-body { font-size:1.05rem;line-height:1.85;color:var(--muted);margin-bottom:1.4rem; }
.intro-list {
  list-style:none;padding:0;margin:0 0 1.4rem;
  display:flex;flex-direction:column;gap:.85rem;
}
.intro-list li {
  font-size:1rem;line-height:1.75;color:var(--muted);
  padding-left:1.2rem;position:relative;
}
.intro-list li::before {
  content:'';
  position:absolute;left:0;top:.7em;
  width:5px;height:5px;border-radius:50%;
  background:var(--ochre);flex-shrink:0;
}
.intro-close {
  font-family:var(--serif);font-size:1.05rem;font-style:italic;
  color:var(--ink);margin-bottom:1.4rem;
  opacity:.85;
}
/* Fact chips — Proposal 2 */
.intro-facts {
  display:flex;flex-wrap:wrap;gap:.6rem;margin-bottom:1.6rem;
}
.intro-facts span {
  font-family:var(--sans);font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;
  padding:.45rem 1rem;border:1px solid var(--stone);border-radius:2px;
  color:var(--ink-soft);background:rgba(255,255,255,.6);
  white-space:nowrap;
}
/* Bandeau réassurance express — Proposal 2 */
.intro-reassure {
  display:flex;flex-wrap:wrap;gap:.45rem 1.4rem;
  margin-bottom:1.6rem;padding:.9rem 1.1rem;
  background:rgba(196,136,42,.06);border-left:2px solid var(--ochre);
}
.intro-reassure span {
  font-family:var(--sans);font-size:.68rem;letter-spacing:.06em;
  color:var(--ink-soft);display:flex;align-items:center;gap:.38rem;
  white-space:nowrap;
  /* état initial — invisible avant l'animation */
  opacity:0;
  transform:translateY(10px) scale(.92);
  transition:opacity .45s var(--ease), transform .45s var(--ease);
}
/* Déclenchement au scroll — chaque chip décalé */
.intro-reassure.vis span:nth-child(1) { opacity:1;transform:none;transition-delay:.08s; }
.intro-reassure.vis span:nth-child(2) { opacity:1;transform:none;transition-delay:.22s; }
.intro-reassure.vis span:nth-child(3) { opacity:1;transform:none;transition-delay:.36s; }
.intro-reassure.vis span:nth-child(4) { opacity:1;transform:none;transition-delay:.50s; }

.intro-cta-row { display:flex;gap:1rem;align-items:center;margin-top:2.5rem; }
.btn-fill { display:inline-block;font-family:var(--sans);font-size:.65rem;letter-spacing:.22em;text-transform:uppercase;padding:.85rem 2rem;background:var(--ink);color:var(--white);border:none;cursor:pointer;transition:background .3s;position:relative;overflow:hidden; }
.btn-fill::after { content:'';position:absolute;inset:0;background:var(--ochre);transform:translateX(-105%);transition:transform .5s var(--ease); }
.btn-fill:hover::after { transform:translateX(0); }
.btn-fill span { position:relative;z-index:1; }
.btn-line { display:inline-block;font-family:var(--sans);font-size:.65rem;letter-spacing:.22em;text-transform:uppercase;padding:.85rem 2rem;background:transparent;color:var(--ink);border:1px solid var(--stone);cursor:pointer;transition:border-color .3s,color .3s; }
.btn-line:hover { border-color:var(--ink); }
.intro-vis { opacity:0;transform:translateX(35px);transition:opacity 1s var(--ease) .15s,transform 1s var(--ease) .15s; }
.intro-vis.vis { opacity:1;transform:translateX(0); }
.intro-main-img { aspect-ratio:3/4; }
.intro-badge { position:absolute;bottom:-1.5rem;left:-1.5rem;background:var(--ink);color:var(--white);padding:1.4rem 1.6rem;text-align:center;min-width:110px; }
.intro-badge-n { font-family:var(--serif);font-size:2.4rem;line-height:1; }
.intro-badge-l { font-size:.55rem;letter-spacing:.2em;text-transform:uppercase;color:rgba(253,252,250,.45);margin-top:.3rem; }
.intro-vis-wrap { position:relative; }

/* ════════════════════════════════════════
   ROOMS — INTERACTIVE SELECTOR
════════════════════════════════════════ */
#rooms { background:var(--cream);padding:4rem 0 0; }
#rooms .s-head { padding:0 4rem 0.5rem; }

/* ── Note intro chambres ── */
.rooms-intro-note {
  font-size:1rem;line-height:1.85;
  color:var(--muted);
  padding:0 4rem 2.5rem;
  max-width:680px;
}

/* Layout : liste à gauche, photo à droite */
.ri-wrap {
  display:grid;
  grid-template-columns:1fr 1fr;
  min-height:80vh;
  border-top:1px solid var(--stone);
}

/* Liste */
.ri-list {
  border-right:1px solid var(--stone);
  padding:0;
  display:flex;flex-direction:column;
}
.ri-item {
  display:flex;align-items:center;gap:2rem;
  padding:1.5rem 4rem;
  border-bottom:1px solid var(--stone);
  cursor:pointer;
  position:relative;
  transition:background .25s,padding-left .3s var(--ease);
}
.ri-item:hover { background:rgba(196,136,42,.04); }
.ri-item-n {
  font-family:var(--serif);font-size:.72rem;
  color:var(--stone);min-width:1.8rem;
  transition:color .25s;
}
.ri-item-name {
  font-family:var(--serif);font-size:1.55rem;font-weight:400;
  color:var(--muted);line-height:1;
  flex:1;
  transition:color .25s var(--ease);
}
.ri-item-type {
  margin-left:auto;font-size:.58rem;letter-spacing:.2em;
  text-transform:uppercase;color:var(--stone);
  white-space:nowrap;
  opacity:0;transform:translateX(6px);
  transition:opacity .25s,transform .25s;
}
.ri-item-meta {
  font-size:.58rem;letter-spacing:.2em;
  text-transform:uppercase;color:var(--ochre);
  white-space:nowrap;opacity:.7;
  margin-left:auto;
}
.ri-item-bar {
  position:absolute;left:0;top:0;bottom:0;
  width:2px;background:var(--ochre);
  transform:scaleY(0);transform-origin:top;
  transition:transform .35s var(--ease);
}
/* État actif */
.ri-item.active { background:rgba(196,136,42,.05);padding-left:4.3rem; }
.ri-item.active .ri-item-n    { color:var(--ochre); }
.ri-item.active .ri-item-name { color:var(--ink); }
.ri-item.active .ri-item-type { opacity:1;transform:translateX(0); }
.ri-item.active .ri-item-bar  { transform:scaleY(1); }

/* Photo */
.ri-photos { position:relative;overflow:hidden; }
.ri-photo {
  position:absolute;inset:0;
  opacity:0;transition:opacity .6s var(--ease);
  will-change:opacity;
}
.ri-photo img {
  width:100%;height:100%;object-fit:cover;
  transition:transform .8s var(--ease);
}
.ri-photo.active { opacity:1; }
.ri-photo.active img { transform:scale(1.04); }
.ri-photo-num {
  position:absolute;top:1.5rem;left:1.5rem;z-index:2;
  font-family:var(--serif);font-size:.8rem;font-weight:300;
  color:rgba(253,252,250,.55);letter-spacing:.08em;
}
.ri-photo-cap {
  position:absolute;bottom:2rem;left:2rem;right:2rem;z-index:2;
  opacity:0;transform:translateY(8px);
  transition:opacity .45s var(--ease) .1s,transform .45s var(--ease) .1s;
}
.ri-photo.active .ri-photo-cap { opacity:1;transform:translateY(0); }
.ri-photo-name {
  font-family:var(--serif);font-size:2rem;font-weight:300;
  color:var(--white);line-height:1;margin-bottom:.35rem;
}
.ri-photo-type {
  font-size:.58rem;letter-spacing:.28em;text-transform:uppercase;
  color:rgba(253,252,250,.5);
}
.ri-photo-amenities {
  font-size:.68rem;line-height:1.7;
  color:rgba(253,252,250,.65);
  margin-top:.4rem;
}

/* ════════════════════════════════════════
   PARALLAX QUOTE
════════════════════════════════════════ */
#pq { position:relative;height:75vh;overflow:hidden;display:flex;align-items:center;justify-content:center; }
.pq-bg { position:absolute;inset:-20%;will-change:transform; }
.pq-bg img { object-position:center 20%; }
.pq-overlay { position:absolute;inset:0;background:rgba(26,20,16,.45); }
.pq-body { position:relative;z-index:2;text-align:center;padding:2rem;max-width:800px; }
.pq-body blockquote { font-family:var(--display);font-size:clamp(1.4rem,2.4vw,2.4rem);font-weight:400;font-style:normal;color:var(--white);line-height:1.35;opacity:0;transform:translateY(24px);transition:opacity 1s var(--ease),transform 1s var(--ease); }
.pq-body blockquote.vis { opacity:1;transform:translateY(0); }
.pq-body cite { display:block;margin-top:2rem;font-family:var(--sans);font-style:normal;font-size:.6rem;letter-spacing:.38em;text-transform:uppercase;color:rgba(253,252,250,.45);opacity:0;transition:opacity .9s var(--ease) .35s; }
.pq-body cite.vis { opacity:1; }

/* ════════════════════════════════════════
   PROCESS — IPHONE MOCKUP
════════════════════════════════════════ */
/* ════════════════════════════════════════
   EXPÉRIENCE DIGITALE — sticky scroll
════════════════════════════════════════ */
/* Section 100vh — le JS intercepte le wheel et bloque le scroll */
#process {
  position: relative;
  background: #3b0d14;
  height: 100vh;
  will-change: auto;
}

.exp-sticky {
  height: 100%;
  display: grid;
  grid-template-columns: 1fr 90px 1fr;
  overflow: hidden;
  background: #3b0d14;
}

/* ══ Gauche : téléphone ══ */
.exp-phone-side {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 4rem 3rem 4rem 6rem;
}

.exp-phone {
  position: relative;
  width: clamp(180px, 20vw, 260px);
  max-height: 74vh;          /* ne dépasse jamais la section */
  aspect-ratio: 9 / 19.5;
  border-radius: 36px;
  border: 6px solid #1c1c1e;
  overflow: hidden;
  box-shadow:
    inset 0 0 0 1.5px rgba(255,255,255,.12),
    0 40px 100px rgba(26,20,16,.22),
    0 8px 32px rgba(26,20,16,.10);
  flex-shrink: 0;
}

.exp-phone-notch {
  position: absolute;
  top: 10px; left: 50%;
  transform: translateX(-50%);
  width: 60px; height: 14px;
  background: #1c1c1e;
  border-radius: 12px;
  z-index: 10;
}

/* Images crossfade à l'intérieur du téléphone */
.exp-phone-img {
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: top center;  /* screenshots : haut de l'écran prioritaire */
  opacity: 0;
  transition: opacity .8s cubic-bezier(0.4,0,0.2,1);
}
.exp-phone-img.active { opacity: 1; }

/* ══ Centre : ligne verticale + cercle ══ */
.exp-mid-col {
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 0;
}
.exp-mid-line {
  flex: 1;
  width: 1px;
  background: rgba(255,255,255,.15);
}
.exp-circle {
  width: 62px;
  height: 62px;
  border-radius: 50%;
  border: 1px solid rgba(255,255,255,.3);
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--serif);
  font-size: 1.4rem;
  font-weight: 300;
  color: var(--white);
  flex-shrink: 0;
  background: rgba(255,255,255,.05);
  transition: transform .38s cubic-bezier(0.34,1.56,0.64,1),
              border-color .4s var(--ease);
}
.exp-circle.bump {
  transform: scale(1.15);
  border-color: var(--ochre);
}

/* ══ Droite : texte ══ */
/* Cercle mobile masqué par défaut (desktop) */
.exp-mobile-circle { display:none; }

.exp-text-side {
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding: 4rem 6rem 4rem 3rem;
  gap: 3.5rem;
}

.exp-eyebrow {
  font-size: .6rem;
  letter-spacing: .42em;
  text-transform: uppercase;
  color: var(--ochre);
  font-family: var(--sans);
}
.exp-h {
  font-family: var(--serif);
  font-size: clamp(1.5rem,2.5vw,2rem);
  font-weight: 400;
  line-height: 1.25;
  color: var(--white);
  margin-top: .6rem;
}
.exp-h em { font-style:italic; color:var(--ochre-lt); }
.exp-reassure-note {
  font-family:var(--sans);font-size:.65rem;letter-spacing:.06em;
  color:rgba(253,252,250,.45);margin-top:1.4rem;
}
.exp-reassure-note strong { color:rgba(253,252,250,.75);font-weight:500; }

/* Slot : étapes superposées, une seule visible */
.exp-slot {
  position: relative;
  min-height: 260px;
}
.exp-text-step {
  position: absolute;
  top: 0; left: 0; right: 0;
  opacity: 0;
  transform: translateY(60px);   /* entre depuis le bas */
  transition: opacity .6s var(--ease), transform .6s var(--ease);
  pointer-events: none;
}
.exp-text-step.active {
  opacity: 1;
  transform: translateY(0);
  pointer-events: auto;
}
.exp-text-step.leaving {
  opacity: 0;
  transform: translateY(-50px);  /* sort vers le haut */
  transition: opacity .45s var(--ease), transform .45s var(--ease);
}

.exp-step-h {
  font-family: var(--display);
  font-size: clamp(1.4rem, 2vw, 2.1rem);
  font-weight: 400;
  line-height: 1.3;
  color: var(--white);
  margin-bottom: 1.4rem;
}
.exp-step-h em { font-style: italic; color: var(--ochre-lt); }

.exp-step-p {
  font-size: 1.02rem;
  line-height: 1.9;
  color: rgba(253,252,250,.65);
  max-width: 400px;
}

/* ── Indicateur bas ── */
.exp-dots { display: flex; gap: 1.6rem; }

.exp-dot {
  font-family: var(--sans);
  font-size: .58rem;
  letter-spacing: .2em;
  color: rgba(255,255,255,.2);
  cursor: default;
  transition: color .4s var(--ease);
  position: relative;
}
.exp-dot::after {
  content: '';
  position: absolute;
  bottom: -5px; left: 0; right: 0;
  height: 1px;
  background: var(--ochre);
  transform: scaleX(0);
  transition: transform .4s var(--ease);
  transform-origin: left;
}
.exp-dot.active { color: rgba(255,255,255,.9); }
.exp-dot.active::after { transform: scaleX(1); }

/* ════════════════════════════════════════
   SPLIT DARK
════════════════════════════════════════ */
#split { background:var(--ink);display:grid;grid-template-columns:1fr 1fr; }
.split-img { position:relative;min-height:640px;overflow:hidden; }
.split-img-inner { position:absolute;inset:-15%;will-change:transform; }
.split-copy { padding:7rem 5rem;display:flex;flex-direction:column;justify-content:center; }
.split-eyebrow { display:inline-flex;align-items:center;gap:.75rem;font-size:.6rem;letter-spacing:.5em;text-transform:uppercase;color:var(--ochre);margin-bottom:2rem; }
.split-eyebrow::before { content:'';width:22px;height:1px;background:var(--ochre); }
.split-h2 { font-family:var(--display);font-size:clamp(1.5rem,2.2vw,2.3rem);font-weight:400;line-height:1.35;color:var(--white);margin-bottom:1.75rem; }
.split-h2 em { font-style:italic;color:var(--ochre-lt); }
.split-p { font-size:1rem;line-height:2;color:rgba(237,232,223,.72);max-width:400px;margin-bottom:2.5rem; }
.split-list { list-style:none;display:flex;flex-direction:column;gap:1rem;margin-bottom:3rem; }
.split-list li { display:flex;align-items:flex-start;gap:.9rem;font-size:.92rem;line-height:1.65;color:rgba(237,232,223,.72);opacity:0;transform:translateX(20px);transition:opacity .7s var(--ease),transform .7s var(--ease); }
.split-list li.vis { opacity:1;transform:translateX(0); }
.split-list li::before { content:'';width:16px;height:1px;background:var(--ochre);flex-shrink:0;margin-top:.6rem; }
.split-btn { display:inline-block;font-family:var(--sans);font-size:.65rem;letter-spacing:.22em;text-transform:uppercase;padding:.85rem 2rem;border:1px solid rgba(237,232,223,.2);color:var(--white);transition:border-color .3s,background .3s;cursor:pointer; }
.split-btn:hover { border-color:rgba(237,232,223,.5);background:rgba(237,232,223,.05); }
.split-copy-anim { opacity:0;transform:translateX(30px);transition:opacity 1s var(--ease),transform 1s var(--ease); }
.split-copy-anim.vis { opacity:1;transform:translateX(0); }
.split-img-anim { opacity:0;transition:opacity 1.2s var(--ease); }
.split-img-anim.vis { opacity:1; }

/* ════════════════════════════════════════
   CAFE
════════════════════════════════════════ */
#cafe { padding:8rem 4rem;background:var(--linen);display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:center; }
.cafe-vis { opacity:0;transform:translateX(-30px);transition:opacity 1s var(--ease),transform 1s var(--ease); }
.cafe-vis.vis { opacity:1;transform:translateX(0); }
.cafe-img-wrap { position:relative; }
.cafe-img-main { aspect-ratio:4/3;overflow:hidden; }
.cafe-img-main img { transition:transform .8s var(--ease); }
.cafe-img-main:hover img { transform:scale(1.04); }
.cafe-img-float { position:absolute;bottom:-2.5rem;right:-2.5rem;width:200px;aspect-ratio:3/4;overflow:hidden;border:4px solid var(--linen); }
.cafe-copy { opacity:0;transform:translateX(30px);transition:opacity 1s var(--ease) .15s,transform 1s var(--ease) .15s; }
.cafe-copy.vis { opacity:1;transform:translateX(0); }
.cafe-hours { display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin:2rem 0;padding:1.5rem;background:var(--white);border:1px solid var(--stone); }
.cafe-hours-item .day { font-size:.6rem;letter-spacing:.25em;text-transform:uppercase;color:var(--muted);margin-bottom:.25rem; }
.cafe-hours-item .time { font-family:var(--serif);font-size:1.1rem;color:var(--ink); }

/* ════════════════════════════════════════
   REASSURANCE FAQ
════════════════════════════════════════ */
#reassure {
  background:var(--ink);
  padding:clamp(4rem,8vw,7rem) clamp(1.5rem,5vw,7rem);
}
#reassure .s-head { margin-bottom:0; }
#reassure .s-eyebrow { color:var(--ochre-lt); }
#reassure .s-title   { color:var(--ochre-lt); }
#reassure .s-rule    { background:rgba(232,184,101,.4); }
.reassure-grid {
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:1px;
  max-width:960px;
  margin:3rem auto 0;
  background:rgba(255,255,255,.07);
}
.reassure-card {
  background:var(--ink);
  padding:2.2rem 2rem;
  transition:background .3s;
}
.reassure-card:hover { background:rgba(255,255,255,.03); }
.reassure-icon {
  font-size:1.4rem;
  margin-bottom:.75rem;
  line-height:1;
}
.reassure-q {
  font-family:var(--serif);
  font-size:clamp(1.2rem,1.6vw,1.45rem);
  font-style:italic;
  color:var(--white);
  margin-bottom:.75rem;
  line-height:1.35;
}
.reassure-a {
  font-size:clamp(1rem,1.2vw,1.15rem);
  line-height:1.85;
  color:rgba(253,252,250,.65);
}
@media(max-width:640px) {
  .reassure-grid { grid-template-columns:1fr; }
}

/* ════════════════════════════════════════
   GALLERY MARQUEE
════════════════════════════════════════ */
#gallery { padding:8rem 0;background:var(--white);overflow:hidden; }
#gallery .s-head { padding:0 4rem; }
.mq-wrap { overflow:hidden; }
.mq-track { display:flex;gap:3px;width:max-content;animation:marquee 24s linear infinite; }
.mq-track.rev { animation-direction:reverse;animation-duration:30s;margin-top:3px; }
.mq-track:hover { animation-play-state:paused; }
.mq-item { width:370px;height:270px;overflow:hidden;flex-shrink:0;position:relative;display:block;cursor:pointer; }
.mq-item img { transition:transform .7s var(--ease); }
.mq-item:hover img { transform:scale(1.07); }


/* ════════════════════════════════════════
   BOOKING
════════════════════════════════════════ */
#booking { padding:8rem 4rem;background:var(--cream); }
.bk-wrap { max-width:1000px;margin:0 auto; }
.bk-form { margin-top:3.5rem;background:var(--white);border:1px solid var(--stone);opacity:0;transform:translateY(22px);transition:opacity .8s var(--ease) .2s,transform .8s var(--ease) .2s; }
.bk-form.vis { opacity:1;transform:translateY(0); }
.bk-grid { display:grid;grid-template-columns:repeat(4,1fr) auto; }
.bk-field { padding:1.75rem 1.5rem;border-right:1px solid var(--linen);position:relative; }
.bk-lbl { display:block;font-size:.58rem;letter-spacing:.3em;text-transform:uppercase;color:var(--ochre);margin-bottom:.55rem; }
.bk-in,.bk-sel { width:100%;background:transparent;border:none;outline:none;font-family:var(--serif);font-size:1.1rem;color:var(--ink);border-bottom:1px solid var(--stone);padding:.2rem 0;transition:border-color .3s;-webkit-appearance:none; }
.bk-in:focus,.bk-sel:focus { border-color:var(--ochre); }
.bk-submit { padding:0 2.5rem;background:var(--ink);color:var(--white);border:none;cursor:pointer;font-family:var(--sans);font-size:.62rem;letter-spacing:.2em;text-transform:uppercase;white-space:nowrap;transition:background .3s; }
.bk-submit:hover { background:var(--ochre); }

/* ════════════════════════════════════════
   ROOM LIST — CTA LABEL
════════════════════════════════════════ */
.ri-item-cta {
  margin-left:auto;
  font-size:.55rem;letter-spacing:.22em;text-transform:uppercase;
  color:var(--ochre);opacity:0;
  transition:opacity .3s var(--ease);
  white-space:nowrap;
}
.ri-item:hover .ri-item-cta,
.ri-item.active .ri-item-cta { opacity:1; }

/* ════════════════════════════════════════
   ROOM DETAIL PANEL
════════════════════════════════════════ */
#room-panel {
  position:fixed;inset:0;z-index:10000;
  display:flex;align-items:stretch;
  pointer-events:none;
  visibility:hidden;
}
#room-panel.open { pointer-events:all; visibility:visible; }
#room-panel-overlay {
  position:absolute;inset:0;
  background:rgba(26,20,16,.6);
  backdrop-filter:blur(3px);
  opacity:0;transition:opacity .5s var(--ease);
}
#room-panel.open #room-panel-overlay { opacity:1; }
#room-panel-inner {
  position:relative;
  margin:auto;
  width:min(1100px,96vw);
  max-height:92vh;
  background:var(--cream);
  display:grid;
  grid-template-columns:1fr 1fr;
  overflow:hidden;
  transform:translateY(40px);
  opacity:0;
  transition:transform .55s var(--ease),opacity .55s var(--ease);
}
#room-panel.open #room-panel-inner { transform:translateY(0);opacity:1; }
#room-panel-close {
  position:absolute;top:1.25rem;right:1.25rem;z-index:2;
  width:38px;height:38px;
  background:var(--cream);border:1px solid var(--stone);
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;color:var(--ink);
  transition:background .3s,color .3s;
}
#room-panel-close:hover { background:var(--ink);color:var(--white); }
#room-panel-left {
  position:relative;overflow:hidden;min-height:500px;
}
#room-panel-left > img {
  position:absolute;inset:0;width:100%;height:100%;object-fit:cover;
  transition:transform .8s var(--ease);
}
#room-panel.open #room-panel-left > img { transform:scale(1.03); }
#room-panel-img2-wrap {
  position:absolute;bottom:1.5rem;right:1.5rem;
  width:130px;height:170px;overflow:hidden;
  border:3px solid var(--cream);
  box-shadow:0 8px 30px rgba(0,0,0,.25);
}
#room-panel-img2 { width:100%;height:100%;object-fit:cover; }
#room-panel-right {
  padding:3.5rem 3rem;
  overflow-y:auto;
  display:flex;flex-direction:column;
  gap:1rem;
}
#room-panel-eyebrow {
  font-size:.58rem;letter-spacing:.4em;text-transform:uppercase;
  color:var(--ochre);
}
#room-panel-name {
  font-family:var(--display);font-size:clamp(1.5rem,2.4vw,2.2rem);
  font-weight:400;line-height:1.25;color:var(--ink);
}
#room-panel-subtitle {
  font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;
  color:var(--muted);
}
#room-panel-rule {
  width:40px;height:1px;background:var(--ochre);margin:.25rem 0;
}
#room-panel-desc {
  font-size:1rem;line-height:1.85;color:var(--ink-soft);
}
#room-panel-amenities {
  list-style:none;
  display:grid;grid-template-columns:1fr 1fr;
  gap:.55rem .5rem;
  margin-top:.25rem;
}
#room-panel-amenities li {
  font-size:.75rem;color:var(--ink-soft);
  display:flex;align-items:center;gap:.5rem;
}
#room-panel-amenities li::before {
  content:'';width:14px;height:1px;background:var(--ochre);flex-shrink:0;
}
#room-panel-price-row {
  margin-top:auto;padding-top:1.5rem;
  border-top:1px solid var(--stone);
  display:flex;align-items:center;justify-content:space-between;gap:1rem;
  flex-wrap:wrap;
}
#room-panel-price {
  font-family:var(--serif);font-size:1.9rem;font-weight:400;color:var(--ink);
}
#room-panel-price-note {
  font-size:.62rem;letter-spacing:.18em;text-transform:uppercase;
  color:var(--muted);margin-top:.15rem;
}
#room-panel-cta {
  display:inline-block;
  font-size:.65rem;letter-spacing:.22em;text-transform:uppercase;
  padding:.9rem 2.2rem;
  background:var(--ink);color:var(--white);
  border:1px solid var(--ink);
  transition:background .3s,color .3s,border-color .3s;
  white-space:nowrap;
}
#room-panel-cta:hover { background:var(--ochre);border-color:var(--ochre); }

/* ════════════════════════════════════════
   TESTIMONIALS — GLASS SWIPER (21st.dev)
════════════════════════════════════════ */
#testi {
  padding:8rem 4rem;
  background:var(--ink);
  overflow:hidden;
}
#testi .s-eyebrow { color:rgba(253,252,250,.35); }
#testi .s-title   { color:var(--white); }
#testi .s-rule    { background:rgba(196,136,42,.4); }

/* Carousel testimonials */
.testi-stack {
  position:relative;
  margin:4rem 0 0;
  overflow:hidden;
  /* height set by JS to tallest card */
}

.t-card {
  position:absolute;
  top:0;
  left:50%;
  width:clamp(280px,62%,600px);
  margin-left:clamp(-300px,-31%,-140px); /* -width/2 to center */
  border-radius:16px;
  cursor:grab;
  user-select:none;
  -webkit-user-select:none;
  transition:transform .52s cubic-bezier(.25,.46,.45,.94),
             opacity   .45s cubic-bezier(.25,.46,.45,.94);
  /* Glass effect */
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.12);
  box-shadow:0 4px 24px rgba(0,0,0,.4),
             inset 0 1px 0 rgba(255,255,255,.08);
  backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  padding:2.4rem;
  /* All cards same height — text grows to fill */
  display:flex;
  flex-direction:column;
}
.t-card.no-transition { transition:none; }

.t-stars { display:flex;gap:3px;margin-bottom:1.2rem; }
.t-stars span { color:var(--ochre-lt);font-size:.85rem; }

.t-text {
  font-family:var(--body);font-size:1.25rem;font-style:italic;line-height:1.8;
  color:rgba(253,252,250,.85);margin-bottom:1.8rem;
  flex:1; /* pousse l'auteur en bas — toutes les cartes ont la même hauteur */
}
.t-sep { height:1px;background:rgba(255,255,255,.1);margin-bottom:1.4rem; }
.t-who { display:flex;align-items:center;gap:.85rem; }
.t-av {
  width:42px;height:42px;border-radius:50%;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;
  font-family:var(--serif);font-size:.95rem;color:var(--white);font-weight:500;
}
.t-name { font-size:.82rem;color:rgba(253,252,250,.9); }
.t-stay { font-size:.6rem;color:rgba(253,252,250,.38);margin-top:.2rem;letter-spacing:.1em; }

/* Pagination dots — outside stack */
.testi-dots {
  display:flex;justify-content:center;gap:.5rem;
  margin-top:2.2rem;
}
.testi-dot {
  width:6px;height:6px;border-radius:999px;
  background:rgba(255,255,255,.22);
  border:none;padding:0;cursor:pointer;
  transition:width .3s ease,background .3s ease;
}
.testi-dot.on { width:20px;background:var(--ochre); }
.testi-dot:hover:not(.on) { background:rgba(255,255,255,.45); }

/* ════════════════════════════════════════
   NEWSLETTER
════════════════════════════════════════ */
#nl { padding:6rem 4rem;background:var(--linen);display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center; }
.nl-copy h2 { font-family:var(--display);font-size:clamp(1.6rem,2.8vw,2.6rem);font-weight:400;line-height:1.3;color:var(--ink); }
.nl-copy h2 em { font-style:italic;color:var(--ochre); }
.nl-copy p { font-size:.95rem;line-height:1.85;color:var(--muted);margin-top:1rem; }
.nl-form-wrap { display:flex;flex-direction:column;gap:.75rem; }
.nl-form { display:flex;border:1px solid var(--stone);overflow:hidden;background:var(--white); }
.nl-in { flex:1;background:transparent;border:none;outline:none;padding:1.1rem 1.5rem;font-family:var(--sans);font-size:.87rem;color:var(--ink); }
.nl-in::placeholder { color:var(--stone); }
.nl-btn { padding:1.1rem 1.8rem;background:var(--ink);color:var(--white);border:none;cursor:pointer;font-family:var(--sans);font-size:.62rem;letter-spacing:.2em;text-transform:uppercase;transition:background .3s; }
.nl-btn:hover { background:var(--ochre); }
.nl-note { font-size:.65rem;color:var(--muted); }

/* ════════════════════════════════════════
   FOOTER
════════════════════════════════════════ */
footer { background:var(--ink);padding:5.5rem 4rem 2.5rem; padding-bottom:max(2.5rem, calc(env(safe-area-inset-bottom) + 1.5rem)); }
.ft-top { display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:4rem;padding-bottom:4rem;border-bottom:1px solid rgba(255,255,255,.08); }
.ft-brand img { height:60px;width:auto;margin-bottom:1.5rem; }
.ft-brand p { font-size:.82rem;line-height:1.85;color:rgba(237,232,223,.38);max-width:260px; }
.ft-contact { font-size:.78rem;line-height:1.9;color:rgba(237,232,223,.35);margin-top:1rem; }
.ft-contact a { color:rgba(237,232,223,.35);transition:color .3s; }
.ft-contact a:hover { color:var(--ochre-lt); }
.ft-socials { display:flex;gap:.5rem;margin-top:1.5rem; }
.ft-soc { width:36px;height:36px;border:1px solid rgba(255,255,255,.12);border-radius:50%;display:flex;align-items:center;justify-content:center;color:rgba(237,232,223,.4);transition:border-color .3s,color .3s; }
.ft-soc svg { width:16px;height:16px; }
.ft-soc:hover { border-color:var(--ochre);color:var(--ochre-lt); }
.ft-col h4 { font-size:.58rem;letter-spacing:.32em;text-transform:uppercase;color:var(--ochre);margin-bottom:1.4rem; }
.ft-col ul { list-style:none;display:flex;flex-direction:column;gap:.6rem; }
.ft-col a { font-size:.8rem;color:rgba(237,232,223,.38);transition:color .3s,padding-left .3s; }
.ft-col a:hover { color:var(--white);padding-left:.4rem; }
.ft-bottom { display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:.5rem;padding-top:2rem;font-size:.68rem;color:rgba(237,232,223,.25); }
.ft-archi { font-size:.68rem;color:rgba(237,232,223,.25); }
.ft-archi em { font-style:italic;color:rgba(196,136,42,.55); }
.ft-bottom a { color:rgba(237,232,223,.25);transition:color .3s; }
.ft-bottom a:hover { color:rgba(237,232,223,.6); }
.ft-links { display:flex;gap:2rem; }

/* ════════════════════════════════════════
   BTT
════════════════════════════════════════ */
#btt { position:fixed;bottom:max(1.75rem, calc(env(safe-area-inset-bottom) + 1rem));right:1.75rem;z-index:1000;width:44px;height:44px;border:1px solid var(--stone);background:rgba(253,252,250,.9);display:flex;align-items:center;justify-content:center;font-size:.9rem;color:var(--ink);cursor:pointer;opacity:0;transform:translateY(8px);transition:opacity .4s,transform .4s,border-color .3s;backdrop-filter:blur(10px); }
#btt.vis { opacity:1;transform:translateY(0); }
#btt:hover { border-color:var(--ink); }

/* ════════════════════════════════════════
   KEYFRAMES
════════════════════════════════════════ */
@keyframes fadeUp    { from{opacity:0;transform:translateY(20px)} to{opacity:1;transform:translateY(0)} }
@keyframes fadeIn    { to{opacity:1;} }
@keyframes scrollPulse { 0%,100%{transform:scaleY(1);transform-origin:top} 50%{transform:scaleY(.4);transform-origin:top} }
@keyframes marquee   { from{transform:translateX(0)} to{transform:translateX(-50%)} }
@keyframes ticker    { from{transform:translateX(0)} to{transform:translateX(-50%)} }

/* ════════════════════════════════════════
   STACKED PANEL CARDS — depth transitions
   Each section is a "card" that slides over
   the previous one. JS drives scale-back
   and image parallax.
════════════════════════════════════════ */
#hero { z-index:1; }

/* Shared card shape for all sections after hero (home page only) */
#intro, #process, #rooms, #testi, #gallery, #nl {
  position:relative;
  border-radius:28px 28px 0 0;
  will-change:transform;
}
/* Footer gets card shape only on home (other pages: flat flush) */
.home footer {
  border-radius:28px 28px 0 0;
  will-change:transform;
}

/* Per-section z-index + shadow depth (darker sections cast deeper shadows) */
#intro   { z-index:2; overflow:hidden; box-shadow:0 -20px 80px rgba(26,14,8,.14); }
#process { z-index:3; will-change:auto; box-shadow:0 -20px 80px rgba(26,14,8,.22); }
/* ↑ will-change:auto sur #process : annule will-change:transform pour que
   position:sticky fonctionne sur .exp-sticky (transform casse le sticky) */
#rooms   { z-index:4; overflow:hidden; box-shadow:0 -20px 80px rgba(26,14,8,.16); }
#testi   { z-index:5;                  box-shadow:0 -20px 80px rgba(26,14,8,.26); }
#gallery { z-index:6;                  box-shadow:0 -20px 80px rgba(26,14,8,.14); }
#nl      { z-index:7; overflow:hidden; box-shadow:0 -20px 80px rgba(26,14,8,.20); }
footer   { z-index:8; overflow:hidden; box-shadow:0 -20px 80px rgba(26,14,8,.30); }
.home footer { position:relative; }

/* Intro hero image — pre-scaled to allow Y travel without empty edges */
.intro-main-img img { transform:scale(1.22); will-change:transform; }

/* ════════════════════════════════════════
   LANGUAGE PICKER
════════════════════════════════════════ */
#lang-picker { position:relative; }
#lang-btn {
  display:flex;align-items:center;gap:5px;
  background:transparent;
  border:1px solid rgba(253,252,250,.22);
  color:rgba(253,252,250,.65);
  font-family:var(--sans);font-size:.54rem;letter-spacing:.18em;text-transform:uppercase;
  padding:.42rem .7rem;border-radius:3px;cursor:pointer;
  transition:border-color .3s,color .3s;white-space:nowrap;
}
#lang-btn:hover { border-color:rgba(253,252,250,.55); color:var(--white); }
.lang-chevron { width:9px;height:9px;flex-shrink:0;transition:transform .25s var(--ease); }
#lang-picker.open .lang-chevron { transform:rotate(180deg); }
#lang-dropdown {
  position:absolute;top:calc(100% + 8px);right:0;
  background:var(--ink);
  border:1px solid rgba(253,252,250,.1);
  border-radius:8px;overflow:hidden;
  opacity:0;visibility:hidden;
  transform:translateY(-6px);
  transition:opacity .2s var(--ease),transform .2s var(--ease),visibility .2s;
  min-width:148px;
  box-shadow:0 10px 40px rgba(0,0,0,.45);
  z-index:2000;
}
#lang-picker.open #lang-dropdown { opacity:1;visibility:visible;transform:translateY(0); }
.lang-opt {
  display:flex;align-items:center;gap:10px;
  width:100%;padding:.65rem 1rem;
  background:transparent;border:none;
  color:rgba(253,252,250,.55);
  font-family:var(--sans);font-size:.6rem;letter-spacing:.14em;text-transform:uppercase;
  cursor:pointer;transition:background .2s,color .2s;text-align:left;
}
.lang-opt:hover { background:rgba(255,255,255,.07); color:var(--white); }
.lang-opt.active { color:var(--ochre-lt); }

/* ════════════════════════════════════════
   ASYMMETRIC SCROLL REVEALS
   Inspiré de kakaocorp.com : chaque bloc
   arrive d'une direction différente pour
   briser la symétrie verticale.
   - Colonnes texte  → depuis la GAUCHE
   - Colonnes images → depuis la DROITE
   - Titres          → direction variée + skew
   Tout converge vers transform:none au repos.
════════════════════════════════════════ */

/* Eyebrows : de la gauche plutôt que du bas */
.s-eyebrow { transform: translateX(-55px); }

/* Colonne texte intro : depuis la gauche */
.intro-copy { transform: translateX(-65px); }

/* Colonne image intro : amplifie l'origine droite existante */
.intro-vis  { transform: translateX(80px); }

/* Section chambres ─ liste depuis gauche (déjà), photos depuis droite */
.ri-photos {
  opacity: 0;
  transform: translateX(70px);
  transition: opacity 1s var(--ease) .15s, transform 1s var(--ease) .15s;
}
.ri-photos.vis { opacity: 1; transform: none; }

/* Note sous le titre "Chambres" : glisse depuis la gauche */
.rooms-intro-note {
  opacity: 0;
  transform: translateX(-55px);
  transition: opacity .85s var(--ease) .25s, transform .85s var(--ease) .25s;
}
.rooms-intro-note.vis { opacity: 1; transform: none; }

/* Témoignages : titre depuis la DROITE (eyebrow déjà depuis gauche → opposition) */
#testi .s-title     { transform: translateX(70px); }
#testi .s-title.vis { opacity: 1; transform: none; }

/* Galerie : titre depuis la gauche avec léger skew éditorial */
#gallery .s-title     { transform: translateX(-65px) skewX(2deg); transform-origin: left; }
#gallery .s-title.vis { opacity: 1; transform: none; }

/* Newsletter : translateY — évite le débordement horizontal dans #nl { overflow:hidden } */
.nl-copy {
  opacity: 0;
  transform: translateY(24px);
  transition: opacity 1s var(--ease), transform 1s var(--ease);
}
.nl-copy.vis { opacity: 1; transform: none; }

.nl-form-wrap {
  opacity: 0;
  transform: translateY(24px);
  transition: opacity 1s var(--ease) .22s, transform 1s var(--ease) .22s;
}
.nl-form-wrap.vis { opacity: 1; transform: none; }

/* ════════════════════════════════════════
   RESPONSIVE
════════════════════════════════════════ */
@media(max-width:1100px){
  nav,nav.scrolled { padding-left:1.2rem;padding-right:1rem; }
  .nav-links { display:none; }
  .nav-cta { display:none; }
  .nav-ham { display:flex; justify-self:end; grid-column:3; margin-right:0; }
  /* Sélecteur langue visible et centré sur mobile */
  .nav-right { display:flex; justify-self:center; grid-column:2; justify-content:center; }
  .nav-right .nav-cta { display:none; } /* masque uniquement le bouton Réserver */
  #nav-mob { display:flex; }
  #intro,#cafe,#nl { grid-template-columns:1fr;gap:3rem; }
  #split { grid-template-columns:1fr; }
  .split-img { min-height:400px; }
  .testi-grid { grid-template-columns:1fr;gap:1.5rem; }
  /* Esprit ORA — réduit la photo sur tablette */
  .intro-vis-wrap { max-width:320px; margin:0 auto; }

  /* Process section : plein écran pour le pin GSAP, contenu centré verticalement */
  #process { height:100vh; height:100svh; }
  .exp-sticky { height:100%; align-content:center; grid-template-columns:1fr; padding:1.5rem 2rem; gap:1.5rem; }
  .exp-phone-side { justify-content:center; padding:0; }
  /* Plafonne la hauteur du mockup pour qu'il ne déborde pas de la section */
  .exp-phone { max-height:42svh; }
  /* Masque la colonne du milieu mais affiche le cercle séparément en mobile */
  .exp-mid-col { display:none; }
  /* Cercle visible sur mobile, positionné au-dessus du texte */
  .exp-mobile-circle { display:flex; align-items:center; justify-content:center; margin-bottom:.5rem; }
  .exp-text-side { padding:0 1rem; align-items:center; text-align:center; }
  .exp-slot { min-height:5rem; position:relative; }
  /* Restaure l'animation des étapes sur mobile */
  .exp-text-step { position:absolute; top:0; left:0; right:0;
    opacity:0; transform:translateY(60px);
    transition:opacity .5s var(--ease), transform .5s var(--ease);
    pointer-events:none; }
  .exp-text-step.active { opacity:1; transform:translateY(0); pointer-events:auto; position:relative; }
  .exp-text-step.leaving { opacity:0; transform:translateY(-40px);
    transition:opacity .35s var(--ease), transform .35s var(--ease); }
  .ft-top { grid-template-columns:1fr 1fr;gap:3rem; }
  .bk-grid { grid-template-columns:1fr 1fr; }
  .hbb-inner { flex-wrap:wrap; }
  .hbb-field { flex:1 1 40%;border-bottom:1px solid var(--linen); }
  #sec-dots { display:none; }
}
@media(max-width:640px){
  #intro,#cafe,#testi,#nl,footer { padding:5rem 1.5rem; }
  /* Esprit ORA : réduit encore la photo sur petit mobile */
  .intro-vis-wrap { max-width:240px; }
  .proc-sticky { padding:4rem 1.5rem 3rem; }
  .proc-big-n { font-size:4.5rem; }
  #rooms .s-head,#gallery .s-head { padding:0 1.5rem; }
  .rooms-intro-note { padding:0 1.5rem 2rem; }
  /* Chambres : photo à droite sur mobile */
  .ri-wrap { grid-template-columns:1fr 42%; min-height:auto; }
  .ri-photos { min-height:55vw; position:relative; }
  .ri-list { border-right:1px solid var(--stone); border-bottom:none; }
  .ri-item { padding:.9rem 1rem; gap:.6rem; }
  .ri-item-type { display:none; }
  .ri-item-meta { display:none; }
  .ri-item-n { font-size:.62rem; min-width:1.2rem; }
  .ri-item-name { font-size:1.1rem; }
  /* Gallery : vignettes plus petites */
  .mq-item { width:210px; height:150px; }
  /* Bouton Réserver visible sur mobile — positionné sous le texte */
  .hero-book-bar {
    position:absolute;
    bottom:auto;
    top:62%;
    left:50%;
    transform:translateX(-50%);
    width:auto;
    right:auto;
    background:transparent;
  }
  .hbb-inner--simple { padding:1rem 1.5rem; background:transparent; backdrop-filter:none; border:none; }
  .hbb-inner--simple .hbb-btn {
    padding:.85rem 2.2rem;
    font-size:.6rem;
    background:transparent;
    border:1px solid rgba(253,252,250,.55);
    color:var(--white);
    border-radius:2px;
  }
  .split-copy { padding:4rem 2rem; }
  .bk-grid { grid-template-columns:1fr; }
  .ft-top { grid-template-columns:1fr; }
  .cafe-img-float { display:none; }
  /* Footer simplifié mobile */
  footer { padding:2.5rem 1.5rem 1.5rem; }
  .ft-col { display:none; }
  .ft-top { grid-template-columns:1fr; gap:1rem; padding-bottom:1.5rem; }
  .ft-brand p { display:none; }
  .ft-brand img { height:40px; margin-bottom:.8rem; }
  .ft-bottom { flex-direction:column;align-items:flex-start;gap:.6rem;padding-top:1rem; }
  .ft-links { display:none; }
  /* Exp digitale : iPhone plus petit + texte adapté */
  .exp-phone { width:clamp(88px,25vw,118px); max-height:30svh; }
  .exp-sticky { gap:.8rem; padding:1rem; }
  .exp-text-side { gap:1rem; padding:0 .5rem; }
  .exp-slot { min-height:auto; }
  .exp-h { font-size:clamp(1.2rem,5vw,1.6rem); }
  .exp-step-h { font-size:clamp(1rem,4.5vw,1.3rem); }
  .exp-step-p { font-size:.85rem; line-height:1.7; max-width:100%; }
  /* Dots cliquables plus gros sur mobile */
  .exp-dot { padding:.5rem .3rem; }
}

/* Room panel responsive */
@media(max-width:860px){
  #room-panel-inner { grid-template-columns:1fr;max-height:90vh;overflow-y:auto; }
  #room-panel-left { min-height:55vw;position:relative; }
  #room-panel-right { padding:2.5rem 2rem; }
}
@media(max-width:480px){
  #room-panel-inner { width:100vw;max-height:100dvh; }
  #room-panel-right { padding:2rem 1.5rem; }
  #room-panel-amenities { grid-template-columns:1fr; }
  #room-panel-price-row { flex-direction:column;align-items:flex-start; }
}

/* ════════════════════════════════════════
   PAGE TRANSITIONS
════════════════════════════════════════ */
/* Fade d'entrée sur un wrapper — le body reste sans transform pour ne pas briser position:fixed */
/* Délai de 1.28s = synchronisé avec la phase de transparence du loader (78% de 1.65s)
   → l'image hero apparaît progressivement au moment exact où le fond du loader s'efface */
body { animation: pageFadeIn 0.6s cubic-bezier(0.16,1,0.3,1) 1.28s both; }
@keyframes pageFadeIn { from { opacity:0; } to { opacity:1; } }

/* Wrapper de page : reçoit le translateY sans affecter #cur, nav, loader */
#page-wrap { animation: pageSlideIn 0.65s cubic-bezier(0.16,1,0.3,1) 1.28s both; }
@keyframes pageSlideIn {
  from { opacity:0; transform:translateY(12px); }
  to   { opacity:1; transform:translateY(0); }
}
/* Après l'animation, le JS retire le transform via removeAttribute/style.transform='' */

body.page-out { opacity:0 !important; transition:opacity .3s ease !important; animation:none !important; }
#page-wrap.page-out { transform:translateY(-10px) !important; transition:transform .3s ease !important; animation:none !important; }

/* ════════════════════════════════════════
   PAGE HERO (sous-pages)
════════════════════════════════════════ */
.page-hero { padding:10rem 4rem 5rem; background:var(--ink); text-align:center; }
.page-hero-eyebrow {
  font-size:.58rem; letter-spacing:.5em; text-transform:uppercase; color:var(--ochre);
  display:flex; align-items:center; justify-content:center; gap:.75rem; margin-bottom:1.5rem;
  opacity:0; transform:translateY(14px);
  animation: heroFadeUp .7s cubic-bezier(0.16,1,0.3,1) .3s both;
}
.page-hero-eyebrow::before,.page-hero-eyebrow::after { content:''; width:30px; height:1px; background:var(--ochre); }
.page-hero h1, .page-hero .page-hero-display {
  font-family:var(--display); font-size:clamp(1.8rem,3.2vw,3.4rem); font-weight:400; color:var(--white); line-height:1.3; margin-bottom:1rem; letter-spacing:0.01em;
  opacity:0; transform:translateY(22px);
  animation: heroFadeUp .8s cubic-bezier(0.16,1,0.3,1) .5s both;
}
.page-hero h1 em { font-style:italic; color:var(--ochre-lt); }
.page-hero p {
  font-size:.78rem; letter-spacing:.15em; color:rgba(253,252,250,.4); text-transform:uppercase;
  opacity:0;
  animation: heroFadeUp .7s cubic-bezier(0.16,1,0.3,1) .75s both;
}
@keyframes heroFadeUp {
  from { opacity:0; transform:translateY(18px); }
  to   { opacity:1; transform:translateY(0); }
}
.page-hero-desc { font-size:1rem !important; letter-spacing:0 !important; text-transform:none !important; color:rgba(253,252,250,.6) !important; max-width:600px; margin:1.5rem auto 0; line-height:1.7; }

/* Nav active state */
.nav-links a.nav-active { color:var(--white); }
.nav-links a.nav-active::after { width:100%; }

/* ════════════════════════════════════════
   CONTACT — SECTION PRINCIPALE
════════════════════════════════════════ */
#contact-section {
  position: relative;
  min-height: 100vh;
  overflow: hidden;
  background-color: rgba(26,20,16,1); /* permet au détecteur de curseur de voir le fond sombre */
  display: flex;
  align-items: stretch;
}

/* Fond photo */
.cs-bg {
  position: absolute;
  inset: 0;
  background: url('images/s-nos-services-hero.jpg') center / cover no-repeat;
}
.cs-bg-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(
    110deg,
    rgba(26,20,16,.92) 0%,
    rgba(26,20,16,.75) 50%,
    rgba(26,20,16,.55) 100%
  );
}

/* Bulles animées */
.cs-bubble {
  position: absolute;
  border-radius: 50%;
  background: rgba(212,175,55,.12);
  border: 1px solid rgba(212,175,55,.18);
  animation: csBubble linear infinite;
  opacity: 0;
  pointer-events: none;
}
@keyframes csBubble {
  0%   { transform: translateY(0) translateX(0) scale(.6); opacity:0; }
  15%  { opacity: 1; }
  85%  { opacity: .6; }
  100% { transform: translateY(-110vh) translateX(var(--bx)) scale(1.2); opacity:0; }
}

/* Layout */
.cs-inner {
  position: relative;
  z-index: 10;
  display: grid;
  grid-template-columns: 1fr 1fr;
  width: 100%;
  max-width: 1400px;
  margin: 0 auto;
  padding: 9rem 5rem 6rem;
  gap: 5rem;
  align-items: center;
}

/* ── Gauche ── */
.cs-left { color: var(--white); }
.cs-eyebrow {
  font-size: .55rem;
  letter-spacing: .5em;
  text-transform: uppercase;
  color: var(--ochre);
  margin-bottom: 1.8rem;
  display: flex;
  align-items: center;
  gap: .75rem;
}
.cs-eyebrow::before { content:''; width:24px; height:1px; background:var(--ochre); }
.cs-title {
  font-family: var(--display);
  font-size: clamp(2.2rem, 3.8vw, 4.5rem);
  font-weight: 400;
  line-height: 1.3;
  color: var(--white);
  margin-bottom: 3rem;
  letter-spacing: 0.01em;
}
.cs-title em { font-style: italic; color: var(--ochre-lt, #D4AF37); }

/* Infos */
.cs-info-list { display: flex; flex-direction: column; gap: 1.6rem; margin-bottom: 2.8rem; }
.cs-info-item { display: flex; flex-direction: column; gap: .35rem; }
.cs-info-lbl {
  font-size: .52rem;
  letter-spacing: .4em;
  text-transform: uppercase;
  color: var(--ochre);
}
.cs-info-val {
  font-family: var(--serif);
  font-size: 1rem;
  color: rgba(253,252,250,.8);
  line-height: 1.65;
  text-decoration: none;
  transition: color .2s;
}
a.cs-info-val:hover { color: var(--ochre-lt, #D4AF37); }

/* Réseaux sociaux */
.cs-socials { display: flex; gap: 1rem; }
.cs-soc {
  width: 40px; height: 40px;
  border: 1px solid rgba(255,255,255,.2);
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  color: rgba(255,255,255,.6);
  transition: border-color .3s, color .3s, background .3s;
  text-decoration: none;
}
.cs-soc:hover {
  border-color: var(--ochre);
  color: var(--ochre);
  background: rgba(212,175,55,.08);
}

/* ── Droite : formulaire ── */
.cs-right { display: flex; align-items: stretch; }
.cs-form-card {
  background: rgba(253,252,250,.97);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  border-radius: 4px;
  padding: 3rem 3rem 2.5rem;
  width: 100%;
  box-shadow: 0 30px 80px rgba(0,0,0,.35);
}
.cs-form-title {
  font-family: var(--display);
  font-size: clamp(1.4rem, 2.2vw, 2.2rem);
  font-weight: 400;
  color: var(--ink);
  line-height: 1.35;
  margin-bottom: .6rem;
  letter-spacing: 0.01em;
}
.cs-wave { font-style: normal; font-size: .8em; }
.cs-form-sub {
  font-size: .62rem;
  letter-spacing: .15em;
  text-transform: uppercase;
  color: var(--muted);
  margin-bottom: 2rem;
}

/* Champs */
.cs-form { display: flex; flex-direction: column; gap: 1.2rem; }
.cs-row { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; }
.cs-field { display: flex; flex-direction: column; gap: .45rem; }
.cs-lbl {
  font-size: .52rem;
  letter-spacing: .3em;
  text-transform: uppercase;
  color: var(--ochre);
}
.cs-in {
  font-family: var(--serif);
  font-size: .95rem;
  color: var(--ink);
  background: transparent;
  border: none;
  border-bottom: 1px solid var(--stone, #c8bfb0);
  padding: .6rem 0;
  outline: none;
  width: 100%;
  transition: border-color .3s;
  -webkit-appearance: none;
}
.cs-in:focus { border-color: var(--ochre); }
.cs-in::placeholder { color: rgba(90,80,68,.4); font-style: italic; }
.cs-ta { resize: vertical; min-height: 90px; line-height: 1.7; }

/* Checkboxes */
.cs-checks-group { margin-top: .4rem; }
.cs-checks-lbl {
  font-size: .52rem;
  letter-spacing: .3em;
  text-transform: uppercase;
  color: var(--ochre);
  margin-bottom: .9rem;
}
.cs-checks {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: .55rem .8rem;
}
.cs-check {
  display: flex;
  align-items: center;
  gap: .5rem;
  cursor: pointer;
  font-size: .75rem;
  color: var(--ink);
  line-height: 1.3;
}
.cs-check input[type="checkbox"] {
  width: 14px; height: 14px;
  border: 1px solid var(--stone);
  border-radius: 2px;
  background: transparent;
  appearance: none;
  -webkit-appearance: none;
  cursor: pointer;
  flex-shrink: 0;
  position: relative;
  transition: border-color .2s, background .2s;
}
.cs-check input[type="checkbox"]:checked {
  background: var(--ink);
  border-color: var(--ink);
}
.cs-check input[type="checkbox"]:checked::after {
  content: '';
  position: absolute;
  top: 1px; left: 4px;
  width: 4px; height: 8px;
  border: 1.5px solid var(--white);
  border-top: none; border-left: none;
  transform: rotate(45deg);
}

/* Submit */
.cs-submit {
  margin-top: .6rem;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: .7rem;
  width: 100%;
  padding: 1.05rem 2rem;
  background: var(--ink);
  color: var(--white);
  border: none;
  cursor: pointer;
  font-family: var(--sans);
  font-size: .6rem;
  letter-spacing: .25em;
  text-transform: uppercase;
  transition: background .3s;
  border-radius: 2px;
}
.cs-submit:hover { background: var(--ochre); }

/* Message succès */
.cs-success {
  display: none;
  margin-top: .8rem;
  padding: .8rem 1rem;
  background: rgba(212,175,55,.1);
  border-left: 2px solid var(--ochre);
  font-size: .75rem;
  color: var(--ink);
  letter-spacing: .05em;
}
.cs-success.show { display: block; }

/* Responsive */
@media(max-width:1000px){
  .cs-inner { grid-template-columns:1fr; padding:8rem 3rem 5rem; gap:3rem; }
  .cs-title  { font-size:clamp(2.4rem,6vw,4rem); }
  .cs-info-list { flex-direction:row; flex-wrap:wrap; gap:1.5rem 3rem; }
}
@media(max-width:600px){
  .cs-inner { padding:7rem 1.5rem 4rem; }
  .cs-form-card { padding:2rem 1.5rem; }
  .cs-row { grid-template-columns:1fr; }
  .cs-checks { grid-template-columns:1fr 1fr; }
}

/* ════════════════════════════════════════
   GALERIE
════════════════════════════════════════ */
#galerie { padding:5rem 4rem 8rem; background:var(--white); }

/* Filtres */
.gal-filters {
  display:flex;align-items:center;gap:1rem;
  margin-bottom:3.5rem;flex-wrap:wrap;
}
.gal-filter {
  font-family:var(--sans);font-size:.58rem;letter-spacing:.3em;text-transform:uppercase;
  padding:.55rem 1.4rem;border:1px solid var(--stone);background:transparent;
  color:var(--muted);cursor:pointer;transition:all .3s;
}
.gal-filter.active,.gal-filter:hover {
  background:var(--ink);color:var(--white);border-color:var(--ink);
}

/* Grille masonry CSS */
.gal-grid {
  columns:3;column-gap:1.2rem;
}
.gal-item {
  break-inside:avoid;
  margin-bottom:1.2rem;
  overflow:hidden;
  border-radius:4px;
  cursor:pointer;
  position:relative;
}
.gal-item img {
  width:100%;display:block;
  transition:transform .7s var(--ease);
}
.gal-item:hover img { transform:scale(1.05); }
.gal-item-overlay {
  position:absolute;inset:0;
  background:linear-gradient(to top, rgba(26,20,16,.65) 0%, transparent 55%);
  opacity:0;transition:opacity .4s;
  display:flex;align-items:flex-end;padding:1.2rem;
}
.gal-item:hover .gal-item-overlay { opacity:1; }
.gal-item-label {
  font-size:.52rem;letter-spacing:.3em;text-transform:uppercase;
  color:rgba(253,252,250,.8);
}

/* Lightbox */
/* Lightbox — <dialog> natif */
#gal-dialog {
  padding:0;border:none;outline:none;
  background:transparent;
  max-width:100vw;max-height:100vh;
  width:100vw;height:100vh;
}
/* display:flex uniquement quand la dialog est ouverte — évite d'écraser le display:none du navigateur */
#gal-dialog[open] {
  display:flex;align-items:center;justify-content:center;
}
#gal-dialog::backdrop {
  background:rgba(10,4,2,.93);
}
#gal-dlg-img {
  max-width:90vw;max-height:88vh;
  object-fit:contain;border-radius:4px;
  box-shadow:0 30px 80px rgba(0,0,0,.7);
  transition:opacity .25s ease;
  cursor:zoom-out;display:block;
}
#gal-dlg-close {
  position:fixed;top:1.5rem;right:1.5rem;
  font-size:1.5rem;color:rgba(255,255,255,.6);cursor:pointer;
  background:none;border:none;line-height:1;transition:color .2s;
  z-index:1;
}
#gal-dlg-close:hover { color:#fff; }
#gal-dlg-prev,#gal-dlg-next {
  position:fixed;top:50%;transform:translateY(-50%);
  font-size:2rem;color:rgba(255,255,255,.5);cursor:pointer;
  background:none;border:none;line-height:1;transition:color .2s;
  padding:1rem;z-index:1;
}
#gal-dlg-prev { left:1rem; }
#gal-dlg-next { right:1rem; }
#gal-dlg-prev:hover,#gal-dlg-next:hover { color:#fff; }
#gal-dlg-cap {
  position:fixed;bottom:1.5rem;left:50%;transform:translateX(-50%);
  font-size:.55rem;letter-spacing:.3em;text-transform:uppercase;
  color:rgba(255,255,255,.4);white-space:nowrap;
  font-family:var(--body);
}

@media(max-width:900px){ .gal-grid { columns:2; } }

/* ════════════════════════════════════════
   CHAMBRES — FLIP GALLERY + ROOM CARDS
════════════════════════════════════════ */
#ch-list {
  padding:7rem 5rem 9rem;
  background:transparent;
  display:flex;
  flex-direction:column;
  gap:8rem;
}

/* ── Intro banner chambres ── */
.ch-intro-banner {
  background:var(--cream);
  padding:clamp(2.5rem,5vw,4.5rem) clamp(1.5rem,6vw,8rem);
  display:flex;flex-direction:column;align-items:center;gap:1.6rem;
  text-align:center;
}
.ch-intro-rule {
  width:0;height:1px;background:var(--ochre);opacity:.55;
  animation: introRuleExpand .9s cubic-bezier(0.16,1,0.3,1) .9s both;
}
@keyframes introRuleExpand { to { width:48px; } }
.ch-intro-phrase {
  font-family:var(--serif);
  font-size:clamp(1.5rem,3vw,2.2rem);
  font-weight:400;
  line-height:1.4;
  color:var(--ink);
  letter-spacing:.01em;
  margin:0;
  opacity:0; transform:translateY(18px);
  animation: heroFadeUp .85s cubic-bezier(0.16,1,0.3,1) .7s both;
}
.ch-intro-phrase em {
  font-style:italic;color:var(--ochre);
}

.ch-room {
  display:grid;
  grid-template-columns:320px 1fr;
  gap:5.5rem;
  align-items:center;
  max-width:1080px;
  margin:0 auto;
  width:100%;
}
.ch-room:nth-child(even) {
  grid-template-columns:1fr 320px;
}
.ch-room:nth-child(even) .ch-room-gallery {
  order:2;
}

/* ── Flip Gallery ── */
.ch-room-gallery { position:relative; }

.flip-gallery {
  --fg-h: 460px;
  position:relative;
  width:100%;
  max-width:320px;
  height:var(--fg-h);
  perspective:800px;
  background:transparent;
}


.fg-unite {
  position:absolute;
  width:100%;
  height:50%;
  overflow:hidden;
  /* auto × --fg-h : maintient le ratio et permet une jointure parfaite */
  background-size:auto var(--fg-h);
  background-repeat:no-repeat;
}
.fg-top,.fg-overlay-top {
  top:0;
  transform-origin:bottom;
  background-position:center top;
}
.fg-bottom,.fg-overlay-bottom {
  bottom:0;
  transform-origin:top;
  background-position:center bottom;
}

/* Contrôles navigation */
.fg-controls {
  display:flex;
  align-items:center;
  justify-content:flex-end;
  gap:.75rem;
  margin-top:.9rem;
}
.fg-btn {
  width:32px;height:32px;
  border:1px solid var(--stone);
  background:none;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  color:var(--ink);
  transition:background .2s,color .2s,border-color .2s;
  flex-shrink:0;
}
.fg-btn:hover { background:var(--ink);color:var(--white);border-color:var(--ink); }
.fg-counter {
  font-size:.58rem;letter-spacing:.15em;
  color:var(--ink-soft);min-width:28px;text-align:center;
}

/* ── Room info ── */
.ch-room-info { display:flex;flex-direction:column; }

.ch-room-num {
  font-family:var(--serif);
  font-size:clamp(9rem,18vw,18rem);
  font-weight:300;
  color:rgba(26,20,16,.07);
  line-height:1;
  margin-bottom:-5rem;
  user-select:none;pointer-events:none;
}
.ch-room-name {
  font-family:var(--display);
  font-size:clamp(1.7rem,2.6vw,2.4rem);
  font-weight:400;
  color:var(--ink);
  line-height:1.3;
}
.ch-room-name em { font-style:italic;color:var(--ochre-lt); }
.ch-room-subtitle {
  font-size:.58rem;letter-spacing:.4em;text-transform:uppercase;
  color:var(--ochre);margin-top:.6rem;
}
.ch-room-rule {
  width:2.5rem;height:1px;
  background:var(--ochre);
  margin:1.5rem 0;
}
.ch-room-desc {
  font-size:1rem;line-height:1.85;
  color:var(--ink-soft);
}
.ch-room-amen {
  list-style:none;padding:0;
  margin:1.75rem 0 0;
  display:grid;grid-template-columns:1fr 1fr;
  gap:.5rem 1.5rem;
}
.ch-room-amen li {
  font-size:.68rem;letter-spacing:.03em;
  color:var(--ink-soft);
  padding-left:1rem;position:relative;
}
.ch-room-amen li::before {
  content:'—';position:absolute;left:0;
  color:var(--ochre);font-size:.62rem;
}
.ch-room-footer {
  display:flex;align-items:center;gap:2rem;flex-wrap:wrap;
  margin-top:2.5rem;padding-top:1.5rem;
  border-top:1px solid var(--stone);
}
.ch-room-price-from {
  font-family:var(--body);
  font-size:.65rem;letter-spacing:.08em;text-transform:uppercase;
  color:var(--ink-soft);display:block;margin-bottom:.2rem;
}
.ch-room-price {
  font-family:var(--serif);
  font-size:2rem;font-weight:300;
  color:var(--ink);display:block;line-height:1;
}
.ch-room-price-note {
  font-size:.58rem;letter-spacing:.08em;
  color:var(--ink-soft);display:block;margin-top:.3rem;
}

/* Responsive */
@media(max-width:960px){
  #ch-list { padding:5rem 2.5rem 7rem;gap:6rem; }
  .ch-room,
  .ch-room:nth-child(even) {
    grid-template-columns:1fr;
    gap:2rem;
  }
  .ch-room:nth-child(even) .ch-room-gallery { order:0; }
  .flip-gallery { max-width:100%; --fg-h:480px; }
}
@media(max-width:640px){
  .flip-gallery { --fg-h:420px; }
  .ch-room-info { padding:2rem 1.5rem 2.5rem; }
}
@media(max-width:480px){
  .flip-gallery { --fg-h:360px; }
  .ch-room-amen { grid-template-columns:1fr; }
  .ch-room-footer { flex-direction:column;align-items:flex-start; }
}
@media(max-width:540px){ .gal-grid { columns:1; } #galerie { padding:4rem 1.5rem 6rem; } }
