/* =====================================================================
   Dolce Vita Privé Wellness — public stylesheet
   Palette: champagne gold / near-black / warm bone (from the brand logo)
   Display: Cormorant (high-contrast serif)  Body: Jost (humanist sans)
   Signature: hairline gold rules + a discreet "private threshold" frame
   ===================================================================== */
:root{
  /* Identity from the Dolce Vita logo: champagne gold + warm light neutrals.
     Lightened for a calm, restful, airy feel. */
  --bone:#FBF8F2;          /* main light background — brighter, softer */
  --bone-warm:#F7F2E9;
  --sand:#F1EBDF;          /* lifted from before */
  --sand-deep:#E8DFCD;
  --gold:#C8A86A;          /* primary champagne gold */
  --gold-bright:#DCBE82;   /* highlight */
  --gold-deep:#9A7A48;     /* readable gold for text/labels */
  --taupe:#3C352B;         /* soft deep neutral (replaces heavy black sections) */
  --taupe-soft:#4A4136;
  --noir:#26221B;          /* used sparingly */
  --ink:#2A271F;           /* primary text — warm near-black, high contrast */
  --ink-soft:#574F42;      /* secondary text — readable */
  --line:rgba(154,122,72,.30);
  --line-soft:rgba(154,122,72,.16);
  --line-dark:rgba(220,190,130,.20);
  --maxw:1180px;
  --ease:cubic-bezier(.22,.61,.36,1);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  background:var(--bone);
  color:var(--ink);
  font-family:'Jost',system-ui,sans-serif;
  font-weight:400;
  line-height:1.7;
  -webkit-font-smoothing:antialiased;
}
h1,h2,h3{font-family:'Cormorant',Georgia,serif;font-weight:500;line-height:1.08;letter-spacing:.01em}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}

/* ---------- Header ---------- */
.site-header{
  position:fixed;inset:0 0 auto 0;z-index:50;
  background:rgba(248,245,238,.86);
  backdrop-filter:blur(10px);
  border-bottom:1px solid var(--line-soft);
  transition:background .4s var(--ease),box-shadow .4s var(--ease),border-color .4s var(--ease);
}
.site-header.scrolled{background:rgba(248,245,238,.96);box-shadow:0 6px 24px -18px rgba(60,46,24,.5)}
.header-inner{
  max-width:var(--maxw);margin:0 auto;padding:16px 28px;
  display:flex;align-items:center;justify-content:space-between;gap:24px;
}
.brand{display:flex;align-items:center;gap:12px;line-height:1}
.brand-logo{height:46px;width:auto}
.brand-name{font-family:'Cormorant',serif;font-size:1.6rem;font-weight:600;letter-spacing:.02em}
.brand-sub{font-size:.62rem;letter-spacing:.42em;text-transform:uppercase;color:var(--gold);margin-top:3px}
.main-nav{display:flex;gap:30px}
.main-nav a{font-size:.78rem;letter-spacing:.16em;text-transform:uppercase;color:var(--ink);font-weight:500;transition:color .3s}
.main-nav a:hover{color:var(--gold-deep)}
.header-actions{display:flex;align-items:center;gap:22px}
.lang-switch{display:flex;gap:4px;font-size:.72rem;letter-spacing:.1em}
.lang-switch a{padding:4px 6px;color:var(--ink-soft);opacity:.7;transition:opacity .3s,color .3s}
.lang-switch a.active,.lang-switch a:hover{opacity:1;color:var(--gold-deep);font-weight:600}
.btn-reserve{
  font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;
  border:1px solid var(--gold);color:var(--gold-deep);
  padding:11px 20px;transition:all .35s var(--ease);
}
.btn-reserve:hover{background:var(--gold);color:var(--bone)}

/* ---------- Buttons ---------- */
.btn{display:inline-block;font-size:.78rem;letter-spacing:.2em;text-transform:uppercase;
  padding:15px 34px;transition:all .4s var(--ease);cursor:pointer}
.btn-solid{background:var(--gold);color:var(--bone)}
.btn-solid:hover{background:var(--gold-deep)}
.btn-ghost{border:1px solid var(--line);color:var(--ink)}
.btn-ghost:hover{border-color:var(--gold);color:var(--gold)}
.btn-lg{padding:18px 46px}
.btn-mini{padding:9px 18px;font-size:.66rem;border:1px solid var(--gold);color:var(--gold-deep)}
.btn-mini:hover{background:var(--gold);color:var(--bone)}

