/* ═════════════════════════════════════════════════════════════════
   SPANISH NEW BUILDS · base styles
   Paleta navy + cream + champagne · tipografía Cormorant + Inter
   ═════════════════════════════════════════════════════════════════ */

:root {
  --navy:        #0E1620;
  --navy-2:      #182434;
  --navy-3:      #243246;
  --ink:         #1C1C1A;
  --ink-soft:    #2C2F35;
  --ink-muted:   #6B6F76;
  --line:        rgba(28, 28, 26, 0.10);
  --line-strong: rgba(28, 28, 26, 0.18);
  --cream:       #F4F0EA;
  --cream-2:     #EBE5DA;
  --paper:       #FAF6EE;
  --white:       #FFFFFF;
  --brass:       #B89460;
  --brass-soft:  #D7BB89;
  --brass-deep:  #8F6E3F;
  --green:       #2E4A3F;
  --red:         #B33B3B;

  --max:         1340px;
  --pad-x:       clamp(1.25rem, 4vw, 3.5rem);
  --ease:        cubic-bezier(0.22, 1, 0.36, 1);
  --ease-cine:   cubic-bezier(0.16, 1, 0.3, 1);
  --t-fast:      0.25s;
  --t-med:       0.55s;
  --t-slow:      1.2s;
}

* { box-sizing: border-box; margin: 0; padding: 0; }
*, *::before, *::after { -webkit-tap-highlight-color: transparent; }
html { scroll-behavior: auto; -webkit-text-size-adjust: 100%; }
html.has-lenis { scroll-behavior: auto; }
body {
  background: var(--paper);
  color: var(--ink);
  font-family: 'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
  font-weight: 400;
  font-size: 16px;
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
  position: relative;
}
body.no-scroll { overflow: hidden; }
::selection { background: var(--navy); color: var(--cream); }
img, video, picture { max-width: 100%; height: auto; display: block; }
a { color: inherit; text-decoration: none; }
button { font: inherit; cursor: pointer; border: 0; background: transparent; color: inherit; }
input, select, textarea { font: inherit; color: inherit; }

.italic, em.italic { font-family: 'Cormorant Garamond', serif; font-style: italic; font-weight: 400; }

/* paper texture (sutil) */
body::before {
  content: "";
  position: fixed; inset: 0; z-index: -1;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='240' height='240' viewBox='0 0 240 240'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0.30 0 0 0 0 0.20 0 0 0 0 0.10 0 0 0 0.025 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
  opacity: 0.7;
  mix-blend-mode: multiply;
  pointer-events: none;
}

/* ═══════════════════ LOADER ═══════════════════ */
.loader {
  position: fixed; inset: 0; z-index: 200;
  background: var(--navy); color: var(--cream);
  display: grid; place-items: center; padding: 2rem;
  transition: opacity 0.6s var(--ease-cine), visibility 0.6s var(--ease-cine);
}
.loader.gone { opacity: 0; visibility: hidden; pointer-events: none; }
.loader-logo {
  width: auto; height: clamp(110px, 24vw, 200px);
  opacity: 0.92;
  animation: loaderFloat 2.2s ease-in-out infinite alternate;
}
@keyframes loaderFloat {
  from { transform: translateY(-2px); opacity: 0.85; }
  to   { transform: translateY(2px);  opacity: 1; }
}
.loader-bar {
  position: absolute; bottom: 6vh; left: 50%; transform: translateX(-50%);
  width: clamp(80px, 16vw, 180px); height: 1px;
  background: rgba(245, 240, 234, 0.16);
  overflow: hidden;
}
.loader-bar span {
  display: block; height: 100%;
  background: var(--brass);
  animation: loaderBar 1.1s var(--ease-cine) forwards;
}
@keyframes loaderBar {
  0% { width: 0%; }
  100% { width: 100%; }
}

/* ═══════════════════ NAV ═══════════════════ */
.nav {
  position: fixed; top: 0; left: 0; right: 0; z-index: 80;
  display: flex; align-items: center; justify-content: space-between;
  padding: clamp(0.85rem, 2vw, 1.5rem) var(--pad-x);
  color: var(--cream);
  transition: background var(--t-med) var(--ease), color var(--t-med) var(--ease), padding var(--t-med) var(--ease), border-bottom-color var(--t-med) var(--ease);
  border-bottom: 1px solid transparent;
}
.nav.scrolled, .nav.solid {
  background: rgba(250, 246, 238, 0.92);
  color: var(--ink);
  border-bottom-color: var(--line);
  backdrop-filter: saturate(160%) blur(14px);
  -webkit-backdrop-filter: saturate(160%) blur(14px);
  padding-top: 0.7rem; padding-bottom: 0.7rem;
}

.nav-brand {
  display: inline-flex; align-items: center; line-height: 1;
  position: relative;
}
.nav-logo {
  height: 52px; width: auto; display: block;
  transition: opacity var(--t-med) var(--ease), transform var(--t-fast) var(--ease);
}
.nav-brand:hover .nav-logo { transform: scale(1.02); }
.nav-logo-dark { opacity: 1; }
.nav-logo-light { position: absolute; left: 0; top: 0; opacity: 0; pointer-events: none; }
.nav.scrolled .nav-logo-dark, .nav.solid .nav-logo-dark { opacity: 0; }
.nav.scrolled .nav-logo-light, .nav.solid .nav-logo-light { opacity: 1; }
.nav.scrolled .nav-logo, .nav.solid .nav-logo { height: 44px; }
@media (max-width: 640px) {
  .nav-logo { height: 44px; }
  .nav.scrolled .nav-logo, .nav.solid .nav-logo { height: 38px; }
}

