*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --ocean:#2c4a52;--ocean-mid:#3d6672;--ocean-light:#5c8a96;--sand:#e8ddd0;--sand-light:#f2ece4;
  --fog:#b8c8cc;--stone:#7a8a8e;--ink:#1a2a2e;--white:#fafaf8;
  --serif:'Playfair Display',serif;--sans:'Jost',sans-serif;
  --pad:110px 6%
}
html{scroll-behavior:smooth}
body{background:var(--white);color:var(--ink);font-family:var(--sans);font-weight:300;overflow-x:hidden}
::-webkit-scrollbar{width:3px}::-webkit-scrollbar-track{background:var(--sand-light)}::-webkit-scrollbar-thumb{background:var(--ocean)}

/* ── HEADER ── */
header{position:fixed;top:0;width:100%;z-index:900;padding:30px 6%;display:flex;align-items:center;justify-content:space-between;transition:all .45s}
header.solid{background:rgba(26,42,46,.96);padding:18px 6%;backdrop-filter:blur(8px)}
.logo{font-family:var(--serif);font-size:1.4rem;font-weight:400;color:var(--white);letter-spacing:.12em;text-decoration:none;line-height:1}
.logo small{display:block;font-family:var(--sans);font-size:.5rem;letter-spacing:.55em;text-transform:uppercase;color:var(--fog);margin-top:4px;font-weight:300}
nav{display:flex;align-items:center;gap:32px}
nav a{color:rgba(250,250,248,.75);font-size:.68rem;letter-spacing:.22em;text-transform:uppercase;text-decoration:none;transition:color .3s;font-weight:300}
nav a:hover{color:var(--sand)}
.btn-reserve{border:1px solid var(--fog);color:var(--white);padding:11px 26px;font-size:.65rem;letter-spacing:.22em;text-transform:uppercase;text-decoration:none;transition:all .3s;font-family:var(--sans);font-weight:300}
.btn-reserve:hover{background:var(--sand);color:var(--ink);border-color:var(--sand)}
.hamburger{display:none;flex-direction:column;gap:6px;background:none;border:none;cursor:pointer;padding:4px}
.hamburger span{width:22px;height:1px;background:var(--white);transition:all .3s;display:block}
.mob-nav{display:none;position:fixed;inset:0;background:var(--ink);z-index:890;flex-direction:column;align-items:center;justify-content:center;gap:28px;opacity:0;transition:opacity .35s}
.mob-nav.open{opacity:1}
.mob-nav a{font-family:var(--serif);font-size:1.6rem;font-weight:300;color:var(--sand-light);text-decoration:none;letter-spacing:.08em;transition:color .3s}
.mob-nav a:hover{color:var(--fog)}
.mob-close{position:absolute;top:28px;right:6%;background:none;border:none;color:var(--fog);font-size:2rem;cursor:pointer;line-height:1}

/* ── HERO ── */
#hero{height:100vh;min-height:620px;position:relative;display:flex;align-items:flex-end;padding-bottom:80px;overflow:hidden}
.hero-media{position:absolute;inset:0;background:url('../assets/img/hero/hero-sea.webp') center/cover no-repeat;transform:scale(1.06);transition:transform 10s ease-out}
.hero-wash{position:absolute;inset:0;background:linear-gradient(160deg,rgba(26,42,46,.18) 0%,rgba(26,42,46,.72) 100%)}
.hero-body{position:relative;z-index:2;max-width:680px;padding:0 6%}
.hero-tag{font-size:.58rem;letter-spacing:.55em;text-transform:uppercase;color:var(--fog);margin-bottom:20px;display:block;opacity:0;animation:riseUp .9s .2s forwards}
h1{font-family:var(--serif);font-size:clamp(2.8rem,6vw,5.2rem);font-weight:300;line-height:1.08;color:var(--white);margin-bottom:28px;opacity:0;animation:riseUp .9s .45s forwards}
h1 i{font-style:italic;color:var(--sand)}
.hero-sub{font-size:.82rem;line-height:1.9;color:rgba(250,250,248,.75);max-width:460px;margin-bottom:40px;letter-spacing:.04em;opacity:0;animation:riseUp .9s .68s forwards}
.hero-ctas{display:flex;gap:14px;flex-wrap:wrap;opacity:0;animation:riseUp .9s .88s forwards}
.cta-fill{background:var(--sand);color:var(--ink);padding:15px 36px;font-size:.68rem;letter-spacing:.22em;text-transform:uppercase;text-decoration:none;font-weight:400;transition:all .3s;border:1px solid var(--sand)}
.cta-fill:hover{background:transparent;color:var(--sand)}
.cta-ghost{background:transparent;color:var(--white);padding:15px 36px;font-size:.68rem;letter-spacing:.22em;text-transform:uppercase;text-decoration:none;border:1px solid rgba(250,250,248,.45);transition:all .3s}
.cta-ghost:hover{border-color:var(--sand);color:var(--sand)}
.hero-scroll{position:absolute;right:6%;bottom:48px;display:flex;flex-direction:column;align-items:center;gap:10px;color:var(--fog);font-size:.55rem;letter-spacing:.35em;text-transform:uppercase;z-index:2}
.scroll-bar{width:1px;height:52px;background:linear-gradient(to bottom,var(--fog),transparent);animation:drip 2s infinite}

