/* ============ RESET & TOKENS ============ */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
:root{
  --black:#0A0A0A;
  --black-soft:#121212;
  --black-card:#161616;
  --gold:#D4AF37;
  --gold-light:#E8C766;
  --gold-deep:#B8932E;
  --cream:#F8F4EC;
  --cream-dim:#cfc8ba;
  --line:rgba(212,175,55,.18);
  --glass:rgba(255,255,255,.04);
  --shadow:0 20px 50px rgba(0,0,0,.55);
  --grad-gold:linear-gradient(135deg,#E8C766 0%,#D4AF37 45%,#B8932E 100%);
  --ease:cubic-bezier(.22,.61,.36,1);
  --maxw:1180px;
  --pad:clamp(18px,5vw,40px);
}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  background:var(--black);
  color:var(--cream);
  font-family:'Jost',system-ui,-apple-system,sans-serif;
  font-weight:300;
  line-height:1.65;
  overflow-x:hidden;
  letter-spacing:.2px;
}
img{max-width:100%;display:block}
a{text-decoration:none;color:inherit}
h1,h2,h3,h4{font-family:'Cormorant Garamond',Georgia,serif;font-weight:600;line-height:1.15;letter-spacing:.5px}
section{padding:clamp(64px,9vw,110px) var(--pad);position:relative}
.wrap{max-width:var(--maxw);margin:0 auto;width:100%}
.center{text-align:center}
.eyebrow{
  font-family:'Jost';font-weight:500;font-size:.72rem;letter-spacing:4px;
  text-transform:uppercase;color:var(--gold);display:inline-block;margin-bottom:14px;
}
.eyebrow::before,.eyebrow::after{content:"";display:inline-block;width:26px;height:1px;background:var(--gold);vertical-align:middle;margin:0 10px;opacity:.6}
.h-title{font-size:clamp(2rem,5.2vw,3.4rem);color:var(--cream);margin-bottom:14px}
.h-title .gold{color:var(--gold)}
.lead{color:var(--cream-dim);max-width:620px;margin:0 auto;font-size:1.02rem}