.nav-links {
  display: flex; gap: 2.2rem;
  position: absolute; left: 50%; top: 50%;
  transform: translate(-50%, -50%);
}
.nav-links a {
  font-size: 0.82rem; letter-spacing: 0.12em; text-transform: uppercase;
  font-weight: 400; opacity: 0.88;
  position: relative; padding: 0.4rem 0;
  transition: opacity var(--t-fast) var(--ease);
}
.nav-links a:hover { opacity: 1; }
.nav-links a::after {
  content: ""; position: absolute; left: 0; right: 0; bottom: 0;
  height: 1px; background: currentColor; transform: scaleX(0); transform-origin: left;
  transition: transform var(--t-med) var(--ease-cine);
}
.nav-links a:hover::after { transform: scaleX(1); }

.nav-right { display: flex; align-items: center; gap: 0.85rem; }
.lang-toggle {
  display: inline-flex; align-items: center; gap: 0.35rem;
  padding: 0.45rem 0.7rem; border: 1px solid currentColor;
  border-radius: 999px; font-size: 0.74rem; letter-spacing: 0.12em;
  text-transform: uppercase; opacity: 0.88;
  transition: opacity var(--t-fast) var(--ease), background var(--t-fast) var(--ease);
}
.lang-toggle:hover { opacity: 1; background: rgba(255, 255, 255, 0.06); }
.nav.scrolled .lang-toggle:hover, .nav.solid .lang-toggle:hover { background: rgba(28, 28, 26, 0.06); }
.lang-flag { font-size: 0.92rem; line-height: 1; }

.nav-cta {
  display: inline-flex; align-items: center;
  padding: 0.7rem 1.1rem;
  background: var(--brass); color: var(--navy);
  font-weight: 500; font-size: 0.78rem; letter-spacing: 0.14em;
  text-transform: uppercase; border-radius: 999px;
  transition: background var(--t-fast) var(--ease), transform var(--t-fast) var(--ease);
}
.nav-cta:hover { background: var(--brass-soft); transform: translateY(-1px); }

.nav-burger {
  display: none;
  width: 38px; height: 38px;
  position: relative;
}
.nav-burger span {
  display: block;
  position: absolute; left: 8px; right: 8px;
  height: 1.5px; background: currentColor;
  transition: transform var(--t-fast) var(--ease), opacity var(--t-fast) var(--ease), top var(--t-fast) var(--ease);
}
.nav-burger span:nth-child(1) { top: 13px; }
.nav-burger span:nth-child(2) { top: 18.5px; }
.nav-burger span:nth-child(3) { top: 24px; }
.nav-burger[aria-expanded="true"] span:nth-child(1) { top: 18.5px; transform: rotate(45deg); }
.nav-burger[aria-expanded="true"] span:nth-child(2) { opacity: 0; }
.nav-burger[aria-expanded="true"] span:nth-child(3) { top: 18.5px; transform: rotate(-45deg); }

/* mobile menu */
.mobile-menu {
  position: fixed; inset: 0; z-index: 70;
  background: var(--navy); color: var(--cream);
  display: flex; flex-direction: column; gap: 1.4rem;
  justify-content: center; align-items: center; text-align: center;
  padding: 5rem var(--pad-x) 3rem;
  opacity: 0; visibility: hidden;
  transition: opacity 0.4s var(--ease), visibility 0.4s var(--ease);
}
.mobile-menu.open { opacity: 1; visibility: visible; }
.mobile-menu a {
  font-family: 'Cormorant Garamond', serif; font-weight: 400;
  font-size: clamp(2rem, 8vw, 3.4rem); line-height: 1.05;
  transform: translateY(20px); opacity: 0;
  transition: transform 0.5s var(--ease-cine), opacity 0.5s var(--ease-cine);
}
.mobile-menu.open a { transform: translateY(0); opacity: 1; }
.mobile-menu.open a:nth-child(1) { transition-delay: 0.10s; }
.mobile-menu.open a:nth-child(2) { transition-delay: 0.16s; }
.mobile-menu.open a:nth-child(3) { transition-delay: 0.22s; }
.mobile-menu.open a:nth-child(4) { transition-delay: 0.28s; }
.mobile-menu.open .mm-wa,
.mobile-menu.open .mm-mail { transition-delay: 0.42s; }
.mm-divider { height: 1px; background: rgba(245, 240, 234, 0.18); margin: 1rem 0; }
.mm-wa, .mm-mail {
  font-family: 'Inter', sans-serif !important;
  font-size: 1rem !important; letter-spacing: 0.04em;
  opacity: 0.86;
}

/* ═══════════════════ HERO ═══════════════════ */
.hero {
  position: relative;
  min-height: 100svh; min-height: 100vh;
  display: flex; flex-direction: column; justify-content: flex-end;
  padding: 0 var(--pad-x) clamp(4rem, 8vh, 7rem);
  color: var(--cream);
  overflow: hidden;
  isolation: isolate;
}
.hero-media {
  position: absolute; inset: 0; z-index: -1;
  clip-path: inset(100% 0 0 0);
  transition: clip-path 1.4s var(--ease-cine);
  will-change: clip-path;
}
body.loaded .hero-media { clip-path: inset(0 0 0 0); }
.hero-media img,
.hero-media video {
  width: 100%; height: 100%;
  object-fit: cover; object-position: center;
}
.hero-media .hero-video {
  position: absolute; inset: 0;
  opacity: 0; transition: opacity 1s ease 0.4s;
}
.hero-media .hero-video.ready { opacity: 1; }
.hero-vignette {
  position: absolute; inset: 0;
  background:
    /* Scrim local: zona del texto (izquierda-centro) bañada en un suave navy
       para garantizar legibilidad sin oscurecer la imagen entera */
    radial-gradient(ellipse 75% 65% at 22% 55%, rgba(14, 22, 32, 0.55) 0%, rgba(14, 22, 32, 0.18) 55%, rgba(14, 22, 32, 0) 80%),
    linear-gradient(180deg, rgba(14, 22, 32, 0.55) 0%, rgba(14, 22, 32, 0.15) 30%, rgba(14, 22, 32, 0.05) 55%, rgba(14, 22, 32, 0.85) 100%),
    linear-gradient(90deg, rgba(14, 22, 32, 0.45) 0%, rgba(14, 22, 32, 0) 65%);
  pointer-events: none;
}
.hero-watch {
  position: absolute; right: var(--pad-x); top: 50%; transform: translateY(-50%);
  display: flex; flex-direction: column; align-items: flex-end; gap: 0.45rem;
  z-index: 3; pointer-events: none;
  opacity: 0; transition: opacity 1s var(--ease-cine) 1.6s;
}
body.loaded .hero-watch { opacity: 0.85; }
.hero-watch .pulse {
  width: 64px; height: 64px; border-radius: 50%;
  border: 1px solid rgba(244,240,234,0.7);
  position: relative;
  display: grid; place-items: center;
}
.hero-watch .pulse::before {
  content: ""; position: absolute; inset: -8px;
  border-radius: 50%;
  border: 1px solid rgba(244,240,234,0.4);
  animation: heroPulse 2.4s var(--ease-cine) infinite;
}
.hero-watch .pulse::after {
  content: "▶"; color: var(--cream); font-size: 0.85rem; padding-left: 3px;
}
.hero-watch small {
  color: rgba(244,240,234,0.85);
  font-size: 0.7rem; letter-spacing: 0.22em; text-transform: uppercase;
}
@keyframes heroPulse { 0%{transform:scale(1);opacity:0.7} 100%{transform:scale(1.45);opacity:0} }
@media (max-width: 700px) { .hero-watch { display: none; } }