/* ── BOOKING STRIP ── */
#booking{background:var(--ocean);padding:28px 6%}
.booking-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:14px;align-items:end;max-width:1100px;margin:0 auto}
.bf{display:flex;flex-direction:column;gap:7px}
.bf label{font-size:.56rem;letter-spacing:.3em;text-transform:uppercase;color:var(--fog)}
.bf input,.bf select{background:transparent;border:none;border-bottom:1px solid rgba(184,210,218,.35);padding:9px 0;color:var(--white);font-family:var(--sans);font-size:.78rem;font-weight:300;outline:none;transition:border-color .3s;-webkit-appearance:none}
.bf input:focus,.bf select:focus{border-color:var(--sand)}
.bf select option{background:var(--ink);color:var(--white)}
.btn-check{background:var(--sand);color:var(--ink);border:none;padding:13px 28px;font-size:.65rem;letter-spacing:.2em;text-transform:uppercase;font-family:var(--sans);font-weight:400;cursor:pointer;transition:background .3s;white-space:nowrap}
.btn-check:hover{background:var(--sand-light)}

/* ── GENERALES ── */
section{padding:var(--pad)}
.eyebrow{font-size:.58rem;letter-spacing:.45em;text-transform:uppercase;color:var(--ocean-light);display:block;margin-bottom:14px}
h2{font-family:var(--serif);font-size:clamp(1.9rem,3.6vw,3rem);font-weight:300;line-height:1.18;color:var(--ink);margin-bottom:18px}
h2 i{font-style:italic;color:var(--ocean-mid)}
.rule{width:40px;height:1px;background:var(--ocean-light);margin:22px 0}
.rule.c{margin:22px auto}
.body-text{font-size:.82rem;line-height:2;color:var(--stone);max-width:560px}
.reveal{opacity:0;transform:translateY(28px);transition:opacity .75s,transform .75s}
.reveal.on{opacity:1;transform:none}

/* ── PHILOSOPHY (2-col) ── */
#philosophy{background:var(--sand-light)}
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:88px;align-items:center;max-width:1200px;margin:0 auto}
.img-stack{position:relative}
.img-main{width:100%;aspect-ratio:3/4;object-fit:cover;filter:brightness(.92);display:block}
.img-pip{position:absolute;bottom:-28px;right:-28px;width:52%;aspect-ratio:1;object-fit:cover;border:7px solid var(--sand-light);filter:brightness(.88)}
.stats-row{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-top:44px}
.stat{border-top:1px solid var(--fog);padding-top:18px}
.stat-n{font-family:var(--serif);font-size:2.2rem;font-weight:300;color:var(--ocean)}
.stat-l{font-size:.6rem;letter-spacing:.2em;text-transform:uppercase;color:var(--stone);margin-top:3px}

