:root{
  --sand-50:#FBF8F2;
  --sand-100:#F4EEE3;
  --sand-200:#E8DEC9;
  --clay:#C2784A;
  --clay-deep:#A35E36;
  --clay-soft:rgba(194,120,74,.12);
  --sage:#7E8E76;
  --sage-deep:#5D6E55;
  --ink:#1F1B17;
  --ink-soft:#4A433C;
  --ink-mute:#7A7269;
  --line:rgba(31,27,23,.10);
  --line-strong:rgba(31,27,23,.20);
  --whats:#25D366;
  --whats-deep:#1FB855;
  --shadow-sm: 0 4px 14px rgba(31,27,23,.06);
  --shadow-md: 0 18px 40px -12px rgba(31,27,23,.18);
  --shadow-lg: 0 30px 60px -20px rgba(31,27,23,.25);
  --radius-sm: 6px;
  --radius-md: 14px;
  --radius-lg: 22px;
  --serif: "Cormorant Garamond", "Times New Roman", serif;
  --sans: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
  --ease: cubic-bezier(.22,.61,.36,1);
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  font-family:var(--sans);
  color:var(--ink);
  background:var(--sand-50);
  font-size:16px;line-height:1.6;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
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}
::selection{background:var(--clay);color:#fff}

/* Visible focus for keyboard users on every interactive surface */
:focus{outline:none}
:focus-visible{
  outline:2px solid var(--clay);
  outline-offset:3px;
  border-radius:4px;
}
.cta:focus-visible,
.lang-toggle button:focus-visible,
.gallery-tab:focus-visible{
  outline-offset:4px;
}

h1,h2,h3,h4{font-family:var(--serif);font-weight:500;letter-spacing:.005em;color:var(--ink)}
h1{font-size:clamp(3.2rem,7vw,6rem);line-height:1.02}
h2{font-size:clamp(2.2rem,4.2vw,3.6rem);line-height:1.08}
h3{font-size:clamp(1.5rem,2.4vw,2rem);line-height:1.2}
.eyebrow{
  font-family:var(--sans);font-size:11px;letter-spacing:.32em;text-transform:uppercase;
  color:var(--clay-deep);font-weight:500;
}

.container{max-width:1280px;margin:0 auto;padding:0 28px}
section{padding:clamp(80px,10vw,140px) 0;position:relative}

/* ---------- Navigation ---------- */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:100;
  padding:18px 0;
  transition:all .4s var(--ease);
  background:transparent;
}
.nav.scrolled{
  background:rgba(251,248,242,.88);
  backdrop-filter:blur(18px) saturate(140%);
  -webkit-backdrop-filter:blur(18px) saturate(140%);
  border-bottom:1px solid var(--line);
  padding:10px 0;
}
.nav-inner{
  max-width:1280px;margin:0 auto;padding:0 28px;
  display:flex;align-items:center;justify-content:space-between;gap:24px;
}
.brand{
  display:flex;align-items:center;gap:14px;
  transition:transform .4s var(--ease);
}
.brand:hover{transform:scale(1.02)}
.brand img{
  height:64px;width:auto;
  filter:brightness(0) invert(1) drop-shadow(0 2px 8px rgba(0,0,0,.25));
  transition:filter .4s var(--ease), height .4s var(--ease);
}
.nav.scrolled .brand img{
  filter:none;
  height:54px;
}

.nav-links{display:flex;gap:30px;align-items:center}
.nav-links a{
  font-size:13px;font-weight:400;color:#fff;letter-spacing:.04em;
  position:relative;padding:6px 0;
  transition:color .3s var(--ease);
}
.nav.scrolled .nav-links a{color:var(--ink-soft)}
.nav-links a::after{
  content:"";position:absolute;left:0;right:0;bottom:0;height:1px;
  background:currentColor;transform:scaleX(0);transform-origin:right;
  transition:transform .4s var(--ease);
}
.nav-links a:hover::after{transform:scaleX(1);transform-origin:left}

.nav-actions{display:flex;align-items:center;gap:14px}

/* Language toggle */
.lang-toggle{
  display:flex;align-items:center;
  border:1px solid rgba(255,255,255,.4);
  border-radius:999px;padding:3px;
  transition:border-color .4s var(--ease);
}
.nav.scrolled .lang-toggle{border-color:var(--line-strong)}
.lang-toggle button{
  font-size:11px;font-weight:600;letter-spacing:.1em;
  padding:5px 11px;border-radius:999px;
  color:#fff;opacity:.6;
  transition:all .3s var(--ease);
}
.nav.scrolled .lang-toggle button{color:var(--ink)}
.lang-toggle button.active{
  background:#fff;color:var(--ink);opacity:1;
}
.nav.scrolled .lang-toggle button.active{
  background:var(--ink);color:#fff;
}