.hero-inner { max-width: var(--max); width: 100%; margin: 0 auto; position: relative; z-index: 2; }
.hero-eyebrow {
  display: inline-flex; align-items: center; gap: 0.55rem;
  font-size: 0.74rem; letter-spacing: 0.22em; text-transform: uppercase;
  font-weight: 500; opacity: 0; transform: translateY(20px);
  text-shadow: 0 1px 6px rgba(14, 22, 32, 0.5);
  transition: opacity 0.9s var(--ease-cine) 0.4s, transform 0.9s var(--ease-cine) 0.4s;
}
.hero-eyebrow .dot { width: 7px; height: 7px; border-radius: 50%; background: var(--brass); }
body.loaded .hero-eyebrow { opacity: 0.95; transform: translateY(0); }

.hero-title {
  font-family: 'Cormorant Garamond', serif;
  font-weight: 400;
  text-shadow: 0 2px 18px rgba(14, 22, 32, 0.55), 0 1px 2px rgba(14, 22, 32, 0.35);
  font-size: clamp(2.7rem, 7vw + 0.5rem, 7.5rem);
  line-height: 0.96;
  letter-spacing: -0.015em;
  margin: 1.25rem 0 1.5rem;
}
.hero-title .line {
  display: block;
  overflow: hidden;
  /* Add extra space below to fit descenders of italic (j, g, p, y, q) */
  padding-bottom: 0.18em;
  margin-bottom: -0.18em;
}
.hero-title .line-inner {
  display: inline-block;
  transform: translateY(110%);
  transition: transform 1.1s var(--ease-cine);
}
body.loaded .hero-title .line:nth-child(1) .line-inner { transition-delay: 0.55s; transform: translateY(0); }
body.loaded .hero-title .line:nth-child(2) .line-inner { transition-delay: 0.75s; transform: translateY(0); }
.hero-title em { color: var(--brass-soft); }

.hero-lede {
  max-width: 640px;
  font-size: clamp(1rem, 1.2vw, 1.18rem);
  line-height: 1.55;
  text-shadow: 0 1px 8px rgba(14, 22, 32, 0.45);
  color: rgba(244, 240, 234, 0.92);
  opacity: 0; transform: translateY(20px);
  transition: opacity 1s var(--ease-cine) 0.9s, transform 1s var(--ease-cine) 0.9s;
}
body.loaded .hero-lede { opacity: 1; transform: translateY(0); }

.hero-actions {
  display: flex; gap: 0.85rem; flex-wrap: wrap;
  margin: 2rem 0 3rem;
  opacity: 0; transform: translateY(20px);
  transition: opacity 1s var(--ease-cine) 1.05s, transform 1s var(--ease-cine) 1.05s;
}
body.loaded .hero-actions { opacity: 1; transform: translateY(0); }

.btn-primary, .btn-ghost {
  display: inline-flex; align-items: center; gap: 0.65rem;
  padding: 1rem 1.5rem;
  font-size: 0.78rem; font-weight: 500; letter-spacing: 0.18em;
  text-transform: uppercase; border-radius: 999px;
  transition: transform var(--t-fast) var(--ease), background var(--t-fast) var(--ease), color var(--t-fast) var(--ease), border-color var(--t-fast) var(--ease);
}
.btn-primary {
  background: var(--brass); color: var(--navy);
  box-shadow: 0 10px 40px -10px rgba(184, 148, 96, 0.55);
}
.btn-primary:hover { background: var(--brass-soft); transform: translateY(-2px); }
.btn-primary span { transition: transform var(--t-fast) var(--ease); }
.btn-primary:hover span { transform: translateX(4px); }
.btn-ghost {
  background: transparent; color: inherit;
  border: 1px solid currentColor;
}
.btn-ghost:hover { background: rgba(244, 240, 234, 0.08); }

.hero-meta {
  display: flex; gap: clamp(2rem, 6vw, 4.5rem); flex-wrap: wrap;
  padding-top: 2rem; border-top: 1px solid rgba(244, 240, 234, 0.18);
  max-width: 760px;
  opacity: 0; transform: translateY(20px);
  transition: opacity 1s var(--ease-cine) 1.25s, transform 1s var(--ease-cine) 1.25s;
}
body.loaded .hero-meta { opacity: 1; transform: translateY(0); }
.hero-meta > div { display: flex; flex-direction: column; gap: 0.2rem; }
.hero-meta strong {
  font-family: 'Cormorant Garamond', serif; font-weight: 500;
  font-size: clamp(1.6rem, 2.4vw, 2.2rem);
  color: var(--brass-soft);
  line-height: 1;
}
.hero-meta span {
  font-size: 0.72rem; letter-spacing: 0.18em; text-transform: uppercase;
  opacity: 0.78;
}

