/* =====================================================================
   Sunrise Pool Villa Cam Ranh — brand.css
   Single shared stylesheet. Built strictly on the Sunrise Design System
   (navy #121E52, gold gradient #D3B16E→#AF733E, Jost / Cormorant / Figtree).
   ===================================================================== */

/* Fonts (Jost / Cormorant Garamond / Figtree) are loaded via <link> in each
   page's <head> for reliable, non-blocking delivery — not @import here. */

/* ---------- Tokens ---------- */
:root{
  /* Navy */
  --navy-900:#0B1233; --navy-800:#0F1844; --navy-700:#121E52;
  --navy-600:#1C2A6B; --navy-100:#E4E7F1;
  --navy:#121E52;
  --navy-85:rgba(11,18,51,.85); --navy-70:rgba(11,18,51,.70);
  --navy-55:rgba(11,18,51,.55); --navy-35:rgba(11,18,51,.35);
  --navy-20:rgba(18,30,82,.20); --navy-08:rgba(18,30,82,.08);

  /* Gold */
  --gold-600:#AF733E; --gold-500:#C19A5B; --gold-400:#D3B16E; --gold-300:#E3CB97;
  --gold:#C19A5B;
  --gold-gradient:linear-gradient(118deg,#D3B16E 0%,#AF733E 100%);
  --gold-gradient-soft:linear-gradient(118deg,#E3CB97 0%,#C19A5B 100%);
  --gold-25:rgba(193,154,91,.25); --gold-50:rgba(193,154,91,.5);

  /* Neutrals */
  --white:#FFFFFF; --cream:#FCFCFC; --sand-50:#F4F7FA; --mist:#EDF1F4;
  --sand-200:#DDE4EC; --taupe-300:#C2CCD8;
  --ink-700:#2B3242; --ink-500:#66718A; --ink-900:#161B28;
  --blush:#FBF2EA;

  /* Fonts */
  --font-display:'Jost',system-ui,sans-serif;
  --font-serif:'Cormorant Garamond',Georgia,serif;
  --font-body:'Figtree',system-ui,sans-serif;

  /* Motion */
  --ease-out:cubic-bezier(.22,1,.36,1);
  --ease-cinema:cubic-bezier(.2,.6,.2,1);
  --dur-fast:160ms; --dur-base:300ms; --dur-slow:600ms;

  --nav-h:78px;
  --maxw:1240px;
}

/* ---------- Reset / base ---------- */
*,*::before,*::after{box-sizing:border-box;}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;}
body{
  margin:0; background:var(--cream); color:var(--ink-700);
  font-family:var(--font-body); font-weight:400; font-size:16px; line-height:1.7;
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility; overflow-x:hidden;
}
img{max-width:100%; display:block;}
a{color:inherit; text-decoration:none;}
h1,h2,h3,h4,p{margin:0;}
::selection{background:var(--gold-300); color:var(--navy-900);}

/* ---------- Layout primitives ---------- */
section{padding:clamp(72px,11vw,140px) 0;}
.wrap{width:100%; max-width:var(--maxw); margin:0 auto; padding:0 clamp(20px,5vw,48px);}
.wrap-narrow{width:100%; max-width:820px; margin:0 auto; padding:0 clamp(20px,5vw,48px);}
.wrap-wide{width:100%; max-width:1440px; margin:0 auto; padding:0 clamp(20px,5vw,48px);}
.bg-cream{background:var(--cream);} .bg-white{background:var(--white);}
/* readable measure: left-aligned paragraph kept centered as a block (for long intros) */
.tl{text-align:left; max-width:64ch; margin-left:auto; margin-right:auto;}
.bg-mist{background:var(--mist);} .bg-blush{background:var(--blush);}
.bg-navy{background:var(--navy-700); color:var(--cream);}
.center{text-align:center;}

/* ---------- Type ---------- */
.eyebrow{
  font-family:var(--font-display); font-weight:300; font-size:11px;
  letter-spacing:.42em; text-transform:uppercase; color:var(--gold-700);
  display:inline-flex; align-items:center; gap:14px; margin-bottom:22px;
}
.eyebrow::before{content:""; width:30px; height:1px; background:var(--gold-500); display:inline-block;}
.eyebrow.center-mark{justify-content:center;}
.eyebrow.on-navy{color:var(--gold-300);} .eyebrow.on-navy::before{background:var(--gold-400);}
.eyebrow.no-rule::before{display:none;}

.heading{
  font-family:var(--font-serif); font-weight:400;
  font-size:clamp(30px,4.4vw,52px); line-height:1.1; letter-spacing:.01em;
  color:var(--navy-700);
}
.bg-navy .heading,.heading.on-navy{color:var(--white);}
.lede{
  font-family:var(--font-serif); font-style:italic; font-weight:400;
  font-size:clamp(19px,2.1vw,24px); line-height:1.5; color:var(--ink-700); margin-top:20px;
}
.bg-navy .lede{color:rgba(252,252,252,.82);}
.prose{font-size:15.5px; line-height:1.85; color:var(--ink-700); margin-top:22px;}
.prose.muted{color:var(--ink-500);}
.bg-navy .prose{color:rgba(252,252,252,.74);}
.prose p+p{margin-top:16px;}

/* ---------- Buttons ---------- */
.btn{
  font-family:var(--font-display); font-weight:400; font-size:11px;
  letter-spacing:.28em; text-transform:uppercase; cursor:pointer;
  display:inline-flex; align-items:center; gap:12px;
  padding:16px 32px; border-radius:999px; border:1px solid transparent;
  transition:background var(--dur-base) var(--ease-out),color var(--dur-base) var(--ease-out),
             border-color var(--dur-base) var(--ease-out),transform var(--dur-fast) var(--ease-out);
}
.btn:active{transform:scale(.97);}
.btn-accent{background:var(--gold-gradient); color:var(--navy-900); border:none;}
.btn-accent:hover{background:var(--gold-600); color:#fff;}
.btn-primary{background:var(--navy-700); color:var(--cream);}
.btn-primary:hover{background:var(--navy-800);}
.btn-outline{background:transparent; color:var(--navy-700); border:1px solid var(--navy-700);}
.btn-outline:hover{background:var(--navy-700); color:var(--cream);}
.btn-light{background:transparent; color:#fff; border:1px solid rgba(255,255,255,.6);}
.btn-light:hover{background:#fff; color:var(--navy-700); border-color:#fff;}
.btn-link{
  font-family:var(--font-display); font-weight:400; font-size:11px; letter-spacing:.26em;
  text-transform:uppercase; color:var(--gold-700); display:inline-flex; align-items:center; gap:10px;
  transition:gap var(--dur-base) var(--ease-out),color var(--dur-base) var(--ease-out);
}
.btn-link .arw{transition:transform var(--dur-base) var(--ease-out);}
.btn-link:hover{color:var(--gold-600);} .btn-link:hover .arw{transform:translateX(6px);}

/* ---------- Navigation ---------- */
.nav{
  position:fixed; top:0; left:0; right:0; z-index:100; height:var(--nav-h);
  display:flex; align-items:center;
  /* top scrim keeps the white logo/links legible over bright hero imagery */
  background:linear-gradient(180deg,rgba(11,18,51,.45) 0%,rgba(11,18,51,0) 100%);
  transition:background var(--dur-base) var(--ease-out),
             box-shadow var(--dur-base) var(--ease-out),
             height var(--dur-base) var(--ease-out);
}
.nav-inner{width:100%; max-width:1440px; margin:0 auto; padding:0 clamp(20px,5vw,48px);
  display:flex; align-items:center; justify-content:space-between; gap:24px;}
.nav-logo{display:flex; align-items:center;}
.nav-logo img{height:38px; width:auto; transition:opacity var(--dur-base) var(--ease-out);}
.nav-logo .logo-navy{display:none;}
.nav-links{display:flex; align-items:center; gap:38px; list-style:none; margin:0; padding:0;}
.nav-links a{
  font-family:var(--font-display); font-weight:300; font-size:12px;
  letter-spacing:.2em; text-transform:uppercase; color:#fff; position:relative; padding:6px 0;
  transition:color var(--dur-base) var(--ease-out);
}
.nav-links a::after{content:""; position:absolute; left:0; bottom:0; height:1px; width:0;
  background:var(--gold-400); transition:width var(--dur-base) var(--ease-out);}
.nav-links a:hover::after,.nav-links a.active::after{width:100%;}
.nav-cta{
  font-family:var(--font-display); font-weight:400; font-size:11px; letter-spacing:.24em;
  text-transform:uppercase; color:#fff; border:1px solid var(--gold-400); border-radius:999px;
  padding:12px 26px; transition:background var(--dur-base) var(--ease-out),color var(--dur-base) var(--ease-out);
}
.nav-cta:hover{background:var(--gold-gradient); color:var(--navy-900); border-color:transparent;}

/* scrolled / solid nav */
.nav.solid{background:rgba(252,252,252,.92); backdrop-filter:blur(14px); -webkit-backdrop-filter:blur(14px);
  box-shadow:0 1px 0 var(--sand-200); height:66px;}
.nav.solid .nav-logo .logo-white{display:none;} .nav.solid .nav-logo .logo-navy{display:block;}
.nav.solid .nav-links a{color:var(--navy-700);}
.nav.solid .nav-cta{color:var(--navy-700); border-color:var(--gold-500);}
.nav.solid .nav-cta:hover{color:var(--navy-900);}
/* pages without a dark hero use solid styling from the start */
.nav.always-solid{background:rgba(252,252,252,.96); backdrop-filter:blur(14px); box-shadow:0 1px 0 var(--sand-200);}
.nav.always-solid .nav-logo .logo-white{display:none;} .nav.always-solid .nav-logo .logo-navy{display:block;}
.nav.always-solid .nav-links a{color:var(--navy-700);}
.nav.always-solid .nav-cta{color:var(--navy-700); border-color:var(--gold-500);}

/* mobile nav */
.nav-toggle{display:none; background:none; border:0; cursor:pointer; width:44px; height:44px; position:relative;}
.nav-toggle span{position:absolute; left:7px; height:1.5px; width:30px; background:#fff; transition:.3s var(--ease-out);}
.nav-toggle span:nth-child(1){top:15px;} .nav-toggle span:nth-child(2){top:21px;} .nav-toggle span:nth-child(3){top:27px;}
.nav.solid .nav-toggle span,.nav.always-solid .nav-toggle span{background:var(--navy-700);}
.nav-toggle.open span{background:var(--navy-700);}
.nav-toggle.open span:nth-child(1){top:21px; transform:rotate(45deg);}
.nav-toggle.open span:nth-child(2){opacity:0;}
.nav-toggle.open span:nth-child(3){top:21px; transform:rotate(-45deg);}

/* ---------- Hero (full page) ---------- */
.hero{position:relative; height:100vh; min-height:620px; display:flex; align-items:flex-end; overflow:hidden;}
.hero-img{position:absolute; inset:0; background-size:cover; background-position:center;
  transform:scale(1.06); animation:kenburns 18s ease-out forwards;}
@keyframes kenburns{to{transform:scale(1.0);}}
.hero::after{content:""; position:absolute; inset:0;
  background:linear-gradient(to top,rgba(11,18,51,.72) 0%,rgba(11,18,51,.15) 42%,rgba(11,18,51,.30) 100%);}
.hero-content{position:relative; z-index:2; width:100%; max-width:1440px; margin:0 auto;
  padding:0 clamp(20px,5vw,48px) clamp(60px,11vh,120px);}
.hero-eyebrow{font-family:var(--font-display); font-weight:300; font-size:12px; letter-spacing:.42em;
  text-transform:uppercase; color:var(--gold-300); margin-bottom:24px;}
.hero h1{font-family:var(--font-serif); font-weight:400; color:#fff; line-height:1.02;
  font-size:clamp(44px,7.6vw,104px); letter-spacing:.01em; max-width:13ch;
  filter:drop-shadow(0 2px 24px rgba(0,0,0,.35));}
.hero-sub{margin-top:26px; max-width:46ch; color:rgba(255,255,255,.9);
  font-size:15.5px; line-height:1.8;}
.hero-actions{margin-top:38px; display:flex; flex-wrap:wrap; gap:16px;}
.scroll-cue{position:absolute; left:50%; bottom:30px; transform:translateX(-50%); z-index:2;
  font-family:var(--font-display); font-size:9px; letter-spacing:.4em; text-transform:uppercase;
  color:rgba(255,255,255,.7); display:flex; flex-direction:column; align-items:center; gap:10px;}
.scroll-cue .line{width:1px; height:46px; background:linear-gradient(rgba(255,255,255,.7),transparent); animation:cue 2.4s ease-in-out infinite;}
@keyframes cue{0%,100%{opacity:.3; transform:scaleY(.6);}50%{opacity:1; transform:scaleY(1);}}

/* ---------- Page hero (inner pages) ---------- */
.page-hero{position:relative; height:64vh; min-height:440px; display:flex; align-items:flex-end; overflow:hidden;}
.page-hero .hero-img{transform:scale(1.04); animation:kenburns 20s ease-out forwards;}
.page-hero::after{content:""; position:absolute; inset:0;
  background:linear-gradient(to top,rgba(11,18,51,.74) 0%,rgba(11,18,51,.12) 55%,rgba(11,18,51,.34) 100%);}
.page-hero-content{position:relative; z-index:2; width:100%; max-width:var(--maxw); margin:0 auto;
  padding:0 clamp(20px,5vw,48px) clamp(46px,8vh,84px);}
.page-hero h1{font-family:var(--font-serif); font-weight:400; color:#fff; line-height:1.04;
  font-size:clamp(38px,6vw,78px); letter-spacing:.02em; filter:drop-shadow(0 2px 20px rgba(0,0,0,.35));}
.page-hero .hero-eyebrow{color:var(--gold-300);}
.page-hero .meta-chips{margin-top:22px; display:flex; flex-wrap:wrap; gap:10px;}
.chip{font-family:var(--font-display); font-weight:300; font-size:10.5px; letter-spacing:.22em;
  text-transform:uppercase; color:#fff; border:1px solid rgba(255,255,255,.45);
  padding:8px 16px; border-radius:999px; backdrop-filter:blur(4px);}

/* ---------- Editorial split (image + text) ---------- */
.split{display:grid; grid-template-columns:1fr 1fr; align-items:center; gap:0;}
.split .split-img{aspect-ratio:4/5; background-size:cover; background-position:center; min-height:420px;}
.split .split-body{padding:clamp(40px,7vw,96px);}
.split.flip .split-img{order:2;}
.split.tall .split-img{aspect-ratio:3/4;}

/* ---------- Villa grid ---------- */
.villa-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:30px;}
.villa-card{display:flex; flex-direction:column; background:var(--white);
  border:1px solid var(--sand-200); border-radius:4px; overflow:hidden;
  transition:transform var(--dur-base) var(--ease-out),box-shadow var(--dur-base) var(--ease-out);}
.villa-card:hover{transform:translateY(-4px); box-shadow:0 18px 44px rgba(18,30,82,.10);}
.villa-card .ph{aspect-ratio:4/3; overflow:hidden;}
.villa-card .ph img{width:100%; height:100%; object-fit:cover; transition:transform 1.1s var(--ease-out);}
.villa-card:hover .ph img{transform:scale(1.05);}
.villa-card .body{padding:28px 28px 32px; display:flex; flex-direction:column; flex:1;}
.villa-card .tag{font-family:var(--font-display); font-weight:300; font-size:10px; letter-spacing:.3em;
  text-transform:uppercase; color:var(--ink-500); display:flex; gap:10px; flex-wrap:wrap;}
.villa-card h3{font-family:var(--font-serif); font-style:italic; font-weight:500;
  font-size:27px; line-height:1.15; color:var(--navy-700); margin:14px 0 0;}
.villa-card .desc{font-size:14px; line-height:1.7; color:var(--ink-500); margin-top:12px; flex:1;}
.villa-card .rule{height:1px; background:var(--sand-200); margin:22px 0 18px;}
.villa-card .foot{display:flex; align-items:center; justify-content:space-between; gap:12px;}
.villa-card .price{font-family:var(--font-serif); font-size:21px; color:var(--navy-700);}
.villa-card .price small{font-family:var(--font-display); font-size:9.5px; letter-spacing:.16em;
  text-transform:uppercase; color:var(--ink-500); display:block; margin-bottom:2px;}
.villa-card .price .per{font-family:var(--font-display); font-size:9.5px; letter-spacing:.14em;
  text-transform:uppercase; color:var(--ink-500);}

/* ---------- Quote band ---------- */
.quote-band{background:var(--navy-700); color:#fff; text-align:center;}
.quote-band .q{font-family:var(--font-serif); font-style:italic; font-weight:400;
  font-size:clamp(24px,3.6vw,40px); line-height:1.4; color:#fff; max-width:20ch; margin:0 auto;}
.quote-band cite{display:block; margin-top:30px; font-style:normal;
  font-family:var(--font-display); font-weight:300; font-size:11px; letter-spacing:.32em;
  text-transform:uppercase; color:var(--gold-300);}
.quote-band cite::before{content:""; display:block; width:34px; height:1px; background:var(--gold-400); margin:0 auto 18px;}

/* ---------- Rate table ---------- */
.rate-table{width:100%; border-collapse:collapse; margin-top:8px;}
.rate-table th,.rate-table td{text-align:left; padding:18px 14px; border-bottom:1px solid var(--sand-200);}
.rate-table th{font-family:var(--font-display); font-weight:300; font-size:10px; letter-spacing:.24em;
  text-transform:uppercase; color:var(--ink-500);}
.rate-table td.r-name{font-family:var(--font-serif); font-style:italic; font-size:20px; color:var(--navy-700);}
.rate-table td.r-meta{font-size:13px; color:var(--ink-500);}
.rate-table td.r-price{font-family:var(--font-serif); font-size:21px; color:var(--navy-700); white-space:nowrap;}
.rate-note{font-size:12.5px; color:var(--ink-500); margin-top:16px;}

/* ---------- Detail / amenities columns ---------- */
.detail-grid{display:grid; grid-template-columns:1fr 1fr 1fr; gap:48px;}
.detail-col h4{font-family:var(--font-display); font-weight:400; font-size:11px; letter-spacing:.28em;
  text-transform:uppercase; color:var(--navy-700); margin-bottom:20px; padding-bottom:14px;
  border-bottom:1px solid var(--gold-50);}
.detail-col ul{list-style:none; margin:0; padding:0;}
.detail-col li{font-size:14px; line-height:1.5; color:var(--ink-700); padding:9px 0 9px 20px; position:relative;}
.detail-col li::before{content:""; position:absolute; left:0; top:16px; width:8px; height:1px; background:var(--gold-500);}

/* ---------- Inclusions (3-col ticks) ---------- */
.inclusions{display:grid; grid-template-columns:repeat(3,1fr); gap:2px; background:var(--sand-200);
  border:1px solid var(--sand-200);}
.inclusions .inc{background:var(--white); padding:34px 28px;}
.inclusions .inc .ico{font-family:var(--font-display); font-size:11px; letter-spacing:.28em;
  text-transform:uppercase; color:var(--gold-700); margin-bottom:14px; display:flex; gap:10px; align-items:center;}
.inclusions .inc .ico::before{content:""; width:24px; height:1px; background:var(--gold-500);}
.inclusions .inc h4{font-family:var(--font-serif); font-size:23px; color:var(--navy-700); margin-bottom:8px;}
.inclusions .inc p{font-size:13.5px; line-height:1.7; color:var(--ink-500);}

/* ---------- Feature cards (experience) ---------- */
.feature-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:30px;}
.feature-grid.two{grid-template-columns:1fr 1fr;}
.feature{border-radius:4px; overflow:hidden; background:var(--white); border:1px solid var(--sand-200);
  transition:transform var(--dur-base) var(--ease-out),box-shadow var(--dur-base) var(--ease-out);}
.feature:hover{transform:translateY(-4px); box-shadow:0 18px 44px rgba(18,30,82,.10);}
.feature .ph{aspect-ratio:3/2; overflow:hidden;}
.feature .ph img{width:100%; height:100%; object-fit:cover; transition:transform 1.1s var(--ease-out);}
.feature:hover .ph img{transform:scale(1.05);}
.feature .body{padding:26px 26px 30px;}
.feature .tag{font-family:var(--font-display); font-size:10px; letter-spacing:.3em; text-transform:uppercase; color:var(--gold-700);}
.feature h3{font-family:var(--font-serif); font-style:italic; font-size:24px; color:var(--navy-700); margin:12px 0 10px;}
.feature p{font-size:14px; line-height:1.7; color:var(--ink-500);}

/* ---------- Gallery ---------- */
.gallery{display:grid; grid-template-columns:repeat(12,1fr); gap:16px;}
.gallery .g{overflow:hidden; border-radius:3px; background:var(--mist);}
.gallery .g img{width:100%; height:100%; object-fit:cover; transition:transform 1.2s var(--ease-out);}
.gallery .g:hover img{transform:scale(1.05);}
.gallery .span6{grid-column:span 6;} .gallery .span4{grid-column:span 4;}
.gallery .span8{grid-column:span 8;} .gallery .span12{grid-column:span 12;}
.gallery .tall{aspect-ratio:3/4;} .gallery .wide{aspect-ratio:3/2;} .gallery .sq{aspect-ratio:1/1;}

/* ---------- Stat / fact row ---------- */
.facts{display:grid; grid-template-columns:repeat(4,1fr); gap:20px; text-align:center;}
.facts .f .n{font-family:var(--font-serif); font-size:clamp(30px,4vw,46px); color:var(--navy-700); line-height:1;}
.bg-navy .facts .f .n{color:#fff;}
.facts .f .l{font-family:var(--font-display); font-weight:300; font-size:10px; letter-spacing:.26em;
  text-transform:uppercase; color:var(--ink-500); margin-top:14px;}
.bg-navy .facts .f .l{color:rgba(252,252,252,.66);}

/* ---------- Dark CTA band ---------- */
.cta-band{position:relative; overflow:hidden; background:var(--navy-700); color:#fff; text-align:center;}
.cta-band .heading{color:#fff;} .cta-band .lede{color:rgba(252,252,252,.82);}
.cta-band .btn-row{margin-top:36px; display:flex; flex-wrap:wrap; gap:16px; justify-content:center;}
.cta-band .aside{margin-top:22px; font-family:var(--font-display); font-weight:300; font-size:11px;
  letter-spacing:.16em; text-transform:uppercase; color:var(--gold-300);}

/* ---------- Sticky reserve bar (villa pages) ---------- */
.sticky-reserve{position:fixed; left:0; right:0; bottom:0; z-index:90; transform:translateY(110%);
  background:rgba(11,18,51,.96); backdrop-filter:blur(10px); color:#fff;
  transition:transform var(--dur-base) var(--ease-out);}
.sticky-reserve.show{transform:translateY(0);}
.sticky-reserve .in{max-width:var(--maxw); margin:0 auto; padding:14px clamp(20px,5vw,48px);
  display:flex; align-items:center; justify-content:space-between; gap:18px;}
.sticky-reserve .sr-name{font-family:var(--font-serif); font-style:italic; font-size:18px;}
.sticky-reserve .sr-price{font-family:var(--font-display); font-weight:300; font-size:11px;
  letter-spacing:.16em; text-transform:uppercase; color:var(--gold-300);}
.sticky-reserve .sr-left{display:flex; flex-direction:column; gap:3px;}

/* ---------- Contact ---------- */
.contact-grid{display:grid; grid-template-columns:1fr 1fr; gap:60px; align-items:start;}
.contact-line{padding:20px 0; border-bottom:1px solid var(--sand-200);}
.contact-line .k{font-family:var(--font-display); font-weight:300; font-size:10px; letter-spacing:.28em;
  text-transform:uppercase; color:var(--ink-500); margin-bottom:8px;}
.contact-line .v{font-size:16px; color:var(--navy-700);}
.contact-line .v a:hover{color:var(--gold-600);}
.map-embed{width:100%; aspect-ratio:4/3; border:0; border-radius:4px; filter:saturate(.9);}
.socials{display:flex; gap:14px; margin-top:8px;}
.socials a{width:44px; height:44px; border:1px solid var(--sand-200); border-radius:999px;
  display:flex; align-items:center; justify-content:center; transition:.3s var(--ease-out);}
.socials a:hover{border-color:var(--gold-500); background:var(--blush);}
.socials svg{width:18px; height:18px; fill:var(--navy-700);}

/* ---------- Footer ---------- */
footer{background:var(--navy-900); color:rgba(252,252,252,.72); padding:84px 0 36px;}
.foot-grid{display:grid; grid-template-columns:1.4fr 1fr 1fr 1.2fr; gap:48px;}
footer .f-logo img{height:46px; margin-bottom:22px;}
footer .f-tag{font-family:var(--font-serif); font-style:italic; font-size:18px; color:rgba(252,252,252,.85); max-width:30ch;}
footer h5{font-family:var(--font-display); font-weight:400; font-size:11px; letter-spacing:.26em;
  text-transform:uppercase; color:var(--gold-300); margin:0 0 20px;}
footer ul{list-style:none; margin:0; padding:0;}
footer li{margin-bottom:13px;}
footer a{font-size:13.5px; color:rgba(252,252,252,.72); transition:color var(--dur-fast) var(--ease-out);}
footer a:hover{color:var(--gold-300);}
footer .f-contact p{font-size:13.5px; line-height:1.8; margin-bottom:10px;}
.foot-bottom{border-top:1px solid rgba(255,255,255,.12); margin-top:60px; padding-top:28px;
  display:flex; flex-wrap:wrap; justify-content:space-between; gap:14px;
  font-size:12px; letter-spacing:.04em; color:rgba(252,252,252,.5);}
.foot-bottom .socials a{border-color:rgba(255,255,255,.2);}
.foot-bottom .socials svg{fill:rgba(252,252,252,.8);}
.foot-bottom .socials a:hover{border-color:var(--gold-400); background:rgba(255,255,255,.05);}

/* ---------- Floating booking button (mobile) ---------- */
.float-book{position:fixed; right:18px; bottom:18px; z-index:80; display:none;
  background:var(--gold-gradient); color:var(--navy-900); border-radius:999px;
  font-family:var(--font-display); font-size:11px; letter-spacing:.22em; text-transform:uppercase;
  padding:15px 24px; box-shadow:0 10px 28px rgba(175,115,62,.4);}

/* ---------- Scroll reveal ---------- */
.reveal{opacity:0; transform:translateY(24px); transition:opacity 1s var(--ease-cinema),transform 1s var(--ease-cinema);}
.reveal.in{opacity:1; transform:none;}
.reveal.d1{transition-delay:.08s;} .reveal.d2{transition-delay:.16s;} .reveal.d3{transition-delay:.24s;}

/* ---------- Focus ---------- */
a:focus-visible,button:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible{
  outline:2px solid var(--gold-500); outline-offset:4px; border-radius:2px;}

/* ====================================================================
   Responsive
   ==================================================================== */
@media(max-width:1000px){
  .detail-grid{grid-template-columns:1fr 1fr; gap:36px;}
  .villa-grid{grid-template-columns:1fr 1fr;}
  .feature-grid{grid-template-columns:1fr 1fr;}
  .foot-grid{grid-template-columns:1fr 1fr; gap:40px;}
}
@media(max-width:820px){
  /* Mobile nav */
  .nav-toggle{display:block; z-index:120;}
  .nav-links{position:fixed; inset:0; background:var(--cream); flex-direction:column;
    justify-content:center; gap:30px; transform:translateX(100%);
    transition:transform .4s var(--ease-out); z-index:110;}
  .nav-links.open{transform:translateX(0);}
  .nav-links a{color:var(--navy-700)!important; font-size:16px; letter-spacing:.16em;}
  .nav-links a::after{display:none;}
  .nav .nav-cta{display:none;}
  .nav-links .mobile-cta{display:inline-flex; margin-top:10px; background:var(--gold-gradient);
    color:var(--navy-900); border:none; padding:14px 30px; border-radius:999px;}
  .float-book{display:inline-flex;}

  .split{grid-template-columns:1fr;}
  .split .split-img{aspect-ratio:16/11; min-height:300px; order:0!important;}
  .split .split-body{padding:clamp(34px,8vw,52px) clamp(20px,6vw,40px);}

  .inclusions{grid-template-columns:1fr;}
  .feature-grid,.feature-grid.two{grid-template-columns:1fr;}
  .villa-grid{grid-template-columns:1fr;}
  .detail-grid{grid-template-columns:1fr; gap:30px;}
  .facts{grid-template-columns:1fr 1fr; gap:34px 20px;}
  .contact-grid{grid-template-columns:1fr; gap:40px;}
  .gallery{grid-template-columns:repeat(2,1fr); gap:10px;}
  .gallery .span6,.gallery .span4,.gallery .span8,.gallery .span12{grid-column:span 1;}
  .foot-grid{grid-template-columns:1fr 1fr; gap:32px;}

  .rate-table thead{display:none;}
  .rate-table tr{display:grid; grid-template-columns:1fr auto; gap:4px 12px; padding:18px 0; border-bottom:1px solid var(--sand-200);}
  .rate-table td{border:0; padding:2px 0;}
  .rate-table td.r-name{grid-column:1; font-size:18px;}
  .rate-table td.r-price{grid-column:2; grid-row:1; align-self:center; text-align:right;}
  .rate-table td.r-meta{grid-column:1;}

  .sticky-reserve .sr-name{font-size:15px;}
  .hero{min-height:560px;}
}
@media(max-width:480px){
  .foot-grid{grid-template-columns:1fr;}
  .facts{grid-template-columns:1fr 1fr;}
  .hero-actions{flex-direction:column; align-items:flex-start;}
  .hero-actions .btn{width:100%; justify-content:center;}
}

/* ---------- Reduced motion ---------- */
@media(prefers-reduced-motion:reduce){
  *{animation:none!important; scroll-behavior:auto!important;}
  .hero-img,.page-hero .hero-img{transform:none!important;}
  .reveal{opacity:1!important; transform:none!important; transition:none!important;}
  .scroll-cue .line{animation:none!important;}
}