/* ---------- Hero ---------- */
.hero{
  min-height:100vh;display:flex;align-items:center;justify-content:center;
  position:relative;text-align:center;padding:140px 24px 90px;
  background:
    radial-gradient(130% 100% at 50% 0%,var(--bone) 0%,var(--bone-warm) 45%,var(--sand) 100%);
  color:var(--ink);
}
.hero-frame{
  max-width:760px;position:relative;z-index:1;padding:60px 40px;
  border:1px solid var(--line);
  animation:fadeUp 1.3s var(--ease) both;
}
.hero-frame::before,.hero-frame::after{
  content:"";position:absolute;width:1px;height:34px;background:var(--gold);left:50%;
}
.hero-frame::before{top:-17px}
.hero-frame::after{bottom:-17px}
.eyebrow{font-size:.74rem;letter-spacing:.4em;text-transform:uppercase;color:var(--gold-deep);font-weight:600;margin-bottom:26px}
.hero-title{font-size:clamp(2.6rem,6vw,4.4rem);font-weight:500;font-style:italic;color:var(--ink)}
.hero-sub{margin:26px auto 38px;max-width:48ch;color:var(--ink-soft);font-size:1.08rem}
.hero-cta{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}
.hero-scroll{position:absolute;bottom:34px;left:50%;width:1px;height:50px;z-index:1;
  background:linear-gradient(var(--gold),transparent);animation:pulse 2.4s var(--ease) infinite}

/* ---------- Sections ---------- */
section{padding:clamp(70px,10vw,130px) 28px}
.section-title{font-size:clamp(2rem,4vw,3rem);font-style:italic}
.section-title.center{text-align:center}
.welcome{max-width:760px;margin:0 auto;text-align:center}
.welcome-rule{width:54px;height:1px;background:var(--gold);margin:0 auto 30px}
.welcome-text{margin-top:24px;font-size:1.12rem;color:var(--ink-soft)}

/* facilities */
.facilities{background:var(--sand);max-width:none}
.facility-grid{max-width:var(--maxw);margin:48px auto 0;display:grid;
  grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1px;background:var(--line)}
.facility-card{background:var(--sand);padding:48px 32px;text-align:center;transition:background .4s}
.facility-card:hover{background:var(--bone)}
.facility-icon{color:var(--gold);font-size:1.4rem}
.facility-card h3{font-size:1.7rem;margin:14px 0 10px;font-style:italic}
.facility-card p{color:var(--ink-soft);font-size:.95rem}

/* packages */
.package-grid{max-width:var(--maxw);margin:52px auto 0;display:grid;
  grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:34px}
.package-card{background:var(--bone);border:1px solid var(--line);overflow:hidden;
  display:flex;flex-direction:column;transition:transform .5s var(--ease),box-shadow .5s var(--ease)}
.package-card:hover{transform:translateY(-6px);box-shadow:0 24px 50px -28px rgba(35,33,28,.4)}
.package-media{height:200px;background:linear-gradient(135deg,var(--sand-deep),#d8cbb2);
  background-size:cover;background-position:center}
.package-body{padding:30px 28px 26px;display:flex;flex-direction:column;flex:1}
.package-body h3{font-size:1.9rem;font-style:italic}
.package-desc{color:var(--ink-soft);font-size:.95rem;margin:10px 0 16px;flex:1}
.package-meta{font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--gold);margin-bottom:18px}
.package-foot{display:flex;align-items:center;justify-content:space-between;
  border-top:1px solid var(--line);padding-top:18px}
.package-price{font-family:'Cormorant',serif;font-size:1.5rem;color:var(--gold-deep)}

/* reviews */
.reviews{background:var(--taupe);color:var(--bone)}
.reviews .section-title{color:var(--bone)}
.review-grid{max-width:var(--maxw);margin:52px auto 0;display:grid;
  grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:34px}