.hero-scroll {
  position: absolute; right: var(--pad-x); bottom: 2rem;
  display: flex; flex-direction: column; align-items: center; gap: 0.6rem;
  font-size: 0.66rem; letter-spacing: 0.32em; text-transform: uppercase;
  opacity: 0.72;
  z-index: 2;
}
.hero-scroll span:first-child {
  width: 1px; height: 38px; background: currentColor;
  animation: scrollLine 2.2s var(--ease-cine) infinite;
  transform-origin: top;
}
@keyframes scrollLine {
  0%   { transform: scaleY(0); transform-origin: top; }
  50%  { transform: scaleY(1); transform-origin: top; }
  51%  { transform: scaleY(1); transform-origin: bottom; }
  100% { transform: scaleY(0); transform-origin: bottom; }
}
@media (max-width: 640px) { .hero-scroll { display: none; } }

/* ═══════════════════ MARQUEE ═══════════════════ */
.marquee {
  background: var(--navy);
  color: var(--cream);
  padding: 1.1rem 0;
  overflow: hidden;
  border-top: 1px solid rgba(244, 240, 234, 0.08);
  border-bottom: 1px solid rgba(244, 240, 234, 0.08);
}
.marquee-track {
  display: inline-flex; align-items: center; gap: 1.2rem;
  white-space: nowrap;
  font-family: 'Cormorant Garamond', serif; font-style: italic;
  font-size: clamp(1.4rem, 3.2vw, 2.2rem);
  font-weight: 400;
  animation: marquee 38s linear infinite;
  padding-left: 1.5rem;
}
.marquee-track .dot { color: var(--brass); font-size: 0.7em; padding: 0 0.4em; }
.marquee:hover .marquee-track { animation-play-state: paused; }
@keyframes marquee {
  from { transform: translateX(0); }
  to   { transform: translateX(-50%); }
}

/* ═══════════════════ SECTION GENERICS ═══════════════════ */
.section-head {
  max-width: var(--max);
  margin: 0 auto;
  padding: 0 var(--pad-x);
  padding-top: clamp(5rem, 10vh, 8rem);
  padding-bottom: clamp(2.5rem, 5vh, 4rem);
}
.eyebrow {
  display: inline-flex; align-items: center; gap: 0.55rem;
  font-size: 0.74rem; letter-spacing: 0.22em; text-transform: uppercase;
  font-weight: 500; color: var(--brass-deep);
  margin-bottom: 1.4rem;
}
.eyebrow .dot { width: 7px; height: 7px; border-radius: 50%; background: var(--brass); }
.section-title {
  font-family: 'Cormorant Garamond', serif;
  font-weight: 400;
  font-size: clamp(2.2rem, 5vw + 0.5rem, 4.6rem);
  line-height: 1.02;
  letter-spacing: -0.015em;
  color: var(--ink);
}
.section-title em { color: var(--brass-deep); }
.section-lede {
  max-width: 640px;
  margin-top: 1.25rem;
  font-size: clamp(0.98rem, 1.05vw, 1.08rem);
  color: var(--ink-soft);
  line-height: 1.6;
}

/* ═══════════════════ REVEAL ANIMATION ═══════════════════ */
.reveal {
  opacity: 0;
  transform: translateY(40px);
  transition: opacity 0.9s var(--ease-cine), transform 0.9s var(--ease-cine);
  will-change: transform, opacity;
}
.reveal.in {
  opacity: 1;
  transform: translateY(0);
}
.reveal-img {
  overflow: hidden;
  position: relative;
}
.reveal-img > * {
  transition: transform 1.4s var(--ease-cine), opacity 1.4s var(--ease-cine);
  transform: scale(1.08);
}
.reveal-img.in > * { transform: scale(1); }
.reveal-img::after {
  content: ""; position: absolute; inset: 0; background: var(--cream);
  transform-origin: bottom;
  transition: transform 1.2s var(--ease-cine) 0.05s;
}
.reveal-img.in::after { transform: scaleY(0); }

/* ═══════════════════ PROPERTIES ═══════════════════ */
.properties { background: var(--paper); }
.props-grid {
  max-width: var(--max); margin: 0 auto;
  padding: 0 var(--pad-x);
  display: grid; gap: clamp(1.5rem, 3vw, 2.5rem);
  grid-template-columns: repeat(3, 1fr);
}
@media (max-width: 1000px) {
  .props-grid {
    grid-template-columns: 1fr;
    /* mobile carousel */
    grid-auto-flow: column;
    grid-auto-columns: minmax(82%, 1fr);
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    scroll-padding-left: var(--pad-x);
    padding-left: var(--pad-x);
    padding-right: var(--pad-x);
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
  }
  .props-grid::-webkit-scrollbar { display: none; }
  .props-grid .prop { scroll-snap-align: start; }
}

