/*
Theme Name:  Keja-fy
Theme URI:   https://keja.fy
Description: Keja-fy — Curated Kenya property stays. Based on elara-stayverse-merged.html.
Version:     1.0.0
Author:      Your Name
Author URI:  https://keja.fy
Text Domain: keja-fy
*/

/* ============================================================
   WORDPRESS THEME ADDITIONS
   Custom logo, image sizing, WP core alignment helpers,
   and gallery/repeater overrides.
   These rules extend (not replace) the elara base CSS below.
   ============================================================ */

/* ── Custom Logo (Customizer → Site Identity → Logo) ── */
.logo-link {
  display: flex;
  align-items: center;
  flex-shrink: 0;
  text-decoration: none;
}
/* WP wraps the img in its own <a>; we size the img directly */
.custom-logo {
  height: 40px;
  width: auto;
  display: block;
  transition: opacity .2s ease, filter .3s ease;
}
.custom-logo:hover { opacity: .85; }

/* Over dark hero: invert a dark logo to white.
   If your logo is already white/transparent, remove this block. */
#header:not(.scrolled):not(.on-light) .custom-logo {
  filter: brightness(0) invert(1);
}
/* On scrolled or light pages: show logo as-is */
#header.scrolled .custom-logo,
#header.on-light .custom-logo {
  filter: none;
}

/* Footer logo — always white/inverted, slightly dimmed */
.footer-logo-wrap .custom-logo {
  height: 34px;
  filter: brightness(0) invert(1);
  opacity: .65;
}

/* Text fallback if no logo uploaded yet */
.logo-text {
  font-family: var(--num);
  font-size: 18px;
  letter-spacing: 4px;
  color: var(--cream);
  transition: color .3s;
}
.logo-text span { color: var(--gold); }
#header.scrolled .logo-text,
#header.on-light .logo-text { color: var(--ink); }
.footer-logo-wrap .logo-text {
  color: rgba(245,240,232,.55);
  font-size: 16px;
}

/* ── WordPress core image alignment ── */
.alignleft  { float: left;  margin: 0 1.5rem 1rem 0; }
.alignright { float: right; margin: 0 0 1rem 1.5rem; }
.aligncenter { display: block; margin: 0 auto 1rem; }
.wp-caption { max-width: 100%; }
.wp-caption-text { font-size: 12px; color: var(--ink-soft); text-align: center; margin-top: 4px; }
img.wp-post-image { display: block; }

/* ── WordPress body classes ── */
.single-stay #header,
.page-template-page-stays #header { /* force light header on these pages */
  /* handled by the on-light class added via JS/PHP — no override needed */
}

/* ── Accessibility: skip link ── */
.skip-link {
  position: absolute;
  top: -100%;
  left: 1rem;
  background: var(--gold);
  color: #0A0908;
  padding: .5rem 1rem;
  border-radius: 0 0 8px 8px;
  font-size: .85rem;
  font-weight: 600;
  z-index: 9999;
  transition: top .2s;
}
.skip-link:focus { top: 0; }

/* ── Screen reader only ── */
.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  overflow: hidden;
  clip: rect(0,0,0,0);
  white-space: nowrap;
}

/* ── Gallery: desktop view-all overlay button ──
   (Shown on 6th thumb when more than 6 photos exist) */
.gallery-view-all-desktop {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(10,9,8,.52);
  cursor: pointer;
  transition: background .2s;
}
.gallery-view-all-desktop:hover { background: rgba(10,9,8,.68); }
.gallery-view-all-desktop span {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  background: rgba(255,255,255,.12);
  border: 1px solid rgba(255,255,255,.3);
  color: #fff;
  font-size: 12px;
  font-weight: 500;
  padding: 9px 18px;
  border-radius: 50px;
  backdrop-filter: blur(6px);
  transition: background .2s, border-color .2s;
  white-space: nowrap;
}
.gallery-view-all-desktop span:hover {
  background: rgba(201,168,76,.25);
  border-color: var(--gold-b);
}

/* ── Prop card: ratio-locked image container ──
   Prevents portrait photos from distorting the grid */
.prop-card-img-wrap {
  position: relative;
  width: 100%;
  overflow: hidden;
}
/* The .prop-card already uses aspect-ratio:3/4 — these rules
   apply to the img inside to enforce object-fit behaviour */
.prop-card-img-wrap .prop-img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
}

/* ── Guest reviews block ── */
.reviews-block { margin-top: 36px; padding-top: 28px; border-top: 1px solid var(--border-soft); }
.reviews-block-head { font-family: var(--disp); font-size: 22px; font-weight: 400; margin-bottom: 20px; color: var(--ink); }
.review-list { display: flex; flex-direction: column; gap: 16px; }
.review-item { padding: 18px 20px; background: var(--surface); border: 1px solid var(--border); border-radius: var(--rd); }
.review-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 8px; }
.review-name { font-size: 13px; font-weight: 600; color: var(--ink); }
.review-stars { font-size: 12px; color: var(--gold); letter-spacing: 1px; }
.review-text { font-size: 13.5px; color: var(--ink-mid); line-height: 1.7; font-weight: 300; }

/* ── Nearby places list ── */
.nearby-list { display: flex; flex-direction: column; gap: 8px; margin-bottom: 28px; }
.nearby-item { display: flex; align-items: center; justify-content: space-between; padding: 10px 14px; background: var(--surface); border: 1px solid var(--border-soft); border-radius: var(--rd); font-size: 13px; }
.nearby-place { color: var(--ink-mid); }
.nearby-dist { color: var(--ink-soft); font-size: 12px; letter-spacing: .5px; }

/* ── WordPress pagination ── */
.wp-pagenavi, .navigation.pagination { text-align: center; margin: 40px 0; }

/* ============================================================
   ELARA BASE CSS  (verbatim from elara-stayverse-merged.html)
   Do not edit this block — edit the source HTML or the
   additions above instead.
   ============================================================ */

:root{
  /* Dark (hero / CTA / footer) */
  --bg:#0A0908;--bg2:#121110;--bg3:#171614;--bg4:#1E1C1A;
  /* Light (content sections) */
  --white:#FFFFFF;--surface:#F8F5EF;--surface2:#EDE9DF;
  /* Gold */
  --gold:#C9A84C;--gold-l:#D4A83C;--gold-d:rgba(201,168,76,.12);--gold-b:rgba(201,168,76,.35);
  /* Dark palette (for hero/CTA) */
  --cream:#F5F0E8;--c70:rgba(245,240,232,.7);--c60:rgba(245,240,232,.6);--c40:rgba(245,240,232,.4);--c30:rgba(245,240,232,.25);--c15:rgba(245,240,232,.1);--c08:rgba(245,240,232,.06);
  /* Light palette (for content) */
  --ink:#1A1810;--ink-mid:#5A5550;--ink-soft:#8A8580;
  --border:rgba(26,24,16,.09);--border-soft:rgba(26,24,16,.05);
  /* WhatsApp */
  --wa:#25D366;--wa2:#128C7E;--wa-glow:rgba(37,211,102,.3);
  --rd:12px;--rd2:20px;
  --disp:'Bricolage Grotesque',system-ui,sans-serif;
  --body:'Bricolage Grotesque',system-ui,sans-serif;
  --num:'Bricolage Grotesque',system-ui,sans-serif;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px}