.review-card{border:1px solid rgba(246,242,234,.18);padding:34px 30px}
.stars{color:var(--gold-bright);letter-spacing:3px;margin-bottom:16px}
.review-card blockquote{font-family:'Cormorant',serif;font-size:1.4rem;font-style:italic;line-height:1.4}
.review-card figcaption{margin-top:18px;font-size:.78rem;letter-spacing:.16em;text-transform:uppercase;color:rgba(246,242,234,.72)}

/* CTA band */
.cta-band{text-align:center;background:var(--sand-deep)}
.cta-band h2{font-size:clamp(2rem,4vw,3.2rem);font-style:italic;margin-bottom:30px;color:var(--ink)}

/* footer */
.site-footer{background:var(--taupe);color:rgba(246,242,234,.86);padding:70px 28px 30px}
.footer-grid{max-width:var(--maxw);margin:0 auto;display:grid;
  grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:40px}
.footer-brand{color:var(--bone);font-size:1.8rem}
.footer-addr{margin-top:12px;font-size:.92rem;line-height:1.7}
.footer-label{font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gold-bright);margin-bottom:10px}
.footer-quote{font-family:'Cormorant',serif;font-style:italic;font-size:1.2rem;color:var(--bone)}
.footer-legal{font-size:.84rem;line-height:1.75;color:rgba(246,242,234,.78);margin-top:4px}
.footer-links{display:flex;flex-wrap:wrap;gap:6px 18px;margin-top:14px}
.footer-links a{font-size:.8rem;color:rgba(246,242,234,.82);border-bottom:1px solid transparent;transition:border-color .3s,color .3s}
.footer-links a:hover{color:var(--gold-bright);border-color:var(--gold-bright)}
.footer-cookie-btn{background:none;border:none;cursor:pointer;font:inherit;font-size:.8rem;
  color:rgba(246,242,234,.82);padding:0;border-bottom:1px solid transparent;transition:border-color .3s,color .3s}
.footer-cookie-btn:hover{color:var(--gold-bright);border-color:var(--gold-bright)}
.footer-base{max-width:var(--maxw);margin:50px auto 0;padding-top:24px;
  border-top:1px solid rgba(246,242,234,.16);font-size:.74rem;letter-spacing:.14em;
  text-transform:uppercase;color:rgba(246,242,234,.6)}

/* ---------- Motion ---------- */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .9s var(--ease),transform .9s var(--ease);transition-delay:var(--d,0ms)}
.reveal.in{opacity:1;transform:none}
@keyframes fadeUp{from{opacity:0;transform:translateY(30px)}to{opacity:1;transform:none}}
@keyframes pulse{0%,100%{opacity:.3;transform:scaleY(.6)}50%{opacity:1;transform:scaleY(1)}}

/* ---------- Responsive ---------- */
@media(max-width:860px){
  .main-nav{display:none}
  .header-inner{padding:16px 20px}
  .hero-frame{padding:44px 24px}
}
@media(prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important}
  .reveal{opacity:1;transform:none}
}

/* =====================================================================
   Reservation wizard
   ===================================================================== */
.reserve-wrap{max-width:1040px;margin:0 auto;padding-top:130px}
.reserve-head{text-align:center;margin-bottom:40px}
.reserve-sub{color:var(--ink-soft);margin-top:14px;max-width:52ch;margin-inline:auto}

/* progress steps */
.rsv-steps{list-style:none;display:flex;justify-content:center;gap:0;flex-wrap:wrap;
  margin:0 auto 46px;max-width:760px}
.rsv-step{display:flex;align-items:center;gap:10px;padding:0 18px;opacity:.45;
  position:relative;transition:opacity .4s}
.rsv-step:not(:last-child)::after{content:"";width:26px;height:1px;background:var(--line);margin-left:18px}
.rsv-step.active,.rsv-step.done{opacity:1}
.rsv-num{width:30px;height:30px;border:1px solid var(--gold);border-radius:50%;
  display:grid;place-items:center;font-size:.82rem;color:var(--gold-deep);transition:all .4s}
.rsv-step.active .rsv-num{background:var(--gold);color:var(--noir)}
.rsv-step.done .rsv-num{background:var(--gold-deep);border-color:var(--gold-deep);color:var(--noir)}
.rsv-label{font-size:.72rem;letter-spacing:.14em;text-transform:uppercase}
@media(max-width:680px){.rsv-label{display:none}.rsv-step:not(:last-child)::after{width:16px;margin-left:8px}}

