*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }

:root {
  --dark: #1a1008;
  --darker: #120d06;
  --cream: #FFFFF3;
  --cream-dim: rgba(255,255,243,0.75);
  --brown:#311602;
  --menu-bg:#1E1105;
  --ease:cubic-bezier(0.76,0,0.24,1);
  --ease-out:cubic-bezier(0.2,0,0,1);
  --gold: #C4A96A;
  --border: rgba(196,169,106,0.18);
  --loader-bg: #F5F0E8;
  --loader-brown: #311602;
}

html, body { width:100%; height:100%; overflow:hidden; }
html { background:var(--darker); }
html.about { background:#FAF6EE; }
body { font-family:'Jost', sans-serif; background:var(--darker); color:var(--cream); }

/* ══════════════════════════════
   SLIDESHOW
══════════════════════════════ */
.slideshow {
  position:fixed; inset:0; z-index:0;
}
.slide {
  position:absolute; inset:0;
  background-size:cover; background-position:center;
  opacity:0;
  transform:scale(1.05);
  transition:opacity 1.8s cubic-bezier(0.4,0,0.2,1),
              transform 9s cubic-bezier(0.0,0,0.2,1);
}
.slide.active {
  opacity:1;
  transform:scale(1);
}
.slide::after {
  content:'';
  position:absolute; inset:0;
  background:linear-gradient(
    to bottom,
    rgba(15,10,5,0.38) 0%,
    rgba(15,10,5,0.08) 35%,
    rgba(15,10,5,0.18) 60%,
    rgba(15,10,5,0.68) 100%
  );
}

/* ══════════════════════════════
   HERO
══════════════════════════════ */
.hero {
  position:fixed; inset:0; z-index:10;
  display:flex; flex-direction:column;
  align-items:center; justify-content:center;
  text-align:center;
  pointer-events:none;
}

.hero-logo {
  width:clamp(260px,45vw,640px);
  margin-bottom:2rem;
  opacity:0;
  transform:translateY(18px);
  animation:fadeUp 1.5s 0.2s cubic-bezier(0.2,0,0,1) forwards;
}

.hero-subtitle {
  font-family:'Cormorant Garamond',serif;
  font-style:italic; font-weight:400;
  font-size:clamp(0.95rem,1.8vw,1.3rem);
  color:var(--cream);
  line-height:1.65;
  max-width:500px;
  padding:0 1.5rem;
  opacity:0;
  animation:fadeUp 1.5s 0.65s cubic-bezier(0.2,0,0,1) forwards;
}

.hero-cta {
  pointer-events:all;
  margin-top:2.2rem;
  display:inline-block;
  border:1px solid rgba(255,255,243,0.55);
  color:var(--cream);
  text-decoration:none;
  font-family:'Jost',sans-serif;
  font-size:0.62rem; letter-spacing:0.2em;
  text-transform:uppercase;
  padding:0.85em 2.2em;
  transition:background 0.35s ease, color 0.35s ease, border-color 0.35s ease;
  opacity:0;
  animation:fadeUp 1.5s 1.05s cubic-bezier(0.2,0,0,1) forwards;
}
.hero-cta:hover {
  background:var(--cream);
  color:var(--darker);
  border-color:var(--cream);
}

.hero-raisin {
  position:absolute;
  bottom:clamp(1.5rem,4vh,4rem);
  left:0; right:0; margin:0 auto;
  width:clamp(90px,9.5vw,140px);
  opacity:0;
  animation:fadeUp 1.5s 1.4s cubic-bezier(0.2,0,0,1) forwards;
}

@keyframes fadeUp {
  to { opacity:1; transform:translateY(0); }
}

/* ══ LOADER ══ */
#loader{position:fixed;inset:0;z-index:1000;background:var(--loader-bg);display:flex;align-items:center;justify-content:center}
#loader.out{animation:loaderOut .9s var(--ease) forwards}
@keyframes loaderOut{to{opacity:0;transform:scale(.97);pointer-events:none}}
.ld-wrap{display:flex;flex-direction:column;align-items:center}
.ld-grape-wrap{position:relative;width:clamp(140px,20vw,190px);opacity:0;animation:gFadeIn .8s ease .3s forwards}
@keyframes gFadeIn{to{opacity:1}}
.ld-grape-wrap svg{width:100%;height:auto;display:block;position:relative;z-index:2}
#grapeInkCanvas{position:absolute;inset:0;z-index:3;width:100%;height:100%;image-rendering:crisp-edges}
.ld-line-wrap{width:clamp(80px,14vw,100px);height:1px;background:rgba(196,169,106,.1);margin-top:22px;overflow:hidden}
.ld-line{height:100%;width:0%;background:var(--gold);animation:lGrow 2.4s var(--ease) .6s forwards}
@keyframes lGrow{0%{width:0%;opacity:.4}65%{width:80%;opacity:1}100%{width:100%;opacity:.8}}

/* ══ NAV — exact captures: two bars side by side with text ══ */
.nav{position:fixed;top:0;left:0;z-index:300;padding:calc(1.3rem + env(safe-area-inset-top,0px)) 2rem 1.3rem;display:flex;align-items:center}
/* Hamburger icon: two stacked bars in a small box */
.mbtn{
  display:inline-flex;align-items:center;gap:10px;
  background:none;border:none;cursor:pointer;padding:0;
  color:var(--cream);font-family:'Jost',sans-serif;
  font-size:.74rem;font-weight:400;letter-spacing:.1em;text-transform:uppercase;
}
.bars-icon{
  position:relative;width:26px;height:9px;flex-shrink:0;
}
.bar{
  position:absolute;left:0;right:0;height:1.3px;background:currentColor;
  transform-origin:center;
  transition:top .45s var(--ease),bottom .45s var(--ease),transform .45s var(--ease),width .35s var(--ease);
}
.b1{top:0;bottom:auto}
.b2{bottom:0;top:auto}
/* Open state → X */
.mbtn.open .b1{top:50%;transform:translateY(-50%) rotate(45deg)}
.mbtn.open .b2{bottom:auto;top:50%;transform:translateY(-50%) rotate(-45deg)}
/* Label swap */
.lbl-menu{transition:opacity .3s,transform .3s}
.lbl-close{position:absolute;left:0;top:0;opacity:0;transform:translateX(4px);transition:opacity .3s,transform .3s;white-space:nowrap}
.mbtn.open .lbl-menu{opacity:0;transform:translateX(-4px)}
.mbtn.open .lbl-close{opacity:1;transform:translateX(-3px)}
.mbtn-labels{position:relative;display:inline-block}

/* ══ MENU BRAND CENTER ══ */
.menu-brand-top{position:fixed;top:0;left:0;right:0;z-index:295;padding:1.2rem 2rem;display:flex;justify-content:center;align-items:center;pointer-events:none;opacity:0;transition:opacity .45s .5s ease}
.menu-brand-top.visible{opacity:1}
.menu-brand-top svg{height:20px;width:auto}

/* ══ INK CANVAS ══ */
#inkCanvas{position:fixed;inset:0;width:100%;height:100%;z-index:250;pointer-events:none}

/* ══ MENU ══ */
.menu-overlay{position:fixed;inset:0;z-index:260;display:grid;overflow-y:auto;background:var(--menu-bg);opacity:0;pointer-events:none;transition:opacity .3s ease}
.menu-overlay.open{opacity:1;pointer-events:all}
@media(min-width:700px){.menu-overlay{grid-template-columns:1fr 1fr}.menu-col-left{border-right:1px solid var(--border)}}
@media(max-width:699px){.menu-overlay{grid-template-columns:1fr}}
.menu-col-left,.menu-col-right{background:var(--menu-bg);padding:clamp(3rem,6vh,5.5rem) 3.5rem clamp(1.8rem,3.5vh,3rem)}
@media(max-width:699px){.menu-col-left{padding:5rem 2rem 1.8rem}.menu-col-right{padding:2rem 2rem 2.6rem;border-top:1px solid var(--border)}}
.m-inner{opacity:0;transform:translateY(12px);transition:opacity .55s ease,transform .55s ease}
.menu-overlay.open .m-inner{opacity:1;transform:translateY(0);transition-delay:.32s}
.m-label{font-family:'Jost',sans-serif;font-weight:400;font-size:.64rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);margin-bottom:.5rem}
.m-nav{list-style:none;margin-bottom:2.1rem}
.m-nav li a{font-family:'Cormorant Garamond',serif;font-weight:400;font-size:clamp(1.15rem,1.9vw,1.5rem);text-transform:uppercase;letter-spacing:.05em;color:rgba(255,255,243,.82);text-decoration:none;line-height:1.4;display:block;transition:color .2s,transform .2s;cursor:pointer}
.m-nav li a:hover{color:var(--gold);transform:translateX(6px)}
.m-divider-lbl{font-size:.55rem;letter-spacing:.24em;text-transform:uppercase;color:var(--gold);padding-bottom:.85rem;border-bottom:1px solid var(--border)}
.voy{display:flex;align-items:center;justify-content:space-between;padding:1.1rem 0;border-bottom:1px solid var(--border);gap:1rem;text-decoration:none}
.voy.clickable:hover{opacity:.62}
.voy-date{font-family:'Jost',sans-serif;font-weight:400;font-size:.64rem;color:var(--gold);letter-spacing:.1em;white-space:nowrap;margin-top:.4rem}
.voy-name{font-family:'Cormorant Garamond',serif;font-weight:400;font-size:clamp(1.4rem,2.5vw,1.95rem);color:var(--cream);text-transform:uppercase;letter-spacing:.05em;line-height:1.12}
.voy-sub{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:.95rem;color:rgba(255,255,243,.5);margin-top:.2rem}
.voy-status{font-family:'Jost',sans-serif;font-weight:400;font-size:.64rem;letter-spacing:.1em;text-transform:uppercase;border:1px solid currentColor;padding:.32em .7em;white-space:nowrap;margin-top:0}
.s-open{color:var(--cream);border-color:rgba(255,255,243,.5)}
.s-soon{color:rgba(255,255,243,.25);border-color:rgba(255,255,243,.16)}
.voy.clickable{cursor:pointer;transition:opacity .2s}.voy.clickable:hover{opacity:.7}
.mesure-text{font-family:'Cormorant Garamond',serif;font-style:italic;font-weight:400;font-size:clamp(1.3rem,2.1vw,1.7rem);color:rgba(255,255,243,.82);line-height:1.4;margin-bottom:.85rem}
.arr{color:var(--cream);text-decoration:none;font-size:1rem;display:inline-block;transition:transform .2s}.arr:hover{transform:translateX(5px)}
.soc{list-style:none;margin-bottom:2.5rem}
.soc li a{font-family:'Cormorant Garamond',serif;font-size:clamp(1.4rem,2.8vw,2.2rem);color:rgba(255,255,243,.88);text-decoration:none;line-height:1.28;display:block;transition:color .2s}.soc li a:hover{color:var(--gold)}
.c-lbl{font-family:'Jost',sans-serif;font-weight:400;font-size:.64rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);margin-bottom:1.1rem}
.c-info{font-family:'Cormorant Garamond',serif;font-style:italic;font-weight:400;font-size:.95rem;letter-spacing:.03em;color:rgba(255,255,243,.72);line-height:1.7}
.c-info a{color:inherit;text-decoration:underline;text-underline-offset:3px}
.c-small{font-size:.56rem;color:rgba(255,255,243,.26);margin-top:1.3rem;line-height:1.7}
.sb{margin-bottom:1.9rem}