body{background:var(--white);color:var(--ink);font-family:var(--body);overflow-x:hidden;-webkit-font-smoothing:antialiased}
img{display:block;max-width:100%;object-fit:cover}
a{text-decoration:none;color:inherit}
button{cursor:pointer;border:none;background:none;font-family:var(--body)}
::selection{background:var(--gold);color:#000}
::-webkit-scrollbar{width:3px;height:3px}
::-webkit-scrollbar-thumb{background:var(--gold);border-radius:3px}
::-webkit-scrollbar-track{background:transparent}

/*  KEYFRAMES  */
@keyframes float{0%,100%{transform:translateY(0) rotate(var(--r,0deg))}50%{transform:translateY(-18px) rotate(var(--r,0deg))}}
@keyframes float2{0%,100%{transform:translateY(0) rotate(var(--r,0deg))}50%{transform:translateY(-24px) rotate(var(--r,0deg))}}
@keyframes fadeUp{from{opacity:0;transform:translateY(40px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes marquee{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}
@keyframes pulse-ring{0%{box-shadow:0 0 0 0 rgba(37,211,102,.5)}70%{box-shadow:0 0 0 14px rgba(37,211,102,0)}100%{box-shadow:0 0 0 0 rgba(37,211,102,0)}}
@keyframes pulse-gold{0%{box-shadow:0 0 0 0 rgba(201,168,76,.4)}70%{box-shadow:0 0 0 14px rgba(201,168,76,0)}100%{box-shadow:0 0 0 0 rgba(201,168,76,0)}}
@keyframes gold-blink{0%,100%{opacity:.6}50%{opacity:1}}
@keyframes spin-slow{from{transform:rotate(0deg)}to{transform:rotate(360deg)}}
@keyframes shapeFloat{0%,100%{translate:0 0}50%{translate:0 15px}}
@keyframes smokeDrift{0%{transform:translate(0,0) scale(1)}33%{transform:translate(30px,-20px) scale(1.05)}66%{transform:translate(-20px,15px) scale(.95)}100%{transform:translate(10px,-10px) scale(1.02)}}
@keyframes pulseRing{0%{transform:scale(.8);opacity:.6}100%{transform:scale(1.6);opacity:0}}
@keyframes shimmer{0%{background-position:-400px 0}100%{background-position:400px 0}}
@keyframes scaleIn{from{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}
@keyframes counterUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
@keyframes spinnerDraw{to{stroke-dashoffset:0}}

/*  UTILITIES  */
.fade-up{opacity:0;transform:translateY(30px);transition:opacity .9s ease,transform .9s ease}
.fade-up.vis{opacity:1;transform:translateY(0)}
.fade-up.d1{transition-delay:.1s}.fade-up.d2{transition-delay:.2s}.fade-up.d3{transition-delay:.3s}.fade-up.d4{transition-delay:.4s}.fade-up.d5{transition-delay:.5s}
.sec-tag{display:inline-block;font-size:10.5px;font-weight:500;letter-spacing:3.5px;text-transform:uppercase;color:var(--gold-l);margin-bottom:14px}
.pcta-note{font-size:11px;color:var(--ink-soft);text-align:center;margin-top:10px;line-height:1.5}
.disp{font-family:var(--disp)}
.num{font-family:var(--num)}
.gold{color:var(--gold)}
/*  CURSOR  */
#cursor{position:fixed;width:8px;height:8px;border-radius:50%;background:var(--gold);pointer-events:none;z-index:9999;transition:transform .15s ease;mix-blend-mode:screen}
@media(pointer:coarse){#cursor{display:none}}

/*  HEADER  */
#header{
  position:fixed;top:0;left:0;right:0;z-index:1000;
  padding:20px 40px;display:flex;align-items:center;justify-content:space-between;
  transition:background .4s,backdrop-filter .4s,padding .3s,border-color .4s,box-shadow .4s;
  border-bottom:1px solid transparent;gap:20px;
}
/* Scrolled on home (scroll past hero) OR forced on non-home pages */
#header.scrolled,
#header.on-light{
  background:rgba(255,255,255,.97);backdrop-filter:blur(20px);
  padding:14px 40px;border-color:rgba(26,24,16,.1);
  box-shadow:0 2px 24px rgba(26,24,16,.06);
}
/* Logo: cream over dark hero, ink on white bg */
.logo{font-family:var(--num);font-size:18px;letter-spacing:4px;color:var(--cream);cursor:pointer;flex-shrink:0;white-space:nowrap;transition:color .3s}
.logo span{color:var(--gold)}
#header.scrolled .logo,
#header.on-light .logo{color:var(--ink)}
/* Nav pill container */
.nav-center{
  display:flex;align-items:center;gap:2px;
  background:rgba(255,255,255,.07);border:1px solid var(--c15);
  border-radius:50px;padding:5px 7px;backdrop-filter:blur(10px);
  flex-wrap:nowrap;transition:background .3s,border-color .3s;
}
#header.scrolled .nav-center,
#header.on-light .nav-center{background:rgba(26,24,16,.04);border-color:rgba(26,24,16,.1)}
/* Pills: cream over dark hero, mid-ink on white */
.nav-pill{
  padding:7px 16px;border-radius:50px;font-size:12.5px;font-weight:400;
  letter-spacing:.4px;color:var(--c60);cursor:pointer;transition:all .25s;white-space:nowrap
}
#header.scrolled .nav-pill,
#header.on-light .nav-pill{color:rgba(26,24,16,.55)}
/* Hover: cream over dark, ink on white */
.nav-pill:hover{color:var(--cream);background:rgba(255,255,255,.09)}
#header.scrolled .nav-pill:hover,
#header.on-light .nav-pill:hover{color:var(--ink);background:rgba(26,24,16,.06)}
/* Active pill: always dark text on gold - readable everywhere */
.nav-pill.active{color:#0A0908 !important;background:var(--gold);font-weight:500}
/* WA button */
.header-wa{
  display:inline-flex;align-items:center;gap:8px;
  background:var(--wa);color:#fff;font-size:13px;font-weight:500;
  padding:10px 18px;border-radius:50px;flex-shrink:0;
  transition:transform .2s,box-shadow .2s;
  animation:pulse-ring 3s ease infinite;
  white-space:nowrap;
}
.header-wa:hover{transform:translateY(-1px);box-shadow:0 8px 24px var(--wa-glow);animation:none}
/* Hamburger */
.ham-btn{
  display:none;flex-direction:column;justify-content:center;align-items:center;
  width:40px;height:40px;gap:5px;cursor:pointer;
  background:var(--c08);border:1px solid var(--c15);border-radius:8px;flex-shrink:0;
  transition:background .3s,border-color .3s;
}
#header.scrolled .ham-btn,
#header.on-light .ham-btn{background:rgba(26,24,16,.05);border-color:rgba(26,24,16,.12)}
.ham-line{width:18px;height:1.5px;background:var(--cream);transition:all .3s}
#header.scrolled .ham-line,
#header.on-light .ham-line{background:var(--ink)}

/*  MOBILE MENU OVERLAY  */
.menu-overlay{
  position:fixed;inset:0;z-index:900;
  background:rgba(8,8,8,.97);backdrop-filter:blur(20px);
  display:flex;flex-direction:column;align-items:flex-start;justify-content:center;
  padding:80px 48px;
  opacity:0;pointer-events:none;
  transition:opacity .4s ease;
}
.menu-overlay.open{opacity:1;pointer-events:all}
.menu-nav-item{
  display:flex;align-items:center;gap:20px;
  padding:16px 0;border-bottom:1px solid var(--c08);
  cursor:pointer;width:100%;
  transform:translateX(-30px);opacity:0;
  transition:transform .4s ease,opacity .4s ease,color .2s;
}
.menu-overlay.open .menu-nav-item{transform:translateX(0);opacity:1}
.menu-nav-num{font-family:var(--num);font-size:11px;letter-spacing:2px;color:var(--gold);opacity:.6}
.menu-nav-text{font-family:var(--disp);font-size:clamp(28px,6vw,48px);font-weight:300;color:var(--cream)}
.menu-nav-item:hover .menu-nav-text{color:var(--gold)}
.menu-nav-arr{margin-left:auto;opacity:0;transform:translateX(-8px);transition:all .2s;color:var(--gold)}
.menu-nav-item:hover .menu-nav-arr{opacity:1;transform:translateX(0)}
.menu-social-row{display:flex;gap:24px;margin-top:40px;padding-top:24px;border-top:1px solid var(--c08)}
.menu-social-link{font-size:11px;letter-spacing:3px;text-transform:uppercase;color:var(--c30);transition:color .2s}
.menu-social-link:hover{color:var(--gold)}

/*  SOCIAL SIDEBAR (Desktop)  */
.social-side{
  position:fixed;left:20px;top:50%;transform:translateY(-50%);
  display:flex;flex-direction:column;align-items:flex-start;gap:6px;z-index:40;
  transition:opacity .4s ease;
}
/* Divider lines adapt */
.social-divider-line{
  width:1px;height:50px;margin:4px auto;align-self:center;
  background:linear-gradient(to bottom,transparent,rgba(245,240,232,.3),transparent);
  transition:background .5s ease;
}
.social-side.light-mode .social-divider-line{
  background:linear-gradient(to bottom,transparent,rgba(26,24,16,.25),transparent);
}
/* Expand pills: default = dark-bg friendly */
.social-expand{
  position:relative;width:40px;height:40px;border-radius:9999px;
  background:rgba(255,255,255,.05);border:1px solid rgba(245,240,232,.12);
  display:flex;align-items:center;justify-content:center;
  overflow:hidden;cursor:pointer;flex-shrink:0;
  color:rgba(245,240,232,.65);
  transition:width .5s cubic-bezier(.23,.86,.39,.96),background .5s ease,border-color .5s ease,box-shadow .5s ease,color .4s ease;
}
.social-expand:hover{width:130px}
/* Light-mode state (scrolled past dark hero) */
.social-side.light-mode .social-expand{
  background:rgba(255,255,255,.85);
  border-color:rgba(26,24,16,.15);
  color:rgba(26,24,16,.6);
  box-shadow:0 2px 12px rgba(26,24,16,.08);
}
/* Hover coloring overrides per platform (same glows, always good) */
.social-expand[data-p="tiktok"]:hover{background:linear-gradient(135deg,rgba(0,242,234,.2),rgba(255,0,80,.15));border-color:rgba(0,242,234,.4);box-shadow:0 0 28px rgba(0,242,234,.2)}
.social-expand[data-p="instagram"]:hover{background:linear-gradient(135deg,rgba(240,148,51,.2),rgba(188,24,136,.15));border-color:rgba(240,148,51,.4);box-shadow:0 0 28px rgba(240,148,51,.2)}
.social-expand[data-p="facebook"]:hover{background:linear-gradient(135deg,rgba(24,119,242,.2),rgba(12,93,199,.15));border-color:rgba(24,119,242,.4);box-shadow:0 0 28px rgba(24,119,242,.2)}
/* Icon inherits color */
.social-expand .soc-icon{position:relative;z-index:2;transition:transform .4s ease;flex-shrink:0}
.social-expand:hover .soc-icon{transform:scale(0)}
.social-expand::before{content:'';position:absolute;inset:0;border-radius:9999px;opacity:0;transition:opacity .5s ease}
.social-expand:hover::before{opacity:1}
/* Label text: white on dark, dark on light */
.social-expand .soc-label{
  position:absolute;left:44px;font-size:10px;text-transform:uppercase;
  letter-spacing:.1em;font-weight:600;
  color:#fff;
  opacity:0;transform:translateX(-8px);
  transition:opacity .3s ease .05s,transform .3s ease .05s,color .4s ease;white-space:nowrap;
}
.social-side.light-mode .social-expand .soc-label{color:var(--ink)}
.social-expand:hover .soc-label{opacity:1;transform:translateX(0)}

/* Mobile socials row, shown when sidebar is hidden (<900px) */
.mobile-socials{
  display:none;justify-content:center;gap:12px;margin-top:28px;
}
.mobile-socials .social-expand{width:40px;height:40px}
.mobile-socials .social-expand:hover{width:120px}
/*  HERO  */
#hero{
  min-height:100vh;position:relative;overflow:hidden;
  display:flex;flex-direction:column;
  background:var(--bg);
}
.sv-hero__bg{
  position:absolute;inset:0;
  background-image:var(--hero-bg-image, none);
  background-size:cover;background-position:center 40%;
  transform:scale(1.04);
  animation:heroZoom 18s ease-out forwards;
  z-index:0;
}
@keyframes heroZoom{
  from{transform:scale(1.04)}
  to{transform:scale(1)}
}
.sv-hero__overlay{
  position:absolute;inset:0;background:
    linear-gradient(105deg,rgba(10,9,8,.84) 0%,rgba(18,17,16,.62) 45%,rgba(10,9,8,.24) 100%),
    linear-gradient(to top,rgba(10,9,8,.82) 0%,transparent 44%);
  z-index:1;
}
#hero::after{
  content:'';position:absolute;inset:0;z-index:2;opacity:.04;pointer-events:none;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  background-size:200px 200px;
}
.sv-hero__content{
  position:relative;z-index:5;flex:1;
  display:flex;flex-direction:column;justify-content:center;
  max-width:680px;padding:132px 48px 132px 96px;
}
.sv-hero__headline{
  font-family:var(--disp);font-weight:800;
  font-size:clamp(2.55rem,5.3vw,5rem);line-height:.94;letter-spacing:-.05em;
  color:var(--cream);margin-bottom:18px;
  animation:fadeUp .75s ease .28s both;
}
.sv-hero__headline-line{display:block;white-space:nowrap}
.sv-hero__headline-strong{font-weight:800;color:var(--gold)}
.sv-hero__sub{
  font-size:clamp(.98rem,1.4vw,1.08rem);font-weight:400;line-height:1.7;
  color:var(--c70);max-width:500px;margin-bottom:34px;
  animation:fadeUp .75s ease .42s both;
}
.sv-hero__ctas{
  display:flex;align-items:center;gap:12px;flex-wrap:wrap;
  animation:fadeUp .75s ease .56s both;
}
.sv-hero__cta-primary,.sv-hero__cta-secondary{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  min-height:48px;padding:12px 26px;border-radius:999px;
  font-size:.92rem;font-weight:600;text-decoration:none;white-space:nowrap;
  transition:transform .22s ease,box-shadow .22s ease,background .22s ease,border-color .22s ease,color .22s ease;
}
.sv-hero__cta-primary{
  background:var(--gold);color:#0A0908;box-shadow:0 12px 34px rgba(10,9,8,.26);
}
.sv-hero__cta-primary:hover{
  transform:translateY(-2px);background:var(--gold-l);box-shadow:0 18px 36px rgba(10,9,8,.34);
}
.sv-hero__cta-secondary{
  color:var(--cream);border:1px solid rgba(245,240,232,.34);
  background:rgba(245,240,232,.04);backdrop-filter:blur(10px);
}
.sv-hero__cta-secondary:hover{
  transform:translateY(-2px);background:rgba(245,240,232,.1);border-color:rgba(245,240,232,.6);
}
.sv-hero__arrow{transition:transform .2s ease}
.sv-hero__cta-secondary:hover .sv-hero__arrow{transform:translateX(3px)}
.sv-hero__bottom{
  position:absolute;left:0;right:0;bottom:0;z-index:5;
  display:flex;align-items:flex-end;justify-content:space-between;gap:32px;
  padding:0 48px 28px 96px;
  animation:fadeUp .75s ease .72s both;
}
.sv-stats{display:flex;align-items:center}
.sv-stat{padding-right:26px}
.sv-stat + .sv-stat{padding-left:26px;border-left:1px solid rgba(245,240,232,.18)}
.sv-stat__num{
  font-family:var(--num);font-weight:700;
  font-size:clamp(1.3rem,2.2vw,1.85rem);line-height:1;letter-spacing:-.04em;color:var(--cream);
}
.sv-stat__label{
  font-size:.7rem;font-weight:500;color:var(--c40);margin-top:6px;letter-spacing:.08em;text-transform:uppercase;
}
.sv-hero__prompt{
  display:flex;align-items:flex-end;gap:8px;color:var(--c70);text-align:right;
}
.sv-hero__prompt-icon{font-size:.95rem;opacity:.65;margin-bottom:2px}
.sv-hero__prompt-text{
  font-family:var(--disp);font-weight:700;
  font-size:clamp(.88rem,1.45vw,1.16rem);line-height:1.2;letter-spacing:-.03em;
}
.sv-hero__line{
  position:absolute;bottom:0;right:48px;width:130px;height:2px;background:rgba(245,240,232,.14);z-index:5;
}
.sv-hero__line::after{
  content:'';position:absolute;right:0;top:0;width:11px;height:11px;
  background:var(--gold);border-radius:50%;transform:translate(50%,-50%);
}
/* WhatsApp magnetic button used outside the hero */
.btn-wa-mag{
  display:inline-flex;align-items:center;gap:10px;
  background:var(--wa);color:#fff;font-size:14px;font-weight:500;
  padding:15px 30px;border-radius:50px;cursor:pointer;
  position:relative;overflow:hidden;
  transition:background .3s ease,box-shadow .3s ease,transform .2s ease;
}
.btn-wa-mag:hover{background:#20bd5a;box-shadow:0 0 40px rgba(37,211,102,.3),0 0 80px rgba(37,211,102,.1);transform:translateY(-2px)}
.btn-wa-mag::before{
  content:'';position:absolute;inset:-4px;border-radius:50px;
  border:1.5px solid rgba(37,211,102,.3);
  animation:spin-slow 8s linear infinite;
}
.wa-particle{
  position:absolute;width:4px;height:4px;border-radius:50%;
  background:rgba(255,255,255,.7);pointer-events:none;
  transition:transform .6s cubic-bezier(.23,.86,.39,.96),opacity .4s ease;
  opacity:.25;
}
.btn-wa-mag:hover .wa-particle{opacity:.9}
/* Hero prop card removed */
/* Social proof line */
.hero-social-proof{
  display:flex;align-items:center;gap:10px;margin-top:20px;
  font-size:11px;letter-spacing:2px;text-transform:uppercase;color:var(--c30);
  animation:fadeUp .9s ease 1s both;
  flex-wrap:wrap;
}
.hero-social-proof .dot{width:3px;height:3px;border-radius:50%;background:var(--c30)}

/*  MARQUEE  */
#marquee{padding:16px 0;background:var(--gold);overflow:hidden;position:relative}
.marquee-track{display:flex;white-space:nowrap;animation:marquee 15s linear infinite}
.marquee-item{
  font-family:var(--num);font-size:10.5px;letter-spacing:3px;text-transform:uppercase;
  color:var(--bg);padding:0 32px;display:inline-flex;align-items:center;gap:32px;
}
.marquee-item::after{content:'';font-size:6px}

/*  FEATURED STAYS  */
#properties{padding:90px 60px;background:var(--white)}
.sec-head{margin-bottom:52px}
.sec-head h2{font-family:var(--disp);font-size:clamp(34px,4.5vw,58px);font-weight:300;line-height:1.12;color:var(--ink)}
.sec-head h2 em{font-style:italic;color:var(--gold-l)}
.sec-head p{font-size:15px;color:var(--ink-mid);max-width:480px;margin-top:10px;line-height:1.7;font-weight:300}
.sec-head.center{text-align:center}
.sec-head.center p{margin:10px auto 0}
.props-row{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;max-width:1300px;margin:0 auto}
.prop-card{
  position:relative;border-radius:16px;overflow:hidden;cursor:pointer;
  aspect-ratio:3/4;box-shadow:0 4px 24px rgba(26,24,16,.1);
  transition:box-shadow .4s,transform .4s;
}
.prop-card:hover{box-shadow:0 12px 48px rgba(26,24,16,.18);transform:translateY(-4px)}
.prop-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .7s cubic-bezier(.25,.46,.45,.94)}
.prop-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.9) 0%,rgba(0,0,0,.3) 45%,rgba(0,0,0,.08) 70%,transparent 100%)}
.prop-tag{
  position:absolute;top:18px;left:18px;
  font-size:10px;font-weight:500;letter-spacing:2.5px;text-transform:uppercase;
  padding:5px 12px;border-radius:50px;
  background:rgba(201,168,76,.9);border:none;color:#0A0908;
}
.prop-body{position:absolute;bottom:0;left:0;right:0;padding:22px}
.prop-loc{font-size:10.5px;letter-spacing:1.5px;text-transform:uppercase;color:rgba(255,255,255,.65);margin-bottom:6px}
.prop-name{font-family:var(--disp);font-size:24px;font-weight:400;color:#FFFFFF;line-height:1.1;margin-bottom:10px}
.prop-meta{display:flex;align-items:center;gap:12px;font-size:12px;color:rgba(255,255,255,.6)}
.prop-meta span{display:flex;align-items:center;gap:4px}
.prop-price{font-family:var(--num);font-size:17px;font-weight:400;color:var(--gold-l);margin-left:auto}
.prop-rating{display:flex;align-items:center;gap:4px;font-size:12px;color:var(--gold-l)}
.prop-wa{
  position:absolute;bottom:88px;left:22px;right:22px;
  display:flex;align-items:center;justify-content:center;gap:8px;
  background:var(--wa);color:#fff;font-size:13px;font-weight:500;
  padding:11px;border-radius:50px;
  opacity:0;transform:translateY(10px);
  transition:opacity .3s,transform .3s;
}
.prop-card:hover .prop-wa{opacity:1;transform:translateY(0)}
.prop-card:hover .prop-img{transform:scale(1.05)}
.view-all-wrap{text-align:center;margin-top:48px}
.btn-outline{
  display:inline-flex;align-items:center;gap:10px;
  border:1.5px solid rgba(26,24,16,.25);color:var(--ink);font-size:14px;
  padding:14px 36px;border-radius:50px;cursor:pointer;
  transition:all .25s;background:transparent;
}
.btn-outline:hover{background:var(--gold);border-color:var(--gold);color:#0A0908}

/*  TOWNS  */
#towns{padding:80px 0 80px 60px;overflow:hidden;background:var(--white);border-top:1px solid var(--border)}
.towns-scroll-wrap{position:relative}
.towns-scroll{display:flex;gap:20px;overflow-x:auto;padding-bottom:16px;padding-right:60px;scrollbar-width:none;scroll-behavior:smooth}
.towns-scroll::-webkit-scrollbar{display:none}
/* Scroll hint arrows */
.towns-scroll-arrows{
  display:flex;align-items:center;gap:8px;
  margin-top:18px;padding-right:60px;
}
.towns-arrow{
  width:38px;height:38px;border-radius:50%;cursor:pointer;
  border:1.5px solid var(--border);background:var(--white);
  display:flex;align-items:center;justify-content:center;
  color:var(--ink-mid);transition:all .2s;flex-shrink:0;
}
.towns-arrow:hover{border-color:var(--gold);background:var(--gold);color:#0A0908}
.towns-scroll-hint{
  font-size:10.5px;letter-spacing:2.5px;text-transform:uppercase;
  color:var(--gold-l);display:flex;align-items:center;gap:8px;margin-left:4px;
}
.towns-scroll-hint-dots{display:flex;gap:4px;align-items:center}
.towns-hint-dot{
  width:5px;height:5px;border-radius:50%;background:var(--border);
  transition:background .3s;flex-shrink:0;
}
.towns-hint-dot.active{background:var(--gold);}
.town-card{flex-shrink:0;width:280px;border-radius:20px;overflow:hidden;position:relative;cursor:pointer;border:1.5px solid var(--border);transition:border-color .3s,transform .4s ease,box-shadow .4s}
.town-card:hover{border-color:var(--gold-b);transform:translateY(-6px);box-shadow:0 16px 48px rgba(26,24,16,.12)}
.town-card img{width:100%;height:360px;object-fit:cover;transition:transform .6s ease}
.town-card:hover img{transform:scale(1.06)}
.town-card-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(10,9,8,.9) 0%,transparent 55%)}
.town-card-body{position:absolute;bottom:0;left:0;right:0;padding:24px}
.town-name{font-family:var(--disp);font-size:26px;font-weight:400;margin-bottom:4px;color:#FFF}
.town-meta{font-size:11px;letter-spacing:2px;text-transform:uppercase;color:rgba(255,255,255,.45)}
.town-count-badge{
  display:inline-flex;align-items:center;gap:6px;margin-top:10px;
  background:rgba(201,168,76,.88);border:none;
  border-radius:20px;padding:4px 12px;
  font-size:11px;color:#0A0908;font-weight:600;
}

/*  HOW IT WORKS ACCORDION CARDS  */
@keyframes howProgress{from{width:0%}to{width:100%}}

#how{padding:100px 60px;background:var(--surface);position:relative;overflow:hidden}
#how::before{content:'';position:absolute;top:-1px;left:0;right:0;height:1px;background:linear-gradient(to right,transparent,var(--gold-b),transparent)}
#how::after{content:'';position:absolute;bottom:-1px;left:0;right:0;height:1px;background:linear-gradient(to right,transparent,var(--gold-b),transparent)}

/*  Desktop: horizontal flex accordion  */
.how-accordion{
  display:flex;gap:10px;
  max-width:1020px;margin:0 auto;
  height:370px;align-items:stretch;
}
.how-tab{
  position:relative;border-radius:20px;overflow:hidden;
  cursor:pointer;flex:0 0 130px;min-width:0;
  transition:flex-grow .55s cubic-bezier(.4,0,.2,1),flex-basis .55s cubic-bezier(.4,0,.2,1);
  will-change:flex-basis;
  user-select:none;-webkit-tap-highlight-color:transparent;
}
.how-tab.active{flex:1 1 auto}

/* Gold/amber/earth palette, 3 distinct but harmonious tones */
.how-tab:nth-child(1){background:linear-gradient(135deg,#E2BF62 0%,#B8891E 100%)}
.how-tab:nth-child(2){background:linear-gradient(135deg,#9A7530 0%,#D4AA4C 100%)}
.how-tab:nth-child(3){background:linear-gradient(135deg,#2A1E08 0%,#7A5A20 100%)}

/*  Collapsed state  */
.how-tab-collapsed{
  position:absolute;inset:0;
  display:flex;flex-direction:column;justify-content:space-between;align-items:flex-start;
  padding:24px 20px;
  opacity:1;transition:opacity .2s ease;pointer-events:none;
}
.how-tab.active .how-tab-collapsed{opacity:0}

.how-tab-num-sm{
  font-family:var(--num);font-size:52px;font-weight:600;
  color:rgba(0,0,0,.15);line-height:1;
}
.how-tab-label{
  writing-mode:vertical-rl;text-orientation:mixed;transform:rotate(180deg);
  font-size:10px;font-weight:700;letter-spacing:3.5px;text-transform:uppercase;
  color:rgba(255,255,255,.55);white-space:nowrap;padding-bottom:4px;
}

/*  Expanded state  */
.how-tab-expanded{
  position:absolute;inset:0;
  display:flex;flex-direction:column;
  padding:32px 32px 0;
  opacity:0;transition:opacity .3s ease .25s;pointer-events:none;
}
.how-tab.active .how-tab-expanded{opacity:1;pointer-events:all}

.how-tab-top{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:8px}
.how-tab-num-lg{
  font-family:var(--num);font-size:84px;font-weight:600;
  color:rgba(0,0,0,.12);line-height:1;margin-top:-8px;
}
.how-tab-check{
  width:38px;height:38px;border-radius:50%;flex-shrink:0;
  border:1.5px solid rgba(255,255,255,.45);
  display:flex;align-items:center;justify-content:center;margin-top:4px;
}
.how-tab-check svg{stroke:rgba(255,255,255,.88);fill:none;stroke-width:2.5;stroke-linecap:round;stroke-linejoin:round}

.how-tab-body{flex:1;display:flex;flex-direction:column;justify-content:flex-end;padding-bottom:0}
.how-tab-title{
  font-family:var(--disp);font-size:clamp(22px,2.4vw,30px);font-weight:400;
  color:#fff;margin-bottom:10px;line-height:1.1;
}
.how-tab-desc{
  font-size:14px;color:rgba(255,255,255,.78);line-height:1.72;font-weight:300;max-width:440px;
}

/* Progress bar */
.how-tab-progress{margin-top:auto;padding-top:20px;flex-shrink:0}
.how-tab-bar-track{height:3px;background:rgba(255,255,255,.2);border-radius:0;overflow:hidden}
.how-tab-bar{height:100%;background:rgba(255,255,255,.82);width:0%;border-radius:1.5px}
/* Note: bar animation is driven entirely by JS  no CSS auto-start rule here */

/*  Tablet: 900px  */
@media(max-width:900px){
  .how-accordion{
    flex-direction:column;height:auto;gap:8px;
  }
  .how-tab{
    flex:none !important;border-radius:16px;
    height:68px;
    transition:height .52s cubic-bezier(.4,0,.2,1);
  }
  .how-tab.active{height:300px}
  .how-tab-collapsed{
    flex-direction:row;align-items:center;
    padding:0 22px;height:68px;gap:16px;
  }
  .how-tab-num-sm{font-size:30px}
  .how-tab-label{
    writing-mode:horizontal-tb;transform:none;
    font-size:10px;letter-spacing:2.5px;padding-bottom:0;
    color:rgba(255,255,255,.65);
  }
  .how-tab-expanded{padding:22px 24px 0}
  .how-tab-num-lg{font-size:56px}
  .how-tab-title{font-size:22px}
  .how-tab-desc{font-size:13px}
  .how-tab-progress{padding-top:12px}
  .how-tab.active{height:280px}
}
/*  Mobile: 640px  */
@media(max-width:640px){
  #how{padding:70px 20px}
  .how-tab-desc{font-size:12.5px}
  .how-tab.active{height:270px}
  .how-tab-expanded{padding:18px 20px 0}
  .how-tab-num-lg{font-size:48px}
}

/*  ABOUT + WHY COMBINED  */
#about{
  padding:100px 60px;
  display:grid;grid-template-columns:1fr 1fr;gap:72px;
  align-items:center;max-width:1300px;margin:0 auto;
}
/* Full-bleed white bg wrapper around the about grid */
#about-wrap{background:var(--white);border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.about-img-wrap{position:relative;border-radius:var(--rd2);overflow:visible;aspect-ratio:4/5}
.about-img-inner{width:100%;height:100%;border-radius:var(--rd2);overflow:hidden;box-shadow:0 12px 56px rgba(26,24,16,.14)}
.about-img-inner img{width:100%;height:100%;object-fit:cover}
.about-img-overlay{position:absolute;inset:0;border-radius:var(--rd2);background:linear-gradient(135deg,rgba(201,168,76,.06),transparent)}
.about-float-card{
  position:absolute;bottom:28px;left:-28px;
  background:var(--white);border:1.5px solid var(--border);
  border-radius:16px;padding:20px 24px;min-width:190px;
  box-shadow:0 16px 48px rgba(26,24,16,.12);
}
.afc-rating{font-family:var(--num);font-size:38px;color:var(--gold-l);line-height:1}
.afc-stars{display:flex;gap:2px;margin:8px 0 4px}
.afc-star{color:var(--gold);font-size:13px}
.afc-label{font-size:11px;letter-spacing:2px;text-transform:uppercase;color:var(--ink-soft)}
.about-corner{position:absolute;top:-12px;right:-12px;width:52px;height:52px;border-top:2px solid rgba(201,168,76,.3);border-right:2px solid rgba(201,168,76,.3);border-radius:0 8px 0 0}
.about-content h2{font-family:var(--disp);font-size:clamp(32px,3.5vw,48px);font-weight:300;line-height:1.15;margin-bottom:18px;color:var(--ink)}
.about-content h2 em{font-style:italic;color:var(--gold-l)}
.about-content p{font-size:14.5px;color:var(--ink-mid);line-height:1.8;font-weight:300;margin-bottom:14px}
.about-more{display:none}
.about-more.open{display:block}
.read-more-btn{
  display:inline-flex;align-items:center;gap:8px;
  color:var(--gold-l);font-size:13px;font-weight:500;letter-spacing:.5px;
  cursor:pointer;margin-top:6px;border:none;background:none;padding:0;
  font-family:var(--body);transition:color .2s;
}
.read-more-btn:hover{color:var(--ink)}
.why-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:32px}
.why-item{
  padding:18px;background:var(--surface);border-radius:var(--rd);
  border:1px solid var(--border-soft);transition:border-color .3s,box-shadow .3s;
}
.why-item:hover{border-color:var(--gold-b);box-shadow:0 4px 20px rgba(26,24,16,.07)}
.why-icon{font-size:18px;margin-bottom:10px;color:var(--gold);line-height:1;display:flex;align-items:center}
.why-title{font-size:13px;font-weight:500;color:var(--ink);margin-bottom:4px}
.why-desc{font-size:12px;color:var(--ink-soft);line-height:1.5;font-weight:300}

/*  CTA / GET IN TOUCH  */
#cta-section{
  padding:100px 60px;text-align:center;position:relative;overflow:hidden;
  background:var(--ink);
}
#cta-section .sec-tag{color:var(--gold-l)}
.cta-watermark{
  font-family:var(--num);font-size:clamp(60px,12vw,160px);font-weight:600;
  color:rgba(201,168,76,.06);letter-spacing:-4px;
  position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  white-space:nowrap;pointer-events:none;user-select:none;
}
.cta-spinner{
  width:80px;height:80px;margin:0 auto 32px;position:relative;
}
.cta-spinner svg{
  position:absolute;inset:0;animation:spin-slow 8s linear infinite;
}
.cta-content{position:relative;z-index:1}
.cta-content h2{font-family:var(--disp);font-size:clamp(36px,5.5vw,72px);font-weight:300;line-height:1.1;margin-bottom:18px;color:var(--cream)}
.cta-content h2 em{font-style:italic;color:var(--gold-l)}
.cta-content p{font-size:16px;color:var(--c60);max-width:480px;margin:0 auto 40px;line-height:1.7;font-weight:300}
.cta-response-note{
  display:flex;align-items:center;justify-content:center;gap:8px;
  font-size:12px;color:var(--c40);margin-top:24px;
}
.cta-trust-bar{
  display:flex;flex-wrap:wrap;justify-content:center;gap:28px;
  margin-top:40px;padding-top:28px;border-top:1px solid rgba(255,255,255,.08);
}
.ctb-item{display:flex;align-items:center;gap:7px;font-size:12px;color:var(--c40);letter-spacing:1px;text-transform:uppercase}

/*  FOOTER  */
#footer{padding:64px 60px 36px;background:var(--bg2);border-top:none}
.footer-grid{
  display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;
  gap:48px;margin-bottom:56px;
}
.footer-brand-name{font-family:var(--num);font-size:22px;letter-spacing:4px;margin-bottom:14px;color:var(--cream)}
.footer-brand-name span{color:var(--gold)}
.footer-tagline{font-size:13px;color:var(--c40);line-height:1.7;max-width:260px;margin-bottom:20px;font-weight:300}
.footer-social{display:flex;gap:8px}
.fsoc{
  width:34px;height:34px;border-radius:50%;
  background:var(--c08);border:1px solid var(--c15);
  display:flex;align-items:center;justify-content:center;
  color:var(--c40);transition:all .25s;
}
.fsoc:hover{background:var(--gold-d);border-color:var(--gold-b);color:var(--gold)}
.footer-col h4{font-size:11px;font-weight:500;letter-spacing:2.5px;text-transform:uppercase;color:var(--gold);margin-bottom:18px;opacity:.8}
.footer-col-link{display:block;font-size:13.5px;color:var(--c40);margin-bottom:10px;cursor:pointer;transition:color .2s;font-weight:300}
.footer-col-link:hover{color:var(--gold-l)}
.footer-bottom{
  display:flex;align-items:center;justify-content:space-between;
  padding-top:22px;border-top:1px solid var(--c08);
  flex-wrap:wrap;gap:12px;
}
.footer-bottom-copy{font-size:12px;color:var(--c30)}
.footer-bottom-links{display:flex;align-items:center;gap:20px;flex-wrap:wrap}
.footer-bottom-link{font-size:12px;color:var(--c30);cursor:pointer;transition:color .2s}
.footer-bottom-link:hover{color:var(--cream)}
.footer-terms-link{
  font-size:12px;color:var(--gold);cursor:pointer;
  border-bottom:1px solid rgba(201,168,76,.35);padding-bottom:1px;
  font-weight:500;transition:border-color .2s;
}
.footer-terms-link:hover{border-color:var(--gold-l)}

/*  FLOATING WA BUTTON  */
#wa-float{
  position:fixed;bottom:28px;right:28px;z-index:990;
  width:56px;height:56px;border-radius:50%;
  background:linear-gradient(135deg,#25D366,#128C7E);
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 8px 32px rgba(37,211,102,.4);
  transition:transform .3s ease,box-shadow .3s ease;
  animation:pulse-ring 3s ease infinite;
}
#wa-float:hover{transform:scale(1.12);box-shadow:0 12px 40px rgba(37,211,102,.55);animation:none}

/*  STAYS PAGE  */
.page-hero{
  height:44vh;min-height:300px;display:flex;align-items:flex-end;
  padding:56px 60px;position:relative;overflow:hidden;
  background:var(--bg2);
  margin-top:80px;
}
.page-hero-bg{position:absolute;inset:0;object-fit:cover;opacity:.25;width:100%;height:100%}
.page-hero-overlay{position:absolute;inset:0;background:linear-gradient(to bottom,rgba(10,9,8,.2),rgba(10,9,8,.88))}
.page-hero-inner{position:relative;z-index:1}
.page-hero-line{width:50px;height:2px;background:var(--gold);margin-bottom:14px}
.page-hero h1{font-family:var(--disp);font-size:clamp(40px,5.5vw,76px);font-weight:300;line-height:1;color:var(--cream)}
.page-hero h1 em{font-style:italic;color:var(--gold-l)}
.stays-filters{
  display:flex;gap:10px;padding:24px 60px;overflow-x:auto;
  scrollbar-width:none;
  border-bottom:1px solid var(--border);
  background:var(--white);
}
.stays-filters::-webkit-scrollbar{display:none}
.filter-pill{
  padding:8px 20px;border-radius:50px;font-size:12.5px;white-space:nowrap;cursor:pointer;
  border:1.5px solid var(--border);color:var(--ink-mid);transition:all .2s;
  background:transparent;
}
.filter-pill:hover{border-color:var(--gold);color:var(--gold-l)}
.filter-pill.active{background:var(--gold);border-color:var(--gold);color:#0A0908;font-weight:500}
.stays-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:20px;
  padding:48px 60px;max-width:1400px;margin:0 auto;
  background:var(--white);
}

/*  PROPERTY DETAIL PAGE  */
/* 6-photo gallery */
.prop-gallery-6{
  display:grid;
  grid-template-columns:2fr 1fr 1fr;
  grid-template-rows:1fr 1fr;
  gap:6px;height:70vh;padding-top:80px;
}
.gallery-main{grid-row:1/3;overflow:hidden;cursor:pointer;position:relative}
.gallery-thumb{overflow:hidden;cursor:pointer;position:relative}
.gallery-img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}
.gallery-main:hover .gallery-img,.gallery-thumb:hover .gallery-img{transform:scale(1.04)}
.gallery-count{display:none}/* removed from main cell, now handled by gallery-view-all-desktop */
.gallery-add-btn{
  position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
  background:rgba(10,9,8,.52);cursor:pointer;transition:background .2s;
}
.gallery-add-btn:hover{background:rgba(10,9,8,.68)}
.gallery-add-btn span{
  display:inline-flex;align-items:center;
  background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.3);
  color:#fff;font-size:12px;font-weight:500;padding:8px 16px;border-radius:50px;
  backdrop-filter:blur(6px);transition:background .2s,border-color .2s;
  white-space:nowrap;
}
.gallery-view-all-desktop span:hover{background:rgba(201,168,76,.25);border-color:var(--gold-b)}
.prop-detail{display:grid;grid-template-columns:1.5fr 1fr;gap:56px;padding:56px 60px;max-width:1300px;margin:0 auto;align-items:start;background:var(--white)}
.pdl h1{font-family:var(--disp);font-size:clamp(32px,3.5vw,52px);font-weight:300;line-height:1.1;margin-bottom:8px;color:var(--ink)}
.pdl h1 em{font-style:italic;color:var(--gold-l)}
.pdl-loc{font-size:12px;letter-spacing:2px;text-transform:uppercase;color:var(--ink-soft);margin-bottom:22px}
.pdl-meta-row{display:flex;gap:20px;padding:18px 0;border-top:1px solid var(--border-soft);border-bottom:1px solid var(--border-soft);margin-bottom:26px;flex-wrap:wrap}
.pm-item{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--ink-mid)}
.pm-icon{width:16px;height:16px;stroke:var(--gold-l);fill:none;stroke-width:1.5;flex-shrink:0}
.pdl-desc{font-size:15px;color:var(--ink-mid);line-height:1.85;font-weight:300;margin-bottom:28px}
.amenities-grid{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:32px}
.amenity-tag{
  font-size:12px;padding:5px 14px;border-radius:50px;
  background:var(--surface);border:1px solid var(--border);color:var(--ink-mid);
}
.prop-cta-card{
  position:sticky;top:100px;background:var(--white);
  border:1.5px solid rgba(201,168,76,.3);border-radius:var(--rd2);padding:28px;
  box-shadow:0 8px 48px rgba(26,24,16,.1);
}
.pcta-price{font-family:var(--num);font-size:40px;font-weight:400;color:var(--gold-l)}
.pcta-price small{font-family:var(--body);font-size:14px;color:var(--ink-soft);font-weight:300}
.pcta-rating{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--gold-l);margin:10px 0 22px}
.pcta-divider{height:1px;background:var(--border-soft);margin:22px 0}
.pcta-wa{
  display:flex;align-items:center;justify-content:center;gap:10px;width:100%;
  background:var(--wa);color:#fff;font-size:15px;font-weight:500;
  padding:15px;border-radius:50px;cursor:pointer;
  transition:transform .2s,box-shadow .2s;border:none;
  position:relative;overflow:hidden;
}
.pcta-wa::before{content:'';position:absolute;inset:-4px;border-radius:50px;border:1.5px solid rgba(37,211,102,.25);animation:spin-slow 8s linear infinite}
.pcta-wa:hover{transform:translateY(-2px);box-shadow:0 14px 36px var(--wa-glow)}

/*  BOOKING ENQUIRY FORM  */
.booking-form{margin-top:0}
.booking-label{
  display:block;font-size:10px;font-weight:500;letter-spacing:2.5px;text-transform:uppercase;
  color:var(--ink-soft);margin-bottom:7px;
}
.booking-input{
  width:100%;background:var(--surface);border:1.5px solid var(--border);border-radius:var(--rd);
  padding:10px 14px;font-size:14px;font-family:var(--body);color:var(--ink);
  transition:border-color .25s,box-shadow .25s;outline:none;
}
.booking-input:focus{border-color:var(--gold-b);box-shadow:0 0 0 3px rgba(201,168,76,.1)}
.booking-input:hover{border-color:rgba(26,24,16,.2)}
.booking-select{
  width:100%;background:var(--surface);border:1.5px solid var(--border);border-radius:var(--rd);
  padding:10px 36px 10px 14px;font-size:14px;font-family:var(--body);color:var(--ink);
  transition:border-color .25s;outline:none;cursor:pointer;
  appearance:none;-webkit-appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg width='12' height='8' viewBox='0 0 12 8' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1L6 7L11 1' stroke='rgba(26,24,16,0.4)' stroke-width='1.5' stroke-linecap='round'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 14px center;
}
.booking-select:focus{border-color:var(--gold-b);box-shadow:0 0 0 3px rgba(201,168,76,.1)}
.booking-row{display:flex;gap:10px}
.booking-row > *{flex:1;min-width:0}
.booking-divider{height:1px;background:var(--border-soft);margin:18px 0}
.booking-nights-preview{
  display:flex;align-items:center;justify-content:space-between;
  font-size:12.5px;color:var(--ink-soft);padding:10px 0;
  border-top:1px solid var(--border-soft);margin-top:12px;
}
.booking-nights-preview .nights-val{color:var(--gold-l);font-weight:500}
/*  Unit selector  */
.unit-selector{margin-bottom:16px;padding-bottom:16px;border-bottom:1px solid var(--border-soft)}
.unit-selector-label{font-size:10px;font-weight:500;letter-spacing:2.5px;text-transform:uppercase;color:var(--ink-soft);margin-bottom:8px}
.unit-option{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;border-radius:var(--rd);border:1.5px solid var(--border);cursor:pointer;transition:border-color .2s,background .2s,box-shadow .2s;background:var(--surface);margin-bottom:6px}
.unit-option:last-of-type{margin-bottom:0}
.unit-option:hover{border-color:var(--gold-b);background:rgba(201,168,76,.05)}
.unit-option.selected{border-color:var(--gold);background:var(--gold-d);box-shadow:0 0 0 3px rgba(201,168,76,.08)}
.unit-option-left{display:flex;flex-direction:column;gap:2px}
.unit-option-label{font-size:13px;color:var(--ink-mid)}
.unit-option.selected .unit-option-label{color:var(--ink);font-weight:500}
.unit-option-beds{font-size:11px;color:var(--ink-soft)}
.unit-option-price{font-size:13px;color:var(--gold-l);font-weight:500;white-space:nowrap}
.unit-check{width:16px;height:16px;border-radius:50%;border:1.5px solid var(--border);display:flex;align-items:center;justify-content:center;margin-right:10px;flex-shrink:0;transition:all .2s;color:transparent;background:transparent}
.unit-option.selected .unit-check{border-color:var(--gold);background:var(--gold);color:#fff}
/*  Booking summary rows  */
.booking-summary-block{padding:10px 0;border-top:1px solid var(--border-soft);margin-top:12px;display:flex;flex-direction:column;gap:5px}
.bsb-row{display:flex;align-items:center;justify-content:space-between;font-size:12.5px;color:var(--ink-soft)}
.bsb-val{color:var(--gold-l);font-weight:500}
.bsb-total{font-size:13.5px;font-weight:600;color:var(--ink);padding-top:4px;border-top:1px solid var(--border-soft);margin-top:2px}
.bsb-total-val{font-family:var(--num);font-size:15px;color:var(--gold-l)}
.pcta-wa-booking{
  display:flex;align-items:center;justify-content:center;gap:10px;width:100%;
  background:var(--wa);color:#fff;font-size:15px;font-weight:500;
  padding:15px;border-radius:50px;cursor:pointer;
  transition:transform .2s,box-shadow .2s;border:none;
  position:relative;overflow:hidden;margin-top:16px;
  font-family:var(--body);
}
.pcta-wa-booking::before{content:'';position:absolute;inset:-4px;border-radius:50px;border:1.5px solid rgba(37,211,102,.25);animation:spin-slow 8s linear infinite}
.pcta-wa-booking:hover{transform:translateY(-2px);box-shadow:0 14px 36px var(--wa-glow)}
.pcta-wa-booking:disabled{opacity:.45;cursor:not-allowed;transform:none;box-shadow:none}
.btn-back{
  display:inline-flex;align-items:center;gap:8px;
  font-size:13px;color:var(--ink-soft);cursor:pointer;padding:14px 0;transition:color .2s;
}
.btn-back:hover{color:var(--ink)}
/*  PLATFORM RATINGS (replaces reviews)  */
.platform-ratings{margin-top:36px;padding-top:28px;border-top:1px solid var(--border-soft)}
.platform-ratings-head{font-family:var(--disp);font-size:22px;font-weight:400;margin-bottom:20px;color:var(--ink)}
.platform-tabs{display:flex;gap:14px;flex-wrap:wrap}
.platform-tab{
  flex:1;min-width:200px;
  padding:20px 22px;border-radius:var(--rd2);
  border:1.5px solid var(--border);background:var(--white);
  transition:border-color .25s,box-shadow .25s,transform .25s;
  cursor:default;
}
.platform-tab:hover{border-color:var(--gold-b);box-shadow:0 6px 28px rgba(26,24,16,.08);transform:translateY(-2px)}
.platform-tab-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}
.platform-tab-logo{display:flex;align-items:center;gap:9px;font-size:13px;font-weight:500;color:var(--ink)}
.platform-tab-logo svg{flex-shrink:0}
.platform-score-wrap{display:flex;align-items:baseline;gap:4px}
.platform-score{font-family:var(--num);font-size:38px;font-weight:400;line-height:1;color:var(--ink)}
.platform-score-denom{font-size:14px;color:var(--ink-soft);font-weight:300}
.platform-bar-wrap{margin-top:12px}
.platform-bar-track{
  height:5px;border-radius:3px;background:var(--surface2);overflow:hidden;
}
.platform-bar-fill{
  height:100%;border-radius:3px;
  background:linear-gradient(to right,var(--gold-l),var(--gold));
  transition:width 1.2s cubic-bezier(.25,.46,.45,.94);
}
.platform-tab-footnote{font-size:11px;color:var(--ink-soft);margin-top:10px;line-height:1.5}
.platform-combined{
  margin-top:14px;padding:14px 18px;
  background:var(--surface);border-radius:var(--rd);
  border:1px solid var(--border-soft);
  display:flex;align-items:center;justify-content:space-between;
  flex-wrap:wrap;gap:8px;
}
.platform-combined-label{font-size:12px;color:var(--ink-mid);letter-spacing:.5px}
.platform-combined-score{font-family:var(--num);font-size:20px;color:var(--gold-l);font-weight:400}
.platform-combined-stars{display:flex;gap:2px;color:var(--gold)}

/*  GALLERY MODAL  */
.modal-overlay{
  position:fixed;inset:0;z-index:2000;
  background:rgba(4,4,4,.96);
  display:flex;align-items:center;justify-content:center;
  opacity:0;pointer-events:none;transition:opacity .3s ease;
}
.modal-overlay.open{opacity:1;pointer-events:all}
.modal-close{
  position:absolute;top:20px;right:24px;
  width:40px;height:40px;border-radius:50%;
  background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.2);
  color:#fff;font-size:18px;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  transition:background .2s;z-index:10;
}
.modal-close:hover{background:rgba(255,255,255,.2)}
.modal-img{max-width:92vw;max-height:90vh;object-fit:contain;border-radius:8px}
.modal-nav{
  position:absolute;top:50%;transform:translateY(-50%);
  width:48px;height:48px;border-radius:50%;
  background:rgba(255,255,255,.5);border:1.5px solid rgba(255,255,255,.65);
  color:#fff;font-size:24px;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  transition:background .2s;z-index:10;
  box-shadow:0 2px 16px rgba(0,0,0,.35);
}
.modal-nav:hover{background:rgba(201,168,76,.3);border-color:var(--gold-b)}
.modal-prev{left:20px}.modal-next{right:20px}
.modal-counter{position:absolute;bottom:16px;left:50%;transform:translateX(-50%);font-size:12px;color:rgba(255,255,255,.5);letter-spacing:2px}