/* panels */
.rsv-form{position:relative;padding-bottom:0}
.rsv-panel{animation:fadeUp .6s var(--ease) both}
.rsv-h{font-family:'Cormorant',serif;font-size:1.9rem;font-style:italic;margin-bottom:22px}
.rsv-h-mt{margin-top:44px}

/* step 1 — package cards */
.rsv-pkg-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:22px}
.rsv-pkg{text-align:left;background:var(--bone);border:1px solid var(--line);
  cursor:pointer;overflow:hidden;display:flex;flex-direction:column;padding:0;
  transition:transform .4s var(--ease),box-shadow .4s var(--ease),border-color .4s}
.rsv-pkg:hover{transform:translateY(-4px);box-shadow:0 18px 40px -26px rgba(11,11,10,.5)}
.rsv-pkg.selected{border-color:var(--gold);box-shadow:0 0 0 1px var(--gold)}
.rsv-pkg-media{height:140px;background:linear-gradient(135deg,var(--sand-deep),#d8cbb2);background-size:cover;background-position:center}
.rsv-pkg-body{padding:20px 22px;display:flex;flex-direction:column;gap:7px}
.rsv-pkg-name{font-family:'Cormorant',serif;font-size:1.5rem;font-style:italic}
.rsv-pkg-desc{font-size:.9rem;color:var(--ink-soft)}
.rsv-pkg-meta{font-size:.68rem;letter-spacing:.12em;text-transform:uppercase;color:var(--gold-deep)}
.rsv-pkg-price{font-family:'Cormorant',serif;font-size:1.35rem;color:var(--gold-deep);margin-top:4px}

/* step 2 — calendar + slots */
.rsv-cal-layout{display:grid;grid-template-columns:1fr 1fr;gap:40px}
@media(max-width:720px){.rsv-cal-layout{grid-template-columns:1fr;gap:30px}}
.rsv-cal{border:1px solid var(--line);padding:20px}
.rsv-cal-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}
.rsv-cal-title{font-family:'Cormorant',serif;font-size:1.3rem;font-style:italic;text-transform:capitalize}
.rsv-cal-nav{background:none;border:1px solid var(--line);width:32px;height:32px;cursor:pointer;
  color:var(--gold-deep);font-size:1rem;transition:all .3s}
.rsv-cal-nav:hover{background:var(--gold);color:var(--noir);border-color:var(--gold)}
.rsv-cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px}
.rsv-dow{font-size:.66rem;letter-spacing:.1em;text-transform:uppercase;color:var(--gold-deep);
  text-align:center;padding:6px 0}
.rsv-day{aspect-ratio:1;border:none;background:var(--sand);cursor:pointer;font-size:.9rem;
  color:var(--ink);transition:all .25s;border-radius:2px}
.rsv-day:hover:not(.disabled){background:var(--gold);color:var(--noir)}
.rsv-day.selected{background:var(--gold-deep);color:var(--noir);font-weight:500}
.rsv-day.disabled{opacity:.28;cursor:not-allowed}
.rsv-slot-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(72px,1fr));gap:10px}
.rsv-slot{border:1px solid var(--line);background:var(--bone);padding:12px 0;cursor:pointer;
  font-size:.92rem;letter-spacing:.05em;transition:all .25s}
.rsv-slot:hover{border-color:var(--gold);color:var(--gold-deep)}
.rsv-slot.selected{background:var(--gold);border-color:var(--gold);color:var(--noir)}
.rsv-hint{color:var(--ink-soft);font-style:italic;font-family:'Cormorant',serif;font-size:1.15rem}

/* step 3 — stepper + extras */
.rsv-stepper{display:flex;align-items:center;gap:18px}
.rsv-pm{width:42px;height:42px;border:1px solid var(--gold);background:none;color:var(--gold-deep);
  font-size:1.3rem;cursor:pointer;border-radius:50%;transition:all .3s;line-height:1}
.rsv-pm:hover{background:var(--gold);color:var(--noir)}
.rsv-count{font-family:'Cormorant',serif;font-size:2rem;min-width:40px;text-align:center}
.rsv-maxhint{font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;color:var(--gold-deep)}
.rsv-extras{display:flex;flex-direction:column;gap:14px}
.rsv-extra{display:flex;align-items:center;gap:18px;border:1px solid var(--line);
  padding:14px 18px;background:var(--bone);transition:border-color .3s,background .3s}