/* ---------- CTA Buttons (glass pill with live dot) ---------- */
.cta{
  display:inline-flex;align-items:center;gap:14px;
  padding:14px 26px;
  background:rgba(31,27,23,.05);
  backdrop-filter:blur(14px) saturate(140%);
  -webkit-backdrop-filter:blur(14px) saturate(140%);
  border:1px solid rgba(31,27,23,.22);
  border-radius:999px;
  color:var(--ink);
  font-family:var(--sans);
  font-size:11px;font-weight:500;letter-spacing:.26em;text-transform:uppercase;
  line-height:1;
  text-decoration:none;cursor:pointer;
  transition:background .4s var(--ease), border-color .4s var(--ease), color .4s var(--ease), transform .4s var(--ease);
  white-space:nowrap;
}
.cta:hover{
  background:rgba(31,27,23,.10);
  border-color:var(--ink);
  transform:translateY(-1px);
}

/* Pulsing dot — signals "live availability" */
.cta__dot{
  width:6px;height:6px;border-radius:50%;
  background:var(--clay);flex-shrink:0;
  box-shadow:0 0 0 0 rgba(194,120,74,.6);
  animation:cta-pulse 2.4s ease-in-out infinite;
}
@keyframes cta-pulse{
  0%,100%{box-shadow:0 0 0 0 rgba(194,120,74,.55)}
  50%{box-shadow:0 0 0 7px rgba(194,120,74,0)}
}

/* WhatsApp icon variant of the dot */
.cta__icon{
  display:inline-flex;width:14px;height:14px;align-items:center;justify-content:center;
  flex-shrink:0;
}
.cta__icon svg{width:100%;height:100%;fill:currentColor;display:block}

/* Arrow */
.cta__arrow{
  display:inline-flex;align-items:center;justify-content:center;
  font-size:14px;line-height:1;font-weight:400;
  transition:transform .45s var(--ease);
}
.cta:hover .cta__arrow{transform:translateX(5px)}

/* ---- Variants ---- */
/* Light glass — for use over dark/photo backgrounds */
.cta--light{
  background:rgba(255,255,255,.14);
  backdrop-filter:blur(14px) saturate(140%);
  -webkit-backdrop-filter:blur(14px) saturate(140%);
  border-color:rgba(255,255,255,.45);
  color:#fff;
}
.cta--light:hover{
  background:rgba(255,255,255,.24);
  border-color:#fff;
}