/*  TERMS MODAL  */
.terms-box{
  background:var(--white);border:1px solid var(--border);border-radius:var(--rd2);
  max-width:640px;width:90%;padding:44px;max-height:84vh;overflow-y:auto;position:relative;
  animation:scaleIn .3s ease;
}
.terms-box h2{font-family:var(--disp);font-size:36px;font-weight:300;margin-bottom:8px;color:var(--ink)}
.terms-box h2 em{font-style:italic;color:var(--gold-l)}
.terms-box h3{font-size:13px;font-weight:600;color:var(--ink);margin:20px 0 6px}
.terms-box p{font-size:13px;color:var(--ink-mid);line-height:1.7;font-weight:300}
/* The close button inside terms modal needs dark treatment */
.terms-box .modal-close{background:var(--surface);border-color:var(--border);color:var(--ink)}
.terms-box .modal-close:hover{background:var(--surface2)}

/*  READ MORE MODAL  */
.story-box{
  background:var(--white);border:1px solid var(--border);border-radius:var(--rd2);
  max-width:640px;width:90%;padding:44px;max-height:84vh;overflow-y:auto;position:relative;
  animation:scaleIn .3s ease;
}
.story-box h2{font-family:var(--disp);font-size:36px;font-weight:300;margin-bottom:8px;color:var(--ink)}
.story-box h2 em{font-style:italic;color:var(--gold-l)}
.story-box p{font-size:14px;color:var(--ink-mid);line-height:1.8;font-weight:300;margin-bottom:14px}

