/* Sunrise Pool Villa — Brand CSS */
:root{
  --navy:#122448;
  --navy-90:rgba(18,36,72,.92);
  --navy-70:rgba(18,36,72,.70);
  --navy-50:rgba(18,36,72,.50);
  --navy-20:rgba(18,36,72,.20);
  --navy-08:rgba(18,36,72,.08);
  --gold:#BA9C6A;
  --gold-dark:#a6885a;
  --cream:#F8F6F1;
  --offwhite:#FAFAF8;
  --white:#FFFFFF;
  --serif:"Cormorant Garamond", Georgia, serif;
  --sans:"Montserrat", Arial, sans-serif;
  --border:rgba(18,36,72,.12);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--sans);font-weight:300;color:var(--navy);
  background:var(--white);-webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;line-height:1.7;font-size:15px;
}
img{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
h1,h2,h3,h4{font-family:var(--serif);font-weight:400;line-height:1.15;letter-spacing:.01em}
.serif{font-family:var(--serif)}
.upper{text-transform:uppercase;letter-spacing:.18em}

.container{max-width:1240px;margin:0 auto;padding:0 28px}
.container-wide{max-width:1440px;margin:0 auto;padding:0 28px}

/* ---------- Header ---------- */
.site-header{position:fixed;top:0;left:0;right:0;z-index:100;padding:14px 0;transition:background .35s ease,padding .35s ease}
.site-header.at-top{background:linear-gradient(180deg,rgba(18,36,72,.55) 0%,rgba(18,36,72,0) 100%)}
.site-header.scrolled{background:rgba(18,36,72,.96);padding:10px 0;backdrop-filter:blur(8px)}
.nav-wrap{display:flex;align-items:center;justify-content:space-between;gap:28px}
.logo-link{display:flex;align-items:center}
.logo-link img{height:78px;width:auto;transition:height .35s ease}
.site-header.scrolled .logo-link img{height:56px}
.nav-links{display:flex;gap:30px;align-items:center}
.nav-links a{color:#fff;font-size:12px;letter-spacing:.18em;text-transform:uppercase;font-weight:400;opacity:.9;transition:opacity .2s}
.nav-links a:hover,.nav-links a.active{opacity:1;color:var(--gold)}
.nav-cta{display:flex;align-items:center;gap:16px}
.btn-availability{border:1.5px solid var(--gold);color:var(--gold);padding:11px 22px;font-size:11px;letter-spacing:.2em;text-transform:uppercase;transition:all .25s}
.btn-availability:hover{background:var(--gold);color:#fff}
.menu-toggle{color:#fff;font-size:22px;display:none;background:none;border:none}
@media (max-width:980px){
  .nav-links{display:none}
  .menu-toggle{display:block}
}

/* Mobile drawer */
.mobile-drawer{position:fixed;inset:0;background:var(--navy);z-index:200;display:none;flex-direction:column;padding:90px 28px 40px}
.mobile-drawer.open{display:flex}
.mobile-drawer a{color:#fff;font-family:var(--serif);font-size:24px;padding:16px 0;border-bottom:1px solid rgba(255,255,255,.08)}
.drawer-close{position:absolute;top:24px;right:24px;color:#fff;font-size:28px}

/* ---------- Hero ---------- */
.hero{position:relative;min-height:100vh;color:#fff;display:flex;align-items:center}
.hero-bg{position:absolute;inset:0;overflow:hidden}
.hero-bg img{width:100%;height:100%;object-fit:cover}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(18,36,72,.55) 0%,rgba(18,36,72,.25) 40%,rgba(18,36,72,.78) 100%)}
.hero-inner{position:relative;z-index:2;width:100%;padding:160px 0 220px;text-align:center;display:flex;flex-direction:column;align-items:center}
.hero h1{font-size:clamp(48px,7.5vw,96px);font-weight:300;line-height:1.05;letter-spacing:.015em;color:#fff;text-shadow:0 2px 30px rgba(0,0,0,.35)}
.hero .gold-divider{width:64px;height:1px;background:var(--gold);margin:28px auto 18px}
.hero .location-line{font-family:var(--sans);font-size:12px;letter-spacing:.32em;text-transform:uppercase;color:var(--gold);margin-bottom:30px}
.hero .tagline{font-family:var(--serif);font-style:italic;font-size:28px;color:#fff;font-weight:300;margin-bottom:12px;text-shadow:0 2px 18px rgba(0,0,0,.35)}
.hero .sub{font-size:14px;font-weight:300;opacity:.92;max-width:520px;margin:0 auto 36px;letter-spacing:.04em}
.hero-ctas{justify-content:center}
.hero-ctas{display:flex;gap:14px;flex-wrap:wrap}
.btn-gold{background:var(--gold);color:#fff;padding:15px 32px;font-size:11px;letter-spacing:.22em;text-transform:uppercase;font-weight:500;transition:background .2s;display:inline-block;border:1.5px solid var(--gold)}
.btn-gold:hover{background:var(--gold-dark);border-color:var(--gold-dark)}
.btn-outline{border:1.5px solid rgba(255,255,255,.7);color:#fff;padding:15px 32px;font-size:11px;letter-spacing:.22em;text-transform:uppercase;font-weight:500;transition:all .2s;display:inline-block;background:transparent}
.btn-outline:hover{background:#fff;color:var(--navy);border-color:#fff}

/* Booking bar */
.booking-bar{position:absolute;left:0;right:0;bottom:-42px;z-index:3;pointer-events:none}
.booking-bar .bar{max-width:880px;margin:0 auto;background:var(--navy);padding:22px 26px;display:grid;grid-template-columns:1fr 1fr 1.2fr auto;gap:20px;align-items:end;pointer-events:auto;box-shadow:0 18px 44px rgba(18,36,72,.28)}
.booking-bar label{display:block;color:rgba(255,255,255,.6);font-size:10px;letter-spacing:.22em;text-transform:uppercase;margin-bottom:6px}
.booking-bar input,.booking-bar select{width:100%;background:transparent;border:none;border-bottom:1px solid rgba(255,255,255,.25);color:#fff;padding:6px 0 8px;font-family:inherit;font-size:13px;font-weight:300;outline:none}
.booking-bar input::placeholder{color:rgba(255,255,255,.55)}
.booking-bar option{color:var(--navy)}
.booking-bar .btn-gold{padding:13px 26px}
@media (max-width:900px){
  .booking-bar{position:static;margin-top:-10px}
  .booking-bar .bar{grid-template-columns:1fr 1fr;margin:0 16px;padding:22px}
  .booking-bar .btn-gold{grid-column:1/-1}
}

/* ---------- Sections ---------- */
section{scroll-margin-top:100px}
.section{padding:110px 0}
.section-sm{padding:70px 0}
.section-title{font-size:clamp(32px,3.4vw,44px);font-weight:300;margin-bottom:10px}
.section-eyebrow{font-size:11px;letter-spacing:.24em;text-transform:uppercase;color:var(--gold);margin-bottom:14px;font-weight:400}
.section-sub{font-family:var(--serif);font-style:italic;color:var(--navy-70);font-size:17px;margin-top:6px}
.gold-rule{width:60px;height:1px;background:var(--gold);margin:18px 0}
.center{text-align:center}
.center .gold-rule{margin:18px auto}

/* Intro */
.intro{text-align:center;padding:100px 0 50px}
.intro h2{font-size:clamp(28px,3vw,38px);font-weight:300;margin-bottom:24px}
.intro p{max-width:520px;margin:0 auto;color:var(--navy-70);font-size:15px;line-height:1.85}
.intro .mark{width:110px;margin:36px auto 0;opacity:.85}

/* ---------- Villa grid ---------- */
.villa-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:22px;margin-top:40px}
@media (max-width:1100px){.villa-grid{grid-template-columns:repeat(3,1fr)}}
@media (max-width:720px){.villa-grid{grid-template-columns:repeat(2,1fr);gap:16px}}
@media (max-width:480px){.villa-grid{grid-template-columns:1fr}}
.villa-card{background:var(--offwhite);transition:transform .3s ease,box-shadow .3s ease;display:flex;flex-direction:column}
.villa-card:hover{transform:translateY(-3px);box-shadow:0 22px 50px rgba(18,36,72,.12)}
.villa-card .thumb{aspect-ratio:1/1;overflow:hidden}
.villa-card .thumb img{width:100%;height:100%;object-fit:cover;transition:transform .6s ease}
.villa-card:hover .thumb img{transform:scale(1.05)}
.villa-card .body{padding:20px 20px 22px;flex:1;display:flex;flex-direction:column}
.villa-card .kicker{font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--gold);margin-bottom:6px}
.villa-card h3{font-family:var(--serif);font-size:22px;font-weight:400;letter-spacing:.02em;margin-bottom:10px;line-height:1.1}
.villa-card .meta{font-size:12px;color:var(--navy-70);margin-bottom:10px}
.villa-card .desc{font-size:13px;color:var(--navy-70);margin-bottom:auto;line-height:1.65}
.villa-card .price{margin-top:18px;padding-top:14px;border-top:1px solid var(--border);font-size:12px;letter-spacing:.1em;color:var(--navy)}
.villa-card .price strong{font-family:var(--serif);font-size:18px;font-weight:400;margin-left:4px}

/* Row header with see-all link */
.row-head{display:flex;align-items:flex-end;justify-content:space-between;gap:20px;flex-wrap:wrap}
.row-head h2{font-size:clamp(30px,3vw,40px);font-weight:300;letter-spacing:.02em}
.row-head .link-gold{color:var(--gold);font-size:11px;letter-spacing:.22em;text-transform:uppercase}
.row-head .link-gold:hover{color:var(--gold-dark)}

/* ---------- Experiences ---------- */
.exp-wrap{display:grid;grid-template-columns:260px repeat(4,1fr);gap:22px;align-items:stretch}
@media (max-width:1100px){.exp-wrap{grid-template-columns:repeat(2,1fr)}}
@media (max-width:540px){.exp-wrap{grid-template-columns:1fr}}
.exp-intro h2{font-size:36px;font-weight:300;line-height:1.1}
.exp-intro p{font-family:var(--serif);font-style:italic;color:var(--navy-70);margin-top:10px}
.exp-item{text-align:center}
.exp-item .thumb{aspect-ratio:1/1;overflow:hidden}
.exp-item .thumb img{width:100%;height:100%;object-fit:cover;transition:transform .6s}
.exp-item:hover .thumb img{transform:scale(1.06)}
.exp-item .label{margin-top:14px;font-family:var(--serif);font-size:18px}

/* ---------- Location ---------- */
.loc-grid{display:grid;grid-template-columns:1fr 1.4fr 1fr;gap:40px;align-items:start}
@media (max-width:1000px){.loc-grid{grid-template-columns:1fr}}
.loc-map{aspect-ratio:16/10;background:#e8eef5;overflow:hidden;position:relative}
.loc-map iframe{width:100%;height:100%;border:0;filter:grayscale(.2) contrast(.95)}
.loc-item{display:flex;gap:14px;align-items:flex-start;padding:14px 0;border-bottom:1px solid var(--border)}
.loc-item:last-child{border-bottom:none}
.loc-item .ico{width:28px;flex:0 0 28px;color:var(--navy)}
.loc-item .ico svg{width:22px;height:22px;stroke:var(--navy);stroke-width:1.4;fill:none}
.loc-item .txt{font-size:13px;color:var(--navy)}
.loc-item .txt .name{font-weight:500;letter-spacing:.06em;text-transform:uppercase;font-size:11px;color:var(--navy);display:block;margin-bottom:3px}
.loc-item .txt .meta{font-size:12px;color:var(--navy-70)}
.loc-left h3{font-size:28px;font-weight:300;margin-bottom:10px}
.loc-left p{font-size:13px;color:var(--navy-70);margin-bottom:10px}
.link-arrow{color:var(--gold);font-size:11px;letter-spacing:.22em;text-transform:uppercase;display:inline-flex;align-items:center;gap:8px;margin-top:14px}

/* Rates preview */
.rates-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:16px;margin-top:30px}
@media (max-width:1100px){.rates-grid{grid-template-columns:repeat(3,1fr)}}
@media (max-width:640px){.rates-grid{grid-template-columns:repeat(2,1fr)}}
.rate-card{background:var(--offwhite);padding:22px 20px;text-align:center;border-top:2px solid var(--gold)}
.rate-card .name{font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--navy);margin-bottom:10px}
.rate-card .from{font-size:9px;letter-spacing:.22em;text-transform:uppercase;color:var(--navy-70);margin-bottom:4px}
.rate-card .price{font-family:var(--serif);font-size:22px;font-weight:400;color:var(--navy)}

/* Why book direct */
.book-direct{background:var(--navy);color:#fff;padding:50px 0}
.bd-wrap{display:grid;grid-template-columns:1.3fr repeat(5,1fr) auto;gap:28px;align-items:center}
@media (max-width:1100px){.bd-wrap{grid-template-columns:1fr 1fr 1fr}}
@media (max-width:640px){.bd-wrap{grid-template-columns:1fr 1fr}}
.bd-title h3{font-size:26px;font-weight:300;line-height:1.1}
.bd-title p{font-family:var(--serif);font-style:italic;opacity:.75;margin-top:6px;font-size:14px}
.bd-item{text-align:center}
.bd-item .ico{display:flex;justify-content:center;margin-bottom:10px}
.bd-item .ico svg{width:26px;height:26px;stroke:var(--gold);stroke-width:1.3;fill:none}
.bd-item .lbl{font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:#fff;line-height:1.5}
.bd-item .sub{font-size:11px;color:rgba(255,255,255,.6);margin-top:2px}
.bd-btn{border:1.5px solid var(--gold);color:var(--gold);padding:13px 24px;font-size:11px;letter-spacing:.22em;text-transform:uppercase;transition:all .25s}
.bd-btn:hover{background:var(--gold);color:#fff}

/* Testimonials */
.testis{text-align:center;padding:110px 0 120px}
.testis h2{font-size:30px;letter-spacing:.3em;font-family:var(--sans);font-weight:400;margin-bottom:50px;color:var(--navy)}
.testis-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:50px;max-width:1100px;margin:0 auto;padding:0 60px;position:relative}
@media (max-width:900px){.testis-grid{grid-template-columns:1fr;gap:34px}}
.testi blockquote{font-family:var(--serif);font-style:italic;font-size:22px;line-height:1.35;color:var(--navy);margin-bottom:14px}
.testi cite{font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--navy-70);font-style:normal}
.testi-arrow{position:absolute;top:50%;transform:translateY(-50%);color:var(--navy-50);font-size:22px;background:none;border:none;cursor:pointer}
.testi-arrow.left{left:0}
.testi-arrow.right{right:0}

/* CTA strip */
.cta-strip{position:relative;min-height:340px;display:flex;align-items:center;justify-content:center;text-align:center;color:#fff;overflow:hidden}
.cta-strip .bg{position:absolute;inset:0}
.cta-strip .bg img{width:100%;height:100%;object-fit:cover}
.cta-strip .bg::after{content:"";position:absolute;inset:0;background:rgba(18,36,72,.55)}
.cta-strip .inner{position:relative;z-index:2;padding:70px 20px}
.cta-strip h2{font-size:clamp(30px,3.6vw,44px);font-weight:300;margin-bottom:10px}
.cta-strip p{font-family:var(--serif);font-style:italic;opacity:.9;margin-bottom:26px}

/* ---------- Footer ---------- */
footer{background:var(--navy);color:#fff;padding:70px 0 30px}
.foot-grid{display:grid;grid-template-columns:1.3fr 1fr 1fr 1fr;gap:40px}
@media (max-width:900px){.foot-grid{grid-template-columns:1fr 1fr;gap:30px}}
@media (max-width:540px){.foot-grid{grid-template-columns:1fr}}
.foot-logo img{height:64px;margin-bottom:14px}
.foot-tag{font-family:var(--serif);font-style:italic;color:rgba(255,255,255,.65);font-size:14px}
.foot-col h4{font-family:var(--sans);font-weight:500;font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:#fff;margin-bottom:18px}
.foot-col ul{list-style:none}
.foot-col li{margin-bottom:10px;font-size:13px;color:rgba(255,255,255,.75)}
.foot-col a:hover{color:var(--gold)}
.foot-col .ico-row{display:flex;gap:10px;align-items:center;margin-bottom:10px;font-size:13px;color:rgba(255,255,255,.75)}
.foot-col .ico-row svg{width:14px;height:14px;stroke:var(--gold);stroke-width:1.4;fill:none;flex:0 0 14px;margin-top:4px}
.social-row{display:flex;gap:12px;margin-top:6px}
.social-row a{width:36px;height:36px;border-radius:50%;border:1px solid rgba(255,255,255,.25);display:flex;align-items:center;justify-content:center;transition:all .2s}
.social-row a:hover{border-color:var(--gold);color:var(--gold)}
.social-row svg{width:15px;height:15px;stroke:currentColor;stroke-width:1.5;fill:none}
.foot-bottom{border-top:1px solid rgba(255,255,255,.12);margin-top:45px;padding-top:22px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:14px;font-size:11px;color:rgba(255,255,255,.55);letter-spacing:.04em}
.foot-bottom a{color:rgba(255,255,255,.7);margin-left:22px}

/* Mobile sticky CTA */
.mobile-cta{display:none;position:fixed;bottom:0;left:0;right:0;background:var(--navy);padding:12px 16px;z-index:80;box-shadow:0 -4px 16px rgba(0,0,0,.15)}
.mobile-cta .btn-gold{width:100%;text-align:center;padding:13px;display:block}
@media (max-width:720px){.mobile-cta{display:block}}

/* ---------- Villa detail pages ---------- */
.page-hero{position:relative;min-height:540px;color:#fff;display:flex;align-items:flex-end;overflow:hidden}
.page-hero .bg{position:absolute;inset:0}
.page-hero .bg img{width:100%;height:100%;object-fit:cover}
.page-hero .bg::after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(18,36,72,.65) 0%,rgba(18,36,72,.15) 60%,rgba(18,36,72,0) 100%)}
.page-hero .inner{position:relative;z-index:2;padding:160px 0 70px;width:100%}
.breadcrumb{font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:rgba(255,255,255,.7);margin-bottom:28px}
.breadcrumb a:hover{color:var(--gold)}
.breadcrumb .sep{margin:0 10px;color:rgba(255,255,255,.4)}
.page-hero h1{font-size:clamp(38px,5.6vw,70px);font-weight:300;line-height:1.05;margin-bottom:16px}
.page-hero .meta-row{font-size:13px;letter-spacing:.14em;color:rgba(255,255,255,.85);margin-bottom:18px}
.page-hero .meta-row span{margin:0 8px}
.page-hero p{max-width:500px;font-size:14px;color:rgba(255,255,255,.88);margin-bottom:28px}
.hero-actions{display:flex;gap:12px;flex-wrap:wrap}

/* In-page tabs */
.tab-bar{position:sticky;top:0;z-index:40;background:#fff;border-bottom:1px solid var(--border)}
.tab-bar .inner{display:flex;gap:36px;justify-content:center;padding:22px 0;flex-wrap:wrap}
.tab-bar a{font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--navy-70);position:relative;padding-bottom:6px;transition:color .2s}
.tab-bar a.active,.tab-bar a:hover{color:var(--gold)}
.tab-bar a.active::after{content:"";position:absolute;left:0;right:0;bottom:-1px;height:2px;background:var(--gold)}

/* Gallery strip */
.gallery-strip{display:grid;grid-template-columns:repeat(5,1fr);gap:4px;margin-top:40px}
@media (max-width:900px){.gallery-strip{grid-template-columns:repeat(3,1fr)}}
@media (max-width:560px){.gallery-strip{grid-template-columns:repeat(2,1fr)}}
.gallery-strip .g-item{aspect-ratio:1/1;overflow:hidden;cursor:pointer}
.gallery-strip .g-item img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.gallery-strip .g-item:hover img{transform:scale(1.05)}
.gallery-strip .g-view{background:var(--navy);color:#fff;display:flex;align-items:center;justify-content:center;flex-direction:column;gap:8px;font-size:11px;letter-spacing:.22em;text-transform:uppercase;cursor:pointer}
.gallery-strip .g-view svg{width:24px;height:24px;stroke:var(--gold);fill:none;stroke-width:1.4}

/* Villa detail main grid */
.villa-main{display:grid;grid-template-columns:1.1fr 1.2fr 0.9fr;gap:44px;padding:80px 0}
@media (max-width:1100px){.villa-main{grid-template-columns:1fr;gap:40px}}
.vm-overview h2,.vm-amenities h2{font-size:26px;font-weight:300;margin-bottom:8px}
.vm-overview p{font-size:13px;color:var(--navy-70);margin-bottom:22px;line-height:1.85}
.vm-list{list-style:none;padding:0}
.vm-list li{display:flex;gap:12px;align-items:center;padding:7px 0;font-size:13px;color:var(--navy)}
.vm-list li svg{width:18px;height:18px;stroke:var(--gold);stroke-width:1.4;fill:none;flex:0 0 18px}

.amenities-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px 12px;margin-top:24px}
.amenity{text-align:center;padding:14px 6px}
.amenity svg{width:28px;height:28px;stroke:var(--navy);stroke-width:1.3;fill:none;margin-bottom:8px}
.amenity .lbl{font-size:11px;letter-spacing:.08em;color:var(--navy);line-height:1.4}

/* Price sidebar */
.price-box{background:var(--offwhite);padding:30px 24px;text-align:center;border-top:3px solid var(--gold);position:sticky;top:110px}
.price-box .from{font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--navy-70);margin-bottom:8px}
.price-box .price{font-family:var(--serif);font-size:38px;font-weight:400;color:var(--navy);line-height:1}
.price-box .per{font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--navy-70);margin-top:8px}
.price-box .kind{font-size:11px;color:var(--navy-70);margin-top:4px;letter-spacing:.1em}
.price-box .btn-gold{width:100%;margin:22px 0 16px;padding:14px}
.price-box .benefits{text-align:left;font-size:12px;color:var(--navy-70)}
.price-box .benefits .row{display:flex;gap:10px;align-items:center;padding:5px 0}
.price-box .benefits svg{width:14px;height:14px;stroke:var(--gold);stroke-width:1.5;fill:none;flex:0 0 14px}

/* Details table */
.details-row{display:grid;grid-template-columns:1fr 1.5fr;gap:0;background:var(--offwhite);padding:30px}
@media (max-width:900px){.details-row{grid-template-columns:1fr}}
.detail-table{width:100%;font-size:13px}
.detail-table tr td{padding:10px 0;border-bottom:1px solid var(--border)}
.detail-table tr td:first-child{color:var(--navy-70);width:44%}
.detail-table tr:last-child td{border-bottom:none}
.floor-plan{background:#f1ecde}
.floor-plan img{width:100%;height:100%;object-fit:contain;padding:30px}

/* Strip features */
.feat-strip{background:var(--offwhite);padding:28px 0;border-top:1px solid var(--border)}
.feat-strip .wrap{display:flex;justify-content:space-around;flex-wrap:wrap;gap:20px}
.feat-strip .f{display:flex;gap:10px;align-items:center;font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--navy)}
.feat-strip svg{width:22px;height:22px;stroke:var(--gold);stroke-width:1.3;fill:none}

/* Tabs for Superior 3 variants */
.variant-tabs{display:flex;justify-content:center;gap:4px;margin:40px 0 20px;flex-wrap:wrap}
.variant-tabs button{padding:14px 26px;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--navy-70);border:1px solid var(--border);background:#fff;transition:all .2s}
.variant-tabs button.active{background:var(--navy);color:#fff;border-color:var(--navy)}
.variant-tabs button:hover{color:var(--navy)}
.variant-tabs button.active:hover{color:#fff}
.variant-panel{display:none}
.variant-panel.active{display:block}

/* Utility */
.hidden-init{display:none}

/* Villa grid variants */
.villa-grid-3{grid-template-columns:repeat(3,1fr);gap:30px;margin-top:40px}
.villa-grid-4{grid-template-columns:repeat(4,1fr);margin-top:40px}
@media (max-width:1100px){.villa-grid-3,.villa-grid-4{grid-template-columns:repeat(2,1fr);gap:20px}}
@media (max-width:560px){.villa-grid-3,.villa-grid-4{grid-template-columns:1fr;gap:18px}}

/* ====================== MOBILE REFINEMENTS ====================== */
@media (max-width:980px){
  /* Hide desktop "Check Availability" button in header on mobile — only hamburger */
  .nav-cta .btn-availability{display:none}
  .site-header{padding:12px 0}
  .logo-link img{height:58px}
  .site-header.scrolled .logo-link img{height:48px}
}

@media (max-width:720px){
  .container,.container-wide{padding:0 20px}

  /* Hero — full-bleed image with overlay content; no awkward block-with-white-gap */
  .hero{display:flex;min-height:92vh;padding-top:0;align-items:center}
  .hero-inner{padding:120px 20px 140px;min-height:0;display:flex;flex-direction:column;justify-content:center;align-items:center;width:100%}
  .hero h1{font-size:44px;line-height:1.02;letter-spacing:.01em}
  .hero h1 br{display:none}
  .hero .gold-divider{margin:18px auto 14px}
  .hero .location-line{font-size:10px;letter-spacing:.28em;margin-bottom:18px}
  .hero .tagline{font-size:19px;margin-bottom:10px;line-height:1.3}
  .hero .sub{font-size:13px;margin:0 auto 22px;padding:0 8px;max-width:340px}
  .hero-ctas{justify-content:center;padding:0 8px;gap:10px;flex-wrap:wrap;width:100%}
  .hero-ctas .btn-gold,.hero-ctas .btn-outline{padding:13px 20px;font-size:10px;letter-spacing:.2em}

  /* Booking bar hidden on mobile — hero CTA + sticky bottom CTA cover booking */
  .booking-bar{display:none}

  /* Page hero (subpages) — proper padding, smaller h1 */
  .page-hero{min-height:380px}
  .page-hero .inner{padding:130px 20px 50px}
  .page-hero h1{font-size:38px;line-height:1.05}
  .page-hero h1 br{display:none}
  .page-hero p{font-size:13px}
  .page-hero .meta-row{font-size:12px;letter-spacing:.1em}
  .breadcrumb{margin-bottom:18px;font-size:9px}

  /* Sections */
  .section{padding:60px 0}
  .section-sm{padding:44px 0}
  .intro{padding:64px 0 30px}
  .intro p{font-size:14px;padding:0 8px}
  .intro .mark{width:80px;margin-top:24px}

  /* Section title sizing */
  .section-title{font-size:28px}
  .row-head h2{font-size:26px}
  .row-head{flex-direction:column;align-items:flex-start;gap:12px}

  /* Villa cards — taller image, no aspect crop */
  .villa-card .thumb{aspect-ratio:4/3}
  .villa-card .body{padding:18px 18px 20px}
  .villa-card h3{font-size:20px}

  /* Mobile sticky CTA: leave room at bottom of pages */
  body{padding-bottom:64px}

  /* Footer */
  footer{padding:50px 0 80px}
  .foot-bottom{flex-direction:column;align-items:flex-start;gap:8px}
  .foot-bottom a{margin-left:0;margin-right:18px}

  /* Why-book-direct: keep readable */
  .book-direct{padding:40px 0}
  .bd-title h3{font-size:22px}

  /* Testimonials */
  .testis{padding:60px 0 70px}
  .testis h2{font-size:18px;letter-spacing:.22em;margin-bottom:34px}
  .testis-grid{padding:0 20px}
  .testi blockquote{font-size:18px}

  /* CTA strip */
  .cta-strip{min-height:260px}
  .cta-strip .inner{padding:50px 20px}

  /* Villa detail page */
  .villa-main{padding:50px 0;gap:30px}
  .price-box{position:static}
  .gallery-strip{margin-top:24px}
  .variant-tabs{margin:24px 0 14px}
  .variant-tabs button{padding:11px 18px;font-size:10px}
  .feat-strip .wrap{justify-content:flex-start;gap:18px}
  .feat-strip .f{font-size:10px}

  /* Location page */
  .loc-grid{gap:30px}
  .loc-left h3{font-size:24px}

  /* Mobile drawer text size */
  .mobile-drawer{padding:80px 24px 30px}
  .mobile-drawer a{font-size:20px;padding:14px 0}
}

@media (max-width:420px){
  .hero{min-height:88vh}
  .hero-inner{padding:110px 16px 120px}
  .hero h1{font-size:38px}
  .hero .tagline{font-size:17px}
  .page-hero h1{font-size:30px}
  .page-hero .inner{padding:120px 20px 44px}
  .booking-bar .bar{grid-template-columns:1fr}
  .hero-ctas{flex-direction:column;align-items:stretch;width:100%;max-width:300px;margin:0 auto}
  .hero-ctas .btn-gold,.hero-ctas .btn-outline{text-align:center;padding:14px 20px}
}

/* ====================== HIGHLIGHTS (3 key selling points) ====================== */
.highlights{padding:90px 0 30px;background:var(--offwhite)}
.highlights .head{text-align:center;max-width:640px;margin:0 auto 50px}
.highlights .head h2{font-size:clamp(28px,3vw,38px);font-weight:300;margin-bottom:10px}
.highlights .head p{color:var(--navy-70);font-size:14px;margin-top:14px}
.highlights-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.highlight-card{position:relative;overflow:hidden;background:#000;aspect-ratio:3/4;color:#fff;display:flex;align-items:flex-end;transition:transform .35s ease,box-shadow .35s ease}
.highlight-card:hover{transform:translateY(-4px);box-shadow:0 24px 55px rgba(18,36,72,.22)}
.highlight-card img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .7s ease;opacity:.92}
.highlight-card:hover img{transform:scale(1.06)}
.highlight-card::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(18,36,72,0) 35%,rgba(18,36,72,.78) 100%);pointer-events:none}
.highlight-card .content{position:relative;z-index:2;padding:30px 28px 32px;width:100%}
.highlight-card .ico{width:42px;height:42px;margin-bottom:16px}
.highlight-card .ico svg{width:100%;height:100%;stroke:var(--gold);stroke-width:1.3;fill:none}
.highlight-card .kicker{font-size:10px;letter-spacing:.24em;text-transform:uppercase;color:var(--gold);margin-bottom:8px}
.highlight-card h3{font-family:var(--serif);font-size:26px;font-weight:400;line-height:1.15;margin-bottom:10px;color:#fff}
.highlight-card p{font-size:13px;line-height:1.6;color:rgba(255,255,255,.88);max-width:320px}
@media (max-width:900px){.highlights-grid{grid-template-columns:1fr;gap:18px}.highlight-card{aspect-ratio:16/11}.highlights{padding:60px 0 20px}}
.muted{color:var(--navy-70)}
.mt-0{margin-top:0}.mt-1{margin-top:8px}.mt-2{margin-top:20px}.mt-3{margin-top:32px}.mt-4{margin-top:48px}
.mb-2{margin-bottom:20px}.mb-3{margin-bottom:32px}.mb-4{margin-bottom:48px}

/* Contact form */
.contact-grid{display:grid;grid-template-columns:1fr 1.2fr;gap:60px}
@media (max-width:900px){.contact-grid{grid-template-columns:1fr;gap:40px}}
.form-row{margin-bottom:20px}
.form-row label{display:block;font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--navy-70);margin-bottom:8px}
.form-row input,.form-row textarea,.form-row select{width:100%;border:none;border-bottom:1px solid var(--border);background:transparent;padding:10px 0;font-family:inherit;font-size:14px;color:var(--navy);outline:none;transition:border-color .2s}
.form-row input:focus,.form-row textarea:focus,.form-row select:focus{border-color:var(--gold)}
.form-row textarea{resize:vertical;min-height:120px}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px}
@media (max-width:540px){.form-grid{grid-template-columns:1fr}}

/* Nearby grid */
.nearby{display:grid;grid-template-columns:repeat(5,1fr);gap:16px;margin-top:40px}
@media (max-width:1000px){.nearby{grid-template-columns:repeat(3,1fr)}}
@media (max-width:560px){.nearby{grid-template-columns:repeat(2,1fr)}}
.nearby .item .thumb{aspect-ratio:4/3;overflow:hidden;margin-bottom:10px}
.nearby .item .thumb img{width:100%;height:100%;object-fit:cover;transition:transform .6s}
.nearby .item:hover .thumb img{transform:scale(1.04)}
.nearby .item .name{font-family:var(--serif);font-size:16px;color:var(--navy);margin-bottom:3px}
.nearby .item .meta{font-size:11px;color:var(--navy-70);letter-spacing:.05em}

/* Two-column narrative */
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:70px;align-items:center}
@media (max-width:900px){.two-col{grid-template-columns:1fr;gap:30px}}
.two-col img{aspect-ratio:4/3;object-fit:cover;width:100%}