/* ── STAYS ── */
#stays{background:var(--white)}
.stays-head{text-align:center;margin-bottom:60px}
.stays-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2px;max-width:1400px;margin:0 auto 44px}
.stay-card{position:relative;overflow:hidden;cursor:pointer}
.stay-card img{width:100%;aspect-ratio:4/5;object-fit:cover;filter:brightness(.72);transition:transform .65s,filter .65s;display:block}
.stay-card:hover img{transform:scale(1.06);filter:brightness(.48)}
.stay-info{position:absolute;bottom:0;left:0;right:0;padding:30px 26px;background:linear-gradient(to top,rgba(26,42,46,.92),transparent)}
.stay-from{font-size:.58rem;letter-spacing:.3em;text-transform:uppercase;color:var(--fog);margin-bottom:7px;display:block}
h3.stay-name{font-family:var(--serif);font-size:1.5rem;font-weight:300;color:var(--white);margin-bottom:5px}
.stay-detail{font-size:.7rem;color:rgba(250,250,248,.65)}
.stay-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .4s}
.stay-card:hover .stay-overlay{opacity:1}
.btn-stay{background:var(--sand);color:var(--ink);padding:11px 26px;font-size:.63rem;letter-spacing:.2em;text-transform:uppercase;font-weight:400;border:none;cursor:pointer;font-family:var(--sans);transition:background .3s}
.btn-stay:hover{background:var(--sand-light)}
.stays-foot{text-align:center}

/* ── WELLNESS ── */
#wellness{background:var(--ink);padding:0}
.wellness-split{display:grid;grid-template-columns:1fr 1fr}
.wellness-img{width:100%;height:640px;object-fit:cover;filter:brightness(.78);display:block}
.wellness-body{display:flex;flex-direction:column;justify-content:center;padding:88px 64px;background:var(--ocean)}
.wellness-body .eyebrow{color:var(--fog)}
.wellness-body h2{color:var(--white)}
.wellness-body h2 i{color:var(--sand)}
.wellness-body .rule{background:var(--fog)}
.wellness-body .body-text{color:rgba(250,250,248,.7);max-width:100%}
.w-list{list-style:none;margin:28px 0;display:flex;flex-direction:column;gap:13px}
.w-list li{font-size:.76rem;color:rgba(250,250,248,.65);display:flex;align-items:center;gap:14px;letter-spacing:.04em}
.w-list li::before{content:'';width:22px;height:1px;background:var(--sand);flex-shrink:0}

/* ── EXPERIENCES ── */
#experiences{background:var(--sand-light)}
.exp-head{text-align:center;margin-bottom:60px}
.exp-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:2px;max-width:1300px;margin:0 auto}
.exp-tile{position:relative;overflow:hidden;cursor:pointer}
.exp-tile img{width:100%;aspect-ratio:3/4;object-fit:cover;filter:brightness(.68);transition:transform .6s,filter .6s;display:block}
.exp-tile:hover img{transform:scale(1.05);filter:brightness(.45)}
.exp-label{position:absolute;bottom:0;left:0;right:0;padding:28px 22px;background:linear-gradient(to top,rgba(26,42,46,.9),transparent)}
h3.exp-name{font-family:var(--serif);font-size:1.3rem;font-weight:300;color:var(--white);margin-bottom:4px}
.exp-sub{font-size:.66rem;color:var(--fog);letter-spacing:.08em}
.exp-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .4s}
.exp-tile:hover .exp-overlay{opacity:1}
.btn-exp{background:transparent;color:var(--white);border:1px solid var(--fog);padding:10px 24px;font-size:.62rem;letter-spacing:.2em;text-transform:uppercase;cursor:pointer;font-family:var(--sans);transition:all .3s}
.btn-exp:hover{background:var(--sand);color:var(--ink);border-color:var(--sand)}

/* ── DINING ── */
#dining{background:var(--white)}
.dining-grid{display:grid;grid-template-columns:1fr 1fr;gap:88px;align-items:center;max-width:1200px;margin:0 auto}
.dining-img{width:100%;aspect-ratio:4/5;object-fit:cover;filter:brightness(.88);display:block}
.d-tabs{display:flex;border-bottom:1px solid var(--fog);margin:28px 0 20px;gap:0}
.d-tab{background:none;border:none;color:var(--stone);font-family:var(--sans);font-size:.63rem;letter-spacing:.2em;text-transform:uppercase;padding:11px 18px;cursor:pointer;border-bottom:1px solid transparent;margin-bottom:-1px;transition:color .3s;font-weight:300}
.d-tab.on{color:var(--ocean);border-bottom-color:var(--ocean)}
.d-panel{display:none}.d-panel.on{display:block}
.d-item{padding:14px 0;border-bottom:1px solid var(--sand)}
.d-name{font-size:.82rem;color:var(--ink);margin-bottom:3px}
.d-desc{font-size:.7rem;color:var(--stone);font-style:italic;margin-bottom:5px}
.d-price{font-size:.72rem;color:var(--ocean-mid)}