.rsv-extra.active{border-color:var(--gold)}
.rsv-extra-media{width:62px;height:62px;flex:0 0 62px;border-radius:3px;
  background:linear-gradient(135deg,var(--sand-deep),#d8cbb2);background-size:cover;background-position:center}
.rsv-extra-body{flex:1;display:flex;flex-direction:column;gap:3px}
.rsv-extra-name{font-family:'Cormorant',serif;font-size:1.3rem;font-style:italic}
.rsv-extra-desc{font-size:.84rem;color:var(--ink-soft)}
.rsv-extra-price{font-size:.82rem;color:var(--gold-deep)}
.rsv-extra-price em{font-style:normal;opacity:.7;font-size:.72rem}
.rsv-extra-stepper{display:flex;align-items:center;gap:10px}
.rsv-extra-stepper .rsv-pm{width:34px;height:34px;font-size:1.1rem}
.rsv-extra-qty{min-width:20px;text-align:center;font-size:1rem}

/* step 4 — fields */
.rsv-fields{display:grid;grid-template-columns:1fr 1fr;gap:22px}
.rsv-field{display:flex;flex-direction:column;gap:8px}
.rsv-field-full{grid-column:1/-1}
.rsv-field span{font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--gold-deep)}
.rsv-field input,.rsv-field textarea{border:1px solid var(--line);background:var(--bone);
  padding:13px 15px;font-family:inherit;font-size:1rem;color:var(--ink);transition:border-color .3s}
.rsv-field input:focus,.rsv-field textarea:focus{outline:none;border-color:var(--gold)}
@media(max-width:620px){.rsv-fields{grid-template-columns:1fr}}

/* step 5 — summary */
.rsv-summary{border:1px solid var(--line)}
.rsv-sum-row{display:flex;justify-content:space-between;padding:14px 22px;border-bottom:1px solid var(--line-dark)}
.rsv-sum-row span:first-child{color:var(--ink-soft)}
.rsv-sum-total{background:var(--taupe);color:var(--bone);border-bottom:none}
.rsv-sum-total span{font-family:'Cormorant',serif;font-size:1.4rem;font-style:italic}
.rsv-sum-total span:last-child{color:var(--gold-bright)}

/* done */
.rsv-done{text-align:center;padding:40px 20px}
.rsv-done-mark{display:inline-grid;place-items:center;width:72px;height:72px;border:1px solid var(--gold);
  border-radius:50%;color:var(--gold);font-size:1.6rem;margin-bottom:22px}
.rsv-done-sub{color:var(--ink-soft);max-width:46ch;margin:0 auto 22px}
.rsv-ref{font-size:.86rem;letter-spacing:.1em}
.rsv-ref strong{color:var(--gold-deep);letter-spacing:.16em}

/* sticky bar */
.rsv-bar{position:sticky;bottom:0;z-index:40;background:rgba(60,53,43,.97);
  backdrop-filter:blur(8px);border-top:1px solid var(--line);
  display:flex;align-items:center;justify-content:space-between;
  padding:16px clamp(20px,5vw,40px);gap:20px;
  margin:40px -28px 0}
.rsv-total-label{font-size:.68rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gold-bright);display:block}
.rsv-total-val{font-family:'Cormorant',serif;font-size:1.8rem;color:var(--bone)}
.rsv-nav{display:flex;gap:12px}
.rsv-bar .btn-ghost{border-color:var(--gold);color:var(--gold-bright);background:transparent}
.rsv-bar .btn-ghost:hover{border-color:var(--gold-bright);color:var(--taupe);background:var(--gold-bright)}
.btn.is-disabled{opacity:.4;pointer-events:none}

/* general solid button gets gold */
.btn-solid{background:var(--gold-deep);color:var(--bone)}
.btn-solid:hover{background:var(--gold);color:var(--taupe)}
.btn-mini{border-color:var(--gold);color:var(--gold-deep)}
.btn-mini:hover{background:var(--gold);color:var(--taupe)}
.btn-reserve{border-color:var(--gold-deep);color:var(--gold-deep)}
.btn-reserve:hover{background:var(--gold-deep);color:var(--bone)}

