/* ============================================================
   Casa con Encanto — Marbella
   Sistema visual: lujo cálido mediterráneo
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,400;0,500;0,600;1,400;1,500&family=Manrope:wght@400;500;600;700&display=swap');

:root{
  /* Paleta cálida mediterránea */
  --bg:        #f6efe3;
  --bg-paper:  #fbf6ec;
  --bg-2:      #efe4d2;
  --ink:       #211c15;
  --ink-soft:  #5d544790;
  --ink-mid:   #6b6051;
  --line:      rgba(33,28,21,.13);
  --line-soft: rgba(33,28,21,.07);
  --terra:     #b9572f;   /* terracota */
  --terra-deep:#9c4623;
  --clay:      #a17a4d;
  --sage:      #6f7657;
  --gold:      #c08a3e;
  --dark:      #211d16;   /* sección oscura cálida */
  --dark-2:    #2c271d;
  --cream-on-dark:#f0e7d6;

  --maxw: 1280px;
  --gutter: clamp(20px, 5vw, 72px);
  --radius: 4px;
  --radius-lg: 10px;

  --serif: "Cormorant Garamond", Georgia, serif;
  --sans:  "Manrope", system-ui, sans-serif;

  --ease: cubic-bezier(.22,.61,.36,1);
}

*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body{
  margin:0;
  font-family:var(--sans);
  background:var(--bg);
  color:var(--ink);
  font-size:17px;
  line-height:1.65;
  font-weight:400;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{ display:block; max-width:100%; }
a{ color:inherit; text-decoration:none; }
button{ font-family:inherit; cursor:pointer; }

/* paper grain */
body::before{
  content:"";
  position:fixed; inset:0; z-index:0; pointer-events:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.35'/%3E%3C/svg%3E");
  mix-blend-mode:multiply; opacity:.04;
}

/* ---------- Layout helpers ---------- */
.wrap{ max-width:var(--maxw); margin:0 auto; padding-inline:var(--gutter); position:relative; z-index:1; }
.section{ padding-block:clamp(72px,9vw,140px); position:relative; }
.eyebrow{
  font-family:var(--sans);
  font-size:12px; font-weight:600; letter-spacing:.28em; text-transform:uppercase;
  color:var(--terra);
  display:inline-flex; align-items:center; gap:.7em; margin:0 0 22px;
}
.eyebrow::before{ content:""; width:26px; height:1px; background:var(--terra); display:inline-block; opacity:.6; }
.eyebrow.center{ justify-content:center; }
.eyebrow.center::after{ content:""; width:26px; height:1px; background:var(--terra); display:inline-block; opacity:.6; }

h1,h2,h3{ font-family:var(--serif); font-weight:500; line-height:1.04; letter-spacing:-.01em; margin:0; }
h2.display{ font-size:clamp(34px,5vw,68px); }
p.lead{ font-size:clamp(18px,1.6vw,22px); line-height:1.6; color:var(--ink-mid); max-width:54ch; }

/* reveal — visible by default; hidden state only when JS confirms the tab
   is compositing (rAF running) so captures / throttled tabs never blank out */
.reveal{ }
@media (prefers-reduced-motion: no-preference){
  html.anim .reveal{ opacity:0; transform:translateY(26px); transition:opacity 1s var(--ease), transform 1s var(--ease); }
  html.anim .reveal.in{ opacity:1; transform:none; }
  html.anim .reveal.d1{ transition-delay:.08s; }
  html.anim .reveal.d2{ transition-delay:.16s; }
  html.anim .reveal.d3{ transition-delay:.24s; }
  html.anim .reveal.d4{ transition-delay:.32s; }
}
@media (prefers-reduced-motion: reduce){
  html{ scroll-behavior:auto; }
}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex; align-items:center; gap:.6em;
  font-size:14px; font-weight:600; letter-spacing:.02em;
  padding:15px 26px; border-radius:100px; border:1px solid transparent;
  transition:all .4s var(--ease); position:relative;
}
.btn .arr{ transition:transform .4s var(--ease); }
.btn:hover .arr{ transform:translateX(4px); }
.btn-primary{ background:var(--terra); color:#fff; }
.btn-primary:hover{ background:var(--terra-deep); transform:translateY(-2px); box-shadow:0 12px 30px -12px rgba(155,70,35,.7); }
.btn-ghost{ border-color:var(--line); color:var(--ink); background:transparent; }
.btn-ghost:hover{ border-color:var(--ink); background:rgba(33,28,21,.04); }
.btn-light{ background:#fff; color:var(--ink); }
.btn-light:hover{ transform:translateY(-2px); box-shadow:0 14px 36px -16px rgba(0,0,0,.5); }
.btn-outline-light{ border-color:rgba(255,255,255,.5); color:#fff; }
.btn-outline-light:hover{ border-color:#fff; background:rgba(255,255,255,.1); }

/* ============================================================
   NAV
   ============================================================ */
.nav{
  position:fixed; top:0; left:0; right:0; z-index:50;
  display:flex; align-items:center; justify-content:space-between;
  padding:20px var(--gutter);
  transition:background .5s var(--ease), padding .5s var(--ease), box-shadow .5s var(--ease);
}
.nav.scrolled{
  background:rgba(246,239,227,.86); backdrop-filter:blur(14px) saturate(1.2);
  padding:13px var(--gutter); box-shadow:0 1px 0 var(--line-soft), 0 18px 40px -34px rgba(0,0,0,.5);
}
.brand{ display:flex; align-items:center; gap:12px; color:#fff; transition:color .5s var(--ease); }
.nav.scrolled .brand{ color:var(--ink); }
.brand .mark{ width:40px; height:40px; border-radius:10px; display:grid; place-items:center; flex:none; background:#fff; box-shadow:0 3px 10px -3px rgba(0,0,0,.3); overflow:hidden; }
.brand .mark img{ width:84%; height:84%; object-fit:contain; }
.brand .bname{ font-family:var(--serif); font-size:21px; font-weight:600; line-height:1; }
.brand .bsub{ font-size:10px; letter-spacing:.26em; text-transform:uppercase; opacity:.75; font-weight:600; }
.nav-links{ display:flex; align-items:center; gap:34px; }
.nav-links a{ color:#fff; font-size:14px; font-weight:500; letter-spacing:.01em; opacity:.92; transition:color .5s var(--ease), opacity .25s; position:relative; }
.nav.scrolled .nav-links a{ color:var(--ink); }
.nav-links a::after{ content:""; position:absolute; left:0; bottom:-6px; height:1px; width:0; background:currentColor; transition:width .35s var(--ease); }
.nav-links a:hover::after{ width:100%; }
.nav-links a:hover{ opacity:1; }
.nav-cta{ display:flex; align-items:center; gap:16px; }
.nav-menu-links{ display:flex; align-items:center; gap:34px; }
.menu-toggle{ display:none; background:none; border:none; color:inherit; }
@media (max-width:1000px){
  .nav-menu-links{ display:none; }
}

/* language switcher */
.lang{ position:relative; }
.lang-btn{ display:flex; align-items:center; gap:7px; font-size:13px; font-weight:600; color:#fff; background:transparent; border:1px solid rgba(255,255,255,.42); padding:9px 13px; border-radius:100px; transition:color .5s var(--ease), border-color .3s, background .3s; }
.lang-btn .globe{ opacity:.85; }
.lang-btn .caret{ opacity:.7; transition:transform .3s var(--ease); }
.lang.open .lang-btn .caret{ transform:rotate(180deg); }
.lang-btn:hover{ border-color:currentColor; }
.nav.scrolled .lang-btn{ color:var(--ink); border-color:var(--line); }
.lang-menu{ position:absolute; top:calc(100% + 10px); right:0; background:var(--bg-paper); border:1px solid var(--line); border-radius:12px; padding:6px; min-width:178px; box-shadow:0 26px 54px -26px rgba(0,0,0,.55); opacity:0; visibility:hidden; transform:translateY(-8px); transition:all .3s var(--ease); z-index:60; }
.lang.open .lang-menu{ opacity:1; visibility:visible; transform:none; }
.lang-menu button{ display:flex; align-items:center; gap:10px; width:100%; text-align:left; background:transparent; border:none; padding:10px 12px; border-radius:8px; font-size:14px; color:var(--ink); transition:background .2s; }
.lang-menu button:hover{ background:var(--bg-2); }
.lang-menu button.active{ color:var(--terra); font-weight:600; }
.lang-menu .lc{ font-size:11px; font-weight:700; letter-spacing:.04em; color:var(--terra); width:24px; flex:none; }

/* ============================================================
   HERO
   ============================================================ */
.hero{ position:relative; min-height:100svh; display:flex; align-items:flex-end; overflow:hidden; color:#fff; }
.hero-bg{ position:absolute; inset:0; z-index:0; background:#3a3228; }
.hero-bg img{ width:100%; height:100%; object-fit:cover; animation:kenburns 22s var(--ease) infinite alternate; }
.hero-bg video{ width:100%; height:100%; object-fit:cover; }
@keyframes kenburns{ from{ transform:scale(1.04); } to{ transform:scale(1.16) translate(-1.5%, -1.5%); } }
.hero::after{
  content:""; position:absolute; inset:0; z-index:1;
  background:linear-gradient(to top, rgba(20,16,10,.82) 0%, rgba(20,16,10,.28) 42%, rgba(20,16,10,.30) 100%);
}
.hero-inner{ position:relative; z-index:2; width:100%; padding-bottom:clamp(40px,7vw,90px); }
.hero .place{
  font-size:13px; letter-spacing:.26em; text-transform:uppercase; font-weight:600;
  display:flex; gap:14px; align-items:center; margin-bottom:26px; opacity:.92;
}
.hero .place span{ position:relative; padding-left:0; }
.hero .place .dot{ width:4px; height:4px; border-radius:50%; background:var(--terra); display:inline-block; }
.hero h1{ font-size:clamp(48px,8.5vw,124px); font-weight:500; line-height:.92; max-width:14ch; }
.hero h1 em{ font-style:italic; color:#f1d9b8; }
.hero-sub{ font-size:clamp(17px,1.5vw,21px); max-width:46ch; margin-top:26px; color:rgba(255,255,255,.86); line-height:1.55; }
.hero-actions{ display:flex; gap:14px; margin-top:38px; flex-wrap:wrap; }
.scrollcue{
  position:absolute; bottom:26px; left:50%; transform:translateX(-50%); z-index:3;
  display:flex; flex-direction:column; align-items:center; gap:9px; color:rgba(255,255,255,.7);
  font-size:11px; letter-spacing:.22em; text-transform:uppercase;
}
.scrollcue .line{ width:1px; height:42px; background:linear-gradient(rgba(255,255,255,.7), rgba(255,255,255,0)); animation:cue 2.2s ease-in-out infinite; transform-origin:top; }
@keyframes cue{ 0%,100%{ transform:scaleY(.4); opacity:.4; } 50%{ transform:scaleY(1); opacity:1; } }

/* facts ribbon */
.facts{
  position:relative; z-index:2;
  display:grid; grid-template-columns:repeat(5,1fr);
  border-top:1px solid rgba(255,255,255,.18);
}
.facts .fact{ padding:22px 8px 4px; }
.facts .fact .n{ font-family:var(--serif); font-size:clamp(26px,2.6vw,38px); font-weight:500; line-height:1; }
.facts .fact .l{ font-size:11px; letter-spacing:.2em; text-transform:uppercase; opacity:.78; margin-top:6px; }
@media (max-width:720px){
  .facts{ grid-template-columns:repeat(2,1fr); gap:0; }
  .facts .fact:nth-child(5){ grid-column:1 / -1; }
}

/* address strip */
.addr{
  background:var(--dark); color:var(--cream-on-dark);
  display:flex; align-items:center; justify-content:center; gap:14px; flex-wrap:wrap;
  padding:16px 20px; font-size:13.5px; letter-spacing:.02em;
}
.addr .sep{ width:4px; height:4px; border-radius:50%; background:var(--terra); }
.addr strong{ font-weight:600; }

/* ============================================================
   INTRO / STORY
   ============================================================ */
.story{ background:var(--bg-paper); }
.story-grid{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(40px,6vw,90px); align-items:center; }
.story-copy h2{ font-size:clamp(30px,4vw,52px); margin-bottom:24px; }
.story-copy .lead{ margin-bottom:30px; }
.tick-list{ list-style:none; margin:0 0 8px; padding:0; display:grid; gap:14px; }
.tick-list li{ display:flex; gap:14px; align-items:flex-start; font-size:16px; color:var(--ink-mid); }
.tick-list li .tk{ flex:none; width:22px; height:22px; border-radius:50%; border:1px solid var(--terra); color:var(--terra); display:grid; place-items:center; margin-top:2px; }
.story-media{ position:relative; }
.story-media .frame{ position:relative; border-radius:var(--radius-lg); overflow:hidden; aspect-ratio:4/5; background:var(--bg-2); }
.story-media .frame img{ width:100%; height:100%; object-fit:cover; }
.story-media .badge{
  position:absolute; left:-22px; bottom:34px; background:var(--bg-paper); color:var(--ink);
  padding:20px 26px; border-radius:var(--radius-lg); box-shadow:0 24px 60px -30px rgba(0,0,0,.4);
  max-width:230px; border:1px solid var(--line-soft);
}
.story-media .badge .q{ font-family:var(--serif); font-size:21px; font-style:italic; line-height:1.25; }
.story-media .badge .by{ font-size:12px; color:var(--terra); margin-top:10px; font-weight:600; letter-spacing:.04em; }
@media (max-width:860px){
  .story-grid{ grid-template-columns:1fr; }
  .story-media .badge{ left:auto; right:18px; }
}

/* ============================================================
   GALLERY
   ============================================================ */
.gallery{ background:var(--bg); }
.gallery-head{ display:flex; align-items:flex-end; justify-content:space-between; gap:30px; margin-bottom:44px; flex-wrap:wrap; }
.gallery-head h2{ font-size:clamp(30px,4.4vw,58px); max-width:16ch; }
.gallery-grid{ display:grid; grid-template-columns:repeat(12,1fr); grid-auto-rows:200px; gap:14px; }
.gtile{ position:relative; overflow:hidden; border-radius:var(--radius-lg); cursor:pointer; background:var(--bg-2); }
.gtile img{ width:100%; height:100%; object-fit:cover; transition:transform 1.1s var(--ease); }
.gtile:hover img{ transform:scale(1.07); }
.gtile::after{ content:""; position:absolute; inset:0; background:linear-gradient(to top, rgba(20,16,10,.55), transparent 55%); opacity:0; transition:opacity .4s; }
.gtile:hover::after{ opacity:1; }
.gtile .cap{ position:absolute; left:18px; bottom:16px; color:#fff; font-size:13px; letter-spacing:.04em; opacity:0; transform:translateY(8px); transition:all .4s var(--ease); z-index:2; display:flex; align-items:center; gap:8px; }
.gtile:hover .cap{ opacity:1; transform:none; }
.gtile .cap .ico{ width:26px; height:26px; border-radius:50%; background:rgba(255,255,255,.18); backdrop-filter:blur(4px); display:grid; place-items:center; }
/* tile spans */
.gtile.a{ grid-column:span 7; grid-row:span 2; }
.gtile.b{ grid-column:span 5; grid-row:span 2; }
.gtile.c{ grid-column:span 4; }
.gtile.d{ grid-column:span 4; }
.gtile.e{ grid-column:span 4; }
.gtile.f{ grid-column:span 5; grid-row:span 2; }
.gtile.g{ grid-column:span 7; grid-row:span 2; }
@media (max-width:860px){
  .gallery-grid{ grid-template-columns:repeat(2,1fr); grid-auto-rows:160px; }
  .gtile.a,.gtile.b,.gtile.c,.gtile.d,.gtile.e,.gtile.f,.gtile.g{ grid-column:span 1; grid-row:span 1; }
  .gtile.a,.gtile.f{ grid-column:span 2; grid-row:span 2; }
}

/* Lightbox */
.lb{ position:fixed; inset:0; z-index:120; background:rgba(18,14,9,.96); display:none; align-items:center; justify-content:center; opacity:0; transition:opacity .4s; }
.lb.open{ display:flex; opacity:1; }
.lb-img{ max-width:88vw; max-height:80vh; border-radius:6px; box-shadow:0 40px 100px -30px rgba(0,0,0,.8); object-fit:contain; }
.lb-cap{ position:absolute; bottom:30px; left:0; right:0; text-align:center; color:rgba(255,255,255,.8); font-size:14px; letter-spacing:.04em; }
.lb-count{ position:absolute; top:28px; left:0; right:0; text-align:center; color:rgba(255,255,255,.55); font-size:12px; letter-spacing:.24em; text-transform:uppercase; }
.lb-btn{ position:absolute; top:50%; transform:translateY(-50%); width:54px; height:54px; border-radius:50%; border:1px solid rgba(255,255,255,.3); background:rgba(255,255,255,.06); color:#fff; display:grid; place-items:center; transition:all .3s; }
.lb-btn:hover{ background:rgba(255,255,255,.16); border-color:#fff; }
.lb-prev{ left:max(20px,3vw); }
.lb-next{ right:max(20px,3vw); }
.lb-close{ position:absolute; top:24px; right:max(20px,3vw); width:46px; height:46px; border-radius:50%; border:1px solid rgba(255,255,255,.3); background:transparent; color:#fff; display:grid; place-items:center; transition:all .3s; }
.lb-close:hover{ background:rgba(255,255,255,.16); transform:rotate(90deg); }

/* ============================================================
   THE HOUSE — rooms + includes
   ============================================================ */
.house{ background:var(--dark); color:var(--cream-on-dark); }
.house .eyebrow{ color:var(--gold); }
.house .eyebrow::before,.house .eyebrow::after{ background:var(--gold); }
.house-head{ max-width:60ch; margin-bottom:54px; }
.house-head h2{ font-size:clamp(30px,4.4vw,56px); color:#fff; margin-bottom:20px; }
.house-head p{ color:rgba(240,231,214,.7); font-size:18px; max-width:52ch; }
.rooms{ display:grid; grid-template-columns:repeat(4,1fr); gap:16px; margin-bottom:64px; }
.room{ position:relative; border-radius:var(--radius-lg); overflow:hidden; aspect-ratio:3/4; background:var(--dark-2); cursor:pointer; }
.room img{ width:100%; height:100%; object-fit:cover; opacity:.92; transition:transform 1s var(--ease), opacity .5s; }
.room:hover img{ transform:scale(1.06); opacity:1; }
.room::after{ content:""; position:absolute; inset:0; background:linear-gradient(to top, rgba(15,12,7,.85), transparent 50%); }
.room .meta{ position:absolute; left:20px; bottom:18px; right:20px; z-index:2; }
.room .meta .rn{ font-family:var(--serif); font-size:24px; color:#fff; }
.room .meta .rd{ font-size:12.5px; color:rgba(240,231,214,.66); margin-top:3px; }
@media (max-width:860px){ .rooms{ grid-template-columns:repeat(2,1fr); } }

.includes{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(30px,5vw,72px); padding-top:54px; border-top:1px solid rgba(240,231,214,.14); }
.inc-col h3{ font-size:13px; font-family:var(--sans); font-weight:600; letter-spacing:.24em; text-transform:uppercase; color:var(--gold); margin-bottom:22px; }
.inc-col ul{ list-style:none; margin:0; padding:0; columns:2; column-gap:30px; }
.inc-col ul li{ padding:11px 0; border-bottom:1px solid rgba(240,231,214,.1); font-size:15px; color:rgba(240,231,214,.88); break-inside:avoid; display:flex; gap:10px; align-items:flex-start; }
.inc-col ul li .d{ color:var(--gold); flex:none; margin-top:1px; }
@media (max-width:860px){ .includes{ grid-template-columns:1fr; } .inc-col ul{ columns:1; } }

/* ============================================================
   FULL-BLEED PANORAMA BAND
   ============================================================ */
.fullbleed{ position:relative; height:min(72vh,580px); overflow:hidden; display:flex; align-items:flex-end; }
.fullbleed img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; animation:kenburns 30s var(--ease) infinite alternate; }
.fullbleed::after{ content:""; position:absolute; inset:0; background:linear-gradient(to top, rgba(20,16,10,.72), rgba(20,16,10,.04) 58%); }
.fullbleed-cap{ position:relative; z-index:2; width:100%; color:#fff; padding-bottom:clamp(34px,5vw,70px); }
.fullbleed-cap .eyebrow{ color:#fff; opacity:.92; }
.fullbleed-cap .eyebrow::before{ background:#fff; opacity:.7; }
.fullbleed-cap h2{ font-size:clamp(30px,4.6vw,62px); max-width:18ch; color:#fff; }

/* ============================================================
   ENTORNO — map + distances + weather
   ============================================================ */
.entorno{ background:var(--bg-paper); }
.ent-head{ display:grid; grid-template-columns:1.2fr 1fr; gap:50px; align-items:end; margin-bottom:50px; }
.ent-head h2{ font-size:clamp(30px,4.4vw,56px); max-width:14ch; }
.ent-head p{ color:var(--ink-mid); }
.ent-grid{ display:grid; grid-template-columns:1fr 1.15fr; gap:24px; align-items:stretch; }

/* POI list */
.poi-panel{ background:var(--bg); border:1px solid var(--line); border-radius:var(--radius-lg); padding:26px; display:flex; flex-direction:column; }
.filters{ display:flex; flex-wrap:wrap; gap:8px; margin-bottom:22px; }
.chip{ font-size:12.5px; font-weight:600; letter-spacing:.02em; padding:8px 15px; border-radius:100px; border:1px solid var(--line); background:transparent; color:var(--ink-mid); transition:all .3s var(--ease); }
.chip:hover{ border-color:var(--ink); color:var(--ink); }
.chip.active{ background:var(--ink); color:var(--bg); border-color:var(--ink); }
.poi-list{ list-style:none; margin:0; padding:0; flex:1; overflow:hidden; }
.poi{ display:flex; align-items:center; gap:16px; padding:15px 4px; border-bottom:1px solid var(--line-soft); transition:opacity .4s, transform .4s, max-height .4s, padding .4s; }
.poi.hide{ display:none; }
.poi .pico{ flex:none; width:40px; height:40px; border-radius:10px; background:var(--bg-2); display:grid; place-items:center; color:var(--terra); }
.poi .pbody{ flex:1; min-width:0; }
.poi .pn{ font-weight:600; font-size:15.5px; }
.poi .pc{ font-size:12.5px; color:var(--ink-soft); color:#8a7f6e; }
.poi .pdist{ text-align:right; flex:none; }
.poi .pdist .pt{ font-family:var(--serif); font-size:20px; font-weight:600; line-height:1; }
.poi .pdist .pm{ font-size:11px; letter-spacing:.08em; text-transform:uppercase; color:#9a8f7d; margin-top:3px; }

/* Map (schematic with distance rings) */
.map-panel{ position:relative; border-radius:var(--radius-lg); overflow:hidden; background:
   radial-gradient(circle at 38% 42%, #e7ddc8, #ddd0b4 60%, #d3c4a4);
   border:1px solid var(--line); min-height:480px; }
.map-plan{ position:absolute; inset:0; width:100%; height:100%; z-index:0; }
.map-zone{ position:absolute; transform:translate(-50%,-50%); font-size:10.5px; letter-spacing:.16em; text-transform:uppercase; font-weight:600; color:#8a7d65; pointer-events:none; z-index:2; white-space:nowrap; }
.map-zone.sea{ color:#235058; font-family:var(--serif); font-style:italic; text-transform:none; letter-spacing:0; font-size:17px; opacity:.85; }
.rings{ position:absolute; left:38%; top:42%; transform:translate(-50%,-50%); z-index:1; }
.ring{ position:absolute; border:1px dashed rgba(33,28,21,.18); border-radius:50%; left:50%; top:50%; transform:translate(-50%,-50%); }
.house-pin{ position:absolute; left:38%; top:42%; transform:translate(-50%,-50%); z-index:6; display:flex; flex-direction:column; align-items:center; gap:6px; }
.house-pin .hp{ width:46px; height:46px; border-radius:50% 50% 50% 4px; transform:rotate(45deg); background:var(--terra); box-shadow:0 10px 24px -8px rgba(155,70,35,.8); display:grid; place-items:center; }
.house-pin .hp svg{ transform:rotate(-45deg); }
.house-pin .hl{ background:var(--ink); color:var(--bg); font-size:11px; font-weight:600; letter-spacing:.1em; text-transform:uppercase; padding:4px 10px; border-radius:100px; white-space:nowrap; }
.mpin{ position:absolute; transform:translate(-50%,-50%); z-index:5; transition:opacity .4s var(--ease), transform .4s var(--ease); }
.mpin.hide{ opacity:.12; pointer-events:none; }
.mpin .pd{ width:16px; height:16px; border-radius:50%; background:#fff; border:3px solid var(--clay); box-shadow:0 4px 10px -2px rgba(0,0,0,.4); transition:all .3s; cursor:pointer; }
.mpin[data-cat="playa"] .pd{ border-color:#3a7c8c; }
.mpin[data-cat="comer"] .pd{ border-color:var(--terra); }
.mpin[data-cat="ocio"] .pd{ border-color:var(--gold); }
.mpin[data-cat="golf"] .pd{ border-color:var(--sage); }
.mpin[data-cat="rutas"] .pd{ border-color:#7a6a92; }
.mpin .pl{ position:absolute; left:22px; top:50%; transform:translateY(-50%); background:rgba(251,246,236,.92); backdrop-filter:blur(4px); padding:4px 10px; border-radius:100px; font-size:11.5px; font-weight:600; white-space:nowrap; opacity:0; transition:opacity .3s; box-shadow:0 4px 14px -6px rgba(0,0,0,.3); pointer-events:none; }
.mpin:hover{ z-index:8; }
.mpin:hover .pd{ transform:scale(1.35); }
.mpin:hover .pl{ opacity:1; }
.map-legend{ position:absolute; top:16px; left:16px; background:rgba(251,246,236,.9); backdrop-filter:blur(6px); border-radius:10px; padding:12px 14px; font-size:11px; display:grid; gap:7px; box-shadow:0 8px 24px -12px rgba(0,0,0,.3); }
.map-legend .lg{ display:flex; align-items:center; gap:8px; color:var(--ink-mid); font-weight:500; }
.map-legend .sw{ width:10px; height:10px; border-radius:50%; border:2px solid; }
@media (max-width:920px){
  .ent-head, .ent-grid{ grid-template-columns:1fr; }
  .map-panel{ min-height:420px; }
}

/* weather strip */
.weather{ display:grid; grid-template-columns:auto 1fr; gap:24px; align-items:center; margin-top:24px; background:var(--dark); color:var(--cream-on-dark); border-radius:var(--radius-lg); padding:22px 26px; }
.weather .wnow{ display:flex; align-items:center; gap:16px; padding-right:24px; border-right:1px solid rgba(240,231,214,.16); }
.weather .wicon{ font-size:34px; line-height:1; }
.weather .wtemp{ font-family:var(--serif); font-size:46px; font-weight:500; line-height:.9; }
.weather .wmeta .wl{ font-size:11px; letter-spacing:.2em; text-transform:uppercase; color:var(--gold); }
.weather .wmeta .wd{ font-size:13px; color:rgba(240,231,214,.72); margin-top:2px; }
.wdays{ display:flex; gap:8px; justify-content:flex-end; flex-wrap:wrap; }
.wday{ text-align:center; padding:8px 12px; border-radius:10px; background:rgba(240,231,214,.06); min-width:62px; }
.wday .wdn{ font-size:11px; letter-spacing:.06em; text-transform:uppercase; color:rgba(240,231,214,.6); }
.wday .wdi{ font-size:20px; margin:5px 0; }
.wday .wdt{ font-size:13px; font-weight:600; }
.wday .wdt .lo{ color:rgba(240,231,214,.5); }
@media (max-width:620px){ .weather{ grid-template-columns:1fr; } .wdays{ justify-content:flex-start; } }

/* VIP spots */
.vip{ background:var(--bg); }
.vip-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:16px; }
.vcard{ border:1px solid var(--line); border-radius:var(--radius-lg); padding:28px 24px; background:var(--bg-paper); transition:all .45s var(--ease); position:relative; overflow:hidden; }
.vcard:hover{ transform:translateY(-6px); border-color:var(--terra); box-shadow:0 30px 60px -34px rgba(0,0,0,.4); }
.vcard .vk{ font-size:11px; letter-spacing:.2em; text-transform:uppercase; color:var(--terra); font-weight:600; }
.vcard h3{ font-size:25px; margin:14px 0 10px; }
.vcard p{ font-size:14.5px; color:var(--ink-mid); line-height:1.55; margin:0; }
.vcard .vno{ position:absolute; top:18px; right:22px; font-family:var(--serif); font-size:40px; color:var(--line); font-weight:500; }
@media (max-width:920px){ .vip-grid{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:540px){ .vip-grid{ grid-template-columns:1fr; } }

/* ============================================================
   REVIEWS
   ============================================================ */
.reviews{ background:var(--bg-2); text-align:center; }
.rev-stage{ max-width:780px; margin:0 auto; position:relative; min-height:240px; }
.rev{ position:absolute; inset:0; opacity:0; transform:translateY(16px); transition:opacity .7s var(--ease), transform .7s var(--ease); pointer-events:none; }
.rev.active{ opacity:1; transform:none; position:relative; pointer-events:auto; }
.rev .stars{ color:var(--terra); letter-spacing:.3em; font-size:15px; margin-bottom:24px; }
.rev .quote{ font-family:var(--serif); font-size:clamp(24px,3.2vw,38px); line-height:1.28; font-style:italic; color:var(--ink); }
.rev .who{ margin-top:26px; font-size:13px; letter-spacing:.16em; text-transform:uppercase; color:var(--ink-mid); font-weight:600; }
.rev .who b{ color:var(--terra); }
.rev-dots{ display:flex; gap:10px; justify-content:center; margin-top:46px; }
.rev-dot{ width:9px; height:9px; border-radius:50%; border:1px solid var(--ink-mid); background:transparent; padding:0; transition:all .3s; }
.rev-dot.active{ background:var(--terra); border-color:var(--terra); transform:scale(1.2); }

/* ============================================================
   BOOKING / CTA
   ============================================================ */
.booking{ background:var(--dark); color:var(--cream-on-dark); position:relative; overflow:hidden; }
.booking::before{ content:""; position:absolute; inset:0; background:radial-gradient(circle at 80% 0%, rgba(185,87,47,.22), transparent 45%); }
.booking .eyebrow{ color:var(--gold); }
.booking .eyebrow::before,.booking .eyebrow::after{ background:var(--gold); }
.book-grid{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(40px,6vw,90px); align-items:center; position:relative; z-index:2; }
.book-copy h2{ font-size:clamp(32px,4.6vw,60px); color:#fff; margin-bottom:22px; }
.book-copy p{ color:rgba(240,231,214,.72); font-size:18px; max-width:46ch; margin-bottom:30px; }
.book-points{ list-style:none; padding:0; margin:0; display:grid; gap:14px; }
.book-points li{ display:flex; gap:12px; font-size:15px; color:rgba(240,231,214,.86); }
.book-points li .d{ color:var(--gold); }

.inquiry{ background:var(--bg-paper); color:var(--ink); border-radius:16px; padding:clamp(26px,3vw,40px); box-shadow:0 50px 90px -40px rgba(0,0,0,.6); }
.inquiry h3{ font-size:27px; margin-bottom:6px; }
.inquiry .isub{ font-size:13.5px; color:var(--ink-mid); margin-bottom:26px; }
.field{ margin-bottom:20px; }
.field label{ display:block; font-size:12px; font-weight:600; letter-spacing:.1em; text-transform:uppercase; color:var(--ink-mid); margin-bottom:9px; }
.field-row{ display:grid; grid-template-columns:1fr 1fr; gap:14px; }
.field input, .field select{ width:100%; font-family:inherit; font-size:15px; padding:13px 14px; border:1px solid var(--line); border-radius:8px; background:var(--bg); color:var(--ink); transition:border .3s; }
.field input:focus, .field select:focus{ outline:none; border-color:var(--terra); }
.stay-val{ font-family:var(--serif); font-size:22px; font-weight:600; color:var(--terra); }
.range{ -webkit-appearance:none; appearance:none; width:100%; height:4px; border-radius:4px; background:var(--bg-2); margin-top:14px; }
.range::-webkit-slider-thumb{ -webkit-appearance:none; width:22px; height:22px; border-radius:50%; background:var(--terra); border:3px solid var(--bg-paper); box-shadow:0 3px 8px -2px rgba(0,0,0,.4); cursor:pointer; }
.range::-moz-range-thumb{ width:22px; height:22px; border-radius:50%; background:var(--terra); border:3px solid var(--bg-paper); cursor:pointer; }
.guests{ display:flex; align-items:center; justify-content:space-between; border:1px solid var(--line); border-radius:8px; padding:8px 8px 8px 14px; }
.guests .gn{ font-weight:600; }
.stepper{ display:flex; align-items:center; gap:4px; }
.stepper button{ width:36px; height:36px; border-radius:7px; border:1px solid var(--line); background:var(--bg); font-size:18px; color:var(--ink); display:grid; place-items:center; transition:all .25s; }
.stepper button:hover{ border-color:var(--terra); color:var(--terra); }
.stepper .gc{ width:34px; text-align:center; font-weight:600; }
.inquiry .btn-primary{ width:100%; justify-content:center; margin-top:8px; }
.inquiry .note{ font-size:12px; color:#9a8f7d; text-align:center; margin-top:14px; }
.toast{ margin-top:16px; background:rgba(111,118,87,.14); border:1px solid var(--sage); color:#4d5337; border-radius:10px; padding:14px 16px; font-size:14px; display:none; align-items:flex-start; gap:10px; }
.toast.show{ display:flex; }
@media (max-width:860px){ .book-grid{ grid-template-columns:1fr; } }

/* ============================================================
   FOOTER
   ============================================================ */
.footer{ background:var(--dark-2); color:rgba(240,231,214,.7); padding:70px 0 34px; }
.foot-grid{ display:grid; grid-template-columns:1.4fr 1fr 1fr; gap:40px; padding-bottom:46px; border-bottom:1px solid rgba(240,231,214,.12); }
.foot-brand .bname{ font-family:var(--serif); font-size:24px; color:#fff; }
.foot-brandrow{ display:flex; align-items:center; gap:12px; margin-bottom:14px; }
.foot-logo{ width:40px; height:40px; border-radius:9px; background:#fff; display:grid; place-items:center; flex:none; }
.foot-logo img{ width:82%; height:82%; object-fit:contain; }
.foot-brand p{ font-size:14px; max-width:34ch; margin:14px 0 0; line-height:1.6; }
.foot-col h4{ font-size:11px; letter-spacing:.2em; text-transform:uppercase; color:var(--gold); margin:0 0 18px; font-weight:600; }
.foot-col a{ display:block; font-size:14px; padding:7px 0; transition:color .25s; }
.foot-col a:hover{ color:#fff; }
.foot-bottom{ display:flex; align-items:center; justify-content:space-between; padding-top:26px; font-size:12.5px; flex-wrap:wrap; gap:12px; }
@media (max-width:860px){ .foot-grid{ grid-template-columns:1fr; gap:30px; } }