/* ============ BUTTONS ============ */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:9px;
  padding:15px 30px;border-radius:50px;font-family:'Jost';font-weight:500;
  font-size:.92rem;letter-spacing:1px;text-transform:uppercase;cursor:pointer;
  border:none;transition:transform .35s var(--ease),box-shadow .35s var(--ease),background .35s;
  will-change:transform;
}
.btn-gold{background:var(--grad-gold);color:#1a1206;box-shadow:0 8px 26px rgba(212,175,55,.32)}
.btn-gold:hover{transform:translateY(-3px);box-shadow:0 14px 38px rgba(212,175,55,.55)}
.btn-ghost{background:var(--glass);color:var(--cream);border:1px solid var(--line);backdrop-filter:blur(8px)}
.btn-ghost:hover{transform:translateY(-3px);border-color:var(--gold);color:var(--gold);box-shadow:0 10px 30px rgba(0,0,0,.4)}

/* ============ HEADER ============ */
header{
  position:fixed;top:0;left:0;width:100%;z-index:900;
  padding:18px var(--pad);transition:background .4s,padding .4s,box-shadow .4s;
}
header.scrolled{background:rgba(10,10,10,.82);backdrop-filter:blur(14px);padding:12px var(--pad);box-shadow:0 6px 24px rgba(0,0,0,.4);border-bottom:1px solid var(--line)}
.nav{max-width:var(--maxw);margin:0 auto;display:flex;align-items:center;justify-content:space-between}
.logo{font-family:'Cormorant Garamond';font-size:1.5rem;font-weight:700;color:var(--cream);letter-spacing:1px}
.logo b{color:var(--gold)}
.nav-links{display:flex;gap:30px;list-style:none;align-items:center}
.nav-links a{font-size:.86rem;letter-spacing:1px;text-transform:uppercase;color:var(--cream-dim);transition:color .3s;position:relative}
.nav-links a:not(.btn)::after{content:"";position:absolute;left:0;bottom:-6px;width:0;height:1px;background:var(--gold);transition:width .35s var(--ease)}
.nav-links a:not(.btn):hover{color:var(--gold)}
.nav-links a:not(.btn):hover::after{width:100%}
.nav-links a.active:not(.btn){color:var(--gold)}
.nav-links a.active:not(.btn)::after{width:100%}
.nav-cta{padding:11px 24px;font-size:.78rem}
.burger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:6px;z-index:950}
.burger span{width:26px;height:2px;background:var(--gold);transition:.35s var(--ease);display:block}
.burger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.burger.open span:nth-child(2){opacity:0}
.burger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* ============ HERO (home) ============ */
.hero{
  min-height:100svh;display:flex;align-items:center;justify-content:center;
  text-align:center;padding-top:90px;position:relative;overflow:hidden;
  background:radial-gradient(ellipse at 50% 20%,#1a1407 0%,#0A0A0A 60%);
}
.hero-bg{position:absolute;inset:0;z-index:0}
.hero-bg::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(10,10,10,.55) 0%,rgba(10,10,10,.74) 55%,#0A0A0A 100%)}
.hero-bg img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.6}
#particles{position:absolute;inset:0;z-index:1;pointer-events:none}
.hero-content{position:relative;z-index:2;max-width:860px;padding:0 var(--pad)}
.hero .eyebrow{opacity:0;animation:fadeUp .9s var(--ease) .2s forwards}
.hero h1{font-size:clamp(2.6rem,8vw,5.2rem);color:var(--cream);margin-bottom:18px;opacity:0;animation:fadeUp 1s var(--ease) .4s forwards}
.hero h1 .gold{background:var(--grad-gold);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.hero p.sub{font-size:clamp(1rem,2.6vw,1.35rem);color:var(--cream-dim);font-weight:300;margin-bottom:34px;opacity:0;animation:fadeUp 1s var(--ease) .6s forwards}
.hero-cta{display:flex;gap:16px;justify-content:center;flex-wrap:wrap;opacity:0;animation:fadeUp 1s var(--ease) .8s forwards}
.scroll-ind{position:absolute;bottom:26px;left:50%;transform:translateX(-50%);z-index:2;opacity:0;animation:fadeUp 1s ease 1.4s forwards}
.scroll-ind span{display:block;width:22px;height:38px;border:1.5px solid var(--gold);border-radius:14px;position:relative}
.scroll-ind span::after{content:"";position:absolute;top:7px;left:50%;transform:translateX(-50%);width:4px;height:7px;background:var(--gold);border-radius:3px;animation:scrollDot 1.8s infinite}
@keyframes scrollDot{0%{opacity:1;top:7px}100%{opacity:0;top:20px}}
@keyframes fadeUp{from{opacity:0;transform:translateY(34px)}to{opacity:1;transform:translateY(0)}}

/* ============ PAGE HERO (inner pages) ============ */
.page-hero{
  min-height:54vh;display:flex;align-items:center;justify-content:center;text-align:center;
  padding:130px var(--pad) 70px;position:relative;overflow:hidden;
  background:radial-gradient(ellipse at 50% 0%,#1a1407 0%,#0A0A0A 65%);
}
.page-hero::before{content:"";position:absolute;inset:0;
  background:url("https://images.unsplash.com/photo-1540555700478-4be289fbecef?auto=format&fit=crop&w=1400&q=60") center/cover;
  opacity:.18}
.page-hero-in{position:relative;z-index:2;max-width:760px}
.page-hero h1{font-size:clamp(2.4rem,7vw,4rem);color:var(--cream);margin-bottom:12px;opacity:0;animation:fadeUp .9s var(--ease) .15s forwards}
.page-hero h1 .gold{color:var(--gold)}
.page-hero p{color:var(--cream-dim);font-size:1.05rem;opacity:0;animation:fadeUp .9s var(--ease) .35s forwards}
.crumb{font-size:.78rem;letter-spacing:1px;color:var(--cream-dim);margin-top:18px;opacity:0;animation:fadeUp .9s var(--ease) .5s forwards}
.crumb a{color:var(--gold)}

/* ============ REVEAL ============ */
.reveal{opacity:0;transform:translateY(40px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
.reveal.in{opacity:1;transform:none}
.reveal.d1{transition-delay:.1s}.reveal.d2{transition-delay:.2s}.reveal.d3{transition-delay:.3s}.reveal.d4{transition-delay:.4s}

/* ============ SERVICES ============ */
.grid{display:grid;gap:22px}
.services-grid{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));margin-top:46px}
.card{
  background:var(--black-card);border:1px solid var(--line);border-radius:18px;
  padding:34px 28px;transition:transform .45s var(--ease),box-shadow .45s,border-color .45s;
  position:relative;overflow:hidden;
}
.card::before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 50% 0%,rgba(212,175,55,.12),transparent 60%);opacity:0;transition:opacity .45s}
.card:hover{transform:translateY(-10px);border-color:var(--gold);box-shadow:0 24px 50px rgba(0,0,0,.55),0 0 0 1px rgba(212,175,55,.25)}
.card:hover::before{opacity:1}
.card .ico{width:62px;height:62px;border-radius:50%;display:grid;place-items:center;margin-bottom:20px;background:rgba(212,175,55,.1);border:1px solid var(--line);transition:transform .45s var(--ease)}
.card:hover .ico{transform:rotate(8deg) scale(1.08)}
.card .ico svg{width:30px;height:30px;stroke:var(--gold);fill:none;stroke-width:1.4}
.card h3{font-size:1.42rem;color:var(--cream);margin-bottom:9px}
.card p{color:var(--cream-dim);font-size:.94rem}
.card .price{margin-top:14px;color:var(--gold);font-family:'Cormorant Garamond';font-size:1.5rem;font-weight:700}