/* =====================================================================
   Site-wide scroll experience
   ===================================================================== */
/* Thin gold progress line pinned to the top of the viewport */
.scroll-progress{
  position:fixed;top:0;left:0;right:0;height:2px;z-index:60;
  background:linear-gradient(90deg,var(--gold-deep),var(--gold-bright));
  transform:scaleX(0);transform-origin:0 50%;
  will-change:transform;
}

/* Reveal base (the .reveal class already exists; this refines the auto ones
   and adds a soft, slightly slower easing for a luxury feel). */
.reveal-auto{opacity:0;transform:translateY(28px);
  transition:opacity 1s var(--ease),transform 1s var(--ease);transition-delay:var(--d,0ms)}
.reveal-auto.in{opacity:1;transform:none}

/* Hero frame transitions smoothly under parallax */
.hero-frame{will-change:transform,opacity}

@media(prefers-reduced-motion:reduce){
  .scroll-progress{display:none}
  .reveal-auto{opacity:1;transform:none;transition:none}
  .hero-frame{transform:none!important;opacity:1!important}
}

/* =====================================================================
   Legibility refinements (stronger contrast & weight on small text)
   ===================================================================== */
.hero-sub{color:var(--ink-soft)}                   /* hero subtitle on light hero */
.welcome-text{color:var(--ink);font-weight:400}
.reserve-sub{color:var(--ink)}
.facility-card p,.package-desc,.rsv-pkg-desc,.rsv-extra-desc{color:var(--ink-soft);font-weight:400}
.eyebrow{color:var(--gold-bright);font-weight:500}
.package-meta,.rsv-pkg-meta,.rsv-maxhint{color:var(--gold-deep);font-weight:500}
.rsv-field span,.footer-label{color:var(--gold-deep);font-weight:600}
.rsv-hint{color:var(--ink-soft)}
.main-nav a{color:var(--ink);font-weight:400}
.lang-switch a{color:var(--ink-soft)}
.rsv-extra-price{color:var(--gold-deep);font-weight:500}
.rsv-sum-row span:first-child{color:var(--ink-soft);font-weight:400}
.rsv-sum-row span:last-child{color:var(--ink);font-weight:500}
.rsv-ref strong{color:var(--gold-deep)}
/* inputs: clearly framed and dark text */
.rsv-field input,.rsv-field textarea{color:var(--ink);font-weight:400;border-width:1.5px}
.rsv-field input::placeholder,.rsv-field textarea::placeholder{color:rgba(58,54,46,.55)}

/* =====================================================================
   Cookie consent banner (GDPR / ePrivacy — Belgium)
   ===================================================================== */
.cookie-overlay{
  position:fixed;inset:auto 0 0 0;z-index:200;display:flex;justify-content:center;
  padding:18px;pointer-events:none;
}
.cookie-box{
  pointer-events:auto;max-width:560px;width:100%;
  background:var(--bone);border:1px solid var(--line);
  box-shadow:0 24px 60px -24px rgba(60,46,24,.5);
  padding:30px 30px 24px;border-radius:4px;
  transform:translateY(20px);opacity:0;transition:opacity .3s var(--ease),transform .3s var(--ease);
}
.cookie-overlay.show .cookie-box{transform:none;opacity:1}
.cookie-title{font-family:'Cormorant',serif;font-size:1.7rem;font-style:italic;margin-bottom:10px;color:var(--ink)}
.cookie-text{font-size:.92rem;color:var(--ink-soft);line-height:1.65}
.cookie-prefs{margin:18px 0 4px;border-top:1px solid var(--line-soft);padding-top:8px}
.cookie-pref{display:flex;align-items:flex-start;justify-content:space-between;gap:18px;
  padding:14px 0;border-bottom:1px solid var(--line-soft);cursor:pointer}
.cookie-pref-name{display:block;font-weight:600;color:var(--ink);font-size:.95rem}
.cookie-pref-desc{display:block;font-size:.82rem;color:var(--ink-soft);margin-top:3px}
.cookie-pref input{width:20px;height:20px;accent-color:var(--gold-deep);margin-top:3px;flex:0 0 auto}
.cookie-actions{display:flex;gap:10px;margin-top:20px;flex-wrap:wrap}
.cookie-btn{flex:1;min-width:130px;padding:13px 16px;font-size:.74rem;letter-spacing:.12em;
  text-transform:uppercase;cursor:pointer;font-family:inherit;transition:all .3s var(--ease)}