.prop {
  background: var(--white);
  border: 1px solid var(--line);
  border-radius: 16px;
  overflow: hidden;
  display: flex; flex-direction: column;
  transition: transform var(--t-med) var(--ease-cine), box-shadow var(--t-med) var(--ease-cine);
}
.prop:hover {
  transform: translateY(-6px);
  box-shadow: 0 30px 60px -30px rgba(14, 22, 32, 0.35);
}
.prop-media {
  position: relative; display: block;
  aspect-ratio: 4 / 3;
  overflow: hidden;
  background: var(--cream-2);
}
.prop-media img {
  width: 100%; height: 100%; object-fit: cover;
  transition: transform 1.4s var(--ease-cine);
}
.prop:hover .prop-media img { transform: scale(1.04); }
.prop-tag {
  position: absolute; top: 1rem; left: 1rem;
  background: rgba(14, 22, 32, 0.86);
  color: var(--cream);
  font-size: 0.66rem; letter-spacing: 0.18em; text-transform: uppercase;
  padding: 0.45rem 0.75rem; border-radius: 999px;
  backdrop-filter: blur(8px);
}
.prop-body { padding: 1.4rem 1.4rem 1.6rem; display: flex; flex-direction: column; gap: 0.55rem; }
.prop-loc {
  font-size: 0.72rem; letter-spacing: 0.2em; text-transform: uppercase;
  color: var(--brass-deep);
}
.prop-name {
  font-family: 'Cormorant Garamond', serif;
  font-weight: 500; font-size: 1.6rem; line-height: 1.1;
  color: var(--ink);
}
.prop-name em { font-style: italic; font-weight: 400; color: var(--brass-deep); }
.prop-desc {
  font-size: 0.92rem; color: var(--ink-soft);
  line-height: 1.55;
}
.prop-foot {
  display: flex; justify-content: space-between; align-items: baseline;
  margin-top: 0.6rem; padding-top: 0.85rem;
  border-top: 1px solid var(--line);
}
.prop-price {
  font-family: 'Cormorant Garamond', serif;
  font-weight: 500; font-size: 1.25rem; color: var(--ink);
}
.prop-cta {
  font-size: 0.72rem; letter-spacing: 0.2em; text-transform: uppercase;
  font-weight: 500; color: var(--brass-deep);
  transition: transform var(--t-fast) var(--ease);
}
.prop:hover .prop-cta { transform: translateX(4px); }

/* ── FILTERS ────────────────────────────────────────── */
.filters {
  position: sticky; top: 70px; z-index: 30;
  max-width: var(--max); margin: 0 auto 1.5rem;
  padding: 0 var(--pad-x);
}
.filters-inner {
  display: flex; gap: 0.5rem; flex-wrap: wrap; align-items: center;
  background: rgba(255,255,255,0.92);
  backdrop-filter: saturate(160%) blur(14px);
  -webkit-backdrop-filter: saturate(160%) blur(14px);
  border: 1px solid var(--line);
  border-radius: 999px;
  padding: 0.55rem 0.7rem;
  box-shadow: 0 8px 24px -16px rgba(14, 22, 32, 0.18);
}
.filter-search { display: flex; align-items: center; gap: 0.4rem; flex: 1 1 220px; min-width: 180px; padding: 0 0.5rem; }
.filter-search .f-icon { color: var(--ink-muted); font-size: 1.1rem; }
.filter-search input { width: 100%; border: 0; background: transparent; outline: none; font-size: 0.9rem; padding: 0.45rem 0; }
.filters select {
  border: 0; background: transparent;
  font-size: 0.84rem; padding: 0.45rem 0.65rem;
  cursor: pointer; outline: none; color: var(--ink-soft);
  border-radius: 999px;
  transition: background var(--t-fast) var(--ease);
}
.filters select:hover { background: rgba(28,28,26,0.05); }
.filter-reset {
  background: transparent; border: 0;
  font-size: 0.74rem; letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--ink-muted); padding: 0.45rem 0.7rem;
  cursor: pointer; border-radius: 999px;
  transition: color var(--t-fast) var(--ease), background var(--t-fast) var(--ease);
}
.filter-reset:hover { color: var(--bordeaux-deep, var(--brass-deep)); background: rgba(28,28,26,0.05); }
.filters-meta {
  margin-top: 0.6rem;
  font-size: 0.74rem; letter-spacing: 0.1em; text-transform: uppercase;
  color: var(--ink-muted); text-align: right;
  padding: 0 0.5rem;
}
@media (max-width: 720px) {
  .filters { position: relative; top: auto; }
  .filters-inner { border-radius: 16px; padding: 0.7rem; }
  .filters select, .filter-reset { font-size: 0.82rem; }
}

/* ── PROPS GRID con datos reales (override del demo) ── */
.properties .props-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
  gap: 1.4rem;
  grid-auto-flow: row;
  /* deshabilitar el carousel del demo override anterior en mobile */
  overflow: visible;
  scroll-snap-type: none;
  padding-left: 0; padding-right: 0;
}
@media (max-width: 700px) {
  .properties .props-grid {
    grid-template-columns: 1fr;
    overflow: visible;
  }
}

.props-skeleton { display: contents; }
.props-skeleton .sk {
  aspect-ratio: 3 / 4;
  background: linear-gradient(135deg, var(--cream-2), var(--paper));
  border-radius: 16px;
  animation: skPulse 1.4s ease-in-out infinite;
  opacity: 0.7;
}
@keyframes skPulse { 0%,100%{opacity:0.55} 50%{opacity:0.85} }

.prop-quick {
  display: flex; gap: 0.85rem; flex-wrap: wrap;
  font-size: 0.78rem; color: var(--ink-muted);
  letter-spacing: 0.02em;
  padding: 0.35rem 0;
}
.prop-quick span { display: inline-flex; align-items: center; gap: 0.3rem; }
.prop-quick b { color: var(--ink); font-weight: 600; font-variant-numeric: tabular-nums; }
.prop-quick .sep { color: var(--line-strong); }

.props-pagination { text-align: center; padding: 1.5rem var(--pad-x) 0; }
.props-pagination .btn-ghost {
  color: var(--ink); border-color: var(--line-strong);
}
.props-pagination .btn-ghost:hover { background: var(--white); border-color: var(--brass); color: var(--brass-deep); }

.props-empty {
  grid-column: 1 / -1;
  text-align: center; padding: 4rem 1rem;
  color: var(--ink-muted); font-family: 'Cormorant Garamond', serif; font-style: italic;
  font-size: 1.3rem;
}