/* ── GALLERY ── */
#gallery{background:var(--ink);padding:80px 6%}
.gal-head{text-align:center;margin-bottom:44px}
.gal-head .eyebrow{color:var(--fog)}
.gal-head h2{color:var(--white)}
.gal-head h2 i{color:var(--sand)}
.gal-grid{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:220px;gap:3px;max-width:1400px;margin:0 auto}
.gal-item{overflow:hidden;cursor:pointer}
.gal-item img{width:100%;height:100%;object-fit:cover;filter:brightness(.75);transition:transform .5s,filter .5s;display:block}
.gal-item:hover img{transform:scale(1.07);filter:brightness(1)}
.gal-item:nth-child(1){grid-column:span 2;grid-row:span 2}

/* ── REVIEWS ── */
#reviews{background:var(--sand-light);text-align:center;padding:100px 6%}
.rev-wrap{max-width:680px;margin:0 auto}
.rev-slide{display:none;animation:fadeIn .5s}.rev-slide.on{display:block}
.rev-stars{color:var(--ocean-mid);font-size:.75rem;letter-spacing:5px;margin-bottom:22px}
blockquote{font-family:var(--serif);font-size:clamp(1.2rem,2.2vw,1.7rem);font-weight:300;font-style:italic;color:var(--ink);line-height:1.65;margin-bottom:28px}
.rev-name{font-size:.62rem;letter-spacing:.3em;text-transform:uppercase;color:var(--ocean)}
.rev-loc{font-size:.62rem;color:var(--stone);margin-top:4px;letter-spacing:.08em}
.rev-dots{display:flex;justify-content:center;gap:10px;margin-top:36px}
.rev-dot{width:5px;height:5px;border-radius:50%;background:var(--fog);cursor:pointer;border:none;transition:background .3s,transform .3s}
.rev-dot.on{background:var(--ocean);transform:scale(1.4)}