/* ══ POPUP LOIRE ══ */
#loirePopup{position:fixed;inset:0;z-index:600;display:flex;align-items:center;justify-content:center;background:rgba(0,0,0,0);pointer-events:none;transition:background .3s ease}
#loirePopup.show{background:rgba(0,0,0,.55);pointer-events:all}
.popup-card{background:#F5F0E8;width:clamp(300px,90vw,390px);padding:2.5rem 2rem 2rem;position:relative;transform:translateY(16px) scale(.97);opacity:0;transition:transform .4s var(--ease-out),opacity .35s ease;pointer-events:none}
#loirePopup.show .popup-card{transform:translateY(0) scale(1);opacity:1;pointer-events:all}
.popup-close{position:absolute;top:1rem;right:1rem;background:none;border:none;cursor:pointer;font-size:.82rem;color:rgba(49,22,2,.45);transition:color .2s;line-height:1;padding:.3rem}
.popup-close:hover{color:rgba(49,22,2,.9)}
.popup-eyebrow{font-family:'Jost',sans-serif;font-size:.58rem;font-weight:300;letter-spacing:.24em;text-transform:uppercase;color:rgba(49,22,2,.45);margin-bottom:.55rem;display:block}
.popup-title{font-family:'Cormorant Garamond',serif;font-weight:400;font-size:2.5rem;text-transform:uppercase;letter-spacing:.05em;color:#311602;line-height:1;margin-bottom:.3rem;display:block}
.popup-sub{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:.88rem;color:rgba(49,22,2,.48);display:block;margin-bottom:1.4rem}
.popup-divider{height:.5px;background:rgba(49,22,2,.1);margin-bottom:1.5rem}
.popup-desc{font-family:'Cormorant Garamond',serif;font-style:italic;font-weight:300;font-size:1rem;line-height:1.62;color:rgba(49,22,2,.7);margin-bottom:1.8rem;display:block}
.popup-field-label{font-family:'Jost',sans-serif;font-size:.56rem;font-weight:300;letter-spacing:.22em;text-transform:uppercase;color:rgba(49,22,2,.42);display:block;margin-bottom:.5rem}
.popup-input{width:100%;background:transparent;border:none;border-bottom:.5px solid rgba(49,22,2,.18);padding:.5rem 0;font-family:'Cormorant Garamond',serif;font-style:italic;font-size:1rem;color:#311602;outline:none;transition:border-color .25s;margin-bottom:1.6rem;display:block}
.popup-input::placeholder{color:rgba(49,22,2,.2)}
.popup-input:focus{border-color:rgba(196,169,106,.6)}
.popup-btn{width:100%;font-family:'Jost',sans-serif;font-size:.6rem;font-weight:300;letter-spacing:.24em;text-transform:uppercase;color:#F5F0E8;background:#1E1C13;border:none;padding:1rem;cursor:pointer;transition:background .2s}
.popup-btn.ready{opacity:1}
.popup-btn.done{opacity:1;background:#3f5d3a;color:#fff;letter-spacing:.14em}.popup-btn:hover{background:#311602}

/* ══════════════════════════════
   SYSTÈME DE PAGES
══════════════════════════════ */
.page{position:fixed;inset:0;overflow-y:auto;opacity:0;visibility:hidden;pointer-events:none;transition:opacity .55s var(--ease-out),visibility .55s}
.page.active{opacity:1;visibility:visible;pointer-events:auto}

/* barre Menu globale : sombre quand on défile sur l'ivoire (lisibilité), claire sinon */
body.nav-dark .mbtn:not(.open){color:#2b241b}

/* ══════════════════════════════
   PAGE À PROPOS
══════════════════════════════ */
#pageAbout{background:#FAF6EE}
.about-nav-spacer{height:0}
.about-hero{position:relative;height:clamp(460px,82vh,840px);min-height:440px;overflow:hidden;display:flex}
.about-hero-bg{position:absolute;top:-16%;left:0;width:100%;height:132%;background-size:cover;background-position:center;will-change:transform}
.about-hero-overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(18,11,4,.20) 0%,rgba(18,11,4,.28) 42%,rgba(18,11,4,.82) 100%)}
.about-hero-content{position:relative;z-index:2;width:100%;display:flex;align-items:flex-end}
.about-hero-title{font-family:'Cormorant Garamond',serif;font-style:italic;font-weight:500;color:var(--cream);font-size:clamp(2.7rem,6vw,5.2rem);line-height:.99;letter-spacing:-.004em;text-align:left;text-shadow:0 2px 40px rgba(0,0,0,.32);margin:0;max-width:17ch}

.about-body{max-width:760px;margin:0 auto;padding:clamp(3.2rem,7vw,6rem) 1.7rem clamp(3.5rem,7vw,6rem)}
.about-section-title{font-family:'Cormorant Garamond',serif;font-style:italic;font-weight:500;text-align:center;color:#23190f;font-size:clamp(1.7rem,3vw,2.5rem);margin:0 0 1rem}
.about-section-sub{text-align:center;font-family:'Jost',sans-serif;font-weight:400;text-transform:uppercase;letter-spacing:.28em;font-size:.6rem;color:var(--gold);margin:0 0 2.9rem}
.about-intro p{font-family:'Jost',sans-serif;font-weight:300;font-size:.82rem;line-height:2.05;color:#473d31;text-align:justify;margin:0 0 1.45rem}
.about-intro p:last-child{margin-bottom:0}

.person-block{max-width:560px;margin:clamp(3.5rem,7vw,6rem) auto 0}
.person-photo{width:100%;aspect-ratio:714/697;overflow:hidden;background:#e6e0d6}
.person-photo img{width:100%;height:100%;object-fit:cover;display:block;filter:grayscale(1);transition:transform 1.3s var(--ease-out),filter 1.3s var(--ease-out)}
.person-block:hover .person-photo img{transform:scale(1.05);filter:grayscale(0)}
.person-name{font-family:'Jost',sans-serif;font-weight:400;text-transform:uppercase;letter-spacing:.26em;font-size:.66rem;color:var(--gold);margin:1.5rem 0 1.2rem}
.person-bio p{font-family:'Jost',sans-serif;font-weight:300;font-size:.82rem;line-height:2.05;color:#473d31;text-align:justify;margin:0 0 1.35rem}
.person-bio p:last-child{margin-bottom:0}

/* ── PIED DE PAGE ── */
.about-footer{background:#241509;color:var(--cream);border-top:1px solid rgba(196,169,106,.16)}
.footer-inner{max-width:1200px;margin:0 auto;padding:clamp(2.6rem,5vw,4rem) 2rem 2rem}
.footer-cols{display:flex;flex-wrap:wrap;gap:2.5rem 3rem;justify-content:space-between}
.footer-col-title{font-family:'Jost',sans-serif;font-weight:400;font-size:.7rem;letter-spacing:.05em;margin:0 0 1.2rem;color:var(--cream)}
.footer-links{list-style:none;margin:0;padding:0}
.footer-links li{margin:0 0 .7rem}
.footer-links li a{color:rgba(255,255,243,.6);text-decoration:none;font-family:'Jost',sans-serif;font-weight:300;font-size:.72rem;transition:color .25s}
.footer-links li a:hover{color:var(--cream)}
.footer-col-newsletter{max-width:300px}
.footer-newsletter-desc{font-family:'Jost',sans-serif;font-weight:300;font-size:.72rem;line-height:1.7;color:rgba(255,255,243,.6);margin:0 0 1.2rem}
.footer-email-row{display:flex;align-items:center;border-bottom:1px solid rgba(255,255,243,.28)}
.footer-email-input{flex:1;background:none;border:none;color:var(--cream);font-family:'Jost',sans-serif;font-size:.6rem;letter-spacing:.18em;text-transform:uppercase;padding:.55rem 0;outline:none}
.footer-email-input::placeholder{color:rgba(255,255,243,.4)}
.footer-email-btn{background:none;border:none;color:var(--cream);font-size:1rem;line-height:1;cursor:pointer;width:34px;height:34px;flex-shrink:0;margin-left:.6rem;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:background .25s,color .25s}
.footer-email-btn:hover{background:#fff;color:#000}
.footer-email-btn.done,.footer-email-btn.done:hover{background:none;color:#8FBF93;font-size:1.15rem;animation:checkPop .45s var(--ease-out)}
@keyframes checkPop{0%{transform:scale(0.2);opacity:0}55%{transform:scale(1.25)}100%{transform:scale(1);opacity:1}}
.footer-credit a{color:inherit;text-decoration:none;border-bottom:1px solid rgba(255,255,243,.3);transition:color .25s,border-color .25s}
.footer-credit a:hover{color:var(--cream);border-color:var(--cream)}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:.8rem 1.6rem;margin-top:clamp(2.6rem,5vw,4rem);padding-top:1.4rem;border-top:1px solid rgba(255,255,243,.12)}
.footer-credit,.footer-copy{font-family:'Jost',sans-serif;font-weight:300;font-size:.62rem;letter-spacing:.04em;color:rgba(255,255,243,.45)}

/* ══════════════════════════════
   PAGE À PROPOS : défilement fenêtre (fichier séparé about.html)
══════════════════════════════ */
html.about{height:auto;overflow-x:hidden;overflow-y:auto}
html.about body{height:auto;overflow:visible}
body.about-page{background:#FAF6EE}

/* ── BARRE AÉRIENNE (Menu + logo) ── */
.scroll-bar{position:fixed;top:0;left:0;right:0;z-index:305;height:74px;pointer-events:none}
.scroll-bar .sb-bg{position:absolute;top:0;left:0;width:100%;height:120px;opacity:0;transition:opacity .6s var(--ease-out);transform:translateZ(0);-webkit-transform:translateZ(0);backface-visibility:hidden;-webkit-backface-visibility:hidden;will-change:opacity;
  background:linear-gradient(180deg,rgba(49,22,2,.4) 0%,rgba(49,22,2,.2) 45%,rgba(49,22,2,.05) 75%,rgba(49,22,2,0) 100%);
  -webkit-mask-image:linear-gradient(180deg,#000 60%,transparent 100%);mask-image:linear-gradient(180deg,#000 60%,transparent 100%);
  backdrop-filter:blur(7px);-webkit-backdrop-filter:blur(7px)}
.scroll-bar.show .sb-bg{opacity:1}
body.menu-open .scroll-bar .sb-bg{opacity:0}
.scroll-bar-inner{position:relative;height:74px;display:flex;align-items:center;justify-content:space-between;padding:0 2rem;pointer-events:none}
.scroll-bar-inner .mbtn{pointer-events:auto}
.bar-logo{pointer-events:auto;display:block;height:clamp(17px,1.9vw,22px);width:auto;line-height:0;opacity:1;transition:opacity .4s var(--ease-out)}
.bar-logo svg{height:100%;width:auto;display:block}
body.menu-open .bar-logo{opacity:0;pointer-events:none}

/* ════════ PAGE TÉMOIGNAGES ════════ */
.tem-body{max-width:1180px;margin:0 auto;padding:0 clamp(1.5rem,5vw,3rem)}
.tem-intro{text-align:center;padding:clamp(2.5rem,6vw,4.5rem) 0 clamp(2.5rem,6vw,4rem)}
.tem-rule{display:block;width:46px;height:1px;background:rgba(49,22,2,.3);margin:0 auto}
.tem-rule-center{margin:1.5rem auto 0}
.tem-intro-text{font-family:'Cormorant Garamond',serif;font-style:italic;font-weight:300;font-size:clamp(1.15rem,2.1vw,1.55rem);line-height:1.95;color:#3a2f23;margin-top:1.7rem}
.tem-divider{height:1px;background:rgba(49,22,2,.16);width:100%}
.tem-divider-wide{max-width:1180px;margin-left:auto;margin-right:auto}

.tem-carousel{padding-top:clamp(2.5rem,6vw,4.5rem)}
.tem-grid{display:grid;grid-template-columns:1fr 1fr;border:1px solid rgba(49,22,2,.2)}
.tem-card{position:relative;display:flex;flex-direction:column;padding:clamp(2rem,3.6vw,3.6rem);min-height:clamp(320px,34vw,440px);border-right:1px solid rgba(49,22,2,.13);border-bottom:1px solid rgba(49,22,2,.13)}
.tem-card:nth-child(2n){border-right:none}
.tem-card:nth-last-child(-n+2){border-bottom:none}
.tem-quote{flex:1;display:flex;align-items:center;font-family:'Cormorant Garamond',serif;font-style:italic;font-weight:300;font-size:clamp(1.05rem,1.55vw,1.4rem);line-height:1.85;color:#3a2f23}
.tem-card-rule{display:block;width:100%;height:1px;background:rgba(49,22,2,.18);margin-bottom:1.6rem}
.tem-card-foot{display:flex;justify-content:space-between;align-items:flex-end;gap:1rem}
.tem-card-name{display:block;font-family:'Jost',sans-serif;font-weight:300;font-size:.7rem;letter-spacing:.24em;text-transform:uppercase;color:#3a2f23}
.tem-card-date{display:block;font-family:'Cormorant Garamond',serif;font-style:italic;font-size:.92rem;color:#9a8b72;margin-top:.45rem}
.tem-card-num{font-family:'Cormorant Garamond',serif;font-style:italic;font-weight:300;font-size:clamp(2.3rem,4vw,3.4rem);line-height:.8;color:#C4A96A;opacity:.85}

.tem-controls{display:flex;flex-direction:column;align-items:center;gap:1.7rem;padding:clamp(2.2rem,5vw,3.6rem) 0 0}
.tem-controls-line{width:min(440px,62%);height:1px;background:rgba(196,169,106,.55)}
.tem-controls-nav{display:flex;align-items:center;gap:1.5rem}
.tem-arrow{width:44px;height:44px;border:1px solid rgba(49,22,2,.25);background:none;color:#3a2f23;font-size:.95rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .35s var(--ease-out),color .35s var(--ease-out),opacity .3s}
.tem-arrow:hover{background:#311602;color:#FAF6EE}
.tem-arrow.disabled{opacity:.28;pointer-events:none}
.tem-dots{display:flex;align-items:center;gap:.55rem}
.tem-dot{width:7px;height:7px;border-radius:50%;background:rgba(49,22,2,.25);transition:width .35s var(--ease-out),background .35s}
.tem-dot.on{width:24px;border-radius:4px;background:#C4A96A}

.tem-cta-wrap{text-align:center;padding:clamp(2.6rem,6vw,4.2rem) 0 clamp(3.5rem,8vw,6rem)}
.tem-cta{display:inline-block;text-decoration:none;font-family:'Jost',sans-serif;font-weight:300;font-size:.7rem;letter-spacing:.3em;text-transform:uppercase;color:#311602;border:1px solid rgba(49,22,2,.42);padding:1.15rem 2.8rem;background:none;cursor:pointer;transition:background .45s var(--ease-out),color .45s var(--ease-out)}
.tem-cta:hover{background:#311602;color:#FAF6EE}

.tem-pull{padding:0 clamp(1.5rem,5vw,3rem)}
.tem-pull-inner{max-width:920px;margin:0 auto;text-align:center;position:relative;padding:clamp(3.5rem,9vw,7rem) 0 clamp(3.5rem,8vw,6rem)}
.tem-quote-mark{position:absolute;top:clamp(1rem,4vw,2.5rem);left:50%;transform:translateX(-40%);font-family:'Cormorant Garamond',serif;font-style:italic;font-size:clamp(8rem,20vw,17rem);line-height:1;color:rgba(196,169,106,.18);pointer-events:none;z-index:0}
.tem-pull-text{position:relative;z-index:1;font-family:'Cormorant Garamond',serif;font-style:italic;font-weight:300;font-size:clamp(1.6rem,3.4vw,2.6rem);line-height:1.5;color:#2a2015}
.tem-pull-label{position:relative;z-index:1;font-family:'Jost',sans-serif;font-weight:300;font-size:.62rem;letter-spacing:.36em;text-transform:uppercase;color:#9a8b72;margin-top:1.3rem}

@media(max-width:720px){
  .tem-grid{grid-template-columns:1fr}
  .tem-card{border-right:none}
  .tem-card:nth-last-child(-n+2){border-bottom:1px solid rgba(49,22,2,.13)}
  .tem-card:last-child{border-bottom:none}
}

/* ════════ PAGE VOYAGE (fiche produit) ════════ */
.vy-hero-content{flex-direction:column}
.vy-subtitle{font-family:'Jost',sans-serif;font-weight:300;font-size:clamp(.62rem,1.1vw,.8rem);letter-spacing:.34em;text-transform:uppercase;color:rgba(255,255,243,.85);margin-top:1rem}
.vy-hero-cta{display:inline-block;margin-top:2.1rem;text-decoration:none;font-family:'Jost',sans-serif;font-weight:300;font-size:.66rem;letter-spacing:.3em;text-transform:uppercase;color:#FFFFF3;border:1px solid rgba(255,255,243,.55);padding:1rem 2.4rem;transition:background .45s var(--ease-out),color .45s var(--ease-out)}
.vy-hero-cta:hover{background:#FFFFF3;color:#311602}

.vy-body{background:#FAF6EE}
.vy-eyebrow{display:block;font-family:'Jost',sans-serif;font-weight:300;font-size:.6rem;letter-spacing:.32em;text-transform:uppercase;color:#C4A96A;margin-bottom:1.4rem}

.vy-intro{max-width:760px;margin:0 auto;text-align:center;padding:clamp(3.5rem,8vw,6rem) clamp(1.5rem,5vw,2rem)}
.vy-intro-text{font-family:'Jost',sans-serif;font-weight:300;font-size:clamp(.92rem,1.4vw,1.05rem);line-height:2;color:#5a4f40}

.vy-facts{background:#EFEADF}
.vy-facts-grid{max-width:1100px;margin:0 auto;padding:clamp(3rem,5.5vw,4.6rem) clamp(1.5rem,5vw,3rem);display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(2.8rem,4.5vw,3.8rem) clamp(1.6rem,3vw,3rem)}
.vy-fact{padding:.15rem 0 .15rem clamp(1.5rem,2.4vw,2.2rem);border-left:1px solid rgba(49,22,2,.14)}
.vy-fact:nth-child(1),.vy-fact:nth-child(5){border-left:none;padding-left:0}
.vy-fact-wide{grid-column:span 2}
.vy-fact-label{display:block;font-family:'Jost',sans-serif;font-weight:300;font-size:.56rem;letter-spacing:.34em;text-transform:uppercase;color:#a98c52;margin-bottom:1rem}
.vy-fact-val{font-family:'Cormorant Garamond',serif;font-weight:400;font-size:clamp(1.18rem,1.9vw,1.55rem);line-height:1.45;color:#2c2114}
.vy-fact-sub{display:inline-block;margin-top:.35rem;font-family:'Jost',sans-serif;font-weight:300;font-size:.72rem;letter-spacing:.04em;color:#857457}
.vy-itin-note{max-width:680px;margin:clamp(2rem,3.6vw,3rem) auto 0;padding:clamp(2rem,3.2vw,2.8rem) 1.6rem 0;text-align:center;position:relative}
.vy-itin-note::before{content:'';position:absolute;top:0;left:50%;transform:translateX(-50%);width:46px;height:1px;background:var(--gold);opacity:.55}
.vy-itin-note-eyebrow{display:block;font-family:'Jost',sans-serif;font-weight:300;font-size:.6rem;letter-spacing:.32em;text-transform:uppercase;color:#C4A96A;margin-bottom:1.1rem}
.vy-itin-note p{margin:0;font-family:'Cormorant Garamond',serif;font-style:italic;font-size:clamp(1rem,1.5vw,1.2rem);line-height:1.65;color:#3a2f20}

.vy-incl{max-width:1000px;margin:0 auto;padding:clamp(3.5rem,8vw,6rem) clamp(1.5rem,5vw,3rem);display:grid;grid-template-columns:1fr 1fr;gap:clamp(2.5rem,6vw,5rem)}
.vy-incl-title{font-family:'Jost',sans-serif;font-weight:300;font-size:.66rem;letter-spacing:.26em;text-transform:uppercase;color:#3a2f23;padding-bottom:1.2rem;border-bottom:1px solid rgba(49,22,2,.2)}
.vy-list{list-style:none;margin-top:.3rem}
.vy-list li{font-family:'Jost',sans-serif;font-weight:300;font-size:.9rem;color:#5a4f40;padding:.95rem 0;border-bottom:1px solid rgba(49,22,2,.1)}

.vy-stay{background:#F1EADB;display:grid;grid-template-columns:1fr 1.15fr;gap:clamp(2rem,5vw,4rem);align-items:start;padding:clamp(3.5rem,8vw,6rem) clamp(1.5rem,6vw,5rem)}
.vy-stay-h{font-family:'Cormorant Garamond',serif;font-style:italic;font-weight:300;font-size:clamp(2rem,4vw,3rem);line-height:1.1;color:#23190f;margin:.3rem 0 1.6rem}
.vy-stay-p{font-family:'Jost',sans-serif;font-weight:300;font-size:.92rem;line-height:1.9;color:#5a4f40;max-width:340px}
.vy-stay-cards{display:flex;flex-direction:column;gap:clamp(2rem,4vw,3rem)}
.vy-hotel-tag{display:block;font-family:'Jost',sans-serif;font-weight:300;font-size:.56rem;letter-spacing:.28em;text-transform:uppercase;color:#C4A96A;margin-bottom:.6rem}
.vy-hotel-name{font-family:'Cormorant Garamond',serif;font-weight:500;font-size:clamp(1.3rem,2.2vw,1.7rem);color:#23190f;margin-bottom:.5rem}
.vy-hotel{display:flex;gap:clamp(1.1rem,2vw,1.7rem);align-items:center;overflow:hidden}
.vy-hotel-info{flex:1}
.vy-hotel-desc{font-family:'Jost',sans-serif;font-weight:300;font-size:.92rem;line-height:1.7;color:#5a4f40}
.vy-hotel-imgwrap{position:relative;display:block;width:clamp(150px,42%,230px);aspect-ratio:4/3;flex-shrink:0;overflow:hidden;padding:0;border:0;margin:0;background:#e6e0d6;cursor:pointer;appearance:none;-webkit-appearance:none}
.vy-hotel-img{width:100%;height:100%;object-fit:cover;display:block;transition:transform 1.1s var(--ease-out)}
.vy-hotel:hover .vy-hotel-img,.vy-hotel-imgwrap:hover .vy-hotel-img{transform:scale(1.06)}
.vy-hotel-imgwrap:focus-visible{outline:2px solid var(--gold);outline-offset:3px}
.vy-hotel-imghint{position:absolute;left:0;right:0;bottom:0;display:flex;align-items:center;justify-content:center;gap:.45rem;padding:.7rem .8rem;font-family:'Jost',sans-serif;font-weight:400;font-size:.64rem;letter-spacing:.2em;text-transform:uppercase;color:#FFFFF3;background:linear-gradient(to top,rgba(18,13,6,.72),rgba(18,13,6,0));opacity:.97;transform:none;transition:opacity .3s var(--ease-out);pointer-events:none}
.vy-hotel-imgwrap:hover .vy-hotel-imghint,.vy-hotel-imgwrap:focus-visible .vy-hotel-imghint{opacity:1;transform:none}
.vy-hotel-imghint svg{width:15px;height:15px;flex:none}

.vy-itin-wrap{padding:clamp(4rem,9vw,7rem) clamp(1.5rem,5vw,3rem)}
.vy-itin-head{text-align:center;margin-bottom:clamp(2.5rem,6vw,4rem)}
.vy-itin-h{font-family:'Cormorant Garamond',serif;font-style:italic;font-weight:300;font-size:clamp(2rem,4vw,3rem);color:#23190f;margin-top:.3rem}
.vy-itin{position:relative;max-width:1080px;margin:0 auto}
.vy-itin::before{content:'';position:absolute;top:.5rem;bottom:.5rem;left:50%;width:1px;background:rgba(49,22,2,.2);transform:translateX(-50%)}
.vy-day{position:relative;width:50%;padding:0 clamp(2rem,4vw,3.6rem) clamp(1.4rem,2.8vw,2.4rem)}
.vy-day:nth-child(odd){left:50%}
.vy-day:nth-child(even){left:0}
.vy-node{position:absolute;top:.5rem;width:9px;height:9px;border-radius:50%;background:#C4A96A;border:2px solid #FAF6EE}
.vy-day:nth-child(odd) .vy-node{left:-5px}
.vy-day:nth-child(even) .vy-node{right:-5px}
.vy-day::before{content:'';position:absolute;top:calc(.5rem + 4px);height:1px;width:clamp(2rem,4vw,3.6rem);background:rgba(49,22,2,.16)}
.vy-day:nth-child(odd)::before{left:0}
.vy-day:nth-child(even)::before{right:0}
.vy-day-inner{display:flex;flex-direction:column;gap:.9rem}
.vy-day:nth-child(odd) .vy-day-inner{align-items:flex-start;text-align:left}
.vy-day:nth-child(even) .vy-day-inner{align-items:flex-end;text-align:right}
.vy-photo-frame{display:block;overflow:hidden;width:clamp(120px,13.5vw,172px);aspect-ratio:4/3;border:1px solid var(--border)}
.vy-photo{width:100%;height:100%;object-fit:cover;display:block;transition:transform 1.1s var(--ease-out)}
.vy-photo-frame:hover .vy-photo{transform:scale(1.08)}
.vy-num{display:block;font-family:'Jost',sans-serif;font-weight:300;font-size:.56rem;letter-spacing:.28em;text-transform:uppercase;color:#C4A96A}
.vy-place{font-family:'Cormorant Garamond',serif;font-weight:500;letter-spacing:.05em;font-size:clamp(1.1rem,1.8vw,1.5rem);color:#23190f;text-transform:uppercase;margin:.4rem 0 .3rem;line-height:1.15}
.vy-date{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:.95rem;color:#8a7d68}
.vy-detail{font-family:'Jost',sans-serif;font-weight:300;font-size:.78rem;line-height:1.6;color:#6a5e4c;margin-top:.4rem}
.vy-cta-mid{text-align:center;padding:clamp(2.4rem,5vw,3.5rem) 1.5rem 0}
.vy-cta-mid-btn{display:inline-block;text-decoration:none;font-family:'Jost',sans-serif;font-weight:300;font-size:.68rem;letter-spacing:.3em;text-transform:uppercase;color:#311602;border:1px solid rgba(49,22,2,.42);padding:1.1rem 2.8rem;transition:background .45s var(--ease-out),color .45s var(--ease-out)}
.vy-cta-mid-btn:hover{background:#311602;color:#FAF6EE}

.vy-hosts{background:#ECE3D1;padding:clamp(3.5rem,8vw,6rem) clamp(1.5rem,5vw,3rem)}
.vy-hosts-h{text-align:center;font-family:'Cormorant Garamond',serif;font-style:italic;font-weight:300;font-size:clamp(1.8rem,3.6vw,2.6rem);color:#23190f;margin-bottom:clamp(2.5rem,5vw,3.5rem)}
.vy-hosts-grid{max-width:1040px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,4rem)}
.vy-host-tag{display:block;font-family:'Jost',sans-serif;font-weight:300;font-size:.6rem;letter-spacing:.26em;text-transform:uppercase;color:#9a7b3e;margin-bottom:1.1rem;padding-bottom:1rem;border-bottom:1px solid rgba(49,22,2,.18)}
.vy-host-bio{font-family:'Jost',sans-serif;font-weight:300;font-size:.84rem;line-height:1.9;color:#5a4f40}

.vy-cta{background:#2a1c0c;text-align:center;padding:clamp(3.5rem,8vw,6rem) 1.5rem}
.vy-cta-price{font-family:'Cormorant Garamond',serif;font-style:italic;font-weight:300;font-size:clamp(1.6rem,3.2vw,2.4rem);color:#FFFFF3;margin-bottom:1.8rem}
.vy-cta-price span{font-size:.6em;color:rgba(255,255,243,.7)}
.vy-cta-btn{display:inline-block;text-decoration:none;font-family:'Jost',sans-serif;font-weight:300;font-size:.68rem;letter-spacing:.3em;text-transform:uppercase;color:#FFFFF3;border:1px solid rgba(255,255,243,.5);padding:1.15rem 2.8rem;transition:background .45s var(--ease-out),color .45s var(--ease-out)}
.vy-cta-btn:hover{background:#FFFFF3;color:#2a1c0c}

@media(max-width:820px){
  .vy-facts-grid{grid-template-columns:1fr 1fr}
  .vy-fact,.vy-fact:nth-child(1),.vy-fact:nth-child(5){border-left:none;padding-left:0}
  .vy-stay{grid-template-columns:1fr}
  .vy-hosts-grid{grid-template-columns:1fr}
}
@media(max-width:720px){
  .vy-incl{grid-template-columns:1fr;gap:2.5rem}
  .vy-itin::before{left:7px}
  .vy-day,.vy-day:nth-child(odd),.vy-day:nth-child(even){width:100%;left:0;padding:0 0 2.4rem 2rem}
  .vy-day-inner,.vy-day:nth-child(odd) .vy-day-inner,.vy-day:nth-child(even) .vy-day-inner{align-items:flex-start;text-align:left}
  .vy-node,.vy-day:nth-child(odd) .vy-node,.vy-day:nth-child(even) .vy-node{left:3px;right:auto}
  .vy-day::before,.vy-day:nth-child(odd)::before,.vy-day:nth-child(even)::before{left:7px;right:auto;width:1.2rem}
}
@media(max-width:560px){
  .vy-facts-grid{grid-template-columns:1fr}
  .vy-fact-wide{grid-column:span 1}
  .vy-hotel{flex-direction:column;align-items:flex-start}
  .vy-hotel-imgwrap{width:100%;max-width:300px}
}

/* ─── apparition au scroll (état initial posé avant rendu via .js) ─── */
.js .about-hero-content,.js .about-intro,.js .about-section-title,.js .about-section-sub,.js .person-block,.js .mesure-text,.js .tem-intro,.js .tem-card,.js .tem-cta-wrap,.js .tem-pull,.js .vy-intro,.js .vy-fact,.js .vy-cta-mid,.js .vy-incl-col,.js .vy-stay-intro,.js .vy-hotel,.js .vy-day,.js .vy-host{opacity:0;transform:translateY(28px);transition:opacity .85s var(--ease-out),transform .85s var(--ease-out)}
.js .about-hero-content.in,.js .about-intro.in,.js .about-section-title.in,.js .about-section-sub.in,.js .person-block.in,.js .mesure-text.in,.js .tem-intro.in,.js .tem-card.in,.js .tem-cta-wrap.in,.js .tem-pull.in,.js .vy-intro.in,.js .vy-fact.in,.js .vy-cta-mid.in,.js .vy-incl-col.in,.js .vy-stay-intro.in,.js .vy-hotel.in,.js .vy-day.in,.js .vy-host.in{opacity:1;transform:none}
/* cascade sur les groupes */
.js .vy-facts-grid .vy-fact:nth-child(2){transition-delay:.07s}
.js .vy-facts-grid .vy-fact:nth-child(3){transition-delay:.14s}
.js .vy-facts-grid .vy-fact:nth-child(4){transition-delay:.21s}
.js .vy-facts-grid .vy-fact:nth-child(6){transition-delay:.1s}
.js .tem-grid .tem-card:nth-child(2){transition-delay:.1s}
.js .tem-grid .tem-card:nth-child(3){transition-delay:.2s}
.js .tem-grid .tem-card:nth-child(4){transition-delay:.3s}
.js .vy-stay-cards .vy-hotel:nth-child(2){transition-delay:.12s}
.js .vy-incl .vy-incl-col:nth-child(2){transition-delay:.12s}
.js .about-section-sub{transition-delay:.08s}
.js .about-section-title{transition-delay:.16s}
@media(prefers-reduced-motion:reduce){.js .about-hero-content,.js .about-intro,.js .about-section-title,.js .about-section-sub,.js .person-block,.js .mesure-text,.js .tem-intro,.js .tem-card,.js .tem-cta-wrap,.js .tem-pull,.js .vy-intro,.js .vy-fact,.js .vy-cta-mid,.js .vy-incl-col,.js .vy-stay-intro,.js .vy-hotel,.js .vy-day,.js .vy-host{opacity:1;transform:none;transition:none}}

/* ===================== PAGE RÉSERVATION ===================== */
.rsv-hero-title{font-style:italic;font-weight:400;text-transform:none;letter-spacing:.01em}
.rsv-body{background:#FAF6EE;padding:clamp(2.4rem,5vw,3.6rem) clamp(1.5rem,5vw,3rem) clamp(4rem,8vw,7rem)}
.rsv-back{display:inline-flex;align-items:center;gap:.55rem;max-width:1200px;margin:0 auto clamp(2rem,4vw,3rem);padding:0;width:100%;font-family:'Jost',sans-serif;font-weight:300;font-size:.74rem;letter-spacing:.16em;text-transform:uppercase;color:#6a5e4c;text-decoration:none;transition:color .4s var(--ease-out)}
.rsv-back-arrow{display:inline-block;transition:transform .4s var(--ease-out)}
.rsv-back:hover{color:#23190f}
.rsv-back:hover .rsv-back-arrow{transform:translateX(-5px)}
.rsv-grid{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:clamp(2.5rem,6vw,7rem);align-items:start}
.rsv-h{font-family:'Cormorant Garamond',serif;font-style:italic;font-weight:400;font-size:clamp(1.9rem,3.4vw,2.7rem);color:#23190f;margin-bottom:clamp(1.8rem,3.5vw,2.8rem)}
.rsv-specs{margin-bottom:clamp(2.4rem,4.5vw,3.4rem)}
.rsv-spec{display:flex;align-items:baseline;gap:clamp(1rem,3vw,2.4rem);padding:clamp(.95rem,1.8vw,1.3rem) 0;border-bottom:1px solid rgba(49,22,2,.16)}
.rsv-spec:first-child{padding-top:0}
.rsv-spec-lbl{flex:0 0 clamp(110px,18%,150px);font-family:'Jost',sans-serif;font-weight:300;font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:#23190f}
.rsv-spec-val{font-family:'Cormorant Garamond',serif;font-weight:400;font-size:clamp(1.05rem,1.7vw,1.35rem);color:#2c2114;line-height:1.3}
.rsv-form{background:#EFEADF;padding:clamp(1.8rem,3.5vw,2.8rem)}
.rsv-form-h{font-family:'Cormorant Garamond',serif;font-style:italic;font-weight:400;font-size:clamp(1.5rem,2.6vw,2rem);color:#23190f;margin-bottom:clamp(1.2rem,2.6vw,1.8rem)}
.rsv-field{display:flex;align-items:center;gap:clamp(1rem,2.5vw,2rem);padding:clamp(.75rem,1.5vw,1.05rem) 0}
.rsv-field+.rsv-field{border-top:1px solid rgba(49,22,2,.1)}
.rsv-field-lbl{flex:0 0 clamp(110px,30%,160px);font-family:'Jost',sans-serif;font-weight:300;font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:#473d31}
.rsv-field-static{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:clamp(1rem,1.6vw,1.25rem);color:#2c2114}
.rsv-voyageurs{flex:1;display:flex;gap:clamp(.7rem,1.5vw,1rem)}
.rsv-vox{position:relative;flex:1;display:flex;align-items:center;gap:.5rem;background:#fff;border:1px solid rgba(49,22,2,.25);padding:.6rem .85rem}
.rsv-vox-cap{font-family:'Jost',sans-serif;font-weight:300;font-size:.74rem;color:#6a5e4c;white-space:nowrap}
/* menu déroulant personnalisé */
.rsv-csel{flex:1;min-width:0}
.rsv-csel-trigger{display:flex;align-items:center;justify-content:space-between;gap:.6rem;width:100%;padding:0;border:0;background:transparent;cursor:pointer;font-family:'Jost',sans-serif;font-weight:300;font-size:.85rem;color:#2c2114;text-align:left}
.rsv-csel-trigger:focus-visible{outline:1px solid rgba(196,169,106,.7);outline-offset:4px}
.rsv-csel-value{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.rsv-csel-value.is-placeholder{color:#9a8c74}
.rsv-csel-chev{flex-shrink:0;width:11px;height:7px;color:#6a5e4c;transition:transform .35s var(--ease-out)}
.rsv-csel.open .rsv-csel-chev{transform:rotate(180deg)}
.rsv-csel-panel{position:absolute;top:calc(100% + 7px);left:0;right:0;z-index:60;margin:0;padding:.35rem;list-style:none;background:#FCFBF7;border:1px solid rgba(49,22,2,.16);box-shadow:0 20px 44px -20px rgba(49,22,2,.4);max-height:248px;overflow-y:auto;opacity:0;visibility:hidden;transform:translateY(-6px);transition:opacity .28s var(--ease-out),transform .28s var(--ease-out),visibility .28s}
.rsv-csel.open .rsv-csel-panel{opacity:1;visibility:visible;transform:none}
.rsv-csel-opt{padding:.62rem .85rem;font-family:'Jost',sans-serif;font-weight:300;font-size:.85rem;color:#473d31;cursor:pointer;transition:background .2s,color .2s}
.rsv-csel-opt:hover,.rsv-csel-opt.is-active{background:rgba(120,96,52,.1);color:#23190f}
.rsv-csel-opt.is-selected{color:#23190f;background:rgba(120,96,52,.07)}
.rsv-room{position:relative;flex:1;background:#fff;border:1px solid rgba(49,22,2,.25);padding:.72rem .9rem}
.rsv-photo-frame{display:block;overflow:hidden;width:100%;aspect-ratio:4/3;background:#e6e0d6}
.rsv-photo-frame[hidden]{display:none}
.rsv-photo{width:100%;height:100%;object-fit:cover;display:block;transition:transform 1.2s var(--ease-out)}
.rsv-photo-frame:hover .rsv-photo{transform:scale(1.05)}
.rsv-caption{font-family:'Cormorant Garamond',serif;font-style:italic;font-weight:400;font-size:clamp(1.4rem,2.4vw,1.95rem);line-height:1.25;color:#3a2f20;margin:clamp(1.4rem,2.6vw,2rem) 0 clamp(1.8rem,3.5vw,2.6rem)}
.rsv-total-label{font-family:'Cormorant Garamond',serif;font-weight:400;font-size:clamp(1.3rem,2vw,1.7rem);color:#473d31;margin-bottom:.3rem}
.rsv-price{font-family:'Cormorant Garamond',serif;font-weight:500;font-size:clamp(2.6rem,5vw,3.8rem);color:#23190f;line-height:1;letter-spacing:.01em}
.rsv-price span{font-style:italic;font-weight:400;font-size:.42em;color:#6a5e4c;letter-spacing:0}
.rsv-taxes{font-family:'Jost',sans-serif;font-weight:300;font-size:.78rem;color:#857457;margin:.9rem 0 clamp(1.6rem,3vw,2.4rem)}
.rsv-cta-btn{display:block;width:100%;text-align:center;padding:1.1rem 1.5rem;border:1px solid #311602;background:transparent;font-family:'Jost',sans-serif;font-weight:300;font-size:.74rem;letter-spacing:.26em;text-transform:uppercase;color:#311602;text-decoration:none;transition:background .5s var(--ease-out),color .5s var(--ease-out)}
.rsv-cta-btn:hover{background:#311602;color:#FFFFF3}
@media(max-width:860px){.rsv-grid{grid-template-columns:1fr;gap:clamp(2.5rem,6vw,3.5rem)}}
@media(max-width:520px){
  .rsv-spec{flex-direction:column;gap:.3rem}
  .rsv-spec-lbl,.rsv-field-lbl{flex:none}
  .rsv-field{flex-direction:column;align-items:flex-start;gap:.6rem}
  .rsv-voyageurs{width:100%}
}
/* reveal page réservation */
.js .rsv-h,.js .rsv-spec,.js .rsv-form,.js .rsv-photo-frame,.js .rsv-caption,.js .rsv-summary{opacity:0;transform:translateY(28px);transition:opacity .85s var(--ease-out),transform .85s var(--ease-out)}
.js .rsv-h.in,.js .rsv-spec.in,.js .rsv-form.in,.js .rsv-photo-frame.in,.js .rsv-caption.in,.js .rsv-summary.in{opacity:1;transform:none}
.js .rsv-specs .rsv-spec:nth-child(2){transition-delay:.07s}
.js .rsv-specs .rsv-spec:nth-child(3){transition-delay:.14s}
.js .rsv-specs .rsv-spec:nth-child(4){transition-delay:.21s}
@media(prefers-reduced-motion:reduce){.js .rsv-h,.js .rsv-spec,.js .rsv-form,.js .rsv-photo-frame,.js .rsv-caption,.js .rsv-summary{opacity:1;transform:none;transition:none}}

/* ═══════════ PAGE PAIEMENT ═══════════ */
.pay-wrap{max-width:1180px;margin:0 auto;padding:clamp(2.4rem,5vw,4rem) clamp(1.4rem,5vw,3rem) clamp(3rem,6vw,5rem)}
.pay-head{text-align:center;margin-bottom:clamp(2.6rem,5.5vw,4.4rem)}
.pay-logo{font-family:'Cormorant Garamond',serif;font-weight:500;font-size:clamp(1.45rem,2.5vw,2rem);letter-spacing:.01em;color:#23190f;text-decoration:none;display:inline-block}
.pay-steps{margin-top:1.05rem;display:flex;gap:.55rem;justify-content:center;align-items:center;font-family:'Jost',sans-serif;font-weight:300;font-size:.66rem;letter-spacing:.2em;text-transform:uppercase;flex-wrap:wrap}
.pay-steps a{color:#a99a80;text-decoration:none;transition:color .3s var(--ease-out)}
.pay-steps a:hover{color:#473d31}
.pay-step-sep{color:#c4b79c}
.pay-steps .is-current{color:#23190f}

.pay-grid{display:grid;grid-template-columns:1.4fr 1fr;gap:clamp(2.4rem,6vw,6rem);align-items:start}
.pay-h{font-family:'Cormorant Garamond',serif;font-style:italic;font-weight:400;font-size:clamp(2rem,3.8vw,3rem);color:#23190f;line-height:1}
.pay-rule{height:1px;background:rgba(49,22,2,.16);margin:clamp(1.3rem,2.4vw,1.9rem) 0 clamp(1.8rem,3.4vw,2.6rem)}

.pay-method{display:flex;align-items:center;gap:.85rem;cursor:pointer;padding:.4rem 0}
.pay-method input{position:absolute;opacity:0;width:0;height:0}
.pay-radio{width:15px;height:15px;border-radius:50%;border:1px solid rgba(49,22,2,.5);flex:0 0 auto;position:relative;transition:border-color .3s var(--ease-out)}
.pay-method input:checked ~ .pay-radio{border-color:#311602}
.pay-method input:checked ~ .pay-radio::after{content:'';position:absolute;inset:3px;border-radius:50%;background:#311602}
.pay-method input:focus-visible ~ .pay-radio{box-shadow:0 0 0 3px rgba(120,96,52,.28)}
.pay-method-label{font-family:'Jost',sans-serif;font-weight:300;font-size:.95rem;color:#2c2114}
.pay-method-sub{color:#8a7c64}

.pay-card-fields{margin:1.4rem 0 1.3rem 1.95rem;overflow:hidden}
.pay-field{margin-bottom:1.45rem}
.pay-field:last-child{margin-bottom:0}
.pay-lbl{display:block;font-family:'Jost',sans-serif;font-weight:300;font-size:.64rem;letter-spacing:.17em;text-transform:uppercase;color:#857457;margin-bottom:.55rem}
.pay-input{width:100%;border:0;border-bottom:1px solid rgba(49,22,2,.28);background:transparent;font-family:'Jost',sans-serif;font-weight:300;font-size:.98rem;color:#2c2114;padding:.4rem 0;transition:border-color .3s var(--ease-out)}
.pay-input::placeholder{color:#b3a78d}
.pay-input:focus{outline:none;border-bottom-color:#311602}
.pay-input.invalid{border-bottom-color:#9b2c2c}
.pay-row{display:flex;gap:clamp(1.4rem,3vw,2.4rem)}
.pay-row .pay-field{flex:1}

.pay-dotted{border-top:1px dotted rgba(49,22,2,.4);margin:.1rem 0 1.3rem}
.pay-or{font-style:normal;font-family:'Jost',sans-serif;font-weight:300;font-size:.82rem;letter-spacing:.06em;color:#a8895a;margin:0 .35rem}
.pay-sep{height:1px;background:rgba(49,22,2,.12);margin:1.3rem 0}
.pay-bank-note{font-family:'Jost',sans-serif;font-weight:300;font-size:.82rem;line-height:1.6;color:#857457;margin:.7rem 0 0 1.95rem}

.pay-summary{background:#EFEADF;padding:clamp(1.3rem,2.4vw,1.8rem)}
.pay-summary-photo{overflow:hidden;aspect-ratio:4/5;margin-bottom:clamp(1.3rem,2.4vw,1.8rem)}
.pay-summary-photo img{width:100%;height:100%;object-fit:cover;display:block;transition:transform 1.2s var(--ease-out)}
.pay-summary:hover .pay-summary-photo img{transform:scale(1.05)}
.pay-escale-lbl{font-family:'Jost',sans-serif;font-weight:300;font-size:.6rem;letter-spacing:.24em;text-transform:uppercase;color:#a8895a}
.pay-escale{font-family:'Cormorant Garamond',serif;font-style:italic;font-weight:400;font-size:clamp(1.3rem,2.2vw,1.7rem);color:#23190f;margin:.5rem 0 .45rem;line-height:1.25}
.pay-escale-dates{font-family:'Jost',sans-serif;font-weight:300;font-size:.82rem;color:#6a5e4c}
.pay-summary-rule{height:1px;background:rgba(49,22,2,.16);margin:clamp(1.2rem,2.3vw,1.7rem) 0}
.pay-total{font-family:'Cormorant Garamond',serif;font-weight:500;font-size:clamp(2.1rem,3.6vw,2.9rem);color:#23190f;line-height:1}
.pay-total-sub{font-family:'Jost',sans-serif;font-weight:300;font-size:.72rem;color:#857457;margin-top:.55rem}

.pay-confirm{display:block;width:100%;margin-top:clamp(1.3rem,2.4vw,1.8rem);padding:1.05rem 1rem;border:1px solid #311602;background:transparent;color:#311602;font-family:'Jost',sans-serif;font-weight:300;font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;cursor:pointer;transition:background .45s var(--ease-out),color .45s var(--ease-out)}
.pay-confirm:hover{background:#311602;color:#FFFFF3}
.pay-confirm:disabled{cursor:default;background:#311602;color:#FFFFF3}
.pay-msg{margin-top:1rem;font-family:'Jost',sans-serif;font-weight:300;font-size:.85rem;line-height:1.65}
.pay-msg.ok{color:#311602}
.pay-msg.err{color:#9b2c2c}

@media(max-width:860px){
  .pay-grid{grid-template-columns:1fr;gap:clamp(2.2rem,7vw,3.2rem)}
}
.pay-wallets{display:flex;align-items:center;gap:.4rem;flex-wrap:wrap}
.pay-method-inline{padding:.4rem 0}

/* ═══════════ PAGE CONFIRMATION ═══════════ */
body.cf-page{background:#120d06 url('images/commun/confirmation-bg.jpg') center center / cover no-repeat fixed;font-family:'Jost',sans-serif;min-height:100vh}
.cf-overlay{position:fixed;inset:0;background:linear-gradient(180deg,rgba(18,11,4,.34),rgba(18,11,4,.26) 38%,rgba(18,11,4,.52));z-index:1}
.cf-wrap{position:relative;z-index:2;max-width:760px;margin:0 auto;padding:clamp(3rem,9vh,7rem) 1.5rem clamp(2.5rem,6vh,4rem);min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center}
.cf-title{font-family:'Cormorant Garamond',serif;font-style:italic;font-weight:500;font-size:clamp(2.2rem,6vw,4.2rem);color:#FFFFF3;text-shadow:0 2px 34px rgba(0,0,0,.4);line-height:1}
.cf-sub{font-family:'Jost',sans-serif;font-weight:300;font-size:clamp(.85rem,1.5vw,1rem);line-height:1.85;color:rgba(255,255,243,.9);margin-top:clamp(1.2rem,2.5vw,1.8rem);max-width:540px;text-shadow:0 1px 18px rgba(0,0,0,.35)}
.cf-card{background:#FFFFF3;color:#2c2114;width:100%;max-width:520px;margin:clamp(2rem,4vw,3rem) 0;padding:clamp(1.8rem,4vw,2.6rem);text-align:left;box-shadow:0 44px 90px -34px rgba(18,11,4,.6)}
.cf-card-lbl{font-family:'Jost',sans-serif;font-weight:300;font-size:.62rem;letter-spacing:.24em;text-transform:uppercase;color:#a8895a}
.cf-ref{font-family:'Jost',sans-serif;font-weight:300;font-size:clamp(1.4rem,3vw,1.9rem);letter-spacing:.06em;color:#23190f;margin-top:.5rem}
.cf-rule{height:1px;background:rgba(49,22,2,.14);margin:clamp(1.2rem,2.5vw,1.6rem) 0}
.cf-list{list-style:none}
.cf-row{display:flex;align-items:flex-start;gap:.9rem;margin-bottom:1.25rem}
.cf-row:last-child{margin-bottom:0}
.cf-ico{flex:0 0 auto;color:#a8895a;margin-top:.1rem}
.cf-ico svg{width:17px;height:17px;display:block}
.cf-row-text{display:flex;flex-direction:column;gap:.22rem}
.cf-row-lbl{font-family:'Jost',sans-serif;font-weight:300;font-size:.78rem;color:#8a7c64}
.cf-row-val{font-family:'Jost',sans-serif;font-weight:300;font-size:.95rem;color:#23190f}
.cf-email{font-family:'Jost',sans-serif;font-weight:300;font-size:.82rem;line-height:1.6;color:#6a5e4c;text-align:center}
.cf-email strong{color:#23190f;font-weight:300}
.cf-btn{display:inline-block;text-decoration:none;font-family:'Jost',sans-serif;font-weight:300;font-size:.7rem;letter-spacing:.26em;text-transform:uppercase;color:#FFFFF3;border:1px solid rgba(255,255,243,.6);padding:1.05rem 2.6rem;transition:background .45s var(--ease-out),color .45s var(--ease-out)}
.cf-btn:hover{background:#FFFFF3;color:#2a1c0c}
.cf-contact{font-family:'Jost',sans-serif;font-weight:300;font-size:.74rem;letter-spacing:.04em;color:rgba(255,255,243,.82);margin-top:clamp(1.6rem,3vw,2.4rem);text-shadow:0 1px 16px rgba(0,0,0,.4)}

/* ═══════════ PAGE VOYAGE SUR MESURE ═══════════ */
.vsm-body{max-width:1080px;margin:0 auto;padding:clamp(2.6rem,6vw,4.6rem) clamp(1.5rem,5vw,3rem) clamp(2.6rem,6vw,4rem)}
.vsm-intro{text-align:center;max-width:780px;margin:0 auto}
.vsm-eyebrow{font-family:'Jost',sans-serif;font-weight:300;font-size:clamp(.66rem,1.4vw,.74rem);letter-spacing:.2em;text-transform:uppercase;color:#a8895a;line-height:1.85}
.vsm-intro-text{font-family:'Jost',sans-serif;font-weight:300;font-size:clamp(.92rem,1.6vw,1.05rem);line-height:1.8;color:#473d31;margin-top:1.2rem}
.vsm-rule{height:1px;background:rgba(49,22,2,.14);margin:clamp(2.2rem,5vw,3.4rem) 0}
.vsm-points-label{font-family:'Jost',sans-serif;font-weight:300;font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;color:#a8895a;margin-bottom:clamp(1.2rem,2.6vw,1.8rem)}
.vsm-points-grid{display:grid;grid-template-columns:1fr 1fr;gap:0 clamp(2.5rem,6vw,5rem)}
.vsm-points-col{list-style:none}
.vsm-points-col li{font-family:'Cormorant Garamond',serif;font-weight:400;font-size:clamp(1.05rem,1.8vw,1.28rem);color:#3a2f23;padding:.95rem 0;border-bottom:1px solid rgba(49,22,2,.13)}
.vsm-form{margin-top:clamp(.4rem,1vw,.8rem)}
.vsm-frow{display:flex;gap:clamp(1.6rem,4vw,3.2rem);margin-bottom:clamp(1.7rem,3vw,2.3rem)}
.vsm-frow .vsm-field{flex:1;min-width:0}
.vsm-field-full{margin-top:.2rem}
.vsm-lbl{display:block;font-family:'Jost',sans-serif;font-weight:300;font-size:.66rem;letter-spacing:.2em;text-transform:uppercase;color:#5a4f40;margin-bottom:.7rem}
.vsm-input{width:100%;border:0;border-bottom:1px solid rgba(49,22,2,.3);background:transparent;font-family:'Jost',sans-serif;font-weight:300;font-size:1rem;color:#2c2114;padding:.5rem 0;transition:border-color .3s var(--ease-out)}
.vsm-input::placeholder{color:#b3a78d}
.vsm-input:focus{outline:none;border-bottom-color:#311602}
.vsm-input.invalid{border-bottom-color:#9b2c2c}
.vsm-csel{position:relative;border-bottom:1px solid rgba(49,22,2,.3);padding:.5rem 0}
.vsm-csel .rsv-csel-trigger{font-size:1rem}
.vsm-textarea{width:100%;background:#F4EFE6;border:1px solid rgba(49,22,2,.1);font-family:'Jost',sans-serif;font-weight:300;font-size:.98rem;color:#2c2114;padding:1.1rem 1.2rem;line-height:1.7;resize:vertical;min-height:150px;transition:border-color .3s var(--ease-out)}
.vsm-textarea::placeholder{color:#b3a78d}
.vsm-textarea:focus{outline:none;border-color:rgba(49,22,2,.35)}
.vsm-cta{background:#EFEAE0;padding:clamp(2.8rem,6vw,4.6rem) clamp(1.5rem,5vw,3rem);text-align:center}
.vsm-cta-inner{max-width:760px;margin:0 auto}
.vsm-cta-text{font-family:'Jost',sans-serif;font-weight:300;font-size:clamp(.92rem,1.6vw,1.02rem);line-height:1.85;color:#473d31}
.vsm-cta-text strong{font-weight:600;color:#23190f}
.vsm-cta-btn{display:inline-block;margin-top:clamp(1.8rem,3.5vw,2.6rem);border:1px solid #311602;background:transparent;color:#311602;font-family:'Jost',sans-serif;font-weight:300;font-size:.72rem;letter-spacing:.24em;text-transform:uppercase;padding:1.1rem 2.7rem;cursor:pointer;transition:background .45s var(--ease-out),color .45s var(--ease-out)}
.vsm-cta-btn:hover{background:#311602;color:#FFFFF3}
.vsm-cta-btn:disabled{cursor:default;background:#311602;color:#FFFFF3}
.vsm-msg{margin-top:1.1rem;font-family:'Jost',sans-serif;font-weight:300;font-size:.85rem;line-height:1.6}
.vsm-msg.ok{color:#3a5a3f}
.vsm-msg.err{color:#9b2c2c}
@media(max-width:760px){
  .vsm-points-grid{grid-template-columns:1fr;gap:0}
  .vsm-frow{flex-direction:column;gap:1.7rem}
}

/* logo du menu cliquable (retour accueil) + logo page confirmation */
.menu-brand-top a.mbt-link{pointer-events:auto;display:inline-flex;align-items:center}
body.menu-open .menu-brand-top a.mbt-link{pointer-events:auto}
.cf-logo{display:inline-block;font-family:'Cormorant Garamond',serif;font-weight:500;font-size:clamp(1.3rem,2.4vw,1.85rem);letter-spacing:.02em;color:#FFFFF3;text-decoration:none;text-shadow:0 1px 22px rgba(0,0,0,.45);margin-bottom:clamp(1.8rem,4vw,3rem);transition:opacity .3s var(--ease-out)}
.cf-logo:hover{opacity:.8}

/* bloc « Voyage sur mesure » entièrement cliquable dans le menu */
a.sb-mesure{display:grid;grid-template-columns:1fr auto;align-items:center;column-gap:1.2rem;text-decoration:none;color:inherit;cursor:pointer;padding:20px;margin:-20px -20px calc(2.4rem - 20px) -20px}
a.sb-mesure .m-label{grid-column:1;grid-row:1}
a.sb-mesure .mesure-text{grid-column:1;grid-row:2;margin-bottom:0}
a.sb-mesure .arr{grid-column:2;grid-row:2;align-self:center;margin-top:0;margin-right:1rem;transition:transform .3s var(--ease-out),color .3s var(--ease-out)}
a.sb-mesure .m-label,a.sb-mesure .mesure-text{transition:color .3s var(--ease-out)}
a.sb-mesure:hover .m-label,a.sb-mesure:hover .mesure-text,a.sb-mesure:hover .arr{color:var(--gold)}
a.sb-mesure:hover .arr{transform:translateX(5px)}

/* ═══════════ PAGE GALERIE (plein écran + page qui se tourne) ═══════════ */
html.gal-html{height:100vh;height:100dvh;overflow:hidden}
body.gal-page{background:#1c1407;font-family:'Jost',sans-serif;height:100vh;height:100dvh;overflow:hidden;overscroll-behavior:none}
.gal-wrap{display:grid;grid-template-columns:minmax(220px,25%) 1fr;grid-template-rows:100vh;grid-template-rows:100dvh;height:100vh;height:100dvh;width:100%}
.gal-side{background:var(--menu-bg);min-height:0;overflow:auto;display:flex;flex-direction:column;justify-content:center;padding:clamp(2rem,5vw,4rem) clamp(1.6rem,3vw,3rem)}
.gal-side-eyebrow{font-family:'Jost',sans-serif;font-weight:300;font-size:.66rem;letter-spacing:.28em;text-transform:uppercase;color:var(--gold);margin-bottom:1.4rem}
.gal-voys{display:flex;flex-direction:column}
.gal-voy{display:block;width:100%;font-family:'Cormorant Garamond',serif;font-style:italic;font-weight:500;font-size:clamp(1.6rem,2.4vw,2.3rem);color:#23190f;text-decoration:none;padding:1.05rem 0;border:0;border-top:1px solid rgba(255,255,243,.14);text-align:left;background:none;cursor:pointer;transition:color .3s var(--ease-out),opacity .3s var(--ease-out)}
.gal-voy:last-child{border-bottom:1px solid rgba(255,255,243,.14)}
.gal-voy.is-soon{font-weight:400;color:#b3a489}
.gal-voy.is-soon:hover{color:#8a7c64}
.gal-voy.is-active:hover{opacity:.7}

.gal-main{position:relative;display:flex;flex-direction:column;min-width:0;min-height:0;overflow:hidden;background:#1c1407}
.gal-stage{position:relative;flex:1;min-height:0;overflow:hidden;transition:opacity .28s ease}
.gal-stage.switching{opacity:0}
.gal-track{display:flex;gap:14px;height:100%;padding:0 14px;overflow-x:auto;overflow-y:hidden;scroll-snap-type:x mandatory;scroll-behavior:smooth;-webkit-overflow-scrolling:touch;overscroll-behavior-x:contain;cursor:grab;scrollbar-width:none}
.gal-track::-webkit-scrollbar{display:none}
.gal-track.is-grabbing{cursor:grabbing;scroll-snap-type:none;scroll-behavior:auto}
.gal-slide{flex:0 0 auto;height:100%;aspect-ratio:699/1520;scroll-snap-align:center;overflow:hidden;background:#241a0c;border-radius:2px;margin:0}
.gal-slide img{width:100%;height:100%;object-fit:cover;display:block;-webkit-user-select:none;user-select:none}

.gal-bar{flex:0 0 auto;display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:clamp(1rem,2vw,1.5rem) 14px;background:#1c1407}
.gal-nav{display:inline-flex;align-items:center;gap:1rem;background:none;border:0;cursor:pointer;font-family:'Jost',sans-serif;font-weight:300;font-size:.66rem;letter-spacing:.22em;text-transform:uppercase;color:rgba(255,255,243,.78);transition:color .3s var(--ease-out)}
.gal-nav:hover:not(:disabled){color:#FFFFF3}
.gal-nav:disabled{opacity:.3;cursor:default}
.gal-sq{display:inline-flex;align-items:center;justify-content:center;width:42px;height:42px;border-radius:50%;border:1px solid rgba(255,255,243,.38);background:rgba(26,16,8,.24);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);color:#FFFFF3;transition:background .45s var(--ease-out),border-color .45s var(--ease-out),transform .45s var(--ease-out)}
.gal-nav:hover:not(:disabled) .gal-sq{background:rgba(26,16,8,.46);border-color:rgba(255,255,243,.7);transform:scale(1.07)}
.gal-arrow{display:inline-flex;align-items:center;justify-content:center}
.gal-arrow svg{width:14px;height:14px}
.gal-arrow svg path{stroke-width:1.2}
.gal-dots{display:flex;align-items:center;gap:.6rem}
.gal-dot{width:7px;height:7px;padding:0;border:0;-webkit-appearance:none;appearance:none;border-radius:99px;background:rgba(255,255,243,.32);cursor:pointer;transition:width .4s var(--ease-out),background .4s var(--ease-out)}
.gal-dot.is-active{width:26px;background:rgba(255,255,243,.85)}

body.gal-page:not(.menu-open) .scroll-bar-inner .mbtn{color:#FFFFF3}
body.gal-page:not(.menu-open) .scroll-bar-inner .mbtn .bar{background:#FFFFF3}
body.gal-page .bar-logo svg{filter:drop-shadow(0 1px 8px rgba(0,0,0,.45))}

@media(max-width:820px){
  .gal-wrap{grid-template-columns:1fr;grid-template-rows:auto 1fr}
  .gal-side{justify-content:flex-start;padding-top:clamp(4.5rem,13vw,6rem)}
  .gal-voys{flex-direction:row;gap:1.6rem}
  .gal-voy{border:0!important;padding:.3rem 0;font-size:1.5rem}
  .gal-voy:last-child{border:0!important}
}

/* galerie : onglets de région + page « bientôt » */
.gal-voy{color:#b3a489}
.gal-voy.is-active{color:var(--cream)}
.gal-voy.is-active:hover{opacity:.75}
.gal-empty{position:absolute;inset:0;z-index:4;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;background:#1c1407;color:#FFFFF3;padding:2rem}
.gal-empty[hidden]{display:none}
.gal-empty-eyebrow{font-family:'Jost',sans-serif;font-weight:300;font-size:.66rem;letter-spacing:.28em;text-transform:uppercase;color:#a8895a;margin-bottom:1rem}
.gal-empty-title{font-family:'Cormorant Garamond',serif;font-style:italic;font-weight:500;font-size:clamp(2.6rem,5.5vw,4.4rem);color:#FFFFF3;line-height:1}
.gal-empty-text{font-family:'Jost',sans-serif;font-weight:300;font-size:.95rem;color:rgba(255,255,243,.7);margin-top:1.1rem;max-width:360px;line-height:1.75}

/* ═══════════ PAGE NOS DESTINATIONS (catalogue) ═══════════ */
.dest-body{max-width:1180px;margin:0 auto;padding:clamp(2.4rem,5vw,4rem) clamp(1.5rem,5vw,3rem) clamp(2.6rem,5vw,4rem)}
.dest-rule{width:54px;height:1px;background:rgba(49,22,2,.32);margin:0 auto clamp(1.8rem,3.5vw,2.6rem)}
.dest-intro{text-align:center;font-family:'Cormorant Garamond',serif;font-style:italic;font-weight:400;font-size:clamp(1.3rem,2.4vw,1.95rem);line-height:1.5;color:#3a2f23;max-width:780px;margin:0 auto clamp(2.6rem,5vw,4rem)}
.dest-grid{display:grid;grid-template-columns:repeat(2,1fr);border-top:1px solid rgba(49,22,2,.14)}
.dest-card{padding:clamp(1.8rem,3.5vw,3rem);border-bottom:1px solid rgba(49,22,2,.14)}
.dest-card:nth-child(odd){border-right:1px solid rgba(49,22,2,.14)}
.dest-card-photo{position:relative;overflow:hidden;aspect-ratio:4/3;margin-bottom:clamp(1.2rem,2.2vw,1.6rem);background:#241a0c}
.dest-card-photo img{width:100%;height:100%;object-fit:cover;display:block;transition:transform 1.1s var(--ease-out)}
.dest-card:hover .dest-card-photo img{transform:scale(1.05)}
.dest-card-name{font-family:'Cormorant Garamond',serif;font-style:italic;font-weight:500;font-size:clamp(1.6rem,2.6vw,2.15rem);color:#23190f;line-height:1.1}
.dest-card-sub{font-family:'Jost',sans-serif;font-weight:300;font-size:.66rem;letter-spacing:.18em;text-transform:uppercase;color:#8a7c64;margin-top:.55rem}
.dest-explore{display:inline-flex;align-items:center;gap:.7rem;margin-top:clamp(1.1rem,2.2vw,1.6rem);font-family:'Jost',sans-serif;font-weight:300;font-size:.82rem;letter-spacing:.12em;color:#a8895a;text-decoration:none;transition:color .3s var(--ease-out)}
.dest-explore:hover{color:#8a6d35}
.dest-arrow{transition:transform .3s var(--ease-out)}
.dest-explore:hover .dest-arrow{transform:translateX(6px)}
.dest-explore.is-disabled{color:#b9ab90;cursor:default}
/* destination « bientôt » */
.dest-card.is-soon .dest-card-photo img{filter:grayscale(.32) brightness(.82)}
.dest-card.is-soon:hover .dest-card-photo img{transform:none}
.dest-badge{position:absolute;top:1rem;left:1rem;background:rgba(18,11,4,.72);color:#FFFFF3;font-family:'Jost',sans-serif;font-weight:300;font-size:.6rem;letter-spacing:.2em;text-transform:uppercase;padding:.45rem .85rem}

.dest-cta{background:#F5F2E2;padding:clamp(3.5rem,8vw,6rem) clamp(1.5rem,5vw,3rem);text-align:center}
.dest-cta-title{font-family:'Cormorant Garamond',serif;font-style:italic;font-weight:500;font-size:clamp(2rem,4.5vw,3.4rem);color:#2a1c0e;line-height:1.12}
.dest-cta-btn{display:inline-block;margin-top:clamp(1.8rem,3.5vw,2.6rem);background:#311602;color:#FFFFF3;border:1px solid #311602;padding:1.05rem 2.7rem;font-family:'Jost',sans-serif;font-weight:300;font-size:.72rem;letter-spacing:.24em;text-transform:uppercase;text-decoration:none;transition:background .45s var(--ease-out),color .45s var(--ease-out)}
.dest-cta-btn:hover{background:transparent;color:#311602}

@media(max-width:760px){
  .dest-grid{grid-template-columns:1fr}
  .dest-card:nth-child(odd){border-right:0}
}

/* galerie : bouton Menu lisible quand on atteint le footer */
body.gal-page .scroll-bar-inner .mbtn{transition:color .3s var(--ease-out)}
body.gal-page.gal-scrolled:not(.menu-open) .scroll-bar-inner .mbtn{color:#FFFFF3}
body.gal-page.gal-scrolled:not(.menu-open) .scroll-bar-inner .mbtn .bar{background:#FFFFF3}

.dest-card-link{display:block;text-decoration:none;color:inherit}

/* paiement en ligne (Stripe Payment Element) */
.pay-online{margin-top:1.4rem}
#payment-element{margin:.4rem 0 .2rem}
.pay-config-note{font-family:'Jost',sans-serif;font-weight:300;font-size:.82rem;line-height:1.55;color:#9a7b3f;margin-top:.9rem}
.pay-bank{margin-top:1rem}

/* ══════════════════════════════
   NOS DESTINATIONS — refonte éditoriale (nd-)
══════════════════════════════ */
.nd-hero{position:relative;height:92vh;min-height:560px;overflow:hidden;display:flex;align-items:flex-end}
.nd-hero-bg{position:absolute;top:-12%;left:0;width:100%;height:124%;background-size:cover;background-position:center;will-change:transform}
.nd-hero-veil{position:absolute;inset:0;background:linear-gradient(180deg,rgba(18,11,4,.26) 0%,rgba(18,11,4,.30) 42%,rgba(18,11,4,.82) 100%)}
.nd-hero-inner{position:relative;z-index:2;width:100%;max-width:1500px;margin:0 auto;padding:clamp(2rem,6vw,5rem) clamp(1.5rem,6vw,5.5rem) clamp(2.8rem,7vw,6rem)}
.nd-hero-eyebrow{font-family:'Jost',sans-serif;font-weight:300;font-size:clamp(.6rem,.9vw,.72rem);letter-spacing:.42em;text-transform:uppercase;color:var(--gold);margin-bottom:clamp(1rem,2.2vw,1.7rem)}
.nd-hero-title{font-family:'Cormorant Garamond',serif;font-weight:300;color:var(--cream);font-size:clamp(3.6rem,11vw,11rem);line-height:.9;letter-spacing:-.012em;text-shadow:0 2px 40px rgba(0,0,0,.3)}
.nd-hero-title em{display:block;font-style:italic;font-weight:500}
.nd-hero-lede{font-family:'Cormorant Garamond',serif;font-style:italic;font-weight:400;font-size:clamp(1.15rem,1.9vw,1.7rem);line-height:1.5;color:var(--cream-dim);max-width:560px;margin-top:clamp(1.5rem,2.8vw,2.3rem)}
.nd-hero-cue{position:absolute;z-index:2;right:clamp(1.4rem,4vw,3.4rem);bottom:clamp(2rem,5vw,3.6rem);display:flex;flex-direction:column;align-items:center;gap:1rem}
.nd-cue-lbl{writing-mode:vertical-rl;font-family:'Jost',sans-serif;font-weight:300;font-size:.6rem;letter-spacing:.34em;text-transform:uppercase;color:var(--cream-dim)}
.nd-cue-line{width:1px;height:64px;background:linear-gradient(var(--gold),rgba(196,169,106,0));transform-origin:top;animation:ndCue 2.6s var(--ease-out) infinite}
@keyframes ndCue{0%{transform:scaleY(0);transform-origin:top}45%{transform:scaleY(1);transform-origin:top}46%{transform:scaleY(1);transform-origin:bottom}100%{transform:scaleY(0);transform-origin:bottom}}

.nd-dossiers{background:#FBF8F1;padding:clamp(3.4rem,8vw,7rem) 0 clamp(1.5rem,3vw,3rem)}
.nd-dossier{display:grid;grid-template-columns:1.04fr .96fr;align-items:center;gap:clamp(2rem,5vw,5.5rem);max-width:1440px;margin:0 auto clamp(4rem,9vw,8.5rem);padding:0 clamp(1.5rem,5vw,4.5rem)}
.nd-dossier:nth-child(even) .nd-figure{order:2}
.nd-figure{position:relative;display:block;text-decoration:none;color:inherit}
.nd-figure-img{position:relative;overflow:hidden;height:clamp(430px,74vh,840px);background:#241a0c}
.nd-figure-img img{width:100%;height:100%;object-fit:cover;display:block;transform:scale(1.01);transition:transform 1.5s var(--ease-out)}
.nd-figure:hover .nd-figure-img img{transform:scale(1.07)}
.nd-index{position:absolute;z-index:3;top:clamp(-.8rem,-1.6vw,-1.6rem);left:clamp(-.2rem,-.8vw,-.9rem);font-family:'Cormorant Garamond',serif;font-style:italic;font-weight:300;font-size:clamp(3.4rem,7vw,6.4rem);line-height:1;color:#FBF8F1;text-shadow:0 2px 30px rgba(0,0,0,.28);pointer-events:none}
.nd-figure-cap{display:block;margin-top:1rem;font-family:'Jost',sans-serif;font-weight:300;font-size:.62rem;letter-spacing:.26em;text-transform:uppercase;color:#9a8b71}
.nd-copy{max-width:450px}
.nd-dossier:nth-child(even) .nd-copy{margin-left:auto}
.nd-copy-eyebrow{display:flex;align-items:center;gap:.9rem;font-family:'Jost',sans-serif;font-weight:300;font-size:.66rem;letter-spacing:.26em;text-transform:uppercase;color:#a8895a;margin-bottom:clamp(1.1rem,2.2vw,1.6rem)}
.nd-copy-eyebrow::before{content:'';width:36px;height:1px;background:#cdb98e;flex:0 0 auto}
.nd-copy-name{font-family:'Cormorant Garamond',serif;font-style:italic;font-weight:500;font-size:clamp(2.7rem,5.6vw,4.6rem);color:#23190f;line-height:.98}
.nd-copy-sub{font-family:'Cormorant Garamond',serif;font-style:italic;font-weight:400;font-size:clamp(1.15rem,1.9vw,1.55rem);color:#6a5a45;margin-top:.55rem}
.nd-copy-text{font-family:'Jost',sans-serif;font-weight:300;font-size:clamp(.92rem,1.05vw,1.02rem);line-height:1.9;color:#4a3e30;margin-top:clamp(1.3rem,2.4vw,2rem)}
.nd-explore{display:inline-flex;align-items:center;gap:1.1rem;margin-top:clamp(1.6rem,3vw,2.5rem);font-family:'Jost',sans-serif;font-weight:300;font-size:.72rem;letter-spacing:.24em;text-transform:uppercase;color:#311602;text-decoration:none;background:none;border:0;padding:0;cursor:pointer}
.nd-explore-arrow{display:inline-flex;align-items:center;justify-content:center;width:48px;height:48px;border:1px solid rgba(49,22,2,.3);border-radius:50%;font-size:.95rem;transition:background .5s var(--ease-out),color .5s var(--ease-out),border-color .5s var(--ease-out),transform .5s var(--ease-out)}
.nd-explore:hover .nd-explore-arrow{background:#311602;color:var(--cream);border-color:#311602;transform:translateX(5px)}
.nd-explore:hover .nd-explore-lbl{color:#5a3a10}

.nd-soon .nd-figure-img img{filter:grayscale(.5) brightness(.84) sepia(.1)}
.nd-soon .nd-figure{cursor:pointer}
.nd-soon .nd-figure:hover .nd-figure-img img{transform:scale(1.03)}
.nd-soon-tag{position:absolute;z-index:3;top:1.1rem;right:1.1rem;background:rgba(18,11,4,.6);-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);color:var(--cream);font-family:'Jost',sans-serif;font-weight:300;font-size:.6rem;letter-spacing:.26em;text-transform:uppercase;padding:.5rem .95rem}
.nd-notify{color:#7a6a52}
.nd-notify .nd-explore-arrow{border-color:rgba(49,22,2,.22)}

.nd-cta{position:relative;overflow:hidden;padding:clamp(3.4rem,7.5vw,6rem) clamp(1.5rem,5vw,3rem);text-align:center}
.nd-cta-bg{position:absolute;inset:0;background-size:cover;background-position:center 38%}
.nd-cta-veil{position:absolute;inset:0;background:linear-gradient(180deg,rgba(18,11,4,.62) 0%,rgba(18,11,4,.78) 100%)}
.nd-cta-inner{position:relative;z-index:2;max-width:780px;margin:0 auto}
.nd-cta-eyebrow{font-family:'Jost',sans-serif;font-weight:300;font-size:.66rem;letter-spacing:.36em;text-transform:uppercase;color:var(--gold);margin-bottom:clamp(1.2rem,2.5vw,1.9rem)}
.nd-cta-title{font-family:'Cormorant Garamond',serif;font-weight:300;font-size:clamp(2.2rem,4.6vw,3.7rem);color:var(--cream);line-height:1.14;max-width:26ch;margin:0 auto}
.nd-cta-title em{font-style:italic;font-weight:500}
.nd-cta-btn{display:inline-block;margin-top:clamp(2rem,4vw,3rem);border:1px solid rgba(255,255,243,.55);color:var(--cream);padding:1.1rem 2.9rem;font-family:'Jost',sans-serif;font-weight:300;font-size:.72rem;letter-spacing:.26em;text-transform:uppercase;text-decoration:none;transition:background .5s var(--ease-out),color .5s var(--ease-out)}
.nd-cta-btn:hover{background:var(--cream);color:#311602}

.js .nd-reveal{opacity:0;transform:translateY(36px);transition:opacity 1.05s var(--ease-out),transform 1.05s var(--ease-out)}
.js .nd-reveal.nd-in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){.js .nd-reveal{opacity:1;transform:none;transition:none}.nd-cue-line{animation:none}}

@media(max-width:860px){
  .nd-hero{height:88vh}
  .nd-dossier{grid-template-columns:1fr;gap:clamp(1.3rem,5vw,2rem);margin-bottom:clamp(3rem,11vw,5rem)}
  .nd-dossier:nth-child(even) .nd-figure{order:0}
  .nd-dossier:nth-child(even) .nd-copy{margin-left:0}
  .nd-figure-img{height:clamp(380px,64vh,560px)}
  .nd-copy{max-width:none}
  .nd-hero-cue{display:none}
  .nd-index{font-size:clamp(2.8rem,12vw,4rem)}
}

/* À propos — garantir la justification du 1er paragraphe d'intro
   (l'emporte même sur un style en ligne ou une classe résiduelle) */
.about-intro p:first-of-type{text-align:justify !important;text-align-last:left}


/* ── En-tête de page harmonisé (éditorial) ── */
.about-hero-inner{width:100%;max-width:1500px;margin:0 auto;padding:clamp(2rem,6vw,5rem) clamp(1.5rem,6vw,5.5rem) clamp(2.6rem,7vw,5.5rem)}
.about-hero-eyebrow{display:flex;align-items:center;gap:.9rem;font-family:'Jost',sans-serif;font-weight:300;font-size:clamp(.6rem,.9vw,.72rem);letter-spacing:.4em;text-transform:uppercase;color:var(--gold);margin-bottom:clamp(.9rem,2vw,1.5rem)}
.about-hero-eyebrow::before{content:'';width:38px;height:1px;background:var(--gold);opacity:.7;flex:0 0 auto}
.about-hero-lede{font-family:'Cormorant Garamond',serif;font-style:italic;font-weight:400;font-size:clamp(1.1rem,1.8vw,1.6rem);line-height:1.5;color:var(--cream-dim);max-width:560px;margin-top:clamp(1.2rem,2.5vw,1.9rem)}
.about-hero-cue{position:absolute;z-index:2;right:clamp(1.4rem,4vw,3.2rem);bottom:clamp(1.8rem,4vw,3.2rem);width:1px;height:62px;background:linear-gradient(var(--gold),rgba(196,169,106,0));transform-origin:top;animation:ndCue 2.6s var(--ease-out) infinite;pointer-events:none}
@media(max-width:860px){.about-hero{height:74vh;min-height:420px}.about-hero-cue{display:none}.about-hero-title{font-size:clamp(2.5rem,9vw,3.6rem)}}
@media(prefers-reduced-motion:reduce){.about-hero-cue{animation:none}}

/* ── Corps À propos enrichi ── */
.about-body{max-width:880px}
.about-section-sub{position:relative;padding-bottom:1.7rem;margin-bottom:2.4rem}
.about-section-sub::after{content:'';position:absolute;left:50%;bottom:0;transform:translateX(-50%);width:46px;height:1px;background:rgba(196,169,106,.65)}
.about-intro{max-width:680px;margin:0 auto}
.about-intro p:first-of-type::first-letter{font-family:'Cormorant Garamond',serif;font-style:italic;font-weight:500;font-size:3.5em;line-height:.78;float:left;margin:.06em .14em -.02em 0;color:#8a6526}
.person-block{max-width:none;margin:clamp(3.4rem,7vw,5.5rem) auto 0;display:grid;grid-template-columns:minmax(0,43%) 1fr;gap:clamp(1.8rem,4.5vw,4.2rem);align-items:center}
.person-reverse .person-photo{order:2}
.person-text{min-width:0}
.person-name{font-family:'Cormorant Garamond',serif;font-style:italic;font-weight:500;text-transform:none;letter-spacing:0;font-size:clamp(2rem,3.4vw,2.9rem);color:#23190f;margin:0}
.person-role{font-family:'Jost',sans-serif;font-weight:300;text-transform:uppercase;letter-spacing:.26em;font-size:.62rem;color:var(--gold);margin:.65rem 0 1.3rem}
.person-bio p{font-size:.84rem;line-height:2}
@media(max-width:760px){
  .person-block{grid-template-columns:1fr;gap:1.4rem;margin-top:clamp(2.8rem,10vw,4rem)}
  .person-reverse .person-photo{order:0}
  .person-photo{aspect-ratio:4/3}
}

/* ══════════════════════════════
   À PROPOS — refonte éditoriale "feature" (ab-)
══════════════════════════════ */
.ab{background:#FAF6EE}
.ab-eyebrow{display:flex;align-items:center;gap:.9rem;font-family:'Jost',sans-serif;font-weight:300;font-size:.66rem;letter-spacing:.32em;text-transform:uppercase;color:#a8895a;margin:0}
.ab-eyebrow::before{content:'';width:36px;height:1px;background:#cdb98e;flex:0 0 auto}
.ab-eyebrow.ab-center{justify-content:center}
.ab-center{text-align:center}

/* 1 · manifeste */
.ab-manifesto{max-width:1200px;margin:0 auto;padding:clamp(4rem,9vw,8rem) clamp(1.5rem,5vw,4rem) clamp(2.5rem,5vw,4rem);display:grid;grid-template-columns:1.08fr .92fr;gap:clamp(2rem,5vw,5.5rem);align-items:start}
.ab-statement{font-family:'Cormorant Garamond',serif;font-style:italic;font-weight:500;font-size:clamp(2rem,4.2vw,3.5rem);line-height:1.1;color:#23190f;margin:clamp(1.3rem,2.5vw,1.9rem) 0 0}
.ab-statement em{color:#7a5a2e}
.ab-manifesto-body{padding-top:.6rem}
.ab-manifesto-body p{font-family:'Jost',sans-serif;font-weight:300;font-size:clamp(.9rem,1vw,.98rem);line-height:2;color:#4a3e30;margin:0 0 1.4rem;text-align:justify}
.ab-manifesto-body p:last-child{margin-bottom:0}

/* 2 · bande citation */
.ab-band{position:relative;overflow:hidden;margin:clamp(1.5rem,4vw,3.5rem) 0;min-height:clamp(360px,62vh,640px);display:flex;align-items:center;justify-content:center}
.ab-band-bg{position:absolute;inset:0;background-size:cover;background-position:center}
.ab-band-veil{position:absolute;inset:0;background:linear-gradient(180deg,rgba(18,11,4,.5),rgba(18,11,4,.66))}
.ab-band-quote{position:relative;z-index:2;max-width:980px;margin:0;text-align:center;font-family:'Cormorant Garamond',serif;font-style:italic;font-weight:400;font-size:clamp(1.6rem,3.6vw,3rem);line-height:1.28;color:#FFFFF3;padding:0 clamp(1.5rem,5vw,3rem);text-shadow:0 2px 34px rgba(0,0,0,.4)}
.ab-band-quote em{color:#e7d09d}

/* 3 · approche */
.ab-approach{max-width:1200px;margin:0 auto;padding:clamp(3.5rem,8vw,7rem) clamp(1.5rem,5vw,4rem)}
.ab-values{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(1.6rem,3.5vw,3.4rem);margin-top:clamp(2.2rem,5vw,3.6rem)}
.ab-value{border-top:1px solid rgba(49,22,2,.16);padding-top:1.5rem}
.ab-num{display:block;font-family:'Cormorant Garamond',serif;font-style:italic;font-weight:300;font-size:clamp(2.4rem,4vw,3.4rem);line-height:1;color:#c4a96a}
.ab-value h3{font-family:'Cormorant Garamond',serif;font-style:italic;font-weight:500;font-size:clamp(1.5rem,2.4vw,2rem);color:#23190f;margin:.5rem 0 .7rem}
.ab-value p{font-family:'Jost',sans-serif;font-weight:300;font-size:.9rem;line-height:1.8;color:#4a3e30}

/* 4 · fondateurs */
.ab-founders{max-width:1240px;margin:0 auto;padding:clamp(2.5rem,6vw,5rem) clamp(1.5rem,5vw,4rem) clamp(4rem,9vw,8rem)}
.ab-founders-title{font-family:'Cormorant Garamond',serif;font-style:italic;font-weight:500;font-size:clamp(2.2rem,4.5vw,3.6rem);color:#23190f;text-align:center;line-height:1.06;margin:1rem 0 clamp(3rem,6vw,5rem)}
.ab-founders-title em{color:#7a5a2e}
.ab-founder{display:grid;grid-template-columns:minmax(0,46%) 1fr;gap:clamp(2rem,5vw,5rem);align-items:start;margin-bottom:clamp(3.5rem,8vw,7rem)}
.ab-founder:last-child{margin-bottom:0}
.ab-reverse .ab-founder-photo{order:2}
.ab-founder-photo{align-self:start;position:relative;overflow:hidden;aspect-ratio:4/5;background:#241a0c}
.ab-founder-photo img{width:100%;height:100%;object-fit:cover;display:block;filter:grayscale(1);transition:transform 1.4s var(--ease-out),filter 1.4s var(--ease-out)}
.ab-founder:hover .ab-founder-photo img{transform:scale(1.05);filter:grayscale(0)}
.ab-founder-index{position:absolute;z-index:3;top:clamp(-.7rem,-1.4vw,-1.3rem);left:clamp(-.2rem,-.6vw,-.7rem);font-family:'Cormorant Garamond',serif;font-style:italic;font-weight:300;font-size:clamp(3rem,6vw,5.4rem);line-height:1;color:#FAF6EE;text-shadow:0 2px 26px rgba(0,0,0,.3);pointer-events:none}
.ab-founder-name{font-family:'Cormorant Garamond',serif;font-style:italic;font-weight:500;font-size:clamp(2.4rem,4.5vw,3.6rem);color:#23190f;line-height:1;margin:0}
.ab-founder-role{font-family:'Jost',sans-serif;font-weight:300;text-transform:uppercase;letter-spacing:.26em;font-size:.62rem;color:var(--gold);margin:.7rem 0 1.4rem}
.ab-founder-pull{font-family:'Cormorant Garamond',serif;font-style:italic;font-weight:400;font-size:clamp(1.2rem,1.9vw,1.55rem);line-height:1.42;color:#6a4a18;border-left:2px solid #cdb98e;padding-left:1.15rem;margin:0 0 1.7rem}
.ab-founder-bio p{font-family:'Jost',sans-serif;font-weight:300;font-size:.92rem;line-height:2;color:#4a3e30;margin:0 0 1.2rem;text-align:justify}
.ab-founder-bio p:last-child{margin-bottom:0}

/* 5 · clôture */
.ab-cta{position:relative;overflow:hidden;padding:clamp(4.5rem,11vw,8rem) clamp(1.5rem,5vw,3rem);text-align:center}
.ab-cta-bg{position:absolute;inset:0;background-size:cover;background-position:center}
.ab-cta-veil{position:absolute;inset:0;background:linear-gradient(180deg,rgba(18,11,4,.6),rgba(18,11,4,.8))}
.ab-cta-inner{position:relative;z-index:2;max-width:760px;margin:0 auto}
.ab-cta-eyebrow{font-family:'Jost',sans-serif;font-weight:300;font-size:.66rem;letter-spacing:.36em;text-transform:uppercase;color:var(--gold);margin-bottom:clamp(1.1rem,2.4vw,1.7rem)}
.ab-cta-title{font-family:'Cormorant Garamond',serif;font-weight:300;font-size:clamp(2.2rem,5vw,3.8rem);color:#FFFFF3;line-height:1.1}
.ab-cta-title em{font-style:italic;font-weight:500}
.ab-cta-btn{display:inline-block;margin-top:clamp(1.9rem,4vw,2.8rem);border:1px solid rgba(255,255,243,.55);color:#FFFFF3;padding:1.1rem 2.9rem;font-family:'Jost',sans-serif;font-weight:300;font-size:.72rem;letter-spacing:.26em;text-transform:uppercase;text-decoration:none;transition:background .5s var(--ease-out),color .5s var(--ease-out)}
.ab-cta-btn:hover{background:#FFFFF3;color:#311602}

/* reveal */
.js .ab-reveal{opacity:0;transform:translateY(34px);transition:opacity 1s var(--ease-out),transform 1s var(--ease-out)}
.js .ab-reveal.ab-in{opacity:1;transform:none}
.js .ab-band.ab-reveal .ab-band-bg{transform:scale(1.09);transition:transform 1.8s var(--ease-out)}
.js .ab-band.ab-in .ab-band-bg{transform:scale(1)}
@media(prefers-reduced-motion:reduce){.js .ab-reveal{opacity:1;transform:none;transition:none}.js .ab-band .ab-band-bg{transform:none}}

@media(max-width:860px){
  .ab-manifesto{grid-template-columns:1fr;gap:clamp(1.4rem,5vw,2rem)}
  .ab-values{grid-template-columns:1fr;gap:0}
  .ab-value{border-top:1px solid rgba(49,22,2,.14);padding:1.4rem 0}
  .ab-value:last-child{border-bottom:1px solid rgba(49,22,2,.14)}
  .ab-num{font-size:2.2rem}
  .ab-founder{grid-template-columns:1fr;gap:1.4rem;margin-bottom:clamp(3rem,11vw,4.5rem)}
  .ab-reverse .ab-founder-photo{order:0}
  .ab-founder-photo{aspect-ratio:4/3}
}

/* ── À propos v2 : hiérarchie resserrée ── */
.ab-intro{max-width:1200px;margin:0 auto;padding:clamp(3.2rem,6vw,5.5rem) clamp(1.5rem,5vw,4rem) clamp(2.8rem,5vw,4.5rem)}
.ab-manifesto{max-width:none;margin:0;padding:0}
.ab-approach{max-width:none;margin:clamp(2.4rem,5vw,3.8rem) 0 0;padding:clamp(2.4rem,5vw,3.6rem) 0 0;border-top:1px solid rgba(49,22,2,.14)}
.ab-values{margin-top:clamp(1.8rem,3.5vw,2.6rem)}

.ab-band{min-height:clamp(300px,48vh,480px);margin:0}

.ab-founders{padding:clamp(3rem,6vw,5rem) clamp(1.5rem,5vw,4rem)}
.ab-founders-head{text-align:center;max-width:680px;margin:0 auto clamp(2.6rem,5vw,4rem)}
.ab-founders-lede{font-family:'Cormorant Garamond',serif;font-style:italic;font-weight:400;font-size:clamp(1.3rem,2.4vw,1.9rem);line-height:1.42;color:#3a2f23;margin-top:1.1rem}
.ab-founder{margin-bottom:clamp(2.8rem,6vw,5rem)}

.ab-cta{position:static;overflow:visible;background:#F5F2E2;padding:clamp(3rem,6vw,4.6rem) clamp(1.5rem,5vw,3rem)}
.ab-cta-eyebrow{color:#a8895a}
.ab-cta-title{color:#2a1c0e}
.ab-cta-btn{border:1px solid #311602;color:#311602}
.ab-cta-btn:hover{background:#311602;color:#FFFFF3}

/* ── À propos v3 : intro mieux hiérarchisée ── */
.ab-lead{max-width:820px;margin-bottom:clamp(2.2rem,4.5vw,3.4rem)}
.ab-statement{font-size:clamp(1.9rem,3.6vw,3rem);line-height:1.12;margin:clamp(1rem,2vw,1.5rem) 0 0}
.ab-intro-text{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,4.5vw,4.5rem)}
.ab-intro-text p{font-family:'Jost',sans-serif;font-weight:300;font-size:clamp(.9rem,1vw,.98rem);line-height:1.95;color:#4a3e30;text-align:left;margin:0}
@media(max-width:760px){.ab-intro-text{grid-template-columns:1fr;gap:1.2rem}}

/* ── Menu : aucun logo affiché quand le menu est ouvert ── */
.menu-brand-top{display:none !important}

/* ── À propos v4 ── */
.ab-founders-head{text-align:left;max-width:none;margin:0 0 clamp(2.4rem,5vw,3.6rem)}
.ab-founders-lede{font-family:'Cormorant Garamond',serif;font-style:italic;font-weight:500;font-size:clamp(1.5rem,2.7vw,2.2rem);line-height:1.16;color:#23190f;max-width:34ch;margin-top:clamp(1rem,2vw,1.4rem)}
.ab-approach{border-top:0;padding-top:0;margin-top:clamp(2.6rem,5vw,4.2rem)}

/* ══════════════════════════════
   RÉSERVATION — repensée
══════════════════════════════ */
@media(min-width:861px){.rsv-grid{grid-template-columns:1.1fr .9fr}}
.rsv-form-eyebrow{display:flex;align-items:center;gap:.8rem;font-family:'Jost',sans-serif;font-weight:300;font-size:.64rem;letter-spacing:.28em;text-transform:uppercase;color:#a8895a;margin-bottom:.9rem}
.rsv-form-eyebrow::before{content:'';width:32px;height:1px;background:#cdb98e;flex:0 0 auto}
.rsv-form .rsv-form-h{font-family:'Cormorant Garamond',serif;font-style:italic;font-weight:400;font-size:clamp(1.9rem,3.4vw,2.6rem);color:#23190f;margin-bottom:clamp(1.4rem,3vw,2rem)}
.rsv-right{position:relative}
.rsv-right-stack{position:sticky;top:86px;display:flex;flex-direction:column;gap:clamp(1.2rem,2vw,1.6rem)}
.rsv-card{background:#fff;border:1px solid rgba(49,22,2,.12);box-shadow:0 34px 70px -46px rgba(49,22,2,.45);overflow:hidden}
.rsv-card .rsv-photo-frame{aspect-ratio:16/10}
.rsv-card-body{padding:clamp(1.5rem,2.8vw,2.1rem)}
.rsv-card-eyebrow{font-family:'Jost',sans-serif;font-weight:400;font-size:.68rem;letter-spacing:.26em;text-transform:uppercase;color:#a8895a}
.rsv-card-title{font-family:'Cormorant Garamond',serif;font-style:italic;font-weight:500;font-size:clamp(1.7rem,2.6vw,2.2rem);color:#23190f;line-height:1;margin:.4rem 0 .15rem}
.rsv-card-sub{font-family:'Cormorant Garamond',serif;font-style:italic;font-weight:400;font-size:1.05rem;color:#6a5a45;margin-bottom:1.2rem}
.rsv-recap{border-top:1px solid rgba(49,22,2,.12)}
.rsv-recap-row{display:flex;justify-content:space-between;gap:1rem;padding:.72rem 0;border-bottom:1px solid rgba(49,22,2,.1)}
.rsv-recap-k{font-family:'Jost',sans-serif;font-weight:300;font-size:.68rem;letter-spacing:.14em;text-transform:uppercase;color:#857457}
.rsv-recap-v{font-family:'Cormorant Garamond',serif;font-weight:400;font-size:1.08rem;color:#2c2114}
.rsv-total-line{display:flex;align-items:baseline;justify-content:space-between;gap:1rem;margin-top:1.2rem}
.rsv-total-line .rsv-total-label{font-family:'Jost',sans-serif;font-weight:500;font-size:.82rem;letter-spacing:.2em;text-transform:uppercase;color:#a8895a;margin:0}
.rsv-card .rsv-price{font-size:clamp(2rem,3.6vw,2.7rem)}
.rsv-card .rsv-taxes{margin:.75rem 0 1.3rem}
@media(max-width:860px){.rsv-right-stack{position:static}}

/* ══════════════════════════════
   PAIEMENT — récap d'abord, plus gros
══════════════════════════════ */
.pay-recap{max-width:920px;margin:0 auto clamp(2.6rem,5vw,4.2rem)}
.pay-recap-eyebrow{display:flex;align-items:center;gap:.85rem;font-family:'Jost',sans-serif;font-weight:300;font-size:.66rem;letter-spacing:.3em;text-transform:uppercase;color:#a8895a}
.pay-recap-eyebrow::before{content:'';width:36px;height:1px;background:#cdb98e}
.pay-recap-h{font-family:'Cormorant Garamond',serif;font-style:italic;font-weight:500;font-size:clamp(2rem,4vw,3.2rem);color:#23190f;line-height:1.04;margin:.7rem 0 clamp(1.6rem,3vw,2.4rem)}
.pay-recap-card{display:grid;grid-template-columns:minmax(0,46%) 1fr;background:#EFEADF;overflow:hidden;align-items:stretch;border:1px solid rgba(49,22,2,.1)}
.pay-recap-photo{position:relative;min-height:clamp(300px,40vh,460px)}
.pay-recap-photo img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform 1.2s var(--ease-out)}
.pay-recap-card:hover .pay-recap-photo img{transform:scale(1.04)}
.pay-recap-body{padding:clamp(1.7rem,3.2vw,2.8rem);display:flex;flex-direction:column}
.pay-recap-body .pay-escale{margin:.5rem 0 .4rem;font-size:clamp(1.5rem,2.6vw,2.05rem)}
.pay-recap-rows{margin:clamp(1.2rem,2.4vw,1.7rem) 0 .4rem;border-top:1px solid rgba(49,22,2,.14);display:grid;grid-template-columns:max-content 1fr;column-gap:1.1rem;align-items:stretch}
.pay-recap-row{display:contents}
.pay-recap-k{font-family:'Jost',sans-serif;font-weight:300;font-size:.68rem;letter-spacing:.14em;text-transform:uppercase;color:#857457;align-self:start;padding:.6rem 0;border-bottom:1px solid rgba(49,22,2,.1)}
.pay-recap-v{font-family:'Cormorant Garamond',serif;font-weight:400;font-size:1.05rem;color:#2c2114;text-align:right;padding:.6rem 0;border-bottom:1px solid rgba(49,22,2,.1)}
.pay-recap-prices{margin:1rem 0 .2rem}
.pay-price-row{display:flex;justify-content:space-between;gap:1rem;padding:.32rem 0;font-family:'Jost',sans-serif;font-weight:300;font-size:.86rem;color:#473d31}
.pay-recap-total{display:flex;align-items:baseline;justify-content:space-between;gap:1rem;border-top:1px solid rgba(49,22,2,.2);margin-top:.7rem;padding-top:1rem}
.pay-recap-total .pay-total-label{font-family:'Jost',sans-serif;font-weight:300;font-size:.74rem;letter-spacing:.2em;text-transform:uppercase;color:#473d31}
.pay-recap-total .pay-total{font-size:clamp(1.9rem,3.4vw,2.7rem)}
.pay-reassure{display:flex;align-items:center;justify-content:center;gap:.6rem;text-align:center;font-family:'Jost',sans-serif;font-weight:300;font-size:.92rem;color:#5c6b46;margin-top:clamp(1.3rem,2.6vw,1.9rem)}
.pay-reassure-check{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:50%;background:#5c6b46;color:#FAF6EE;font-size:.7rem;flex:0 0 auto}
.pay-pay{max-width:720px;margin:0 auto}
@media(max-width:760px){
  .pay-recap-card{grid-template-columns:1fr}
  .pay-recap-photo{min-height:0;aspect-ratio:3/2}
}

/* ── Paiement v2 : mise en page aboutie ── */
.pay-recap{max-width:880px}
.pay-recap-eyebrow{margin-bottom:clamp(1.3rem,2.6vw,1.9rem)}
.pay-recap-body{justify-content:center}
.pay-pay{max-width:760px}
.pay-foot{margin-top:clamp(1.8rem,3.4vw,2.6rem)}
.pay-foot-total{display:flex;align-items:baseline;justify-content:space-between;gap:1rem;padding-bottom:1.1rem;margin-bottom:1.3rem;border-bottom:1px solid rgba(49,22,2,.18)}
.pay-foot-total-lbl{font-family:'Jost',sans-serif;font-weight:300;font-size:.74rem;letter-spacing:.2em;text-transform:uppercase;color:#473d31}
.pay-foot-total-val{font-family:'Cormorant Garamond',serif;font-weight:500;font-size:clamp(1.6rem,2.8vw,2.1rem);color:#23190f}
.pay-foot .pay-confirm{margin-top:0}
.pay-secure{display:flex;align-items:center;justify-content:center;gap:.5rem;margin-top:1rem;font-family:'Jost',sans-serif;font-weight:300;font-size:.78rem;letter-spacing:.03em;color:#857457}
.pay-lock{width:14px;height:14px;color:#a8895a;flex:0 0 auto}

/* ── Réservation : finitions ── */
.rsv-form .rsv-form-h{margin-bottom:.65rem}
.rsv-form-intro{font-family:'Cormorant Garamond',serif;font-style:italic;font-weight:400;font-size:clamp(1.02rem,1.5vw,1.2rem);line-height:1.5;color:#6a5a45;margin:0 0 clamp(1.5rem,3vw,2.1rem)}
.rsv-assurance{list-style:none;display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(.9rem,2vw,1.6rem);margin:clamp(1.7rem,3vw,2.4rem) 0 0;padding:0}
.rsv-assurance-item{display:flex;align-items:center;gap:.65rem;font-family:'Jost',sans-serif;font-weight:300;font-size:.76rem;line-height:1.35;color:#473d31}
.rsv-assurance-ic{width:19px;height:19px;color:#a8895a;flex:0 0 auto}
@media(max-width:560px){.rsv-assurance{grid-template-columns:1fr;gap:.85rem}}

/* ── Bourgogne : photos de la frise agrandies (frise conservée) ── */
.vy-itin{max-width:1140px}
.vy-photo-frame{width:100%;aspect-ratio:4/3}
.vy-day{padding-bottom:clamp(2.8rem,5.5vw,4.5rem)}
.vy-day-inner{gap:1.1rem}

/* ── Bourgogne : photos du programme mises en valeur ── */
.vy-photo-frame{border:0;box-shadow:0 26px 54px -34px rgba(49,22,2,.55)}
.vy-photo-frame:hover{box-shadow:0 30px 60px -32px rgba(49,22,2,.62)}

/* ── Bourgogne : intro éditoriale + FRISE HORIZONTALE ── */
.vy-intro{max-width:860px}
.vy-intro-text{font-family:'Cormorant Garamond',serif;font-style:italic;font-weight:400;font-size:clamp(1.3rem,2.2vw,1.85rem);line-height:1.5;color:#3a2f20}

.vy-itin-hint{font-family:'Jost',sans-serif;font-weight:300;font-size:.66rem;letter-spacing:.2em;text-transform:uppercase;color:#a8895a;margin-top:.9rem}
.vy-htl{position:relative;margin-top:clamp(1.6rem,3vw,2.6rem)}
.vy-htl-track{display:flex;gap:clamp(1.4rem,2.6vw,2.6rem);overflow-x:auto;scroll-snap-type:x proximity;padding:.5rem clamp(1.5rem,5vw,3rem) 1.7rem;scrollbar-width:thin;scrollbar-color:rgba(196,169,106,.6) transparent}
.vy-htl-track::-webkit-scrollbar{height:3px}
.vy-htl-track::-webkit-scrollbar-track{background:rgba(49,22,2,.08)}
.vy-htl-track::-webkit-scrollbar-thumb{background:rgba(196,169,106,.7);border-radius:3px}
.vy-hday{position:relative;flex:0 0 clamp(258px,28vw,330px);scroll-snap-align:start;display:flex;flex-direction:column}
.vy-hmark{position:relative;display:flex;align-items:center;gap:.7rem;height:30px;margin-bottom:1rem}
.vy-hmark::before{content:'';position:absolute;left:0;top:50%;width:calc(100% + clamp(1.4rem,2.6vw,2.6rem));height:1px;background:rgba(49,22,2,.22);z-index:0}
.vy-hday:last-child .vy-hmark::before{width:100%}
.vy-hnode{position:relative;z-index:2;width:9px;height:9px;border-radius:50%;background:#C4A96A;border:2px solid #FAF6EE;flex:0 0 auto}
.vy-hnum{position:relative;z-index:2;background:#FAF6EE;padding-right:.7rem;font-family:'Jost',sans-serif;font-weight:300;font-size:.62rem;letter-spacing:.24em;text-transform:uppercase;color:#a8895a}
.vy-hphoto-frame{position:relative;overflow:hidden;width:100%;aspect-ratio:3/2;flex-shrink:0}
.vy-hphoto{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block;transition:transform 1.2s var(--ease-out)}
.vy-hday:hover .vy-hphoto{transform:scale(1.06)}
.vy-htext{padding-top:1.1rem;flex:1;display:flex;flex-direction:column}
.vy-hplace{font-family:'Cormorant Garamond',serif;font-weight:500;font-size:clamp(1.35rem,1.9vw,1.7rem);letter-spacing:.04em;color:#23190f;line-height:1.1;margin:0 0 .35rem}
.vy-hdate{display:block;font-family:'Jost',sans-serif;font-weight:300;font-size:.72rem;letter-spacing:.05em;color:#9a8b72;margin-bottom:.65rem}
.vy-hdetail{font-family:'Jost',sans-serif;font-weight:300;font-size:.84rem;line-height:1.6;color:#473d31;margin:0 0 .35rem}
.vy-hdetail:last-child{margin-bottom:0}
.vy-htl::after{content:'';position:absolute;top:0;right:0;bottom:1.7rem;width:60px;background:linear-gradient(90deg,rgba(250,246,238,0),#FAF6EE);pointer-events:none;z-index:3}
@media(max-width:700px){.vy-hday{flex-basis:78vw}.vy-htl::after{width:32px}}

/* ── Bourgogne v3 : plus éditorial / désirable ── */
/* intro un peu plus petite */
.vy-intro-text{font-size:clamp(1.05rem,1.7vw,1.42rem)}

/* frise : navigation souris */
.vy-htl-track{cursor:grab}
.vy-htl-track.drag{cursor:grabbing;scroll-snap-type:none}
.vy-htl-track.drag .vy-hphoto{transition:none}
.vy-htl-nav{display:flex;justify-content:center;gap:.7rem;margin-top:clamp(1.2rem,2.5vw,1.7rem)}
.vy-htl-arrow{width:46px;height:46px;border-radius:50%;border:1px solid rgba(49,22,2,.28);background:transparent;color:#5a4a2e;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .4s var(--ease-out),color .4s var(--ease-out),border-color .4s var(--ease-out),opacity .3s}
.vy-htl-arrow svg{width:17px;height:17px}
.vy-htl-arrow:hover{background:#311602;border-color:#311602;color:#FFFFF3}
.vy-htl-arrow:disabled{opacity:.28;cursor:default;background:transparent;color:#5a4a2e;border-color:rgba(49,22,2,.28)}
@media(max-width:700px){.vy-htl-nav{display:none}.vy-htl-track{cursor:auto}}

/* bande cinématographique */
.vy-band{position:relative;overflow:hidden;min-height:clamp(340px,60vh,600px);display:flex;align-items:center;justify-content:center;margin:clamp(1rem,2.5vw,2.5rem) 0}
.vy-band-bg{position:absolute;inset:0;background-size:cover;background-position:center;transform:scale(1.02)}
.vy-band-veil{position:absolute;inset:0;background:linear-gradient(180deg,rgba(18,11,4,.48),rgba(18,11,4,.66))}
.vy-band-inner{position:relative;z-index:2;max-width:940px;text-align:center;padding:0 clamp(1.5rem,5vw,3rem)}
.vy-band-eyebrow{font-family:'Jost',sans-serif;font-weight:300;font-size:.66rem;letter-spacing:.3em;text-transform:uppercase;color:#e7d09d;margin-bottom:clamp(1.1rem,2.4vw,1.7rem)}
.vy-band-q{font-family:'Cormorant Garamond',serif;font-style:italic;font-weight:400;font-size:clamp(1.7rem,3.6vw,3rem);line-height:1.3;color:#FFFFF3;margin:0;text-shadow:0 2px 34px rgba(0,0,0,.4)}
.vy-band-q em{color:#e7d09d}

/* barre Réserver flottante */
.vy-bookbar{position:fixed;left:0;right:0;bottom:0;z-index:200;transform:translateY(110%);transition:transform .55s var(--ease-out);pointer-events:none}
.vy-bookbar.show{transform:none;pointer-events:auto}
body.menu-open .vy-bookbar{transform:translateY(110%)!important}
.vy-bookbar-inner{display:flex;align-items:center;justify-content:space-between;gap:1.4rem;background:rgba(26,16,8,.94);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);padding:.85rem clamp(1.2rem,4vw,3rem);box-shadow:0 -18px 44px -26px rgba(0,0,0,.7)}
.vy-bookbar-name{font-family:'Cormorant Garamond',serif;font-style:italic;font-weight:500;font-size:1.35rem;color:#FFFFF3;margin-right:.85rem}
.vy-bookbar-meta{font-family:'Jost',sans-serif;font-weight:300;font-size:.78rem;letter-spacing:.07em;color:rgba(255,255,243,.72)}
.vy-bookbar-btn{flex:0 0 auto;font-family:'Jost',sans-serif;font-weight:300;font-size:.7rem;letter-spacing:.24em;text-transform:uppercase;color:#1c1407;background:#C4A96A;padding:.95rem 2.2rem;text-decoration:none;transition:background .4s var(--ease-out)}
.vy-bookbar-btn:hover{background:#FFFFF3}
@media(max-width:600px){.vy-bookbar-meta{display:none}.vy-bookbar-inner{padding:.7rem .9rem .7rem 1.1rem}.vy-bookbar-btn{padding:.85rem 1.4rem;letter-spacing:.18em}.vy-bookbar-name{font-size:1.15rem}}

/* ── Bourgogne v4 : frise vue d'ensemble + hôtels agrandis ── */
/* frise : photos un peu moins hautes (paysage), flèches en superposition */
.vy-hday{flex-basis:clamp(300px,33vw,410px)}
.vy-hphoto-frame{width:100%;aspect-ratio:3/2}
.vy-htl-arrow{position:absolute;top:50%;transform:translateY(-50%);z-index:6;background:rgba(250,246,238,.93);backdrop-filter:blur(5px);-webkit-backdrop-filter:blur(5px);border:1px solid rgba(49,22,2,.16);box-shadow:0 12px 30px -14px rgba(49,22,2,.5)}
.vy-htl-arrow.prev{left:clamp(.4rem,1.5vw,1.4rem)}
.vy-htl-arrow.next{right:clamp(.4rem,1.5vw,1.4rem)}
.vy-htl-arrow:hover{background:#311602;border-color:#311602;color:#FFFFF3}
.vy-htl-arrow:disabled{opacity:.32;pointer-events:none}
@media(max-width:700px){.vy-htl-arrow{display:none}}

/* hôtels : grandes photos côte à côte */
.vy-stay{display:block}
.vy-stay-intro{max-width:680px;margin:0 auto clamp(2.4rem,5vw,3.4rem);text-align:center}
.vy-stay-p{max-width:520px;margin:0 auto}
.vy-stay-cards{display:grid;grid-template-columns:1fr 1fr;gap:clamp(1.6rem,3.2vw,2.8rem)}
.vy-hotel{flex-direction:column;align-items:stretch;gap:0}
.vy-hotel-imgwrap{width:100%;max-width:none;aspect-ratio:3/2;box-shadow:0 26px 54px -36px rgba(49,22,2,.5)}
.vy-hotel-info{flex:none;padding-top:1.2rem}
.vy-hotel-name{font-size:clamp(1.5rem,2.4vw,1.95rem)}
@media(max-width:760px){.vy-stay-cards{grid-template-columns:1fr;gap:2rem}}

/* ── Bourgogne : retouches finales ── */
/* 1) masquer la barre de défilement sous la frise (flèches + glisser suffisent) */
.vy-htl-track{scrollbar-width:none;-ms-overflow-style:none}
.vy-htl-track::-webkit-scrollbar{display:none;height:0;width:0}
/* 3) supprimer la marge blanche entre la bande citation et les hôtels */
.vy-band{margin-bottom:0}

/* ── Bourgogne : flèches de frise plus discrètes & élégantes ── */
.vy-htl-arrow{width:42px;height:42px;border:1px solid rgba(255,255,243,.38);background:rgba(26,16,8,.24);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);color:#FFFFF3;box-shadow:none;transition:background .45s var(--ease-out),border-color .45s var(--ease-out),transform .45s var(--ease-out)}
.vy-htl-arrow svg{width:14px;height:14px}
.vy-htl-arrow svg path{stroke-width:1.2}
.vy-htl-arrow:hover{background:rgba(26,16,8,.46);border-color:rgba(255,255,243,.7);color:#FFFFF3;transform:translateY(-50%) scale(1.07)}
.vy-htl-arrow:disabled{opacity:.22;pointer-events:none}

/* ── Correctifs : barres du menu identiques + flèche footer ── */
.bar{height:1px}
.footer-email-row{align-items:center;padding-bottom:.45rem}
.footer-email-btn{width:30px;height:30px}

/* ── Accueil : proportions agrandies (réf. maquette) ── */
.hero-logo{width:clamp(320px,76vw,1440px);margin-bottom:clamp(1.6rem,3vw,2.8rem)}
.hero-subtitle{font-size:clamp(1.05rem,2vw,1.7rem);max-width:900px;line-height:1.6}
.hero-cta{font-size:clamp(.66rem,.9vw,.8rem);letter-spacing:.22em;padding:1.05em 2.6em;margin-top:clamp(2rem,3.2vw,2.8rem)}
.hero-raisin{width:clamp(90px,9.5vw,140px)}

/* ═══════════════════════════════════════════
   ACCESSIBILITÉ — libellés de section plus grands & plus contrastés
   (lisibilité, notamment pour les personnes âgées)
═══════════════════════════════════════════ */
/* — étiquettes/surtitres dorés sur fond clair — */
.vy-fact-label,.vy-eyebrow,.ab-eyebrow,.ab-cta-eyebrow,.rsv-form-eyebrow,
.rsv-card-eyebrow,.pay-recap-eyebrow,.pay-escale-lbl,.gal-side-eyebrow,
.gal-empty-eyebrow,.vsm-eyebrow,.nd-copy-eyebrow,.nd-figure-cap,.vy-itin-hint,
.vy-hnum,.vy-host-tag,.vy-hotel-tag,.popup-eyebrow{
  font-size:.8rem;font-weight:400;letter-spacing:.2em;color:#856326
}
/* — étiquettes neutres sur fond clair (formulaires, récap) — */
.rsv-field-lbl,.rsv-recap-k,.pay-recap-k,.pay-foot-total-lbl,
.vy-fact-sub,.vy-hdate,.pay-price-row{
  font-size:.8rem;font-weight:400;color:#473A28
}
/* — étiquettes sur fond sombre (hero, bande, footer, barre) : on éclaircit — */
.about-hero-eyebrow,.nd-hero-eyebrow{
  font-size:clamp(.78rem,1vw,.9rem);font-weight:400;letter-spacing:.26em;color:#E6D3A0
}
.vy-band-eyebrow,.nd-cta-eyebrow{font-size:.82rem;font-weight:400;color:#E6D3A0}
.footer-col-title{font-size:.84rem;font-weight:500;color:#FFFFF3}
.vy-bookbar-meta{font-size:.85rem;color:rgba(255,255,243,.9)}
.nd-soon-tag{font-size:.74rem;font-weight:400}
/* — liens & textes du footer : meilleur contraste — */
.footer-links li a{font-size:.8rem;color:rgba(255,255,243,.82)}
.footer-newsletter-desc{font-size:.8rem;color:rgba(255,255,243,.72)}
.footer-email-input{font-size:.72rem}
.footer-email-input::placeholder{color:rgba(255,255,243,.6)}

/* ── Compléments lisibilité + hiérarchie frise ── */
/* rôles des fondateurs (À propos) */
.ab-founder-role{font-size:.8rem;font-weight:400;letter-spacing:.2em;color:#856326}
/* page avis : libellé "L'esprit…" + dates */
.tem-pull-label{font-size:.8rem;font-weight:400;letter-spacing:.26em;color:#856326}
.tem-card-name{font-size:.78rem;font-weight:400;color:#2c2114}
.tem-card-date{font-size:1.02rem;color:#7a6a4e}
/* Bourgogne : sous-mentions ("Transport sur place inclus"…) */
.vy-fact-sub{font-size:.9rem}
/* menu : libellés & dates plus grands et plus clairs (fond sombre) */
.m-label,.m-divider-lbl{font-size:.7rem;color:#C4A96A}
.voy-date{font-size:.72rem;color:#C4A96A;letter-spacing:.12em}
.voy-status{font-size:.76rem}
.voy-sub{font-size:.82rem;color:rgba(255,255,243,.6)}
/* frise : distinguer la DATE (libellé doré) de l'ACTIVITÉ (texte foncé) */
.vy-hdate{font-family:'Jost',sans-serif;font-weight:400;font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:#856326;margin-bottom:.55rem}
.vy-hdetail{font-family:'Jost',sans-serif;font-weight:400;font-size:.92rem;line-height:1.55;color:#2c2114}

/* ── Frise Bourgogne : ce ne sont PAS des surtitres ── */
/* Texte d'aide : indication discrète (pas un libellé doré) */
.vy-itin-hint{text-transform:none;letter-spacing:.02em;font-weight:400;font-size:.85rem;color:#6e5f47}
/* Date de l'étape : "dateline" en italique serif (≠ libellé, ≠ activité) */
.vy-hdate{font-family:'Jost',sans-serif;font-style:normal;font-weight:300;text-transform:none;letter-spacing:.06em;font-size:.8rem;color:#7a5616;margin-bottom:.85rem}

/* Frise : interligne resserré pour les activités */
.vy-hdetail{line-height:1.38;margin-bottom:.3rem}

/* ═══ MENU réorganisé : voyages en avant (gauche), reste (droite) ═══ */
@media(min-width:700px){.menu-overlay{grid-template-columns:1.12fr .88fr}}
/* Colonne gauche — les voyages sont la priorité visuelle */
.voy{padding:clamp(.6rem,1.5vh,1.15rem) 0}
.voy-date{display:block;font-size:.7rem;letter-spacing:.16em;color:#C4A96A;margin:0 0 .4rem;white-space:normal}
.voy-name{display:block;font-size:clamp(1.7rem,3.4vw,2.6rem);line-height:1.05}
.voy-sub{font-size:.92rem;margin-top:.35rem}
.menu-col-left a.sb-mesure{margin-top:clamp(1rem,2.6vh,2.4rem)}
/* Colonne droite — navigation secondaire, réseaux réduits */
.m-nav li a{font-size:clamp(1.3rem,2.1vw,1.7rem)}
.m-nav{margin-bottom:1.9rem}
@media(max-width:699px){.m-nav li a{padding:.62rem 0;line-height:1.2}}
.soc{display:flex;gap:1.7rem;margin-bottom:2rem}
.soc li a{font-size:.95rem}

/* Menu : titres CONTACT / ADRESSE identiques aux autres */
.c-lbl{font-size:.7rem;color:#C4A96A;letter-spacing:.2em;border-bottom:0;padding-bottom:0;margin-bottom:.5rem}

/* ═══ Mention légale / confiance (permis Québec + Globe Tourisme) mise en valeur ═══ */
/* — dans le menu (fond sombre) — */
.c-trust{display:flex;align-items:flex-start;gap:.7rem;margin-top:2rem;padding-top:1.3rem;border-top:1px solid var(--border)}
.c-trust-ic{width:22px;height:22px;flex:0 0 auto;color:#C4A96A;margin-top:.1rem}
.c-trust-txt{font-family:'Jost',sans-serif;font-weight:300;font-size:.7rem;line-height:1.6;color:rgba(255,255,243,.6);margin:0}
.c-trust-txt strong{font-weight:400;color:rgba(255,255,243,.85)}
.c-trust-permit{display:block;margin-top:.2rem;color:#C4A96A;letter-spacing:.04em}
/* — dans le footer (fond sombre, présent sur toutes les pages dont paiement) — */
.footer-trust{display:flex;align-items:center;gap:.7rem;margin-top:clamp(2rem,4vw,3rem);padding-top:1.5rem;border-top:1px solid rgba(255,255,243,.12)}
.footer-trust-ic{width:24px;height:24px;color:#C4A96A;flex:0 0 auto}
.footer-trust-txt{font-family:'Jost',sans-serif;font-weight:300;font-size:.82rem;letter-spacing:.03em;color:rgba(255,255,243,.7);margin:0}
.footer-trust-txt strong{font-weight:400;color:#FFFFF3}
.footer-trust-permit{color:#C4A96A}
/* éviter le double séparateur juste sous le bloc confiance */
.footer-bottom{border-top:0;margin-top:1.4rem}

/* Lien partenaire (mention confiance) */
.trust-link{color:inherit;text-decoration:none;border-bottom:1px solid rgba(220,196,136,.45);transition:border-color .25s var(--ease-out),color .25s var(--ease-out)}
.trust-link:hover{border-color:#C4A96A;color:#C4A96A}
.trust-link strong{color:inherit}

/* Étalonnage "cinématographique" des photos de header (Bourgogne, Témoignages) */
.about-hero-bg.hero-graded{filter:contrast(1.1) saturate(1.18) brightness(1.02) sepia(.07)}

/* Paiement : bloc coordonnées */
.pay-contact{margin-bottom:2.4rem}
.pay-contact-note{font-family:'Jost',sans-serif;font-weight:300;font-size:.78rem;line-height:1.5;color:#857457;margin:.1rem 0 0}

/* Réservation : prix par chambre + détail + total dynamique */
.rsv-opt-price{color:#856326;font-size:.82em;margin-left:.3rem}
.rsv-csel.is-locked{opacity:.6}
.rsv-csel.is-locked .rsv-csel-trigger{cursor:not-allowed}
.rsv-breakdown{margin-top:.4rem;padding-top:.9rem;border-top:1px solid rgba(49,22,2,.14)}
.rsv-select-msg{font-family:'Jost',sans-serif;font-weight:400;font-size:.78rem;color:#9a4a2a;margin:.2rem 0 .9rem}
/* Confirmation : montant réglé */
.cf-total{display:flex;align-items:baseline;justify-content:space-between;gap:1rem;margin:0}
.cf-total-lbl{font-family:'Jost',sans-serif;font-weight:400;font-size:.74rem;letter-spacing:.18em;text-transform:uppercase;color:#856326}
.cf-total-val{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:1.5rem;color:#23190f}

/* ══════════════════════════════
   MENU — colonnes pleine hauteur ; la liste des destinations défile,
   « Voyage sur mesure » reste juste en dessous (desktop)
══════════════════════════════ */
@media(min-width:700px){
  .menu-overlay{overflow:hidden}
  .menu-col-left,.menu-col-right{height:100vh;height:100dvh}
  .menu-col-left{display:flex;flex-direction:column;overflow:hidden}
  .menu-col-left>.m-inner{flex:1;min-height:0;display:flex;flex-direction:column}
  /* la liste prend sa hauteur naturelle puis défile si trop de destinations / écran court */
  .m-voyages{flex:0 1 auto;min-height:0;overflow-y:auto;overscroll-behavior:contain;margin-right:-.4rem;padding-right:1.4rem}
  /* le titre et « Voyage sur mesure » ne se compriment pas : seule la liste défile */
  .menu-col-left>.m-inner>.m-dest,
  .menu-col-left>.m-inner>.m-divider-lbl,
  .menu-col-left>.m-inner>.sb-mesure{flex:none}
  .menu-col-right{overflow-y:auto;overscroll-behavior:contain}
  .menu-col-right::-webkit-scrollbar{width:3px}
  .menu-col-right::-webkit-scrollbar-thumb{background:rgba(196,169,106,.32);border-radius:3px}
}

/* ══════════════════════════════
   NOS DESTINATIONS — Galerie (palette de marque : brun · crème · or)
══════════════════════════════ */
.ndg{background:#FBF8F1;padding:clamp(2.2rem,5vw,3.8rem) clamp(1.3rem,4vw,3.4rem) clamp(1.8rem,3vw,3.2rem)}
.ndg-head{max-width:1360px;margin:0 auto clamp(1.7rem,3vw,2.6rem);display:flex;align-items:baseline;justify-content:space-between;gap:.8rem;flex-wrap:wrap;border-top:1px solid rgba(49,22,2,.16);padding-top:clamp(1rem,2vw,1.5rem)}
.ndg-head-eyebrow{font-family:'Jost',sans-serif;font-weight:300;font-size:.66rem;letter-spacing:.3em;text-transform:uppercase;color:#a8895a}
.ndg-head-count{font-family:'Cormorant Garamond',serif;font-style:italic;font-weight:400;font-size:clamp(1.05rem,1.6vw,1.4rem);color:#8a7a60}

.ndg-grid{max-width:1360px;margin:0 auto;display:grid;grid-template-columns:1fr;gap:clamp(1.9rem,3vw,2.8rem) clamp(1.1rem,1.8vw,1.7rem)}
@media(min-width:600px){.ndg-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1080px){.ndg-grid{grid-template-columns:repeat(4,1fr)}}

.ndg-card{position:relative}
.ndg-media{position:relative;display:block;overflow:hidden;aspect-ratio:3/4;background:#241a0c;text-decoration:none;cursor:pointer}
.ndg-media img{width:100%;height:100%;object-fit:cover;display:block;transform:scale(1.02);transition:transform 1.5s var(--ease-out),filter 1.2s var(--ease-out)}
.ndg-card:hover .ndg-media img{transform:scale(1.07)}
/* voile chaud unificateur — harmonise des photos d'origines différentes */
.ndg-media::after{content:'';position:absolute;inset:0;pointer-events:none;background:linear-gradient(180deg,rgba(26,15,5,.22) 0%,rgba(26,15,5,0) 30%,rgba(26,15,5,.04) 58%,rgba(26,15,5,.66) 100%)}

/* plaque SAISON + DATE — différenciateur, en crème + filet or */
.ndg-badge{position:absolute;z-index:2;top:1rem;left:1rem;display:inline-flex;align-items:center;background:rgba(20,12,4,.5);-webkit-backdrop-filter:blur(7px);backdrop-filter:blur(7px);color:var(--cream);font-family:'Jost',sans-serif;font-weight:300;font-size:.64rem;letter-spacing:.16em;text-transform:uppercase;padding:.5rem .85rem;border-left:2px solid var(--gold)}
.ndg-tag{position:absolute;z-index:2;bottom:1rem;left:1rem;color:rgba(255,255,243,.85);font-family:'Jost',sans-serif;font-weight:300;font-size:.54rem;letter-spacing:.2em;text-transform:uppercase;padding:.4rem .7rem;border:1px solid rgba(255,255,243,.22);-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);background:rgba(20,12,4,.3)}
.ndg-tag.is-open{color:var(--gold);border-color:rgba(196,169,106,.55)}
.ndg-pin{position:absolute;z-index:2;right:1rem;bottom:1rem;width:42px;height:42px;border:1px solid rgba(255,255,243,.5);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--cream);transition:background .5s var(--ease-out),color .5s var(--ease-out),border-color .5s var(--ease-out)}
.ndg-pin svg{width:17px;height:17px}
.ndg-card:hover .ndg-pin{background:var(--cream);color:#311602;border-color:var(--cream)}

.ndg-body{padding-top:.95rem}
.ndg-name{font-family:'Cormorant Garamond',serif;font-style:italic;font-weight:500;font-size:clamp(1.6rem,2vw,2rem);color:#23190f;line-height:1.04;transition:color .35s var(--ease-out)}
.ndg-card:hover .ndg-name{color:#8a6d35}
.ndg-sub{font-family:'Cormorant Garamond',serif;font-style:italic;font-weight:400;font-size:1rem;color:#6a5a45;margin-top:.15rem}
.ndg-meta{margin-top:.65rem;padding-top:.6rem;border-top:1px solid rgba(49,22,2,.14);font-family:'Jost',sans-serif;font-weight:300;font-size:.7rem;letter-spacing:.05em;color:#6c5d48}
.ndg-meta strong{font-weight:400;color:#9a7b3a;letter-spacing:.08em}
.ndg-notify-link{display:inline-block;margin-top:.55rem;background:none;border:0;padding:0;cursor:pointer;font-family:'Jost',sans-serif;font-weight:300;font-size:.64rem;letter-spacing:.14em;text-transform:uppercase;color:#a8895a;text-decoration:underline;text-underline-offset:3px;transition:color .3s var(--ease-out)}
.ndg-notify-link:hover{color:#8a6d35}

/* MENU — distinction nette voyages ouverts / à venir */
.voy-status.s-open{color:#1E1105;background:#C4A96A;border-color:#C4A96A;font-weight:400}
.voy-status.s-soon{color:rgba(255,255,243,.72);border-color:rgba(255,255,243,.42);background:transparent}
.voy.clickable:has(.s-soon){opacity:.74}
.voy.clickable:has(.s-soon):hover{opacity:.92}

/* ══════════════════════════════
   NOS DESTINATIONS — version immersive (sombre, cinématographique)
══════════════════════════════ */
/* — Hero diaporama (Ken Burns + fondu enchaîné) — */
.nd-imm-hero{height:clamp(580px,92vh,1000px)}
.nd-imm-bg .nd-slide{position:absolute;inset:0;background-size:cover;background-position:center;opacity:0;
  animation:ndKen 24s var(--ease) infinite;will-change:opacity,transform;
  filter:contrast(1.06) saturate(1.14) brightness(.97) sepia(.06)}
.nd-imm-bg .nd-slide:nth-child(1){animation-delay:0s}
.nd-imm-bg .nd-slide:nth-child(2){animation-delay:8s}
.nd-imm-bg .nd-slide:nth-child(3){animation-delay:16s}
@keyframes ndKen{
  0%{opacity:0;transform:scale(1.05)}
  4%{opacity:1}
  29%{opacity:1}
  35%{opacity:0;transform:scale(1.13)}
  100%{opacity:0;transform:scale(1.05)}
}
/* voile qui fond vers le brun de la galerie */
.nd-imm-veil{background:linear-gradient(180deg,rgba(18,11,4,.34) 0%,rgba(18,11,4,.16) 36%,rgba(18,11,4,.58) 76%,#150d07 100%)}
.nd-imm-hero .about-hero-title{font-style:normal;font-size:clamp(3rem,8vw,6.4rem);line-height:.95;max-width:none}
.nd-imm-hero .about-hero-title em{font-style:italic;font-weight:500}
.nd-imm-hero .about-hero-lede{max-width:620px}
@media(max-width:700px){.nd-imm-hero{height:86vh;min-height:520px}}
@media(prefers-reduced-motion:reduce){
  .nd-imm-bg .nd-slide{animation:none}
  .nd-imm-bg .nd-slide:nth-child(1){opacity:1}
}

/* — Galerie sur fond brun profond — */
.ndg{background:radial-gradient(125% 78% at 50% 0%,#23160b 0%,#180f07 58%,#130c06 100%)}
.ndg-head{border-top-color:rgba(196,169,106,.22)}
.ndg-head-eyebrow{color:var(--gold)}
.ndg-head-count{color:rgba(255,255,243,.6)}
.ndg-media{box-shadow:0 30px 70px -36px rgba(0,0,0,.85);border:1px solid rgba(196,169,106,.07)}
.ndg-name{color:var(--cream)}
.ndg-card:hover .ndg-name{color:var(--gold)}
.ndg-sub{color:rgba(255,255,243,.52)}
.ndg-meta{color:rgba(255,255,243,.55);border-top-color:rgba(196,169,106,.2)}
.ndg-meta strong{color:#C4A96A}
.ndg-notify-link{color:var(--gold)}
.ndg-notify-link:hover{color:#ECD7A6}

/* — Bandeau-citation : flux continu, sans coupure claire — */
.nd-band{margin:0;min-height:clamp(380px,66vh,640px)}
.nd-band .vy-band-veil{background:linear-gradient(180deg,rgba(19,12,6,.62),rgba(19,12,6,.5) 45%,rgba(19,12,6,.74))}
@media(max-width:600px){.ndg-head{flex-direction:column;align-items:flex-start;gap:.5rem}.ndg-head-count{font-size:1.05rem}}

/* ══════════════════════════════
   NOS DESTINATIONS — cartes sensuelles (images qui respirent, texte structuré)
══════════════════════════════ */
.ndg-grid{gap:clamp(2.8rem,4vw,4rem) clamp(1.8rem,2.8vw,3rem)}
/* image épurée : pas de cartouches, ombre douce, voile très léger */
.ndg-media{aspect-ratio:4/5;border:0;box-shadow:0 42px 84px -46px rgba(0,0,0,.82)}
.ndg-media::after{background:linear-gradient(180deg,rgba(15,10,5,.12) 0%,rgba(15,10,5,0) 26%,rgba(15,10,5,0) 68%,rgba(15,10,5,.4) 100%)}
.ndg-media::before{content:none}

/* texte aéré et hiérarchisé */
.ndg-body{padding-top:1.4rem;display:flex;flex-direction:column;gap:.42rem}
.ndg-season{font-family:'Jost',sans-serif;font-weight:300;font-size:.62rem;letter-spacing:.26em;text-transform:uppercase;color:var(--gold);margin:0}
.ndg-name{font-family:'Cormorant Garamond',serif;font-style:italic;font-weight:500;font-size:clamp(1.7rem,2.1vw,2.15rem);line-height:1.04;color:var(--cream);margin:.12rem 0 0;transition:color .35s var(--ease-out)}
.ndg-sub{font-family:'Cormorant Garamond',serif;font-style:italic;font-weight:400;font-size:1.04rem;line-height:1.4;color:rgba(255,255,243,.5);margin:0}

.ndg-foot{margin-top:1rem;padding-top:.95rem;border-top:1px solid rgba(196,169,106,.18);display:flex;align-items:center;justify-content:space-between;gap:.9rem;flex-wrap:wrap}
.ndg-status{display:inline-flex;align-items:center;gap:.5rem;font-family:'Jost',sans-serif;font-weight:300;font-size:.6rem;letter-spacing:.2em;text-transform:uppercase;color:rgba(255,255,243,.5)}
.ndg-status::before{content:'';width:6px;height:6px;border-radius:50%;background:rgba(255,255,243,.3);flex:0 0 auto}
.ndg-status.is-open{color:var(--gold)}
.ndg-status.is-open::before{background:var(--gold);box-shadow:0 0 0 4px rgba(196,169,106,.16)}

.ndg-link{display:inline-flex;align-items:center;gap:.55rem;background:none;border:0;padding:0;cursor:pointer;font-family:'Jost',sans-serif;font-weight:300;font-size:.66rem;letter-spacing:.16em;text-transform:uppercase;color:rgba(255,255,243,.82);text-decoration:none;transition:color .35s var(--ease-out)}
.ndg-arrow{transition:transform .35s var(--ease-out)}
.ndg-card:hover .ndg-name,.ndg-card:hover .ndg-link,.ndg-link:hover{color:var(--gold)}
.ndg-card:hover .ndg-arrow{transform:translateX(5px)}

/* ══════════════════════════════
   NOS DESTINATIONS — galerie en vedette + magie (poussière dorée, tilt 3D)
══════════════════════════════ */
/* la galerie domine : plus d'ampleur */
.ndg{position:relative;overflow:hidden;isolation:isolate;padding-top:clamp(3rem,6vw,5.6rem);padding-bottom:clamp(3rem,6vw,5.4rem)}
.ndg-head,.ndg-grid{position:relative;z-index:2}

/* en-tête ample et marquant */
.ndg-head{display:block;border-top-color:rgba(196,169,106,.22)}
.ndg-head-eyebrow{display:block;margin-bottom:clamp(.7rem,1.4vw,1rem)}
.ndg-head-title{font-family:'Cormorant Garamond',serif;font-style:normal;font-weight:500;font-size:clamp(2rem,4.2vw,3.5rem);line-height:1.02;color:var(--cream);margin:0;max-width:16ch}
.ndg-head-title em{font-style:italic;font-weight:500;color:#E6D3A0}
@media(max-width:600px){.ndg-head{display:block}.ndg-head-title{font-size:clamp(1.9rem,8vw,2.6rem)}}

/* révélation en cascade */
.ndg-grid .ndg-card:nth-child(2){transition-delay:.09s}
.ndg-grid .ndg-card:nth-child(3){transition-delay:.18s}
.ndg-grid .ndg-card:nth-child(4){transition-delay:.27s}

/* tilt 3D + reflet lumineux */
.ndg-media{transition:transform .5s var(--ease-out),box-shadow .5s var(--ease-out);transform-style:preserve-3d;backface-visibility:hidden}
.ndg-card:hover .ndg-media{box-shadow:0 60px 110px -50px rgba(0,0,0,.92)}
.ndg-gleam{position:absolute;inset:0;z-index:5;pointer-events:none;opacity:0;transition:opacity .45s var(--ease-out);mix-blend-mode:screen}

@media(prefers-reduced-motion:reduce){.ndg-media{transition:none}}

/* CTA réduit : redevient secondaire */
.nd-cta{padding:clamp(2.3rem,4vw,3.4rem) clamp(1.5rem,5vw,3rem)}
.nd-cta-veil{background:linear-gradient(180deg,rgba(18,11,4,.72) 0%,rgba(18,11,4,.86) 100%)}
.nd-cta-eyebrow{margin-bottom:clamp(.7rem,1.5vw,1.1rem)}
.nd-cta-title{font-size:clamp(1.5rem,2.7vw,2.2rem);max-width:24ch}
.nd-cta-btn{margin-top:clamp(1.3rem,2.4vw,1.9rem);padding:.9rem 2.3rem}

/* images plus immersives (hauteur accrue) */
.ndg-media{aspect-ratio:2/3}

/* ══════════════════════════════
   MENU — titres "à venir" grisés comme Loire
══════════════════════════════ */
.voy.clickable:has(.s-soon) .voy-name{opacity:.32}

/* ══════════════════════════════
   NOS DESTINATIONS — TEST fond clair lumineux & chic
══════════════════════════════ */
.ndg{background:#FBF8F1}
.ndg-head{border-top-color:rgba(49,22,2,.16)}
.ndg-head-eyebrow{color:#a8895a}
.ndg-season{color:#9a7b3a}
.ndg-name{color:#23190f}
.ndg-card:hover .ndg-name{color:#8a6d35}
.ndg-sub{color:#6a5a45}
.ndg-foot{border-top-color:rgba(49,22,2,.14)}
.ndg-status{color:#6c5d48}
.ndg-status::before{background:rgba(49,22,2,.28)}
.ndg-status.is-open{color:#9a7b3a}
.ndg-status.is-open::before{background:#C4A96A;box-shadow:0 0 0 4px rgba(196,169,106,.18)}
.ndg-link{color:#311602}
.ndg-card:hover .ndg-link,.ndg-link:hover{color:#8a6d35}
.ndg-media{box-shadow:0 30px 64px -42px rgba(49,22,2,.42)}
.ndg-card:hover .ndg-media{box-shadow:0 46px 92px -46px rgba(49,22,2,.5)}
/* hero : raccord vers le clair (ne plus fondre vers le brun foncé) */
.nd-imm-veil{background:linear-gradient(180deg,rgba(18,11,4,.32) 0%,rgba(18,11,4,.15) 36%,rgba(18,11,4,.5) 76%,rgba(18,11,4,.82) 100%)}


/* ══════════════════════════════
   EN-TÊTE — logo à gauche, son + menu à droite
══════════════════════════════ */
.scroll-bar-inner{flex-direction:row}
.sb-right{display:flex;align-items:center;gap:clamp(14px,1.8vw,24px);pointer-events:auto}
.nav{left:auto;right:0;gap:clamp(14px,1.8vw,24px)}
.mbtn{gap:9px}
/* libellés à gauche de l'icône (sens inversé pour le côté droit) */
.mbtn .mbtn-labels{order:0}
.mbtn .bars-icon{order:1}
.mbtn.open .lbl-menu{transform:translateX(4px)}
.mbtn.open .lbl-close{transform:translateX(3px)}

/* ══════════════════════════════
   SON D'AMBIANCE — icône équaliseur
══════════════════════════════ */
.snd-toggle{background:none;border:0;padding:8px;margin:0;cursor:pointer;display:inline-flex;align-items:center;color:var(--cream);line-height:0;-webkit-tap-highlight-color:transparent;position:relative}
.snd-toggle.muted .snd-bars{opacity:.4}
.snd-toggle.muted::after{content:"";position:absolute;left:50%;top:50%;width:24px;height:1.6px;background:currentColor;border-radius:2px;transform:translate(-50%,-50%) rotate(-45deg);pointer-events:none}
.snd-bars{display:flex;align-items:center;gap:4.5px;height:28px}
.snd-bars span{display:block;width:1.2px;height:18px;background:currentColor;border-radius:1px;opacity:.85;transform-origin:50% 50%;transform:scaleY(.4);transition:transform .24s cubic-bezier(.16,1,.3,1),opacity .25s;will-change:transform;backface-visibility:hidden}
.snd-bars span:nth-child(5){display:none}                 /* 4 barres comme auwa */
.snd-bars span:nth-child(1){transform:scaleY(.45)}
.snd-bars span:nth-child(2){transform:scaleY(.82)}
.snd-bars span:nth-child(3){transform:scaleY(.55)}
.snd-bars span:nth-child(4){transform:scaleY(.7)}
.snd-toggle:hover .snd-bars span,.snd-toggle.playing .snd-bars span{opacity:1}

/* ══════════════════════════════
   CURSEUR PERSONNALISÉ — cercle + point central (doré)
══════════════════════════════ */
@media(hover:hover) and (pointer:fine){
  html,body{cursor:url("data:images/svg+xml,%3Csvg%20xmlns%3D%22http%3A//www.w3.org/2000/svg%22%20width%3D%2228%22%20height%3D%2228%22%20viewBox%3D%220%200%2028%2028%22%3E%3Ccircle%20cx%3D%2214%22%20cy%3D%2214%22%20r%3D%229%22%20fill%3D%22none%22%20stroke%3D%22%23C4A96A%22%20stroke-width%3D%221.4%22/%3E%3Ccircle%20cx%3D%2214%22%20cy%3D%2214%22%20r%3D%222.4%22%20fill%3D%22%23C4A96A%22/%3E%3C/svg%3E") 14 14,auto}
  a,button,[role="button"],.clickable,.voy.clickable,.ndg-media,.mbtn,.snd-toggle,.nd-cta-btn,label[for],summary,.rsv-csel{cursor:url("data:images/svg+xml,%3Csvg%20xmlns%3D%22http%3A//www.w3.org/2000/svg%22%20width%3D%2230%22%20height%3D%2230%22%20viewBox%3D%220%200%2030%2030%22%3E%3Ccircle%20cx%3D%2215%22%20cy%3D%2215%22%20r%3D%2210%22%20fill%3D%22none%22%20stroke%3D%22%23C4A96A%22%20stroke-width%3D%221.6%22/%3E%3Ccircle%20cx%3D%2215%22%20cy%3D%2215%22%20r%3D%223.4%22%20fill%3D%22%23C4A96A%22/%3E%3C/svg%3E") 15 15,pointer}
  .gal-slide{cursor:url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20width='40'%20height='40'%20viewBox='0%200%2040%2040'%3E%3Ccircle%20cx='20'%20cy='20'%20r='15'%20fill='rgba(30,17,5,0.35)'%20stroke='%23C4A96A'%20stroke-width='1.6'/%3E%3Cpath%20d='M20%2013v14M13%2020h14'%20stroke='%23C4A96A'%20stroke-width='1.6'%20stroke-linecap='round'/%3E%3C/svg%3E") 20 20,zoom-in}
  input,textarea,select{cursor:auto}
}

/* ══════════════════════════════
   CARTES — minimalistes (légende superposée façon éditorial)
══════════════════════════════ */
.ndg-media::after{content:none}
.ndg-grad{position:absolute;inset:0;z-index:1;pointer-events:none;background:linear-gradient(to top,rgba(14,9,4,.85) 0%,rgba(14,9,4,.42) 24%,rgba(14,9,4,.05) 46%,rgba(14,9,4,0) 62%)}
.ndg-cap{position:absolute;left:clamp(1.1rem,1.7vw,1.6rem);right:clamp(1.1rem,1.7vw,1.6rem);bottom:clamp(1.2rem,2vw,1.7rem);z-index:2;display:block;color:var(--cream)}
.ndg-cap-date{display:block;font-family:'Jost',sans-serif;font-weight:300;font-size:.6rem;letter-spacing:.26em;text-transform:uppercase;color:#EAD29A;margin-bottom:.5rem}
.ndg-cap-name{font-family:'Cormorant Garamond',serif;font-style:italic;font-weight:500;font-size:clamp(1.75rem,2.4vw,2.4rem);line-height:1;color:var(--cream);margin:0}
.ndg-cap-link{display:inline-flex;align-items:center;gap:.5rem;margin-top:.7rem;font-family:'Jost',sans-serif;font-weight:300;font-size:.62rem;letter-spacing:.18em;text-transform:uppercase;color:rgba(255,255,243,.82);transition:color .35s var(--ease-out)}
.ndg-cap-link i{font-style:normal;transition:transform .35s var(--ease-out)}
.ndg-card:hover .ndg-cap-link{color:#fff}
.ndg-card:hover .ndg-cap-link i{transform:translateX(5px)}

/* respiration sous la galerie (apaisement) */
.ndg{padding-bottom:clamp(5.5rem,12vw,11rem)}
.ndg-grid{margin-bottom:clamp(1.5rem,4vw,3.5rem)}

/* libellés menu : fondu sans décalage, "Fermer" au même espacement que "Menu" */
.mbtn-labels{text-align:right}
.lbl-menu{position:absolute;right:0;left:auto;top:0;opacity:1;transform:none;transition:opacity .3s}
.lbl-close{position:static;left:auto;display:inline-block;opacity:0;transform:none;transition:opacity .3s;white-space:nowrap}
.mbtn.open .lbl-menu{opacity:0;transform:none}
.mbtn.open .lbl-close{opacity:1;transform:none}
/* espacement constant comme menu */

/* ══════════════════════════════
   GALERIE — espace sous les cartes ≈ espace au-dessus
══════════════════════════════ */
.ndg-grid{margin-bottom:0}
.ndg{padding-bottom:calc(clamp(3rem,6vw,5.6rem) + 4.9rem)}

/* ══════════════════════════════
   CURSEUR ANIMÉ — anneau + point doré qui danse (organique)
══════════════════════════════ */
.vc-ring,.vc-dot{position:fixed;left:0;top:0;pointer-events:none;z-index:99999;opacity:0;transition:opacity .3s ease}
.vc-ring{width:28px;height:28px;border:1.4px solid #C4A96A;border-radius:50%;will-change:transform}
.vc-dot{width:6px;height:6px;background:#C4A96A;border-radius:50%;will-change:transform}
html.vcursor-on,html.vcursor-on *{cursor:none !important}
@media(hover:none),(pointer:coarse){.vc-ring,.vc-dot{display:none}}

/* ══════════════════════════════
   CARTES — lisibilité (texte sur photo) + différenciation
══════════════════════════════ */
/* Dégradé très doux : à peine perceptible, la photo respire */
.ndg-grad{background:linear-gradient(to top,rgba(12,8,3,.58) 0%,rgba(12,8,3,.24) 30%,rgba(12,8,3,.03) 54%,rgba(12,8,3,0) 70%)}
.ndg-media::after{content:none}
/* angles légèrement adoucis */
.ndg-media{border-radius:clamp(6px,.7vw,12px)}

/* beaucoup plus d'air autour du texte */
.ndg-cap{left:clamp(1.7rem,2.6vw,2.7rem);right:clamp(1.7rem,2.6vw,2.7rem);bottom:clamp(1.9rem,3vw,2.8rem);text-shadow:0 1px 14px rgba(0,0,0,.42)}

/* Date : un simple libellé qui flotte — sans boîte, sans ligne — sobre et calme */
.ndg-cap-date{
  display:block;
  font-family:'Jost',sans-serif;
  font-weight:300;
  font-size:clamp(.7rem,.85vw,.8rem);
  letter-spacing:.26em;
  text-transform:uppercase;
  white-space:nowrap;
  color:var(--cream);
  background:none;
  border:0;
  padding:0;
  -webkit-backdrop-filter:none;backdrop-filter:none;
  border-radius:0;
  margin:0 0 1.4rem;
  text-shadow:0 1px 10px rgba(0,0,0,.5);
}
/* Titre : plus grand, plus léger, plus posé */
.ndg-cap-name{font-weight:400;font-size:clamp(2rem,2.7vw,2.9rem);line-height:1.05}
/* Lien : discret, bien détaché du titre */
.ndg-cap-link{margin-top:1.3rem;font-size:.62rem;letter-spacing:.22em;color:rgba(255,255,243,.78)}

/* Nuance de saison portée discrètement par la photo seule (aucun voile coloré) */
.ndg-card[data-season="automne"] .ndg-media img{filter:saturate(1.06) brightness(.99)}
.ndg-card[data-season="printemps"] .ndg-media img{filter:saturate(1.0) brightness(1.05)}
.ndg-card[data-season="ete"] .ndg-media img{filter:saturate(1.03) brightness(1.02)}

/* ══════════════════════════════════════════════════
   CARTES — destination + lien SUR la photo, période DESSOUS
   seule la photo s'anime au survol
══════════════════════════════════════════════════ */
/* le lien-carte empile la figure (image) puis la période */
.ndg-card .ndg-media{display:block;position:static;aspect-ratio:auto;overflow:visible;background:none;box-shadow:none;border-radius:0;text-decoration:none;cursor:pointer}

/* figure = image + texte en surimpression ; angles vifs.
   Ratio unique : la hauteur suit toujours la largeur → la photo s'adapte à l'écran */
.ndg-card .ndg-fig{display:block;position:relative;overflow:hidden;aspect-ratio:3/5;border-radius:0;background:#241a0c;box-shadow:0 16px 40px -30px rgba(49,22,2,.3);transition:box-shadow .6s var(--ease-out),transform .6s var(--ease-out)}
.ndg-card .ndg-fig img{width:100%;height:100%;object-fit:cover;display:block;transform:scale(1.01);transition:transform 1.4s var(--ease-out),filter 1.2s var(--ease-out)}
/* le survol n'agit QUE sur la photo (pas sur la zone de texte en dessous) */
/* 1) on annule l'ancien zoom déclenché par le survol de la carte entière */
.ndg-card:hover .ndg-media img{transform:scale(1.01)}
/* 2) seul le survol de la photo s'anime : zoom + léger soulèvement */
.ndg-card .ndg-media .ndg-fig:hover img{transform:scale(1.05)}
.ndg-card .ndg-fig:hover{transform:translateY(-7px);box-shadow:0 30px 60px -34px rgba(49,22,2,.46)}
/* on neutralise tout ancien effet de survol porté par la carte entière */
.ndg-card:hover .ndg-media{box-shadow:none}

/* dégradé bas pour la lisibilité du texte blanc */
.ndg-card .ndg-fig .ndg-grad{position:absolute;inset:0;z-index:1;pointer-events:none;background:linear-gradient(to top,rgba(14,9,4,.74) 0%,rgba(14,9,4,.36) 24%,rgba(14,9,4,.05) 48%,rgba(14,9,4,0) 66%)}

/* surimpression : destination + lien, en bas à gauche */
.ndg-card .ndg-fig-cap{position:absolute;z-index:2;left:clamp(1.1rem,1.7vw,1.7rem);right:clamp(1.1rem,1.7vw,1.7rem);bottom:clamp(1.2rem,1.8vw,1.7rem);display:block;color:var(--cream);text-shadow:0 1px 18px rgba(0,0,0,.4)}
.ndg-card .ndg-cap-name{font-family:'Cormorant Garamond',serif;font-style:italic;font-weight:500;font-size:clamp(1.7rem,2.3vw,2.45rem);line-height:1.02;color:var(--cream);margin:0}
.ndg-card .ndg-cap-link{display:inline-flex;align-items:center;gap:.5rem;margin-top:.7rem;font-family:'Jost',sans-serif;font-weight:300;font-size:.62rem;letter-spacing:.2em;text-transform:uppercase;color:rgba(255,255,243,.86)}
.ndg-card .ndg-cap-link i{font-style:normal}

/* période + statut SOUS la photo (fond crème) */
.ndg-card .ndg-cap{position:static;left:auto;right:auto;bottom:auto;display:block;color:#2a1809;text-shadow:none;padding:clamp(.95rem,1.2vw,1.25rem) .1rem 0}
.ndg-card .ndg-cap-date{display:block;font-family:'Jost',sans-serif;font-weight:400;font-size:clamp(.7rem,.85vw,.78rem);letter-spacing:.22em;text-transform:uppercase;color:#8a6d35;background:none;border:0;padding:0;border-radius:0;margin:0;text-shadow:none}
.ndg-card .ndg-cap-status{color:rgba(49,22,2,.42);font-weight:300}
.ndg-card .ndg-cap-status.is-open{color:#9a7324}

/* tonalité de saison portée par la photo : automne plus chaud & dense, printemps plus clair */
.ndg-card[data-season="automne"] .ndg-fig img{filter:saturate(1.12) contrast(1.04) brightness(.96)}
.ndg-card[data-season="printemps"] .ndg-fig img{filter:saturate(1.0) brightness(1.07)}
.ndg-card[data-season="ete"] .ndg-fig img{filter:saturate(1.04) brightness(1.02)}

/* neutralise d'anciens effets de survol sur le texte : seule la photo bouge */
.ndg-card:hover .ndg-cap-link{color:rgba(255,255,243,.86)}
.ndg-card:hover .ndg-cap-link i{transform:none}

/* ── Note « autre saison » en bas de la page Bourgogne ── */
.vy-next{background:#FAF6EE;padding:clamp(3.5rem,8vw,6rem) clamp(1.5rem,5vw,2rem);text-align:center}
.vy-next-inner{max-width:660px;margin:0 auto}
.vy-next-eyebrow{font-family:'Jost',sans-serif;font-weight:300;font-size:.7rem;letter-spacing:.28em;text-transform:uppercase;color:#8a6d35;margin-bottom:1.1rem}
.vy-next-title{font-family:'Cormorant Garamond',serif;font-style:italic;font-weight:300;font-size:clamp(1.7rem,3.2vw,2.4rem);line-height:1.12;color:#23190f;margin-bottom:1.2rem}
.vy-next-text{font-family:'Jost',sans-serif;font-weight:300;font-size:clamp(.92rem,1.4vw,1.02rem);line-height:1.85;color:#5a4f40;margin-bottom:1.8rem}
.vy-next-link{display:inline-flex;align-items:center;gap:.55rem;text-decoration:none;font-family:'Jost',sans-serif;font-weight:400;font-size:.66rem;letter-spacing:.24em;text-transform:uppercase;color:#8a6d35;transition:color .4s var(--ease-out)}
.vy-next-link i{font-style:normal;transition:transform .4s var(--ease-out)}
.vy-next-link:hover{color:#5a4326}
.vy-next-link:hover i{transform:translateX(5px)}

/* ══════════════════════════════════════════════════
   Destinations : grille pleine largeur + dynamisme
══════════════════════════════════════════════════ */
/* la collection occupe toute la largeur de la page (3 cartes) */
.ndg-head{max-width:none;margin-left:0;margin-right:0}
.ndg-grid{max-width:none;margin-left:0;margin-right:0;grid-template-columns:1fr}
@media(min-width:900px){.ndg-grid{grid-template-columns:repeat(3,1fr)}}

/* apparition en cascade à l'arrivée dans le champ de vision */
.js .ndg-card{opacity:0;transform:translateY(42px) scale(.985);transition:opacity .95s var(--ease-out),transform .95s var(--ease-out)}
.js .ndg-card.in{opacity:1;transform:none}
.js .ndg-card:nth-child(2){transition-delay:.14s}
.js .ndg-card:nth-child(3){transition-delay:.28s}
@media(prefers-reduced-motion:reduce){.js .ndg-card{opacity:1;transform:none;transition:none}}

/* suppression de la petite ligne dorée animée du hero (sur la droite) */
.about-hero-cue{display:none}





/* ── "Nos destinations" : en tête de colonne, traité autrement que les noms ── */
.m-dest{display:flex;align-items:baseline;justify-content:space-between;gap:1rem;text-decoration:none;color:var(--cream);margin-bottom:.55rem;transition:color .3s var(--ease-out)}
.m-dest-name{font-family:'Cormorant Garamond',serif;font-style:normal;font-weight:400;text-transform:uppercase;letter-spacing:.05em;font-size:clamp(1.3rem,2.1vw,1.7rem);line-height:1.12;color:inherit}
.m-dest .arr{flex:none;color:var(--gold);transition:transform .3s var(--ease-out)}
.m-dest:hover{color:var(--gold)}
.m-dest:hover .arr{transform:translateX(5px)}

/* Header « Nos destinations » : photo unique, fixe (pas d'effet Ken Burns/fondu) */
.nd-imm-bg .nd-slide{animation:none;opacity:1;transform:none}

/* Header destinations : vidéo de fond (couvre, repli sur le poster) */
.nd-imm-bg .nd-video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;border:0}
@media(prefers-reduced-motion:reduce){.nd-imm-bg .nd-video{display:none}}

/* Message « chambres restantes » sous le sélecteur d'hôtel (réservation) */
.rsv-stock{margin:.55rem 0 0;font-family:'Jost',sans-serif;font-size:.72rem;letter-spacing:.05em;color:var(--gold,#C4A96A)}
.rsv-stock.is-low{color:#c2763f}
.rsv-stock.is-full{color:#b1483a}

/* Grappe décorative en bas de la page de confirmation */
.cf-raisin{width:clamp(86px,10vw,128px);margin:clamp(2rem,4.5vh,3.2rem) auto 0;opacity:0;animation:cfRaisinIn 1.3s .35s var(--ease-out,ease) forwards}
.cf-raisin svg{width:100%;height:auto;display:block}
@keyframes cfRaisinIn{to{opacity:.82}}

/* Intro « mode de paiement souhaité » (page réservation, plus de paiement en ligne) */
.pay-pay-intro{font-family:'Jost',sans-serif;font-weight:300;font-size:.82rem;line-height:1.6;color:#857457;margin:0 0 1.15rem}

/* Bouton musique sur la page de paiement (fond clair) : coin haut-droit, teinte foncée */
.pay-snd{position:fixed;top:clamp(1rem,2.4vw,1.6rem);right:clamp(1rem,2.4vw,1.6rem);z-index:60;color:#6f5b3e}

/* Vrai logo (wordmark) sur la page de paiement */
.pay-logo-wm{display:block;height:clamp(22px,3.4vw,34px);width:auto;color:#23190f}

/* Mention « réservé aux adultes » sous le sélecteur de voyageurs (réservation) */
.rsv-adult-note{font-family:'Jost',sans-serif;font-weight:300;font-size:.72rem;line-height:1.5;letter-spacing:.02em;color:#857457;margin:.75rem 0 0;max-width:34rem}

/* Liens légaux dans le footer */
.footer-legal{display:flex;flex-wrap:wrap;align-items:center;gap:.2rem .7rem;font-family:'Jost',sans-serif;font-weight:300;font-size:.66rem;letter-spacing:.04em}
.footer-bottom-end{display:flex;flex-wrap:wrap;align-items:center;gap:.35rem 1.2rem}
.footer-legal a{color:rgba(255,255,243,.6);text-decoration:none;transition:color .3s var(--ease-out,ease)}
.footer-legal a:hover{color:var(--cream)}
.footer-legal-sep{color:rgba(255,255,243,.3)}

/* Pages légales (mentions, confidentialité) */
.legal-head{text-align:center;padding:clamp(2.2rem,5vw,3.6rem) 1.5rem 0}
.legal-wrap{max-width:720px;margin:0 auto;padding:clamp(1.8rem,4.5vw,3rem) 1.5rem clamp(3rem,7vw,5rem)}
.legal-back{display:inline-block;font-family:'Jost',sans-serif;font-weight:300;font-size:.7rem;letter-spacing:.16em;text-transform:uppercase;color:#7a6443;text-decoration:none;margin-bottom:1.8rem}
.legal-back:hover{color:#23190f}
.legal-title{font-family:'Cormorant Garamond',serif;font-weight:500;font-style:italic;font-size:clamp(1.9rem,4.5vw,2.8rem);line-height:1.15;color:#23190f;margin:0 0 .4rem}
.legal-updated{font-family:'Jost',sans-serif;font-weight:300;font-size:.74rem;letter-spacing:.04em;color:#8a795c;margin:0 0 2.4rem}
.legal-wrap h2{font-family:'Cormorant Garamond',serif;font-weight:500;font-size:clamp(1.2rem,2.6vw,1.55rem);color:#23190f;margin:2.3rem 0 .55rem}
.legal-wrap p,.legal-wrap li{font-family:'Jost',sans-serif;font-weight:300;font-size:1rem;line-height:1.78;color:#473827}
.legal-wrap ul{margin:.4rem 0 0;padding-left:1.1rem}
.legal-wrap li{margin:.28rem 0}
.legal-wrap a{color:#7a5a2a}
.legal-ph{color:#9c6f2b;background:rgba(196,169,106,.16);padding:0 .28em;font-style:italic}

/* Destinations : ligne « puis … » des départs suivants (mineure) */
.ndg-card .ndg-cap-more{display:block;margin-top:.32rem;font-family:'Jost',sans-serif;font-weight:300;font-size:clamp(.6rem,.7vw,.66rem);letter-spacing:.16em;text-transform:uppercase;color:#856326}
.ndg-card .ndg-cap-plus{color:#9a7324;font-weight:400}

/* Bourgogne complet : message + boutons désactivés */
.vy-closed{max-width:32rem;margin:1.7rem auto 0;font-family:'Jost',sans-serif;font-weight:300;font-size:.8rem;line-height:1.7;letter-spacing:.02em;color:rgba(255,255,243,.72)}
.vy-closed-link{display:inline-block;margin-top:.5rem;color:#E4C77E;text-decoration:none;letter-spacing:.1em;text-transform:uppercase;font-size:.66rem}
.vy-closed-link i{font-style:normal;display:inline-block;margin-left:.3rem;transition:transform .35s var(--ease-out)}
.vy-closed-link:hover i{transform:translateX(4px)}
.vy-cta-btn.is-closed{cursor:pointer;background:rgba(255,255,243,.08);color:rgba(255,255,243,.5);border-color:rgba(255,255,243,.18)}
.vy-cta-btn.is-closed:hover{background:rgba(255,255,243,.14);color:rgba(255,255,243,.62)}
.vy-bookbar-btn.is-closed{cursor:pointer;background:rgba(255,255,243,.18);color:rgba(255,255,243,.7)}
.vy-bookbar-btn.is-closed:hover{background:rgba(255,255,243,.26)}
.ndg-card .ndg-cap-status.is-closed{color:#b0654a;font-weight:400}

/* Menu : badge « Voyage complet » (grisé, état clôturé) */
.voy-status.s-full{color:rgba(255,255,243,.72);background:transparent;border-color:rgba(255,255,243,.42);font-weight:400}

/* Bloc « Voyage complet » sur la fiche (lisible, sans coins arrondis) */
.vy-soldout{margin-top:.4rem;display:none;flex-direction:column;align-items:center;gap:1rem}
.vy-soldout.is-on{display:flex}
.vy-soldout-tag{font-family:'Jost',sans-serif;font-weight:300;font-size:.76rem;letter-spacing:.34em;text-transform:uppercase;color:#C4A96A;padding-left:.34em}
.vy-soldout-text{font-family:'Cormorant Garamond',serif;font-style:italic;font-weight:300;font-size:1.1rem;color:rgba(255,255,243,.8);margin:0}
.vy-soldout-btn{margin-top:.2rem;-webkit-appearance:none;appearance:none;background:transparent;border-radius:0;cursor:pointer}

/* Frise Bourgogne : évocation littéraire de chaque étape */
.vy-hnarr{font-family:'Jost',sans-serif;font-weight:300;font-style:normal;font-size:clamp(.92rem,1vw,.98rem);line-height:1.72;color:#473d31;margin:0 0 1rem}

/* Frise : activités mises en valeur dans le texte (repérage rapide) */
.vy-act{font-weight:300;color:#856326}

/* Confort de lecture : base agrandie pour les textes courants */
html{font-size:112.5%}

/* ═══ Menu gauche : 1re ligne rapprochée du titre + affordance de scroll ═══ */
.m-voyages > .voy:first-child{padding-top:.45rem}
.m-voyages{position:relative;scrollbar-width:thin;scrollbar-color:rgba(220,196,136,.45) transparent}
.m-voyages::-webkit-scrollbar{width:4px}
.m-voyages::-webkit-scrollbar-thumb{background:rgba(220,196,136,.45)}
.m-voyages::-webkit-scrollbar-track{background:transparent}
/* dégradés haut/bas, collés au cadre de défilement, visibles seulement s'il y a plus à voir */
.m-voyages::before,.m-voyages::after{content:'';position:sticky;left:0;right:0;display:block;height:30px;pointer-events:none;opacity:0;transition:opacity .25s ease;z-index:2}
.m-voyages::before{top:0;margin-bottom:-30px;background:linear-gradient(var(--menu-bg),rgba(30,17,5,0))}
.m-voyages::after{bottom:0;height:54px;margin-top:-54px;background:linear-gradient(rgba(30,17,5,0),var(--menu-bg))}
.m-voyages.sc-less::before{opacity:1}
.m-voyages.sc-more::after{opacity:1}

/* Menu colonne droite : sections nettes, séparées par un filet discret */
.menu-col-right .m-nav{margin-bottom:0}
.menu-col-right .soc{margin-bottom:0}
.menu-col-right .sb,.menu-col-right .c-trust{margin:.9rem 0 0;border-top:1px solid rgba(196,169,106,.16);padding-top:1rem}

/* ═══ Halo sombre discret derrière les textes de hero (lisibilité sur image) ═══ */
.hero-subtitle{text-shadow:0 1px 2px rgba(0,0,0,.45)}
.about-hero-eyebrow{text-shadow:0 1px 2px rgba(0,0,0,.45)}
.about-hero-title{text-shadow:0 1px 3px rgba(0,0,0,.4)}
.about-hero-lede{text-shadow:0 1px 2px rgba(0,0,0,.42)}


/* ── Halo sombre diffus derrière les textes hero (vrai halo, pas une ombre) ── */
.about-hero-inner{position:relative}
.about-hero-inner>*{position:relative;z-index:1}
.about-hero-inner::before{content:'';position:absolute;inset:0;z-index:0;pointer-events:none;background:radial-gradient(58% 72% at 30% 74%,rgba(0,0,0,.62) 0%,rgba(0,0,0,.34) 42%,rgba(0,0,0,0) 70%);filter:blur(7px)}
.hero-logo,.hero-subtitle,.hero-cta{position:relative;z-index:1}
.hero::before{content:'';position:absolute;z-index:0;pointer-events:none;left:50%;top:50%;transform:translate(-50%,-50%);width:min(1100px,92vw);height:min(720px,80vh);background:radial-gradient(ellipse at 50% 55%,rgba(0,0,0,.74) 0%,rgba(0,0,0,.56) 38%,rgba(0,0,0,.28) 58%,rgba(0,0,0,0) 74%);filter:blur(22px);-webkit-mask-image:linear-gradient(to bottom,transparent 0%,transparent 14%,#000 44%,#000 66%,transparent 100%);mask-image:linear-gradient(to bottom,transparent 0%,transparent 14%,#000 44%,#000 66%,transparent 100%)}

/* Lien "voir plus de photos" sous la frise Bourgogne */
.vy-morephotos{text-align:center;margin-top:clamp(1.2rem,2.6vw,2rem);padding:0 1.5rem}
.vy-morephotos-link{display:inline-flex;align-items:center;gap:.6rem;font-family:'Jost',sans-serif;font-weight:400;font-size:.82rem;letter-spacing:.18em;text-transform:uppercase;color:#7a5616;text-decoration:none;border-bottom:1px solid rgba(122,86,22,.45);padding-bottom:.45rem;transition:color .25s,border-color .25s}
.vy-morephotos-link:hover{color:#5a3f10;border-color:#7a5616}
.vy-mp-arrow{transition:transform .25s var(--ease-out)}
.vy-morephotos-link:hover .vy-mp-arrow{transform:translateX(4px)}

/* Flèche retour sur la galerie (visible seulement si on vient de la page Bourgogne) */
.gal-back{align-self:flex-start;display:inline-flex;align-items:center;gap:.5rem;font-family:'Jost',sans-serif;font-weight:400;font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);text-decoration:none;margin-bottom:1.6rem;transition:color .25s}
.gal-back:hover{color:var(--cream)}
.gal-back-arrow{display:inline-block;font-size:1.05em;transition:transform .25s var(--ease-out)}
.gal-back:hover .gal-back-arrow{transform:translateX(-3px)}
.gal-back[hidden]{display:none}

/* Bouton "voir plus de photos" sur les cartes hôtels */
.vy-hotel-more{margin-top:1.3rem;display:inline-flex;align-items:center;gap:.55rem;font-family:'Jost',sans-serif;font-weight:400;font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:#23190f;background:none;border:1px solid rgba(49,22,2,.3);border-radius:2px;padding:.7rem 1.25rem;cursor:pointer;transition:background .25s,color .25s,border-color .25s}
.vy-hotel-more:hover{background:#23190f;color:#F1EADB;border-color:#23190f}
.vy-hm-arrow{transition:transform .25s var(--ease-out)}
.vy-hotel-more:hover .vy-hm-arrow{transform:translateX(4px)}

/* Lightbox galerie hôtels */
.hg-lightbox{position:fixed;inset:0;z-index:2000;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .3s var(--ease-out)}
.hg-lightbox.is-open{opacity:1}
.hg-lightbox[hidden]{display:none}
.hg-backdrop{position:absolute;inset:0;background:rgba(15,10,4,.94);cursor:pointer}
.hg-figure{position:relative;z-index:1;margin:0;max-width:min(92vw,1300px);max-height:84vh;display:flex;flex-direction:column;align-items:center;gap:1rem}
.hg-img{max-width:min(92vw,1300px);max-height:74vh;width:auto;height:auto;object-fit:contain;border-radius:3px;box-shadow:0 24px 60px rgba(0,0,0,.5);opacity:0;transform:scale(.985);transition:opacity .4s var(--ease-out),transform .4s var(--ease-out)}
.hg-img.is-in{opacity:1;transform:none}
.hg-cap{display:flex;align-items:center;gap:1rem;font-family:'Jost',sans-serif}
.hg-cap-name{font-size:.8rem;letter-spacing:.16em;text-transform:uppercase;color:var(--cream)}
.hg-cap-count{font-size:.72rem;letter-spacing:.14em;color:var(--gold)}
.hg-close{position:absolute;top:clamp(1rem,3vw,2rem);right:clamp(1rem,3vw,2rem);z-index:3;width:46px;height:46px;border-radius:50%;border:1px solid rgba(255,255,243,.3);background:rgba(0,0,0,.25);color:var(--cream);font-size:1.1rem;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .25s,border-color .25s}
.hg-close:hover{background:rgba(0,0,0,.5);border-color:var(--gold)}
.hg-nav{position:absolute;top:50%;transform:translateY(-50%);z-index:3;width:42px;height:42px;border-radius:50%;border:1px solid rgba(255,255,243,.38);background:rgba(26,16,8,.24);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);color:#FFFFF3;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .45s var(--ease-out),border-color .45s var(--ease-out),transform .45s var(--ease-out)}
.hg-nav svg{width:14px;height:14px}
.hg-nav svg path{stroke-width:1.2}
.hg-nav:hover{background:rgba(26,16,8,.46);border-color:rgba(255,255,243,.7);transform:translateY(-50%) scale(1.07)}
.hg-prev{left:clamp(.8rem,3vw,2.5rem)}
.hg-next{right:clamp(.8rem,3vw,2.5rem)}
.hg-dots{position:absolute;bottom:clamp(1rem,3vw,2rem);left:50%;transform:translateX(-50%);z-index:3;display:flex;gap:.5rem}
.hg-dot{width:8px;height:8px;border-radius:50%;border:0;padding:0;background:rgba(255,255,243,.32);cursor:pointer;transition:background .25s,transform .25s}
.hg-dot.is-active{background:var(--gold);transform:scale(1.25)}
@media(max-width:640px){
  .hg-nav{width:42px;height:42px}
  .hg-cap{flex-direction:column;gap:.3rem;text-align:center}
}

/* Réservation — encart détail de la chambre (dynamique) */
.rsv-roomcard{margin-top:0;background:#fff;border:1px solid rgba(49,22,2,.12);box-shadow:0 24px 50px -40px rgba(49,22,2,.4);overflow:hidden;opacity:0;transform:translateY(8px);transition:opacity .45s var(--ease-out),transform .45s var(--ease-out)}
.rsv-roomcard.is-in{opacity:1;transform:none}
.rsv-roomcard[hidden]{display:none}
.rsv-roomcard-photo{width:100%;aspect-ratio:16/10;background:#e6e0d6;overflow:hidden}
.rsv-roomcard-photo img{width:100%;height:100%;object-fit:cover;display:block}
.rsv-roomcard-body{padding:clamp(1.5rem,2.8vw,2.1rem)}
.rsv-roomcard-eyebrow{font-family:'Jost',sans-serif;font-weight:300;font-size:.66rem;letter-spacing:.26em;text-transform:uppercase;color:#a8895a;margin:0}
.rsv-roomcard-title{font-family:'Cormorant Garamond',serif;font-style:italic;font-weight:500;font-size:clamp(1.5rem,2.3vw,1.9rem);color:#23190f;line-height:1.05;margin:.3rem 0 .9rem}
.rsv-roomcard-specs{list-style:none;margin:0 0 1.2rem;padding:0;display:flex;flex-wrap:wrap;gap:.75rem 1.7rem}
.rsv-roomcard-specs li{display:flex;align-items:center;gap:.5rem;font-family:'Jost',sans-serif;font-weight:300;font-size:.92rem;color:#473d31}
.rsv-roomcard-specs svg{width:18px;height:18px;flex:none;color:#a8895a}
.rsv-roomcard-desc{font-family:'Jost',sans-serif;font-weight:300;font-size:.99rem;line-height:1.6;color:#5a4f40;margin:0 0 1.3rem}
.rsv-roomcard-price{margin:0;border-top:1px solid rgba(49,22,2,.08);padding-top:1.15rem}
#rsvRoomPriceNight{display:inline-flex;align-items:baseline;gap:.5rem}
.rsv-roomcard-amount{font-family:'Cormorant Garamond',serif;font-style:italic;font-weight:500;font-size:1.6rem;color:#8a6a2e;line-height:1}
.rsv-roomcard-per{font-family:'Jost',sans-serif;font-weight:300;font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;color:#9b8a6f}

/* Réservation — détails enrichis de la chambre */
.rsv-roomcard-specs li[hidden]{display:none}
.rsv-roomcard-amen-lbl{font-family:'Jost',sans-serif;font-weight:500;font-size:.74rem;letter-spacing:.18em;text-transform:uppercase;color:#a8895a;margin:.25rem 0 .8rem;padding-top:1.15rem;border-top:1px solid rgba(49,22,2,.08)}
.rsv-roomcard-amen-lbl[hidden]{display:none}
.rsv-roomcard-amen{list-style:none;display:flex;flex-wrap:wrap;align-items:center;gap:.55rem 1rem;margin:0 0 1.55rem;padding:0}
.rsv-roomcard-amen li{font-family:'Jost',sans-serif;font-weight:300;font-size:.87rem;letter-spacing:.03em;color:#6b5d49;display:inline-flex;align-items:center;gap:.7rem}
.rsv-roomcard-amen li:not(:last-child)::after{content:"";width:3px;height:3px;border-radius:50%;background:#C4A96A;opacity:.55}

/* Réservation — photo d'attente (colonne droite) + barre récap horizontale */
.rsv-right-photo{aspect-ratio:4/3;border:1px solid rgba(49,22,2,.1);box-shadow:0 28px 60px -44px rgba(49,22,2,.4)}
.rsv-summary{max-width:1200px;margin:clamp(2.6rem,5vw,4.2rem) auto 0;background:#fff;border:1px solid rgba(49,22,2,.12);box-shadow:0 34px 70px -50px rgba(49,22,2,.42)}
.rsv-summary-inner{display:grid;grid-template-columns:max-content max-content max-content max-content;justify-content:space-between;align-items:stretch;padding:clamp(1.6rem,2.8vw,2.3rem) 0}
.rsv-summary-inner>*{display:flex;flex-direction:column;justify-content:center;min-width:0;padding:.1rem clamp(.8rem,1.5vw,1.4rem)}
.rsv-summary-inner>*+*{border-left:1px solid rgba(49,22,2,.1)}
.rsv-sum-trip{padding-left:39px;padding-right:39px;align-items:flex-start}
.rsv-sum-title{font-family:'Cormorant Garamond',serif;font-style:italic;font-weight:500;font-size:clamp(1.75rem,2.5vw,2.3rem);color:#23190f;line-height:1.06;margin:0 0 .25rem}
.rsv-sum-trip .rsv-card-eyebrow{margin:0 0 .55rem}
.rsv-sum-date{font-family:'Jost',sans-serif;font-weight:300;font-size:1rem;letter-spacing:.01em;color:#6a5a45;margin:.4rem 0 0}
.rsv-sum-cells{display:flex;flex-direction:column;gap:1rem;align-items:flex-start;padding-left:39px;padding-right:39px}
.rsv-sum-cell{display:flex;flex-direction:row;align-items:baseline;gap:.55rem;white-space:nowrap}
.rsv-sum-cell .rsv-recap-k{font-size:.72rem;letter-spacing:.15em;color:#a8895a}
.rsv-sum-cell .rsv-recap-v{font-size:1.18rem;line-height:1.15;color:#23190f;text-align:left}
.rsv-sum-breakdown{display:flex;flex-direction:column;gap:.35rem}
.rsv-sum-breakdown .rsv-recap-row{display:flex;justify-content:space-between;align-items:baseline;gap:.7rem;padding:0;border:0}
.rsv-sum-breakdown .rsv-recap-k{font-size:.66rem;letter-spacing:.06em;white-space:nowrap;color:#a8895a}
.rsv-sum-breakdown .rsv-recap-v{font-family:'Jost',sans-serif;font-weight:300;font-size:.96rem;white-space:nowrap;color:#2c2114}
.rsv-sum-price{padding-left:39px;padding-right:39px;align-items:flex-start}
.rsv-sum-price .rsv-total-line{display:flex;align-items:baseline;justify-content:space-between;gap:.7rem;margin:0}
.rsv-sum-price .rsv-price{font-size:clamp(2.05rem,3vw,2.65rem);color:#23190f}
.rsv-sum-price .rsv-taxes{margin:.55rem 0 0;font-size:.78rem;line-height:1.45}
.rsv-summary .rsv-cta-btn{display:block;width:100%;text-align:center;border:1px solid #311602;background:transparent;color:#311602;font-weight:300;font-size:.74rem;line-height:1.5;letter-spacing:.16em;padding:1.1rem calc(1rem - .08em) 1.1rem calc(1rem + .08em);transition:background .55s var(--ease-out),color .55s var(--ease-out)}
.rsv-summary .rsv-cta-btn:hover{background:#311602;border-color:#311602;color:#FFFFF3}
.rsv-sum-action{justify-content:center;padding-left:39px;padding-right:39px}
.rsv-sum-action .rsv-select-msg{margin:0 0 .5rem;text-align:center;max-width:13rem}
/* tablette + mobile : la barre s'empile proprement */
@media(max-width:1040px){
  .rsv-summary-inner{grid-template-columns:1fr;gap:0;padding-left:clamp(1.4rem,5vw,1.9rem);padding-right:clamp(1.4rem,5vw,1.9rem)}
  .rsv-summary-inner>*{padding:1.15rem 0}
  .rsv-summary-inner>*+*{border-left:0;border-top:1px solid rgba(49,22,2,.1)}
  .rsv-sum-trip{padding-top:0}
  .rsv-sum-cells{padding-left:0;padding-right:0}
}
@media(max-width:400px){.rsv-sum-cells{grid-template-columns:1fr}}

/* ══════════════════════════════
   GALERIE — lightbox plein écran
══════════════════════════════ */
.gal-lightbox{position:fixed;inset:0;z-index:400;display:flex;align-items:center;justify-content:center;padding:clamp(.6rem,3vw,2.4rem);background:rgba(18,11,4,.94);opacity:0;pointer-events:none;transition:opacity .3s var(--ease-out)}
.gal-lightbox.open{opacity:1;pointer-events:auto}
.gal-lightbox[hidden]{display:none}
.gal-lb-img{max-width:100%;max-height:100%;width:auto;height:auto;object-fit:contain;box-shadow:0 30px 80px rgba(0,0,0,.5);transform:scale(.97);transition:transform .35s var(--ease-out);-webkit-user-select:none;user-select:none}
.gal-lightbox.open .gal-lb-img{transform:scale(1)}
.gal-lb-close{position:absolute;top:clamp(1rem,2.5vw,1.8rem);right:clamp(1rem,2.5vw,1.8rem);width:46px;height:46px;display:inline-flex;align-items:center;justify-content:center;background:none;border:none;color:#FFFFF3;font-size:1.5rem;line-height:0;cursor:pointer;opacity:.82;transition:opacity .25s var(--ease-out),transform .25s var(--ease-out)}
.gal-lb-close:hover{opacity:1;transform:scale(1.12)}
.gal-lb-nav{position:absolute;top:50%;transform:translateY(-50%);width:46px;height:46px;display:inline-flex;align-items:center;justify-content:center;border-radius:50%;border:1px solid rgba(255,255,243,.38);background:rgba(26,16,8,.24);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);color:#FFFFF3;cursor:pointer;transition:background .45s var(--ease-out),border-color .45s var(--ease-out),transform .35s var(--ease-out)}
.gal-lb-nav svg{width:15px;height:15px}
.gal-lb-nav svg path{stroke-width:1.2}
.gal-lb-nav:hover:not(:disabled){background:rgba(26,16,8,.5);border-color:rgba(255,255,243,.78);transform:translateY(-50%) scale(1.07)}
.gal-lb-nav:disabled{opacity:.22;cursor:default;pointer-events:none}
.gal-lb-prev{left:clamp(.4rem,2vw,1.6rem)}
.gal-lb-next{right:clamp(.4rem,2vw,1.6rem)}
@media(max-width:600px){.gal-lb-nav{width:42px;height:42px}}

/* ══════════════════════════════
   MENU — responsive (tablettes & mobiles)
══════════════════════════════ */
/* tablettes étroites encore en 2 colonnes : on resserre pour éviter tout débordement */
@media(min-width:700px) and (max-width:820px){
  .menu-col-left,.menu-col-right{padding-left:clamp(1.8rem,3vw,2.4rem);padding-right:clamp(1.8rem,3vw,2.4rem)}
  .voy-name{font-size:clamp(1.4rem,3vw,1.7rem)}
  .voy-status{font-size:.64rem;padding:.3em .55em;letter-spacing:.08em}
  .m-nav li a{font-size:clamp(1.2rem,2.4vw,1.5rem)}
}

/* colonnes empilées (mobile / petite tablette portrait) :
   plus de double marge haute, un filet sépare les deux sections */
@media(max-width:699px){
  .menu-overlay{overflow-x:hidden}
  .menu-col-left{padding:4.8rem 1.6rem 1.8rem}
  .menu-col-right{padding:1.8rem 1.6rem 2.6rem;border-top:1px solid var(--border)}
  .voy>div{min-width:0}                 /* le contenu peut se réduire sans pousser le statut */
  a.sb-mesure .arr{margin-right:0}       /* flèche alignée avec les statuts (flush en mobile) */
}

/* petits téléphones : tailles réduites pour que nom + statut tiennent sur une ligne */
@media(max-width:520px){
  .voy{gap:.7rem}
  .voy-name{font-size:clamp(1.35rem,6.4vw,1.7rem)}
  .voy-status{font-size:.6rem;padding:.3em .55em;letter-spacing:.07em}
  .m-nav li a{font-size:clamp(1.2rem,5.6vw,1.5rem)}
  .soc li a{font-size:1.02rem}
  .mesure-text{font-size:clamp(1.18rem,5.2vw,1.5rem)}
}

/* très petits écrans (≤360px) */
@media(max-width:360px){
  .menu-col-left{padding:4.6rem 1.2rem 1.6rem}
  .menu-col-right{padding:1.6rem 1.2rem 2rem}
  .voy-name{font-size:1.3rem}
  .voy-status{font-size:.56rem;padding:.28em .5em;letter-spacing:.05em}
}

/* ══════════════════════════════
   FRISE BOURGOGNE — activités en façade + popup détail
══════════════════════════════ */
.vy-hday{cursor:pointer}
.vy-hfull{display:none}
.vy-hacts{list-style:none;margin:0;padding:.85rem 0 0;border-top:1px solid rgba(49,22,2,.13);display:flex;flex-direction:column;gap:.5rem}
.vy-hacts li{position:relative;padding-left:.95rem;font-family:'Jost',sans-serif;font-weight:300;font-size:.92rem;line-height:1.5;color:#3a2e1f}
.vy-hacts li::before{content:'';position:absolute;left:0;top:.6em;width:4px;height:4px;border-radius:50%;background:#856326}
.vy-hmore{display:inline-flex;align-self:flex-start;align-items:center;gap:.45rem;margin-top:auto;padding-top:1.45rem;font-family:'Jost',sans-serif;font-weight:400;font-size:.66rem;letter-spacing:.16em;text-transform:uppercase;color:#856326;transition:gap .25s var(--ease-out),color .25s}
.vy-hmore i{font-style:normal;transition:transform .25s var(--ease-out)}
.vy-hday:hover .vy-hmore{color:#5a3f10}
.vy-hday:hover .vy-hmore i{transform:translateX(4px)}

/* Popup détail d'étape */
.itin-popup{position:fixed;inset:0;z-index:500;display:flex;align-items:center;justify-content:center;gap:clamp(.5rem,1.6vw,1.4rem);padding:clamp(1rem,4vw,2.5rem);opacity:0;pointer-events:none;transition:opacity .3s var(--ease-out)}
.itin-popup.open{opacity:1;pointer-events:auto}
.itin-popup[hidden]{display:none}
.itin-pop-backdrop{position:absolute;inset:0;background:rgba(18,11,4,.82)}
.itin-pop-card{position:relative;z-index:1;flex:0 1 880px;display:flex;flex-direction:column;height:min(660px,88vh);background:#F5F0E8;overflow:hidden;box-shadow:0 30px 90px rgba(0,0,0,.5);transform:translateY(14px) scale(.985);transition:transform .35s var(--ease-out)}
.itin-popup.open .itin-pop-card{transform:none}
.itin-pop-body{flex:1;padding:clamp(1.7rem,3vw,2.6rem);overflow-y:auto;min-height:0;overscroll-behavior:contain;-webkit-overflow-scrolling:touch}
.itin-pop-head{margin-bottom:clamp(1.4rem,2.4vw,2rem)}
.itin-pop-sections{display:flex;flex-direction:column;gap:clamp(2rem,3.4vw,2.8rem)}
.itin-sec{display:flex;flex-direction:column}
.itin-sec-photo{position:relative;width:100%;aspect-ratio:16/10;overflow:hidden;background:#e6ddcd;margin-bottom:clamp(1rem,1.8vw,1.35rem)}
.itin-sec-photo img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block}
.itin-sec-title{font-family:'Cormorant Garamond',serif;font-style:italic;font-weight:500;font-size:clamp(1.35rem,2.2vw,1.7rem);color:#23190f;line-height:1.12;margin:0 0 .7rem}
.itin-sec-text{font-family:'Jost',sans-serif;font-weight:300;font-size:clamp(.95rem,1.3vw,1.04rem);line-height:1.75;color:#3a2e1f}
.itin-sec-text p{margin:0 0 1rem}
.itin-sec-text p:last-child{margin-bottom:0}
.itin-sec-mystere{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:clamp(1rem,1.4vw,1.13rem);line-height:1.7;color:#857457}
.itin-pop-num{display:block;font-family:'Jost',sans-serif;font-weight:300;font-size:.64rem;letter-spacing:.26em;text-transform:uppercase;color:#856326}
.itin-pop-place{font-family:'Cormorant Garamond',serif;font-weight:500;text-transform:uppercase;letter-spacing:.04em;font-size:clamp(1.5rem,3vw,2.1rem);color:#23190f;margin:.55rem 0 .25rem;line-height:1.12}
.itin-pop-date{display:block;margin-top:.45rem;font-family:'Cormorant Garamond',serif;font-style:italic;color:#7a5616;font-size:1.05rem}
.itin-sec-text .vy-act{color:#7a5616;font-weight:500}
.itin-pop-close{position:absolute;top:.85rem;right:.85rem;z-index:2;width:40px;height:40px;display:inline-flex;align-items:center;justify-content:center;background:rgba(245,240,232,.92);border:0;color:#2c2114;font-size:1rem;cursor:pointer;border-radius:50%;transition:background .25s}
.itin-pop-close:hover{background:#fff}
/* flèches : dans les marges, hors de la carte (préserve l'effet « carte postale ») — style exact de la frise */
.itin-pop-nav{flex:0 0 auto;z-index:3;width:42px;height:42px;display:inline-flex;align-items:center;justify-content:center;border-radius:50%;border:1px solid rgba(255,255,243,.38);background:rgba(26,16,8,.24);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);color:#FFFFF3;cursor:pointer;transition:background .45s var(--ease-out),border-color .45s var(--ease-out),transform .45s var(--ease-out),opacity .25s}
.itin-pop-nav svg{width:14px;height:14px}
.itin-pop-nav svg path{stroke-width:1.2}
.itin-pop-nav:hover:not(:disabled){background:rgba(26,16,8,.46);border-color:rgba(255,255,243,.7);transform:scale(1.07)}
.itin-pop-nav:disabled{opacity:0;pointer-events:none}
/* fondu doux lors du changement d'étape */
.itin-pop-body{transition:opacity .2s var(--ease-out)}
.itin-pop-card.swapping .itin-pop-body{opacity:.25}
.itin-pop-cue{position:absolute;left:50%;bottom:.9rem;transform:translateX(-50%);width:34px;height:34px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:rgba(245,240,232,.92);box-shadow:0 3px 12px rgba(49,22,2,.22);pointer-events:none;z-index:2;transition:opacity .35s var(--ease-out)}
.itin-pop-cue svg{width:18px;height:18px;color:#856326;animation:itinCue 1.6s ease-in-out infinite}
.itin-pop-card.at-end .itin-pop-cue{opacity:0}
@keyframes itinCue{0%,100%{transform:translateY(0)}50%{transform:translateY(4px)}}
@media(max-width:680px){
  .itin-popup{gap:0}
  .itin-pop-card{flex:0 1 100%;height:88vh;height:88dvh;max-height:none}
  .itin-pop-body{min-height:0}
  .itin-pop-nav{position:absolute;top:50%;transform:translateY(-50%);width:42px;height:42px}
  .itin-pop-nav:hover:not(:disabled){transform:translateY(-50%) scale(1.08)}
  .itin-pop-prev{left:.5rem}
  .itin-pop-next{right:.5rem}
}