.props-foot {
  max-width: var(--max); margin: 0 auto;
  padding: 3rem var(--pad-x) 6rem;
  text-align: center;
}
.link-underline {
  display: inline-block;
  font-size: 0.92rem; color: var(--ink-soft);
  border-bottom: 1px solid var(--brass);
  padding-bottom: 0.2rem;
  transition: color var(--t-fast) var(--ease), border-color var(--t-fast) var(--ease);
}
.link-underline:hover { color: var(--brass-deep); border-color: var(--brass-deep); }

/* ═══════════════════ AREAS ═══════════════════ */
.areas {
  position: relative;
  background: var(--navy);
  padding-bottom: clamp(4rem, 8vh, 6rem);
  color: var(--cream);
  overflow: hidden;
  isolation: isolate;
}
.areas .section-title { color: var(--cream); }
.areas .section-title em { color: var(--brass-soft); }
.areas .eyebrow { color: var(--brass-soft); }
.areas .section-lede { color: rgba(244,240,234,0.78); }
.areas-bg {
  position: absolute; inset: 0; z-index: -1;
}
.areas-bg-video {
  width: 100%; height: 100%; object-fit: cover; display: block;
  opacity: 0; transition: opacity 1s ease;
}
.areas-bg-video.ready { opacity: 0.55; }
.areas-bg-overlay {
  position: absolute; inset: 0;
  background:
    linear-gradient(180deg, rgba(14,22,32,0.85), rgba(14,22,32,0.55) 35%, rgba(14,22,32,0.8) 100%);
}
.areas .area {
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(244,240,234,0.12);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  color: var(--cream);
}
.areas .area:hover { border-color: var(--brass); background: rgba(255,255,255,0.08); }
.areas .area-num { color: var(--brass-soft); }
.areas .area-name { color: var(--cream); }
.areas .area-towns { color: rgba(244,240,234,0.6); }
.areas .area-desc { color: rgba(244,240,234,0.84); }
.areas .area-stats { border-top-color: rgba(244,240,234,0.18); }
.areas .area-stats strong { color: var(--brass-soft); }
.areas .area-stats small { color: rgba(244,240,234,0.6); }
.areas-grid {
  max-width: var(--max); margin: 0 auto;
  padding: 0 var(--pad-x);
  display: grid; grid-template-columns: 1fr 1fr;
  gap: clamp(1.5rem, 3vw, 3rem);
}
@media (max-width: 900px) { .areas-grid { grid-template-columns: 1fr; } }
.area {
  background: var(--white);
  border: 1px solid var(--line);
  border-radius: 16px;
  padding: clamp(1.6rem, 3vw, 2.6rem);
  display: flex; flex-direction: column; gap: 0.85rem;
  transition: transform var(--t-med) var(--ease-cine), border-color var(--t-med) var(--ease-cine);
}
.area:hover { transform: translateY(-4px); border-color: var(--brass); }
.area-num {
  font-family: 'Cormorant Garamond', serif; font-style: italic;
  font-weight: 400; font-size: 1.1rem;
  color: var(--brass-deep);
}
.area-name {
  font-family: 'Cormorant Garamond', serif;
  font-weight: 500; font-size: clamp(1.6rem, 2.5vw, 2.2rem);
  line-height: 1.05; color: var(--ink);
}
.area-towns {
  font-size: 0.84rem; color: var(--ink-muted);
  letter-spacing: 0.04em; line-height: 1.55;
}
.area-desc {
  font-size: 0.96rem; color: var(--ink-soft);
  line-height: 1.6;
}
.area-stats {
  display: flex; gap: 2.2rem; flex-wrap: wrap;
  margin-top: 1rem; padding-top: 1.1rem;
  border-top: 1px solid var(--line);
}
.area-stats span { display: flex; flex-direction: column; gap: 0.2rem; }
.area-stats strong {
  font-family: 'Cormorant Garamond', serif; font-weight: 500;
  font-size: 1.5rem; color: var(--brass-deep); line-height: 1;
}
.area-stats small {
  font-size: 0.7rem; letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--ink-muted);
}

/* ═══════════════════ APPROACH ═══════════════════ */
.approach {
  background: var(--navy); color: var(--cream);
  padding-bottom: clamp(5rem, 10vh, 8rem);
}
.approach .section-title { color: var(--cream); }
.approach .section-title em { color: var(--brass-soft); }
.approach .eyebrow { color: var(--brass-soft); }
.approach .section-lede { color: rgba(244, 240, 234, 0.78); }

.steps {
  max-width: var(--max); margin: 0 auto;
  padding: 0 var(--pad-x);
  list-style: none;
  display: grid; grid-template-columns: repeat(5, 1fr);
  gap: clamp(1rem, 2vw, 2rem);
}
@media (max-width: 1000px) { .steps { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 600px)  { .steps { grid-template-columns: 1fr; } }
.step {
  padding: 1.6rem 0 1.6rem;
  border-top: 1px solid rgba(244, 240, 234, 0.18);
  display: flex; flex-direction: column; gap: 0.6rem;
  position: relative;
  transition: border-color var(--t-med) var(--ease);
}
.step:hover { border-color: var(--brass); }
.step-num {
  font-family: 'Cormorant Garamond', serif; font-style: italic;
  font-size: 0.9rem; color: var(--brass-soft);
  letter-spacing: 0.1em;
}
.step h4 {
  font-family: 'Cormorant Garamond', serif; font-weight: 500;
  font-size: 1.4rem; line-height: 1.15; color: var(--cream);
}
.step p {
  font-size: 0.92rem; color: rgba(244, 240, 234, 0.78);
  line-height: 1.55;
}

/* ═══════════════════ TESTI ═══════════════════ */
.testi {
  background: var(--paper);
  padding: clamp(5rem, 10vh, 8rem) var(--pad-x);
  text-align: center;
}
.testi-quote {
  max-width: 880px; margin: 0 auto;
  font-family: 'Cormorant Garamond', serif;
  font-style: italic; font-weight: 400;
  font-size: clamp(1.5rem, 3vw, 2.4rem);
  line-height: 1.35;
  color: var(--ink);
  position: relative;
}
.testi-quote::before {
  content: "“";
  display: block;
  font-family: 'Cormorant Garamond', serif;
  font-size: clamp(4rem, 10vw, 7rem); line-height: 0.6;
  color: var(--brass);
  margin-bottom: 0.5rem;
}
.testi-quote footer {
  margin-top: 2rem;
  font-family: 'Inter', sans-serif; font-style: normal;
  font-size: 0.84rem; letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--ink-muted);
  font-weight: 500;
}
.testi-quote footer em {
  font-family: 'Cormorant Garamond', serif; font-style: italic;
  letter-spacing: 0.02em; text-transform: none;
  color: var(--brass-deep);
}