/* ── CONTACT ── */
#contact{background:url('../assets/img/resort.webp') center/cover no-repeat;position:relative}
#contact::before{content:'';position:absolute;inset:0;background:rgba(26,42,46,.84)}
.contact-inner{position:relative;z-index:1;max-width:680px;margin:0 auto;text-align:center}
.contact-inner h2{color:var(--white)}
.contact-inner h2 i{color:var(--sand)}
.contact-inner .rule{background:var(--fog)}
.contact-inner .body-text{color:rgba(250,250,248,.7);margin:0 auto 48px;text-align:center}
.c-form{display:grid;gap:18px;text-align:left}
.c-row{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.c-group{display:flex;flex-direction:column;gap:7px}
.c-group label{font-size:.58rem;letter-spacing:.28em;text-transform:uppercase;color:var(--fog)}
.c-group input,.c-group select,.c-group textarea{background:rgba(255,255,255,.06);border:1px solid rgba(184,210,218,.22);padding:13px 15px;color:var(--white);font-family:var(--sans);font-size:.78rem;font-weight:300;outline:none;transition:border-color .3s;resize:vertical}
.c-group input:focus,.c-group select:focus,.c-group textarea:focus{border-color:var(--sand)}
.c-group select option{background:var(--ink)}
.c-note{font-size:.63rem;color:var(--fog);text-align:center;margin-top:6px}

/* ── FOOTER ── */
footer{background:var(--ink);padding:80px 6% 40px;border-top:1px solid rgba(92,138,150,.15)}
.foot-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:56px;max-width:1200px;margin:0 auto 56px}
.foot-brand .logo{display:inline-block;margin-bottom:14px}
.foot-desc{font-size:.73rem;color:var(--stone);line-height:2;max-width:270px;margin-bottom:22px}
.socials{display:flex;gap:12px}
.soc{width:34px;height:34px;border:1px solid rgba(92,138,150,.3);display:flex;align-items:center;justify-content:center;color:var(--stone);text-decoration:none;font-size:.65rem;transition:all .3s}
.soc:hover{border-color:var(--sand);color:var(--sand)}
.foot-col h4{font-size:.56rem;letter-spacing:.32em;text-transform:uppercase;color:var(--ocean-light);margin-bottom:18px}
.foot-col ul{list-style:none;display:flex;flex-direction:column;gap:11px}
.foot-col ul li a{color:var(--stone);text-decoration:none;font-size:.75rem;transition:color .3s}
.foot-col ul li a:hover{color:var(--sand)}
.foot-bot{max-width:1200px;margin:0 auto;padding-top:28px;border-top:1px so#contact{background:url('https://images.unsplash.com/photo-1439130490301-25e322d88054?w=1920&q=85') center/cover fixed;position:relative}
#contact::before{content:'';position:absolute;inset:0;background:rgba(26,42,46,.84)}
.contact-inner{position:relative;z-index:1;max-width:680px;margin:0 auto;text-align:center}
.contact-inner h2{color:var(--white)}
.contact-inner h2 i{color:var(--sand)}
.contact-inner .rule{background:var(--fog)}
.contact-inner .body-text{color:rgba(250,250,248,.7);margin:0 auto 48px;text-align:center}
.c-form{display:grid;gap:18px;text-align:left}
.c-row{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.c-group{display:flex;flex-direction:column;gap:7px}
.c-group label{font-size:.58rem;letter-spacing:.28em;text-transform:uppercase;color:var(--fog)}
.c-group input,.c-group select,.c-group textarea{background:rgba(255,255,255,.06);border:1px solid rgba(184,210,218,.22);padding:13px 15px;color:var(--white);font-family:var(--sans);font-size:.78rem;font-weight:300;outline:none;transition:border-color .3s;resize:vertical}
.c-group input:focus,.c-group select:focus,.c-group textarea:focus{border-color:var(--sand)}
.c-group select option{background:var(--ink)}
.c-note{font-size:.63rem;color:var(--fog);text-align:center;margin-top:6px}
lid rgba(92,138,150,.12);display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:14px}
.foot-bot p,.foot-bot a{font-size:.62rem;color:var(--stone)}
.foot-bot a{text-decoration:none;transition:color .3s}.foot-bot a:hover{color:var(--sand)}
.foot-legal{display:flex;gap:20px}

/* ── BACK TOP ── */
.back-top{position:fixed;bottom:30px;right:30px;width:42px;height:42px;background:var(--ocean);color:var(--white);border:none;cursor:pointer;font-size:.9rem;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .3s;z-index:100}
.back-top.show{opacity:1}

/* ── MODALES ── */
.modal-bg{display:none;position:fixed;inset:0;background:rgba(10,20,22,.9);z-index:2000;align-items:center;justify-content:center;padding:20px}
.modal-bg.open{display:flex}
.m-close{position:absolute;top:16px;right:20px;background:none;border:none;color:var(--fog);font-size:1.8rem;cursor:pointer;line-height:1;z-index:1;transition:color .3s}
.m-close:hover{color:var(--sand)}

/* STAY DETAIL MODAL */
.stay-modal{background:var(--ink);max-width:880px;width:100%;max-height:90vh;overflow-y:auto;position:relative;display:grid;grid-template-columns:1fr 1fr}
.stay-modal-img{width:100%;height:100%;object-fit:cover;display:block;min-height:340px}
.stay-modal-body{padding:48px 40px;display:flex;flex-direction:column;justify-content:center}
.stay-modal-body .eyebrow{color:var(--fog)}
.stay-modal-body h3{font-family:var(--serif);font-size:1.9rem;font-weight:300;color:var(--white);margin-bottom:8px}
.stay-modal-price{font-size:.76rem;color:var(--sand);letter-spacing:.1em;margin-bottom:20px}
.stay-modal-rule{width:32px;height:1px;background:var(--fog);margin-bottom:20px}
.stay-modal-desc{font-size:.76rem;color:rgba(250,250,248,.65);line-height:2;margin-bottom:24px}
.stay-feats{list-style:none;display:flex;flex-direction:column;gap:9px;margin-bottom:28px}
.stay-feats li{font-size:.72rem;color:rgba(250,250,248,.6);display:flex;align-items:center;gap:12px}
.stay-feats li::before{content:'';width:18px;height:1px;background:var(--sand);flex-shrink:0}

/* ALL STAYS MODAL */
.allstays-modal{background:var(--ink);max-width:940px;width:100%;max-height:90vh;overflow-y:auto;position:relative;padding:52px 48px 44px}
.allstays-modal .eyebrow{color:var(--fog)}
.allstays-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:16px;margin-top:32px}
.st-thumb{border:1px solid rgba(92,138,150,.18);padding:24px 20px;cursor:pointer;transition:border-color .3s,background .3s}
.st-thumb:hover{border-color:rgba(184,210,218,.5);background:rgba(92,138,150,.08)}
.st-thumb-cat{font-size:.56rem;letter-spacing:.3em;text-transform:uppercase;color:var(--ocean-light);display:block;margin-bottom:9px}
.st-thumb-name{font-family:var(--serif);font-size:1.2rem;font-weight:300;color:var(--white);margin-bottom:5px}
.st-thumb-size{font-size:.68rem;color:var(--stone);margin-bottom:12px}
.st-thumb-price{font-size:.73rem;color:var(--sand)}
.allstays-hint{font-size:.68rem;color:var(--stone);text-align:center;margin-top:24px}