.cookie-btn-line{background:transparent;border:1px solid var(--gold-deep);color:var(--gold-deep)}
.cookie-btn-line:hover{background:var(--sand)}
.cookie-btn-fill{background:var(--gold-deep);border:1px solid var(--gold-deep);color:var(--bone)}
.cookie-btn-fill:hover{background:var(--gold);color:var(--taupe)}
.cookie-links{margin-top:16px;font-size:.82rem;color:var(--ink-soft)}
.cookie-links a{color:var(--gold-deep);border-bottom:1px solid transparent;transition:border-color .3s}
.cookie-links a:hover{border-color:var(--gold-deep)}
@media(max-width:520px){.cookie-btn{flex-basis:100%}}

/* =====================================================================
   Legal / content pages (privacy, terms, cookies, about)
   ===================================================================== */
.page-wrap{max-width:820px;margin:0 auto;padding:150px 28px 90px}
.page-head{text-align:center;margin-bottom:50px}
.page-head .eyebrow{margin-bottom:18px}
.page-title{font-size:clamp(2.2rem,5vw,3.4rem);font-style:italic;color:var(--ink)}
.page-body{font-size:1.02rem;line-height:1.8;color:var(--ink)}
.page-body h2{font-family:'Cormorant',serif;font-size:1.7rem;font-style:italic;
  margin:42px 0 14px;color:var(--ink)}
.page-body h3{font-family:'Jost',sans-serif;font-size:1rem;font-weight:600;
  letter-spacing:.04em;margin:26px 0 8px;color:var(--gold-deep)}
.page-body p{margin-bottom:16px;color:var(--ink-soft)}
.page-body ul{margin:0 0 18px 22px;color:var(--ink-soft)}
.page-body li{margin-bottom:8px}
.page-body a{color:var(--gold-deep);border-bottom:1px solid var(--line);transition:border-color .3s}
.page-body a:hover{border-color:var(--gold-deep)}
.page-body strong{color:var(--ink)}
.legal-meta{margin-top:40px;padding-top:20px;border-top:1px solid var(--line-soft);
  font-size:.85rem;color:var(--ink-soft)}
.legal-card{background:var(--sand);border:1px solid var(--line-soft);padding:24px 26px;margin:24px 0;border-radius:4px}
.legal-card p{margin-bottom:6px}

/* =====================================================================
   Step 4 — details + live overview side by side (confirm directly)
   ===================================================================== */
.rsv-confirm-layout{display:grid;grid-template-columns:1.3fr 1fr;gap:40px;align-items:start}
.rsv-confirm-aside .rsv-summary{margin-top:4px}
@media(max-width:820px){
  .rsv-confirm-layout{grid-template-columns:1fr;gap:30px}
  .rsv-confirm-aside{order:-1}            /* show the summary first on mobile */
}

/* Ensure the [hidden] attribute always wins over .btn display rules
   (otherwise the hidden Next/Confirm button would still show). */
[hidden]{display:none !important}

/* =====================================================================
   Sticky footer — keep the footer at the bottom on short pages
   (e.g. the reservation page) instead of floating mid-screen.
   ===================================================================== */
body{display:flex;flex-direction:column;min-height:100vh}
body > main{flex:1 0 auto}
.site-footer{flex-shrink:0}

/* Footer credit line */
.footer-credit{margin-top:8px;font-size:.72rem;letter-spacing:.04em}
.footer-credit a{color:var(--gold-bright);border-bottom:1px solid transparent;transition:border-color .3s}
.footer-credit a:hover{border-color:var(--gold-bright)}

/* =====================================================================
   Public gallery
   ===================================================================== */
.gallery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:16px;margin-top:10px}
.gallery-item{margin:0;overflow:hidden;border-radius:6px;border:1px solid var(--line-soft);background:var(--sand)}
.gallery-item img{width:100%;height:240px;object-fit:cover;display:block;transition:transform .6s var(--ease)}
.gallery-item:hover img{transform:scale(1.04)}
@media(max-width:560px){.gallery-item img{height:200px}}