/* ═══════════════════ CONTACT ═══════════════════ */
.contact {
  background: var(--cream);
  padding: clamp(4rem, 8vh, 6rem) var(--pad-x) clamp(6rem, 12vh, 9rem);
}
.contact-inner {
  max-width: var(--max); margin: 0 auto;
  display: grid; grid-template-columns: 1fr 1.1fr;
  gap: clamp(2rem, 4vw, 5rem);
  align-items: start;
}
@media (max-width: 900px) { .contact-inner { grid-template-columns: 1fr; } }

.contact-text { display: flex; flex-direction: column; gap: 1.25rem; }
.contact-text .eyebrow { margin-bottom: 0.5rem; }
.contact-text .section-lede { margin-top: 0.5rem; }

.contact-direct {
  list-style: none;
  display: flex; flex-direction: column; gap: 0.4rem;
  margin-top: 1.5rem;
}
.contact-direct a {
  display: flex; justify-content: space-between; align-items: baseline;
  padding: 1rem 0;
  border-bottom: 1px solid var(--line);
  transition: padding var(--t-fast) var(--ease), color var(--t-fast) var(--ease);
}
.contact-direct a:hover { padding-left: 0.6rem; color: var(--brass-deep); }
.contact-direct .lbl {
  font-size: 0.72rem; letter-spacing: 0.2em; text-transform: uppercase;
  color: var(--ink-muted);
}
.contact-direct .val {
  font-family: 'Cormorant Garamond', serif;
  font-size: 1.15rem; color: var(--ink);
  font-weight: 500;
}

.contact-form {
  background: var(--white);
  border: 1px solid var(--line);
  border-radius: 18px;
  padding: clamp(1.6rem, 3vw, 2.6rem);
  display: flex; flex-direction: column; gap: 1rem;
  box-shadow: 0 20px 60px -30px rgba(14, 22, 32, 0.25);
}
.prop-banner {
  display: flex; align-items: center; gap: 0.6rem;
  padding: 0.7rem 0.85rem;
  background: var(--navy); color: var(--cream);
  border-radius: 10px;
  font-size: 0.85rem;
}
.prop-banner .pb-icon { color: var(--brass-soft); font-size: 0.9rem; }
.prop-banner .pb-txt b { color: var(--brass-soft); font-weight: 500; }
.prop-banner .pb-txt em { font-style: italic; color: var(--brass-soft); }
.prop-banner .pb-clear {
  margin-left: auto;
  width: 24px; height: 24px;
  display: grid; place-items: center;
  background: rgba(255,255,255,0.1); color: var(--cream);
  border-radius: 50%; font-size: 1rem; line-height: 1;
}
.prop-banner .pb-clear:hover { background: rgba(255,255,255,0.2); }
.prop-ref {
  position: absolute; bottom: 0.85rem; right: 1rem;
  background: rgba(14, 22, 32, 0.72);
  color: var(--brass-soft);
  font-family: 'Inter', sans-serif;
  font-size: 0.62rem; letter-spacing: 0.16em; text-transform: uppercase;
  padding: 0.32rem 0.6rem; border-radius: 999px;
  backdrop-filter: blur(8px);
  font-weight: 500;
}
.cf-row { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; }
@media (max-width: 540px) { .cf-row { grid-template-columns: 1fr; } }
.cf-field { display: flex; flex-direction: column; gap: 0.35rem; }
.cf-field span {
  font-size: 0.7rem; letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--ink-muted); font-weight: 500;
}
.cf-field input, .cf-field select, .cf-field textarea {
  padding: 0.75rem 0.9rem;
  border: 1px solid var(--line);
  border-radius: 10px;
  background: var(--paper);
  font-size: 0.95rem;
  transition: border-color var(--t-fast) var(--ease), background var(--t-fast) var(--ease);
}
.cf-field input:focus, .cf-field select:focus, .cf-field textarea:focus {
  outline: none;
  border-color: var(--brass);
  background: var(--white);
}
.cf-field textarea { resize: vertical; min-height: 4rem; font-family: inherit; }
.cf-full { grid-column: 1 / -1; }
.cf-check {
  display: flex; align-items: flex-start; gap: 0.55rem;
  font-size: 0.78rem; color: var(--ink-muted); line-height: 1.45;
  margin-top: 0.5rem;
}
.cf-check input { margin-top: 0.18rem; accent-color: var(--brass); }
.cf-submit { width: 100%; justify-content: center; margin-top: 0.5rem; }
.cf-submit:hover span { transform: translateX(4px); }
.cf-foot {
  font-size: 0.74rem; color: var(--ink-muted); text-align: center;
  letter-spacing: 0.04em;
}