/* Solid ink — for max emphasis */
.cta--ink{
  background:var(--ink);color:#fff;
  border-color:var(--ink);
  backdrop-filter:none;-webkit-backdrop-filter:none;
}
.cta--ink:hover{background:#000;border-color:#000}
.cta--ink .cta__dot{background:#fff;box-shadow:0 0 0 0 rgba(255,255,255,.6);animation-name:cta-pulse-light}
@keyframes cta-pulse-light{
  0%,100%{box-shadow:0 0 0 0 rgba(255,255,255,.55)}
  50%{box-shadow:0 0 0 7px rgba(255,255,255,0)}
}

/* Clay — accent variant */
.cta--clay{
  background:var(--clay);color:#fff;border-color:var(--clay);
  backdrop-filter:none;-webkit-backdrop-filter:none;
}
.cta--clay:hover{background:var(--clay-deep);border-color:var(--clay-deep)}
.cta--clay .cta__dot{background:#fff;animation-name:cta-pulse-light}

/* WhatsApp — green tint */
.cta--whats{
  background:rgba(37,211,102,.14);
  border-color:rgba(37,211,102,.55);
  color:var(--whats-deep);
}
.cta--whats:hover{
  background:rgba(37,211,102,.24);
  border-color:var(--whats);
  color:#0E7C39;
}
.cta--whats .cta__dot{background:var(--whats);animation-name:cta-pulse-green}
@keyframes cta-pulse-green{
  0%,100%{box-shadow:0 0 0 0 rgba(37,211,102,.5)}
  50%{box-shadow:0 0 0 7px rgba(37,211,102,0)}
}

/* Solid WhatsApp — for use over light backgrounds where extra contrast helps */
.cta--whats-solid{
  background:var(--whats);color:#fff;border-color:var(--whats);
  backdrop-filter:none;-webkit-backdrop-filter:none;
}
.cta--whats-solid:hover{background:var(--whats-deep);border-color:var(--whats-deep)}
.cta--whats-solid .cta__dot{background:#fff;animation-name:cta-pulse-light}

/* Sizes */
.cta--sm{padding:10px 18px;font-size:10px;letter-spacing:.22em;gap:10px}
.cta--sm .cta__dot{width:5px;height:5px}
.cta--sm .cta__arrow{font-size:12px}
.cta--lg{padding:18px 32px;font-size:12px;gap:16px}
.cta--lg .cta__dot{width:7px;height:7px}
.cta--lg .cta__arrow{font-size:16px}

/* Nav button — adapts to scroll state */
.nav:not(.scrolled) .nav-actions .cta{
  background:rgba(255,255,255,.14);
  border-color:rgba(255,255,255,.5);
  color:#fff;
}
.nav:not(.scrolled) .nav-actions .cta:hover{
  background:rgba(255,255,255,.24);border-color:#fff;
}

.menu-toggle{display:none;width:40px;height:40px;align-items:center;justify-content:center;color:#fff}
.nav.scrolled .menu-toggle{color:var(--ink)}

/* ---------- Hero ---------- */
.hero{
  height:100vh;min-height:680px;
  position:relative;overflow:hidden;
  display:flex;align-items:flex-end;
  color:#fff;
  padding-bottom:90px;
}
.hero-bg{position:absolute;inset:0;z-index:1}
.hero-slide{position:absolute;inset:0;opacity:0;transition:opacity 1.6s var(--ease)}
.hero-slide.active{opacity:1}
.hero-slide img{width:100%;height:100%;object-fit:cover;transform:scale(1.05);will-change:transform}
.hero-slide.active img{animation:kenBurns 14s ease-in-out infinite}
@keyframes kenBurns{
  0%  {transform:scale(1.05) translate(0,0)}
  50% {transform:scale(1.18) translate(-2%,-1.5%)}
  100%{transform:scale(1.05) translate(0,0)}
}

/* Cursor-follow spotlight over the hero photo */
.hero-spotlight{
  position:absolute;inset:0;z-index:2;
  background:radial-gradient(circle 340px at var(--mx,50%) var(--my,50%), rgba(255,255,255,.12), transparent 65%);
  pointer-events:none;
  opacity:0;
  transition:opacity .4s var(--ease);
  mix-blend-mode:soft-light;
}
.hero:hover .hero-spotlight{opacity:1}

.hero-overlay{
  position:absolute;inset:0;z-index:2;
  background:
    linear-gradient(to bottom, rgba(31,27,23,.30) 0%, rgba(31,27,23,0) 30%, rgba(31,27,23,0) 50%, rgba(31,27,23,.55) 100%),
    linear-gradient(to right, rgba(31,27,23,.35) 0%, rgba(31,27,23,0) 60%);
}
.hero-content{position:relative;z-index:3;max-width:1280px;margin:0 auto;padding:0 28px;width:100%}
@media (min-width:961px){
  .hero-content{padding-left:100px}
}
.hero-eyebrow{
  color:#fff;opacity:.85;
  font-size:11px;letter-spacing:.28em;text-transform:uppercase;font-weight:400;
  margin-bottom:28px;display:flex;align-items:center;gap:14px;flex-wrap:wrap;
}
.hero-eyebrow::before{content:"";width:42px;height:1px;background:#fff;opacity:.7;flex-shrink:0}
.hero h1{
  color:#fff;font-style:italic;font-weight:400;
  font-size:clamp(2.6rem, 5.2vw, 4.8rem);
  line-height:1.05;
  margin-bottom:22px;
  text-shadow:0 2px 30px rgba(0,0,0,.25);
  max-width:18ch;
  overflow-wrap:break-word;
  hyphens:auto;
}
@media (max-width:900px){
  .hero h1{font-size:clamp(2.2rem, 7vw, 3.6rem);max-width:20ch}
}
@media (max-width:560px){
  .hero h1{font-size:clamp(2rem, 9vw, 2.8rem);line-height:1.08;max-width:none}
  .hero-eyebrow{font-size:10px;letter-spacing:.24em;margin-bottom:20px}
  .hero-eyebrow::before{width:28px}
}
.hero p.tagline{
  font-size:clamp(1.05rem,1.5vw,1.3rem);font-weight:300;
  max-width:42ch;margin-bottom:42px;
  color:rgba(255,255,255,.92);
  text-shadow:0 1px 20px rgba(0,0,0,.2);
}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap;align-items:center}

.hero-dots{
  position:absolute;bottom:32px;left:50%;transform:translateX(-50%);
  z-index:4;display:flex;gap:10px;
}
.hero-dots button{width:32px;height:2px;background:rgba(255,255,255,.35);transition:all .4s var(--ease)}
.hero-dots button.active{background:#fff;width:48px}

.hero-scroll{
  position:absolute;bottom:32px;right:32px;z-index:4;
  color:#fff;font-size:10px;letter-spacing:.3em;text-transform:uppercase;
  writing-mode:vertical-rl;text-orientation:mixed;opacity:.7;
  display:flex;align-items:center;gap:14px;
}
.hero-scroll::after{
  content:"";width:1px;height:60px;background:#fff;
  animation:scrollLine 2s ease-in-out infinite;
}
@keyframes scrollLine{0%,100%{transform:scaleY(.3);transform-origin:top}50%{transform:scaleY(1);transform-origin:top}}

/* ---------- Social rail ---------- */
.social-rail{
  position:fixed;left:24px;top:50%;transform:translateY(-50%);
  z-index:90;display:flex;flex-direction:column;gap:14px;align-items:center;
}
.social-rail::before,.social-rail::after{
  content:"";width:1px;height:48px;background:rgba(255,255,255,.5);
}
.social-rail a{
  width:38px;height:38px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  color:#fff;background:rgba(255,255,255,.12);
  backdrop-filter:blur(8px);
  border:1px solid rgba(255,255,255,.2);
  transition:all .35s var(--ease);
}
.social-rail a:hover{transform:translateY(-2px) scale(1.06)}
.social-rail a.fb:hover{background:#1877F2;border-color:#1877F2}
.social-rail a.ig:hover{background:linear-gradient(45deg,#F58529,#DD2A7B,#8134AF);border-color:transparent}
.social-rail a.wa:hover{background:var(--whats);border-color:var(--whats)}
.social-rail svg{width:16px;height:16px;fill:currentColor}

/* ---------- Section title ---------- */
.section-head{text-align:center;max-width:720px;margin:0 auto 70px}
.section-head .eyebrow{margin-bottom:18px;display:inline-block}
.section-head h2{margin-bottom:18px;font-style:italic}
.section-head p{color:var(--ink-mute);font-size:1.05rem}

/* ---------- Stats ribbon ---------- */
.ribbon{background:var(--ink);color:var(--sand-100);padding:44px 0;overflow:hidden}
.ribbon-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:40px;text-align:center}
.ribbon-item{position:relative}
.ribbon-item:not(:last-child)::after{
  content:"";position:absolute;right:-20px;top:50%;transform:translateY(-50%);
  width:1px;height:36px;background:rgba(255,255,255,.12);
}
.ribbon-item .num{
  font-family:var(--serif);font-size:3rem;color:#fff;font-style:italic;line-height:1;margin-bottom:8px;
  font-variant-numeric:tabular-nums;
  display:inline-block;
}
.ribbon-item .num .suffix{font-size:.55em;font-style:normal;margin-left:2px;opacity:.85}
.ribbon-item .num .unit{font-size:.45em;font-style:normal;margin-left:6px;opacity:.85;letter-spacing:.04em}
.ribbon-item .lbl{font-size:11px;letter-spacing:.3em;text-transform:uppercase;opacity:.65}

/* ---------- Stay ---------- */
.stay{background:var(--sand-100)}
.stay-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:80px;align-items:center}
.stay-text .eyebrow{margin-bottom:20px;display:inline-block}
.stay-text h2{margin-bottom:24px;font-style:italic}
.stay-text p{color:var(--ink-soft);margin-bottom:18px;font-size:1.02rem}
.stay-amenities{
  display:grid;grid-template-columns:1fr 1fr;gap:14px 28px;
  margin:32px 0 36px;padding:28px 0;
  border-top:1px solid var(--line);border-bottom:1px solid var(--line);
}
.stay-amenities li{
  list-style:none;font-size:14px;color:var(--ink-soft);
  display:flex;align-items:center;gap:10px;
}
.stay-amenities li::before{content:"";width:5px;height:5px;border-radius:50%;background:var(--clay);flex-shrink:0}

.stay-actions{display:flex;gap:12px;flex-wrap:wrap}

.stay-images{display:grid;grid-template-columns:1fr 1fr;grid-template-rows:240px 200px;gap:14px}
.stay-images figure{overflow:hidden;border-radius:var(--radius-md);position:relative;isolation:isolate}
.stay-images figure:nth-child(1){grid-row:1 / span 2;height:auto}
.stay-images figure img{width:100%;height:100%;object-fit:cover;transition:transform 1s var(--ease)}
.stay-images figure:hover img{transform:scale(1.08)}

/* Diagonal gleam sweep on hover — reusable across image cards */
.stay-images figure::before,
.wellness-image::before,
.masonry figure::before{
  content:"";
  position:absolute;top:0;left:-75%;
  width:55%;height:100%;
  background:linear-gradient(115deg, transparent 0%, rgba(255,255,255,.28) 50%, transparent 100%);
  transform:skewX(-20deg);
  transition:left .9s var(--ease);
  pointer-events:none;
  z-index:2;
}
.stay-images figure:hover::before,
.wellness-image:hover::before,
.masonry figure:hover::before{left:135%}

/* ---------- Video reel ---------- */
.reel{
  position:relative;height:78vh;min-height:520px;
  overflow:hidden;background:#000;
  padding:0;
}
.reel video{
  position:absolute;inset:0;width:100%;height:100%;
  object-fit:cover;display:block;
}
.reel-overlay{
  position:absolute;inset:0;
  background:
    linear-gradient(to bottom, rgba(0,0,0,.25) 0%, rgba(0,0,0,0) 35%, rgba(0,0,0,.5) 100%),
    linear-gradient(to right, rgba(0,0,0,.25), rgba(0,0,0,0) 50%);
}
.reel-frame{
  position:absolute;inset:32px;
  border:1px solid rgba(255,255,255,.18);
  pointer-events:none;
}
.reel-content{
  position:relative;z-index:2;height:100%;
  max-width:1280px;margin:0 auto;padding:0 64px;
  display:flex;flex-direction:column;justify-content:flex-end;
  color:#fff;
  padding-bottom:80px;
}
.reel-content .eyebrow{color:rgba(255,255,255,.85);margin-bottom:16px;display:inline-flex;align-items:center;gap:14px}
.reel-content .eyebrow::before{content:"";width:36px;height:1px;background:#fff;opacity:.7}
.reel-content h2{
  color:#fff;font-style:italic;font-weight:400;margin-bottom:10px;
  text-shadow:0 2px 30px rgba(0,0,0,.3);max-width:18ch;
}
.reel-content p{
  color:rgba(255,255,255,.85);max-width:38ch;font-size:1.05rem;
  text-shadow:0 1px 14px rgba(0,0,0,.3);margin:0;
}
.reel-mute{
  position:absolute;top:56px;right:56px;z-index:3;
  width:44px;height:44px;border-radius:50%;
  background:rgba(255,255,255,.12);
  backdrop-filter:blur(8px);
  border:1px solid rgba(255,255,255,.25);
  color:#fff;
  display:flex;align-items:center;justify-content:center;
  transition:all .3s var(--ease);
}
.reel-mute:hover{background:rgba(255,255,255,.22)}
.reel-mute svg{width:18px;height:18px;fill:currentColor}

/* ---------- Wellness ---------- */
.wellness{background:var(--sand-50);position:relative;overflow:hidden}
.wellness::before{
  content:"";position:absolute;top:-200px;right:-200px;width:500px;height:500px;
  background:radial-gradient(circle, rgba(126,142,118,.15), transparent 70%);pointer-events:none;
}
.wellness-grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center;position:relative}
.wellness-image{
  border-radius:var(--radius-lg);overflow:hidden;
  aspect-ratio:4/5;box-shadow:var(--shadow-lg);
  position:relative;isolation:isolate;
}
.wellness-image img{width:100%;height:100%;object-fit:cover;transition:transform 1.2s var(--ease)}
.wellness-image:hover img{transform:scale(1.05)}
.wellness-text .eyebrow{color:var(--sage-deep);margin-bottom:20px;display:inline-block}
.wellness-text h2{margin-bottom:24px;font-style:italic}
.wellness-text p{color:var(--ink-soft);margin-bottom:18px;font-size:1.02rem;max-width:46ch}

.wellness-cards{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin:36px 0}
.wellness-card{
  background:#fff;padding:24px;border-radius:var(--radius-md);
  border:1px solid var(--line);
  transition:transform .4s var(--ease), box-shadow .4s var(--ease);
  transform-style:preserve-3d;
  will-change:transform;
}
.wellness-card:hover{box-shadow:var(--shadow-md)}
.wellness-card h4{font-family:var(--sans);font-size:14px;font-weight:600;margin-bottom:6px;letter-spacing:.02em}
.wellness-card p{font-size:13px;color:var(--ink-mute);margin:0;line-height:1.5}

/* ---------- Gallery ---------- */
.gallery-section{background:var(--sand-100)}
.gallery-tabs{display:flex;gap:6px;justify-content:center;margin-bottom:48px;flex-wrap:wrap}
.gallery-tab{
  padding:10px 22px;border-radius:999px;
  font-size:12px;letter-spacing:.1em;text-transform:uppercase;font-weight:500;
  color:var(--ink-mute);transition:all .3s var(--ease);
}
.gallery-tab.active,
.gallery-tab[aria-pressed="true"]{background:var(--ink);color:#fff}
.gallery-tab:hover:not(.active){color:var(--ink)}

.masonry{columns:3;column-gap:14px}
.masonry figure{
  break-inside:avoid;margin-bottom:14px;
  border-radius:var(--radius-md);overflow:hidden;
  cursor:pointer;position:relative;
  isolation:isolate;
  transition:transform .5s var(--ease), box-shadow .5s var(--ease);
}
.masonry figure img{width:100%;height:auto;display:block;transition:transform 1.2s var(--ease), filter .5s var(--ease)}
.masonry figure:hover{
  transform:translateY(-6px) scale(1.015);
  box-shadow:0 24px 50px -14px rgba(194,120,74,.4);
}
.masonry figure:hover img{transform:scale(1.06);filter:brightness(.94) saturate(1.1)}
.masonry figure::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(to top, rgba(31,27,23,.4), transparent 50%);
  opacity:0;transition:opacity .4s var(--ease);
}
.masonry figure:hover::after{opacity:1}

.masonry.filter-exteriores figure[data-cat="interiores"]{display:none}
.masonry.filter-interiores figure[data-cat="exteriores"]{display:none}

/* ---------- Reviews ---------- */
.reviews{background:var(--sand-50)}
.reviews-rating{text-align:center;margin-bottom:60px}
.reviews-rating .stars{color:var(--clay);font-size:24px;letter-spacing:6px;margin-bottom:12px}
.reviews-rating .score{font-family:var(--serif);font-size:4rem;font-style:italic;line-height:1;color:var(--ink)}
.reviews-rating .score small{font-size:1.2rem;color:var(--ink-mute);font-style:normal}
.reviews-rating .meta{color:var(--ink-mute);font-size:13px;letter-spacing:.1em;text-transform:uppercase;margin-top:8px}

/* Auto-scrolling review marquee */
.reviews-track-wrap{
  overflow:hidden;position:relative;
  margin:0 -28px;
  -webkit-mask-image:linear-gradient(to right, transparent 0, black 6%, black 94%, transparent 100%);
          mask-image:linear-gradient(to right, transparent 0, black 6%, black 94%, transparent 100%);
}
.reviews-track{
  display:flex;gap:24px;
  width:max-content;
  animation:reviewsScroll 80s linear infinite;
  padding:24px 0;
}
.reviews-track-wrap:hover .reviews-track,
.reviews-track-wrap:focus-within .reviews-track{animation-play-state:paused}
@keyframes reviewsScroll{
  0%{transform:translateX(0)}
  100%{transform:translateX(-50%)}
}
.review{
  background:#fff;padding:36px 32px;border-radius:var(--radius-md);
  border:1px solid var(--line);position:relative;
  flex:0 0 380px;display:flex;flex-direction:column;
  min-height:240px;
}
.review::before{display:none}
.review-text{
  position:relative;
  font-family:var(--serif);font-size:1.1rem;font-style:italic;
  color:var(--ink-soft);line-height:1.55;margin:14px 0 22px;flex:1;
}
.review-author{
  font-size:12px;letter-spacing:.16em;text-transform:uppercase;
  color:var(--clay-deep);font-weight:500;
  display:flex;align-items:center;gap:10px;
}
.review-author small{
  color:var(--ink-mute);letter-spacing:.04em;text-transform:none;font-weight:400;
  font-size:11px;
}
.review-author::after{
  content:"";flex:1;height:1px;background:var(--line);margin-left:6px;
}
.review-source{
  position:absolute;top:24px;right:24px;
  font-size:9px;letter-spacing:.2em;text-transform:uppercase;
  color:var(--ink-mute);
}

/* ---------- Booking band ---------- */
.booking-band{
  background:linear-gradient(135deg, var(--ink) 0%, #2A241F 100%);
  color:#fff;padding:80px 0;position:relative;overflow:hidden;
}
.booking-band::before{
  content:"";position:absolute;top:-100px;right:-100px;width:400px;height:400px;
  background:radial-gradient(circle, rgba(194,120,74,.18), transparent 70%);pointer-events:none;
}
.booking-band-inner{
  max-width:980px;margin:0 auto;padding:0 28px;
  display:grid;grid-template-columns:1.4fr 1fr;gap:48px;align-items:center;position:relative;
}
.booking-band h2{color:#fff;font-style:italic;margin-bottom:16px}
.booking-band p{color:rgba(255,255,255,.75);margin-bottom:0}
.booking-band .actions{display:flex;flex-direction:column;gap:10px}
.booking-band .actions .cta{justify-content:center}
/* On dark background the ghost CTA needs to invert defaults */
.booking-band .cta--ghost{--color:#fff;--border:rgba(255,255,255,.45);--bg-hover:rgba(255,255,255,.1)}

/* ---------- Contact ---------- */
.contact{background:var(--sand-100)}
.contact-grid{display:grid;grid-template-columns:1fr 1.2fr;gap:60px;align-items:start}
.contact-card{
  background:#fff;padding:44px;border-radius:var(--radius-md);
  border:1px solid var(--line);
}
.contact-card h3{margin-bottom:18px;font-style:italic}
.contact-card p{color:var(--ink-soft);margin-bottom:28px;font-size:.97rem}
.contact-channels{display:flex;flex-direction:column;gap:10px;margin-bottom:32px}
.contact-channel{
  display:flex;align-items:center;gap:14px;
  padding:14px 18px;border-radius:var(--radius-sm);
  background:var(--sand-50);
  transition:all .3s var(--ease);
  border:1px solid transparent;
}
.contact-channel:hover{border-color:var(--line-strong);transform:translateX(4px)}
.contact-channel-icon{
  width:40px;height:40px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
}
.contact-channel-icon svg{width:18px;height:18px;fill:#fff}
.ic-wa{background:var(--whats)}
.ic-fb{background:#1877F2}
.ic-ig{background:linear-gradient(45deg,#F58529,#DD2A7B,#8134AF)}
.contact-channel-meta{flex:1}
.contact-channel-meta strong{display:block;font-size:14px;font-weight:500;color:var(--ink)}
.contact-channel-meta span{font-size:13px;color:var(--ink-mute)}
.contact-channel-arrow{color:var(--ink-mute);transition:transform .3s var(--ease)}
.contact-channel:hover .contact-channel-arrow{transform:translateX(4px);color:var(--clay)}

.contact-info{
  padding-top:28px;border-top:1px solid var(--line);
  display:grid;grid-template-columns:1fr 1fr;gap:18px;
}
.contact-info div small{font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-mute);display:block;margin-bottom:4px}
.contact-info div strong{font-size:14px;font-weight:500;color:var(--ink)}

.map-wrap{
  border-radius:var(--radius-md);overflow:hidden;
  border:1px solid var(--line);height:560px;
  box-shadow:var(--shadow-sm);
}
.map-wrap iframe{width:100%;height:100%;border:0;filter:grayscale(.15) contrast(1.05)}

/* ---------- Footer ---------- */
footer{background:var(--ink);color:var(--sand-200);padding:80px 0 32px}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:48px;margin-bottom:60px}
.footer-brand{display:flex;align-items:center;gap:14px;margin-bottom:18px}
.footer-brand img{height:54px;width:auto;filter:brightness(0) invert(1)}
.footer p{color:rgba(244,238,227,.6);font-size:14px;line-height:1.65;max-width:34ch}
.footer h4{font-family:var(--sans);font-size:11px;letter-spacing:.32em;text-transform:uppercase;color:#fff;margin-bottom:18px;font-weight:500}
.footer ul{list-style:none}
.footer ul li{margin-bottom:10px}
.footer ul a{font-size:14px;color:rgba(244,238,227,.7);transition:color .3s var(--ease)}
.footer ul a:hover{color:var(--clay)}
.footer-social{display:flex;gap:10px;margin-top:18px}
.footer-social a{
  width:38px;height:38px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  background:rgba(255,255,255,.08);
  transition:all .3s var(--ease);color:#fff;
}
.footer-social a svg{width:16px;height:16px;fill:currentColor}
.footer-social a.fb:hover{background:#1877F2}
.footer-social a.ig:hover{background:linear-gradient(45deg,#F58529,#DD2A7B,#8134AF)}
.footer-social a.wa:hover{background:var(--whats)}
.footer-bottom{
  padding-top:32px;border-top:1px solid rgba(255,255,255,.08);
  display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px;
  font-size:12px;color:rgba(244,238,227,.5);
}

/* ---------- Floating WhatsApp ---------- */
.wa-float{
  position:fixed;bottom:24px;right:24px;z-index:90;
  width:48px;height:48px;border-radius:50%;
  background:var(--whats);color:#fff;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 8px 24px rgba(37,211,102,.35);
  transition:all .35s var(--ease);
  animation:wapulse 3s ease-in-out infinite;
}
.wa-float:hover{transform:scale(1.08);background:var(--whats-deep)}
.wa-float svg{width:22px;height:22px;fill:currentColor}
@keyframes wapulse{
  0%,100%{box-shadow:0 8px 24px rgba(37,211,102,.35),0 0 0 0 rgba(37,211,102,.4)}
  50%{box-shadow:0 8px 24px rgba(37,211,102,.35),0 0 0 12px rgba(37,211,102,0)}
}

/* ---------- Reveal ---------- */
.reveal{opacity:0;transform:translateY(28px);transition:opacity 1s var(--ease),transform 1s var(--ease)}
.reveal.in{opacity:1;transform:translateY(0)}
.reveal-delay-1{transition-delay:.12s}
.reveal-delay-2{transition-delay:.24s}

/* Visually-hidden helper for SR-only text we want available to assistive tech */
.sr-only{
  position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;
  clip:rect(0 0 0 0);white-space:nowrap;border:0;
}

/* ---------- Responsive ---------- */
@media (max-width:960px){
  .nav-links{
    position:fixed;top:0;right:-100%;
    width:80%;max-width:340px;height:100vh;
    background:var(--sand-50);
    flex-direction:column;justify-content:center;
    padding:48px;gap:24px;
    transition:right .4s var(--ease);
    box-shadow:var(--shadow-lg);
  }
  .nav-links.open{right:0}
  .nav-links a{color:var(--ink) !important;font-size:18px;font-family:var(--serif);letter-spacing:.02em}
  .menu-toggle{display:flex}
  .nav-actions .cta{display:none}
  .social-rail{display:none}
  .brand img{height:54px}
  .nav.scrolled .brand img{height:46px}

  .stay-grid,.wellness-grid,.contact-grid,.booking-band-inner{grid-template-columns:1fr;gap:48px}
  .wellness-image{aspect-ratio:1/1;max-height:480px}
  .ribbon-grid{grid-template-columns:1fr 1fr;gap:32px}
  .ribbon-item:not(:last-child)::after{display:none}
  .review{flex:0 0 320px}
  .masonry{columns:2}
  .footer-grid{grid-template-columns:1fr 1fr;gap:32px}
  .map-wrap{height:380px}
  .stay-images{grid-template-columns:1fr;grid-template-rows:auto auto auto}
  .stay-images figure:nth-child(1){grid-row:auto;height:300px}
  .stay-images figure{height:240px}
  .hero{padding-bottom:120px;min-height:560px}
  .hero-scroll{display:none}
  .wellness-cards{grid-template-columns:1fr}
  .stay-amenities{grid-template-columns:1fr}
  .reel{height:60vh;min-height:380px}
  .reel-frame{inset:20px}
  .reel-content{padding:0 36px 56px}
  .reel-mute{top:36px;right:36px;width:38px;height:38px}
}
@media (max-width:560px){
  .container,.nav-inner{padding:0 20px}
  .masonry{columns:1}
  .footer-grid{grid-template-columns:1fr}
  .ribbon-grid{grid-template-columns:1fr 1fr;gap:24px}
  .ribbon-item .num{font-size:2rem}
  .gallery-tabs{flex-wrap:wrap}
  .contact-card{padding:28px}
  .review{padding:28px 24px}
  .wa-float{width:44px;height:44px;bottom:18px;right:18px}
  .wa-float svg{width:20px;height:20px}
  .brand img{height:46px}
  .nav.scrolled .brand img{height:40px}
}

/* ---------- Reduced motion ---------- */
@media (prefers-reduced-motion: reduce){
  *,
  *::before,
  *::after{
    animation-duration:.001ms !important;
    animation-iteration-count:1 !important;
    transition-duration:.001ms !important;
    scroll-behavior:auto !important;
  }
  .hero-slide img,
  .hero-slide.active img{transform:none;animation:none}
  .hero-spotlight{display:none}
  .reviews-track{animation:none;transform:none}
  .reveal{opacity:1;transform:none}
  .cta__dot,
  .wa-float{animation:none}
  .hero-scroll::after{animation:none;transform:scaleY(1)}
  .stay-images figure::before,
  .wellness-image::before,