/* service card with image */
.card-img{padding:0}
.card-img .thumb{aspect-ratio:16/11;overflow:hidden;border-radius:18px 18px 0 0}
.card-img .thumb img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease)}
.card-img:hover .thumb img{transform:scale(1.08)}
.card-img .body{padding:24px 26px 28px}

/* ============ WHY / COUNTERS ============ */
.why{background:linear-gradient(180deg,#0A0A0A,#0d0b06,#0A0A0A)}
.stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:30px;margin-top:50px}
.stat{text-align:center;padding:24px 12px;border-radius:16px;border:1px solid var(--line);background:var(--glass);transition:transform .4s var(--ease),border-color .4s}
.stat:hover{transform:translateY(-6px);border-color:var(--gold)}
.stat .num{font-family:'Cormorant Garamond';font-size:clamp(2.4rem,6vw,3.3rem);font-weight:700;background:var(--grad-gold);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;line-height:1}
.stat .lbl{margin-top:8px;font-size:.82rem;letter-spacing:1.5px;text-transform:uppercase;color:var(--cream-dim)}

/* ============ GALLERY ============ */
.gallery{columns:3;column-gap:16px;margin-top:46px}
.gallery figure{break-inside:avoid;margin-bottom:16px;border-radius:14px;overflow:hidden;position:relative;cursor:pointer;border:1px solid var(--line);background:#161616}
.gallery img{width:100%;height:auto;transition:transform .6s var(--ease);display:block}
.gallery figure::after{content:"⤢";position:absolute;inset:0;display:grid;place-items:center;color:var(--gold);font-size:1.6rem;background:rgba(10,10,10,.45);opacity:0;transition:opacity .4s}
.gallery figure:hover img{transform:scale(1.1)}
.gallery figure:hover::after{opacity:1}

/* Lightbox */
.lightbox{position:fixed;inset:0;background:rgba(5,5,5,.94);z-index:1200;display:none;align-items:center;justify-content:center;padding:20px;backdrop-filter:blur(6px)}
.lightbox.open{display:flex;animation:fadeUp .3s ease}
.lightbox img{max-width:92vw;max-height:86vh;border-radius:10px;border:1px solid var(--line)}
.lightbox .close{position:absolute;top:22px;right:26px;font-size:2rem;color:var(--gold);cursor:pointer;background:none;border:none;line-height:1}

/* ============ TESTIMONIALS ============ */
.testi{background:linear-gradient(180deg,#0A0A0A,#100c05)}
.testi-track-wrap{overflow:hidden;margin-top:46px;-webkit-mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent)}
.testi-track{display:flex;gap:22px;width:max-content;animation:scrollX 38s linear infinite}
.testi-track:hover{animation-play-state:paused}
@keyframes scrollX{to{transform:translateX(-50%)}}
.testi-card{width:340px;flex-shrink:0;background:var(--black-card);border:1px solid var(--line);border-radius:16px;padding:30px}
.testi-card .stars{color:var(--gold);letter-spacing:3px;margin-bottom:12px}
.testi-card p{color:var(--cream);font-style:italic;font-family:'Cormorant Garamond';font-size:1.22rem;line-height:1.5;margin-bottom:18px}
.testi-card .who{display:flex;align-items:center;gap:12px}
.testi-card .av{width:42px;height:42px;border-radius:50%;background:var(--grad-gold);display:grid;place-items:center;color:#1a1206;font-weight:600;font-family:'Jost'}
.testi-card .who b{display:block;color:var(--cream);font-weight:500;font-size:.95rem}
.testi-card .who span{font-size:.78rem;color:var(--cream-dim)}

/* ============ OFFERS ============ */
.offers-grid{grid-template-columns:repeat(auto-fit,minmax(270px,1fr));margin-top:46px}
.offer{position:relative;border-radius:18px;padding:38px 30px;overflow:hidden;border:1px solid var(--line);background:linear-gradient(160deg,#181206,#0d0b06)}
.offer::after{content:"";position:absolute;top:0;left:-120%;width:60%;height:100%;background:linear-gradient(110deg,transparent,rgba(232,199,102,.28),transparent);transform:skewX(-20deg);animation:shine 5s infinite}
.offer:nth-child(2)::after{animation-delay:1.6s}.offer:nth-child(3)::after{animation-delay:3.2s}
@keyframes shine{0%{left:-120%}45%,100%{left:140%}}
.offer .tag{font-size:.72rem;letter-spacing:2px;text-transform:uppercase;color:var(--gold);border:1px solid var(--line);padding:5px 12px;border-radius:30px;display:inline-block;margin-bottom:16px}
.offer h3{font-size:1.9rem;color:var(--cream);margin-bottom:8px}
.offer .big{font-size:2.6rem;font-family:'Cormorant Garamond';font-weight:700;color:var(--gold);line-height:1}
.offer p{color:var(--cream-dim);font-size:.92rem;margin:10px 0 20px}

/* ============ BOOKING ============ */
.book{background:linear-gradient(180deg,#0d0b06,#0A0A0A)}
.book-wrap{display:grid;grid-template-columns:1fr 1fr;gap:50px;align-items:center}
.book-info h2{font-size:clamp(2rem,5vw,3rem);color:var(--cream);margin-bottom:16px}
.book-info h2 .gold{color:var(--gold)}
.book-info p{color:var(--cream-dim);margin-bottom:22px}
.book-info ul{list-style:none;display:grid;gap:14px}
.book-info li{display:flex;align-items:center;gap:12px;color:var(--cream)}
.book-info li svg{width:20px;height:20px;stroke:var(--gold);fill:none;stroke-width:1.6;flex-shrink:0}
form{background:var(--black-card);border:1px solid var(--line);border-radius:20px;padding:34px;box-shadow:var(--shadow)}
.field{margin-bottom:16px}
.field label{display:block;font-size:.78rem;letter-spacing:1px;text-transform:uppercase;color:var(--cream-dim);margin-bottom:7px}
.field input,.field select,.field textarea{
  width:100%;background:#0d0d0d;border:1px solid var(--line);border-radius:10px;
  padding:13px 15px;color:var(--cream);font-family:'Jost';font-size:.95rem;transition:border-color .3s,box-shadow .3s;
}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 3px rgba(212,175,55,.14)}
.field textarea{resize:vertical;min-height:90px}
.field.err input,.field.err select{border-color:#c0392b}
.field small{color:#e07b6f;font-size:.74rem;display:none;margin-top:5px}
.field.err small{display:block}
form .btn{width:100%;margin-top:6px}
.form-success{display:none;text-align:center;padding:24px 10px}
.form-success.show{display:block;animation:fadeUp .5s ease}
.form-success .check{width:70px;height:70px;border-radius:50%;border:2px solid var(--gold);display:grid;place-items:center;margin:0 auto 16px;color:var(--gold);font-size:2rem;animation:pop .5s var(--ease)}
@keyframes pop{0%{transform:scale(0)}70%{transform:scale(1.15)}100%{transform:scale(1)}}

/* ============ FAQ ============ */
.faq-list{max-width:780px;margin:46px auto 0;display:grid;gap:14px}
.faq-item{border:1px solid var(--line);border-radius:14px;background:var(--black-card);overflow:hidden}
.faq-q{width:100%;text-align:left;background:none;border:none;cursor:pointer;padding:20px 22px;color:var(--cream);font-family:'Jost';font-size:1.02rem;font-weight:400;display:flex;justify-content:space-between;align-items:center;gap:14px}
.faq-q .pl{color:var(--gold);font-size:1.5rem;transition:transform .35s var(--ease);flex-shrink:0;line-height:1}
.faq-item.open .pl{transform:rotate(45deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .4s var(--ease)}
.faq-a p{padding:0 22px 20px;color:var(--cream-dim);font-size:.94rem}

/* ============ ABOUT / CONTENT ============ */
.split{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}
.split .img-frame{border-radius:18px;overflow:hidden;border:1px solid var(--line);position:relative}
.split .img-frame img{width:100%;height:100%;object-fit:cover;aspect-ratio:4/3}
.split h2{font-size:clamp(1.9rem,4.5vw,2.8rem);color:var(--cream);margin-bottom:14px}
.split h2 .gold{color:var(--gold)}
.split p{color:var(--cream-dim);margin-bottom:14px}
.feat-list{list-style:none;display:grid;gap:12px;margin-top:8px}
.feat-list li{display:flex;gap:11px;align-items:flex-start;color:var(--cream)}
.feat-list svg{width:20px;height:20px;stroke:var(--gold);fill:none;stroke-width:1.6;flex-shrink:0;margin-top:3px}

/* contact info cards */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:40px;margin-top:46px;align-items:start}
.info-cards{display:grid;gap:16px}
.info-card{display:flex;gap:16px;align-items:flex-start;background:var(--black-card);border:1px solid var(--line);border-radius:14px;padding:22px}
.info-card .ico{width:46px;height:46px;border-radius:12px;background:rgba(212,175,55,.1);border:1px solid var(--line);display:grid;place-items:center;flex-shrink:0}
.info-card .ico svg{width:22px;height:22px;stroke:var(--gold);fill:none;stroke-width:1.6}
.info-card h4{color:var(--cream);font-size:1.2rem;margin-bottom:3px}
.info-card a,.info-card p{color:var(--cream-dim);font-size:.92rem;display:block}
.info-card a:hover{color:var(--gold)}
.map-full{margin-top:18px;border-radius:14px;overflow:hidden;border:1px solid var(--line);line-height:0}
.map-full iframe{width:100%;height:280px;border:0;filter:grayscale(.3) contrast(1.05)}

/* ============ CTA STRIP ============ */
.cta-strip{background:linear-gradient(135deg,#1a1206,#0d0b06);text-align:center}
.cta-strip h2{font-size:clamp(2rem,5vw,3.2rem);color:var(--cream);margin-bottom:14px}
.cta-strip h2 .gold{color:var(--gold)}
.cta-strip p{color:var(--cream-dim);max-width:560px;margin:0 auto 26px}
.cta-strip .hero-cta{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}

/* ============ FOOTER ============ */
footer{background:#070707;border-top:1px solid var(--line);padding:64px var(--pad) 130px}
.foot-grid{max-width:var(--maxw);margin:0 auto;display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:36px}
.foot-col h4{color:var(--gold);font-size:1.15rem;margin-bottom:16px;letter-spacing:1px}
.foot-col p,.foot-col a{color:var(--cream-dim);font-size:.9rem;display:block;margin-bottom:10px;transition:color .3s}
.foot-col a:hover{color:var(--gold)}
.foot-logo{font-family:'Cormorant Garamond';font-size:1.6rem;font-weight:700;color:var(--cream);margin-bottom:12px}
.foot-logo b{color:var(--gold)}
.socials{display:flex;gap:12px;margin-top:8px}
.socials a{width:40px;height:40px;border-radius:50%;border:1px solid var(--line);display:grid;place-items:center;background:var(--glass)}
.socials a:hover{border-color:var(--gold);background:rgba(212,175,55,.12);transform:translateY(-3px)}
.socials svg{width:18px;height:18px;fill:var(--gold)}
.foot-contact a{display:flex;align-items:center;gap:10px}
.foot-contact svg{width:17px;height:17px;stroke:var(--gold);fill:none;stroke-width:1.6}
.map-embed{margin-top:14px;border-radius:12px;overflow:hidden;border:1px solid var(--line);line-height:0}
.map-embed iframe{width:100%;height:150px;border:0;filter:grayscale(.3) contrast(1.05)}
.copyright{max-width:var(--maxw);margin:40px auto 0;padding-top:22px;border-top:1px solid var(--line);text-align:center;color:var(--cream-dim);font-size:.82rem}

/* ============ FLOATING CONTACT BAR ============ */
.contact-bar{
  position:fixed;left:0;right:0;bottom:0;z-index:1000;
  display:flex;gap:10px;padding:10px 12px calc(10px + env(safe-area-inset-bottom));
  background:rgba(10,10,10,.9);backdrop-filter:blur(14px);border-top:1px solid var(--line);
}
.contact-bar a{
  flex:1;display:flex;align-items:center;justify-content:center;gap:9px;
  padding:15px;border-radius:14px;font-weight:600;font-size:.98rem;letter-spacing:.5px;
  min-height:54px;transition:transform .3s var(--ease);
}
.cb-call{background:var(--grad-gold);color:#1a1206}
.cb-wa{background:#1faf54;color:#fff}
.contact-bar a:active{transform:scale(.96)}
.contact-bar svg{width:20px;height:20px;flex-shrink:0}
.cb-call svg{fill:#1a1206}.cb-wa svg{fill:#fff}
.contact-bar a.pulse{animation:pulseBtn 1.2s ease}
@keyframes pulseBtn{0%,100%{box-shadow:0 0 0 0 rgba(212,175,55,0)}40%{box-shadow:0 0 0 12px rgba(212,175,55,.18)}}
.cb-wa.pulse{animation:pulseWa 1.2s ease}
@keyframes pulseWa{0%,100%{box-shadow:0 0 0 0 rgba(31,175,84,0)}40%{box-shadow:0 0 0 12px rgba(31,175,84,.22)}}

/* ============ RESPONSIVE ============ */
@media(max-width:860px){
  .nav-links{
    position:fixed;top:0;right:0;height:100svh;width:78%;max-width:330px;
    flex-direction:column;justify-content:center;align-items:center;gap:26px;
    background:rgba(10,10,10,.97);backdrop-filter:blur(16px);
    transform:translateX(100%);transition:transform .45s var(--ease);
    border-left:1px solid var(--line);
  }
  .nav-links.open{transform:translateX(0)}
  .nav-links a:not(.btn){font-size:1.05rem}
  .nav-links .nav-cta{display:inline-flex}
  .nav-cta-solo{display:none}
  .burger{display:flex}
  .book-wrap,.split,.contact-grid{grid-template-columns:1fr;gap:34px}
  .split .order-img{order:-1}
  .gallery{columns:2}
  .foot-grid{grid-template-columns:1fr 1fr;gap:30px}
}
/* hide the in-menu Book Now on desktop; show standalone instead */
@media(min-width:861px){
  .nav-links .nav-cta{display:none}
}
@media(max-width:520px){
  .gallery{columns:2;column-gap:10px}
  .foot-grid{grid-template-columns:1fr}
  .hero-cta .btn,.cta-strip .hero-cta .btn{width:100%}
  section{padding-bottom:84px}
  body{padding-bottom:74px}
}
@media(prefers-reduced-motion:reduce){
  *{animation-duration:.001s!important;animation-iteration-count:1!important;transition-duration:.001s!important}
  .reveal{opacity:1;transform:none}
}