/* ═══════════════════ FOOTER ═══════════════════ */
.foot {
  background: var(--navy); color: var(--cream);
  padding: clamp(3rem, 6vh, 5rem) var(--pad-x) 1.6rem;
}
.foot-grid {
  max-width: var(--max); margin: 0 auto;
  display: grid; grid-template-columns: 1.5fr 1fr 1fr 1fr;
  gap: clamp(1.5rem, 3vw, 3rem);
  padding-bottom: 3rem;
  border-bottom: 1px solid rgba(244, 240, 234, 0.16);
}
@media (max-width: 800px) { .foot-grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 500px) { .foot-grid { grid-template-columns: 1fr; } }
.foot-brand { display: flex; flex-direction: column; gap: 0.6rem; max-width: 320px; }
.foot-mark {
  font-family: 'Cormorant Garamond', serif; font-style: italic;
  font-weight: 500; font-size: 1.4rem; color: var(--brass-soft);
  letter-spacing: 0.06em;
}
.foot-brand h4 {
  font-family: 'Cormorant Garamond', serif; font-weight: 500;
  font-size: 1.4rem;
}
.foot-brand p {
  font-size: 0.88rem; color: rgba(244, 240, 234, 0.78);
  line-height: 1.55;
}
.foot-grid h5 {
  font-size: 0.72rem; letter-spacing: 0.22em; text-transform: uppercase;
  font-weight: 500; color: var(--brass-soft);
  margin-bottom: 0.85rem;
}
.foot-grid a {
  display: block;
  font-size: 0.88rem; color: rgba(244, 240, 234, 0.85);
  padding: 0.35rem 0;
  transition: color var(--t-fast) var(--ease);
}
.foot-grid a:hover { color: var(--brass-soft); }
.foot-mini {
  max-width: var(--max); margin: 0 auto;
  display: flex; justify-content: space-between; gap: 1rem;
  padding-top: 1.6rem;
  font-size: 0.72rem; letter-spacing: 0.12em; text-transform: uppercase;
  color: rgba(244, 240, 234, 0.5);
  flex-wrap: wrap;
}

/* ═══════════════════ FAB WhatsApp ═══════════════════ */
.fab-wa {
  position: fixed; right: 18px; bottom: 18px; z-index: 60;
  display: inline-flex; align-items: center; justify-content: center;
  width: 56px; height: 56px;
  background: #25D366; color: #fff;
  border-radius: 999px;
  box-shadow: 0 10px 28px -8px rgba(20, 40, 20, 0.45), 0 2px 6px rgba(0, 0, 0, 0.12);
  transition: transform var(--t-fast) var(--ease), box-shadow var(--t-fast) var(--ease);
}
.fab-wa:hover { transform: translateY(-2px); box-shadow: 0 14px 36px -8px rgba(20, 40, 20, 0.55); }
.fab-wa svg { width: 26px; height: 26px; }

/* ═══════════════════ RESPONSIVE NAV ═══════════════════ */
@media (max-width: 960px) {
  .nav-links { display: none; }
  .nav-cta { display: none; }
  .nav-burger { display: block; }
}
@media (max-width: 640px) {
  .lang-toggle { padding: 0.4rem 0.55rem; }
  .lang-code { display: none; }
}

/* ═══════════════════ ACCESSIBILITY ═══════════════════ */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
  }
  .hero-media { clip-path: none; }
  .reveal { opacity: 1; transform: none; }
  .marquee-track { animation: none; }
}

/* Print */
@media print {
  .nav, .fab-wa, .hero-scroll, .marquee, .loader { display: none !important; }
  body { background: white; color: black; }
}

/* ═══════════ FAQ ═══════════ */
.faq {
  max-width: 1100px;
  margin: 0 auto;
  padding: clamp(4rem, 8vw, 7rem) clamp(1rem, 4vw, 3rem) clamp(3rem, 6vw, 5rem);
}
.faq-list {
  display: flex; flex-direction: column; gap: 0.5rem;
  margin-top: clamp(2rem, 4vw, 3rem);
}
.faq-item {
  border-top: 1px solid var(--line);
  padding: 1.25rem 0;
}
.faq-item:last-child { border-bottom: 1px solid var(--line); }
.faq-item summary {
  list-style: none;
  cursor: pointer;
  display: flex; align-items: center; justify-content: space-between; gap: 1.5rem;
  font-family: 'Cormorant Garamond', serif;
  font-weight: 500;
  font-size: clamp(1.15rem, 1.9vw, 1.5rem);
  color: var(--ink);
  letter-spacing: -0.005em;
  transition: color var(--t-fast) var(--ease);
}
.faq-item summary::-webkit-details-marker { display: none; }
.faq-item summary:hover { color: var(--brass-deep); }
.faq-toggle {
  font-family: 'Inter', sans-serif;
  font-weight: 300;
  font-size: 1.4rem;
  line-height: 1;
  color: var(--brass);
  flex-shrink: 0;
  transition: transform var(--t-fast) var(--ease);
}
.faq-item[open] .faq-toggle { transform: rotate(45deg); }
.faq-item p {
  margin-top: 0.9rem;
  font-size: 0.98rem;
  line-height: 1.65;
  color: var(--ink-soft);
  max-width: 70ch;
}

/* ═══════════ Footer SEO ═══════════ */
.foot-seo {
  border-top: 1px solid rgba(255,255,255,0.08);
  padding: 2rem 0 1.5rem;
  margin-top: 2rem;
}
.foot-seo h5 {
  font-size: 0.7rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  font-weight: 500;
  color: rgba(255,255,255,0.5);
  margin-bottom: 0.9rem;
}
.foot-tags {
  font-size: 0.78rem;
  line-height: 1.9;
  color: rgba(255,255,255,0.6);
}
.foot-tags a {
  color: rgba(255,255,255,0.7);
  text-decoration: none;
  transition: color var(--t-fast) var(--ease);
}
.foot-tags a:hover { color: var(--brass-soft); }
.foot-microcopy {
  margin-top: 1rem;
  font-size: 0.72rem;
  line-height: 1.7;
  color: rgba(255,255,255,0.4);
  max-width: 78ch;
}
.foot-mini a {
  color: rgba(255,255,255,0.5);
  text-decoration: none;
}
.foot-mini a:hover { color: var(--brass-soft); }