/* EXP DETAIL MODAL */
.exp-modal{background:var(--ink);max-width:600px;width:100%;max-height:90vh;overflow-y:auto;position:relative;padding:52px 48px 44px}
.exp-modal .eyebrow{color:var(--fog)}
.exp-modal h3{font-family:var(--serif);font-size:1.9rem;font-weight:300;color:var(--white);margin-bottom:8px}
.exp-modal-rule{width:32px;height:1px;background:var(--fog);margin:18px 0}
.exp-modal-desc{font-size:.78rem;color:rgba(250,250,248,.65);line-height:2;margin-bottom:24px}
.exp-feats{list-style:none;display:flex;flex-direction:column;gap:9px;margin-bottom:28px}
.exp-feats li{font-size:.72rem;color:rgba(250,250,248,.6);display:flex;align-items:center;gap:12px}
.exp-feats li::before{content:'';width:18px;height:1px;background:var(--sand);flex-shrink:0}

/* LIGHTBOX */
.lb-img{max-width:90vw;max-height:86vh;object-fit:contain;display:block}

/* ── KEYFRAMES ── */
@keyframes riseUp{from{opacity:0;transform:translateY(22px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes drip{0%,100%{opacity:.6;transform:scaleY(1)}50%{opacity:1;transform:scaleY(1.12)}}

/* ── RESPONSIVE ── */
@media(max-width:1024px){
  .two-col,.dining-grid{grid-template-columns:1fr;gap:48px}
  .img-pip{display:none}
  .wellness-split{grid-template-columns:1fr}.wellness-img{height:380px}.wellness-body{padding:60px 44px}
  .stay-modal,.stays-grid{grid-template-columns:1fr}
  .stay-modal-img{min-height:240px;max-height:280px}
  .gal-grid{grid-template-columns:repeat(2,1fr)}.gal-item:nth-child(1){grid-column:span 1;grid-row:span 1}
  .foot-grid{grid-template-columns:1fr 1fr;gap:36px}
}
@media(max-width:768px){
  :root{--pad:72px 5%}
  nav{display:none}.hamburger{display:flex}
  .hero-ctas{flex-direction:column;align-items:flex-start}
  .c-row{grid-template-columns:1fr}
  .foot-grid{grid-template-columns:1fr}.foot-bot{flex-direction:column;text-align:center}
  .stays-grid{grid-template-columns:1fr}
  .booking-row{grid-template-columns:1fr 1fr}
  .allstays-modal{padding:40px 24px}
  .exp-modal{padding:40px 24px}
}
@media(max-width:480px){
  .booking-row{grid-template-columns:1fr}
  .gal-grid{grid-template-columns:1fr 1fr}
  .exp-grid{grid-template-columns:1fr}
}

.hero-wash {
  display: none !important;
}

.hero-scroll {
  display: none !important;
}

.hero-media {
  transform: none !important;
}

button,
.btn,
a {
  transition: transform .25s ease, opacity .25s ease;
}