/*  RESPONSIVE  */
@media(max-width:1100px){
  .sv-hero__content{padding:124px 40px 136px 88px}
  .sv-hero__bottom{padding:0 40px 28px 88px}
}
/* Mobile gallery view-all button, hidden by default, shown on mobile */
.gallery-view-all-mobile{
  display:none;
  position:absolute;bottom:16px;right:16px;
  align-items:center;gap:8px;
  background:rgba(8,8,8,.75);backdrop-filter:blur(10px);
  border:1px solid rgba(255,255,255,.2);
  color:var(--cream);font-size:12px;font-weight:500;letter-spacing:.5px;
  padding:9px 18px;border-radius:50px;cursor:pointer;
  transition:background .2s,border-color .2s;
}
.gallery-view-all-mobile:hover{background:rgba(201,168,76,.2);border-color:var(--gold-b);color:var(--gold-l)}
.gallery-view-all-mobile svg{flex-shrink:0}

@media(max-width:900px){
  .nav-center{display:none}
  .ham-btn{display:flex}
  .social-side{
    display:flex;
    left:auto;
    right:14px;
    top:50%;
    bottom:auto;
    transform:translateY(-50%);
    flex-direction:column;
    align-items:flex-end;
    gap:6px;
  }
  .social-divider-line{display:none}
  .props-row,.stays-grid{grid-template-columns:repeat(2,1fr)}
  .footer-grid{grid-template-columns:1fr 1fr;gap:32px}
  #about{grid-template-columns:1fr;gap:48px}
  .about-float-card{left:auto;right:-16px}
  .prop-detail{grid-template-columns:1fr;gap:32px}
  .prop-cta-card{position:static}
  /* Tablet gallery */
  .prop-gallery-6{grid-template-columns:1fr 1fr;grid-template-rows:260px 200px;height:auto}
  .gallery-main{grid-row:1/2;grid-column:1/3}
  .gallery-thumb:nth-child(n+4){display:none}
  .sv-hero__content{padding:118px 32px 150px}
  .sv-hero__bottom{padding:0 32px 24px}
}
@media(max-width:640px){
  #hero{min-height:90dvh}
  #header{padding:14px 20px}
  #header.scrolled,#header.on-light{padding:12px 20px}
  .sv-hero__content{
    padding:76px 20px 86px;
    max-width:100%;align-items:flex-start;
  }
  .sv-hero__headline{font-size:clamp(2.1rem,9.2vw,3.85rem);line-height:.92}
  .sv-hero__sub{max-width:100%;font-size:.94rem}
  .sv-hero__ctas{gap:10px}
  .sv-hero__cta-primary,.sv-hero__cta-secondary{
    min-height:44px;padding:11px 20px;font-size:.84rem;
  }
  .sv-hero__bottom{
    flex-direction:column;align-items:flex-start;gap:12px;
    padding:0 20px 20px;
  }
  .sv-stats{width:100%;justify-content:space-between}
  .sv-stat{flex:1;padding-right:0;text-align:center}
  .sv-stat + .sv-stat{padding-left:0}
  .sv-stat__num{font-size:1.24rem}
  .sv-stat__label{font-size:.62rem}
  .sv-hero__prompt,.sv-hero__line{display:none}
  #properties,.stays-grid-wrap{padding:60px 20px}
  #properties{padding:60px 20px}
  .props-row,.stays-grid{grid-template-columns:1fr;padding:36px 20px}
  #towns{padding:60px 0 60px 20px}
  #how,#cta-section{padding:70px 20px}
  #about{padding:70px 20px}
  .footer-grid{grid-template-columns:1fr 1fr;gap:24px 32px}
  .footer-grid > div:first-child{grid-column:1 / -1}
  #footer{padding:44px 20px 28px}
  .page-hero{padding:44px 20px}
  .stays-filters{padding:20px}
  .prop-detail{padding:32px 20px}
  /* Mobile gallery, one photo, no grid, "See all photos" button */
  .prop-gallery-6{display:block;height:auto;padding-top:80px;position:relative}
  .gallery-main{display:block;width:100%;height:280px;position:relative}
  .gallery-thumb{display:none !important}
  .gallery-count{display:none}
  .gallery-view-all-mobile{display:flex !important}
  .cta-watermark{font-size:clamp(40px,18vw,120px)}
  /* Booking form responsive */
  .booking-row{flex-direction:column !important;gap:10px !important}
  .booking-row > *{width:100% !important}
  /* Stats bar wraps to 22 on mobile */
}
/* Social sidebar takes over above 900px, hide mobile row */
@media(min-width:901px){.mobile-socials{display:none}}
