/* ============================================================
   GIMÉNEZ ZAPIOLA — Sistema de diseño
   Versión 1.0 | 2025
   
   TIPOGRAFÍAS:
   - Principal: Milligram (titulares y CTAs)
     → Agregar archivos .woff2 en /fonts/ cuando el cliente
       proporcione la licencia de uso web.
   - Secundaria: Inter (cuerpos y subtítulos)
     → Cargada desde Google Fonts.
   ============================================================ */

/* ── @font-face Milligram (activar cuando se tengan los archivos) ── */
/*
@font-face {
  font-family: 'Milligram';
  src: url('../fonts/Milligram-Light.woff2') format('woff2');
  font-weight: 300; font-style: normal; font-display: swap;
}
@font-face {
  font-family: 'Milligram';
  src: url('../fonts/Milligram-Regular.woff2') format('woff2');
  font-weight: 400; font-style: normal; font-display: swap;
}
@font-face {
  font-family: 'Milligram';
  src: url('../fonts/Milligram-Medium.woff2') format('woff2');
  font-weight: 500; font-style: normal; font-display: swap;
}
@font-face {
  font-family: 'Milligram';
  src: url('../fonts/Milligram-Bold.woff2') format('woff2');
  font-weight: 700; font-style: normal; font-display: swap;
}
*/

/* ── Variables de Diseño ── */
:root {
  /* Paleta principal */
  --gz-red:        #9f2019;
  --gz-red-dark:   #7a1812;
  --gz-red-light:  #b5261e;
  --gz-black:      #202020;
  --gz-black-deep: #141414;
  --gz-cream:      #edece2;
  --gz-cream-dark: #e0dfd4;
  --gz-white:      #ffffff;

  /* Paleta secundaria */
  --gz-olive:      #7a7960;
  --gz-olive-dark: #5d5b47;
  --gz-slate:      #4d4f5a;
  --gz-slate-dark: #3a3b44;
  --gz-sky:        #ccd7df;
  --gz-sky-light:  #e5edf2;

  /* Tipografía */
  --font-heading:  'Milligram', 'Outfit', 'Inter', sans-serif;
  --font-body:     'Inter', 'Outfit', sans-serif;

  /* Espaciado */
  --spacing-xs:    4px;
  --spacing-sm:    8px;
  --spacing-md:    16px;
  --spacing-lg:    24px;
  --spacing-xl:    40px;
  --spacing-2xl:   64px;
  --spacing-3xl:   96px;
  --spacing-4xl:   128px;

  /* Layout */
  --container-max: 1280px;
  --container-pad: 24px;
  --navbar-h:      80px;

  /* Radios */
  --radius-sm:     2px;
  --radius-md:     4px;
  --radius-lg:     8px;

  /* Transiciones */
  --transition:    250ms cubic-bezier(0.25, 0.46, 0.45, 0.94);
  --transition-slow: 500ms cubic-bezier(0.25, 0.46, 0.45, 0.94);

  /* Sombras */
  --shadow-sm:     0 2px 12px rgba(0,0,0,0.06);
  --shadow-md:     0 8px 32px rgba(0,0,0,0.10);
  --shadow-lg:     0 20px 60px rgba(0,0,0,0.15);
  --shadow-card:   0 4px 24px rgba(0,0,0,0.08);
}

/* ── Reset ── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; font-size: 16px; -webkit-font-smoothing: antialiased; }
body {
  font-family: var(--font-body);
  font-weight: 300;
  color: var(--gz-black);
  background: var(--gz-white);
  overflow-x: hidden;
  line-height: 1.6;
}
html { overflow-x: hidden; }
img { display: block; max-width: 100%; }
a { text-decoration: none; color: inherit; }
ul { list-style: none; }
button { cursor: pointer; border: none; background: none; font-family: inherit; }
input, select, textarea { font-family: inherit; outline: none; }

/* ── Tipografía ── */
h1, h2, h3, h4, h5 {
  font-family: var(--font-heading);
  line-height: 1.05;
  letter-spacing: -0.02em;
  font-weight: 500;
}
h1 { font-size: clamp(3rem, 7vw, 5.5rem); }
h2 { font-size: clamp(2rem, 4vw, 3.25rem); line-height: 1.1; }
h3 { font-size: clamp(1.2rem, 2vw, 1.6rem); letter-spacing: -0.01em; line-height: 1.25; }
h4 { font-size: 1.1rem; letter-spacing: 0; }
p  { font-size: 1rem; font-weight: 300; line-height: 1.75; color: inherit; }

/* ── Contenedor ── */
.container {
  max-width: var(--container-max);
  margin-inline: auto;
  padding-inline: var(--container-pad);
}

/* ── Utilidades de sección ── */
.section--cream     { background: var(--gz-cream); }
.section--dark      { background: var(--gz-black); color: var(--gz-cream); }
.section--dark-alt  { background: var(--gz-black-deep); color: var(--gz-cream); }
.section--red       { background: var(--gz-red); color: var(--gz-cream); }
.section--black     { background: #0f0f0f; color: var(--gz-cream); }
.section--slate     { background: var(--gz-slate); color: var(--gz-cream); }

/* ── Eyebrow ── */
.eyebrow {
  display: inline-block;
  font-family: var(--font-body);
  font-size: 0.7rem;
  font-weight: 500;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--gz-red);
  margin-bottom: var(--spacing-md);
}
.eyebrow--light  { color: var(--gz-cream); opacity: 0.7; }
.eyebrow--cream  { color: var(--gz-cream); opacity: 0.8; }

/* ── Section Header ── */
.section-header {
  margin-bottom: var(--spacing-2xl);
  max-width: 640px;
}
.section-header h2 { margin-bottom: var(--spacing-md); }
.section-subtitle {
  font-size: 1.05rem;
  font-weight: 300;
  opacity: 0.65;
  max-width: 520px;
}

/* ── Botones ── */
.btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-family: var(--font-body);
  font-size: 0.875rem;
  font-weight: 500;
  letter-spacing: 0.04em;
  padding: 14px 28px;
  border-radius: var(--radius-sm);
  transition: all var(--transition);
  white-space: nowrap;
}
.btn svg { flex-shrink: 0; transition: transform var(--transition); }
.btn:hover svg { transform: translateX(3px); }

.btn-primary {
  background: var(--gz-red);
  color: var(--gz-cream);
}
.btn-primary:hover {
  background: var(--gz-black-deep);
  transform: translateY(-1px);
  box-shadow: 0 8px 24px rgba(20,20,20,0.25);
}

.btn-outline {
  border: 1.5px solid currentColor;
  color: var(--gz-black);
}
.btn-outline:hover {
  background: var(--gz-black);
  color: var(--gz-cream);
  border-color: var(--gz-black);
}
.btn-outline--light {
  color: var(--gz-cream);
}
.btn-outline--light:hover {
  background: var(--gz-cream);
  color: var(--gz-black);
  border-color: var(--gz-cream);
}

.btn-whatsapp {
  background: transparent;
  border: 1.5px solid currentColor;
  color: var(--gz-black);
  padding: 10px 20px;
  font-size: 0.8rem;
  border-radius: 100px;
}
.btn-whatsapp:hover {
  background: var(--gz-black);
  color: var(--gz-cream);
  border-color: var(--gz-black);
}
.btn-full { width: 100%; justify-content: center; }

/* ── Textura Dotwork ── */
.dotwork {
  position: relative;
}
.dotwork::after {
  content: '';
  position: absolute;
  inset: 0;
  background-image: radial-gradient(circle, rgba(255,255,255,0.07) 1px, transparent 1px);
  background-size: 18px 18px;
  pointer-events: none;
  z-index: 1;
}

/* ────────────────────────────────────────
   NAVBAR
──────────────────────────────────────── */
.navbar {
  position: fixed;
  top: 0; left: 0; right: 0;
  z-index: 10000;
  height: var(--navbar-h);
  background: rgba(255,255,255,0.97);
  backdrop-filter: blur(12px);
  box-shadow: 0 1px 0 rgba(0,0,0,0.07);
  transition: all var(--transition);
}
.navbar.scrolled {
  box-shadow: 0 2px 12px rgba(0,0,0,0.1);
}
.navbar .nav-link { color: rgba(32,32,32,0.75); }
.navbar .nav-link:hover { color: var(--gz-red); }
.navbar .btn-whatsapp { color: var(--gz-black); }
.navbar .btn-whatsapp:hover { color: var(--gz-cream); }

/* Logos: solo se usa navbar__logo en estado normal */
.logo-dark  { display: block; }
.logo-light { display: none; }

.navbar__container {
  max-width: var(--container-max);
  margin-inline: auto;
  padding-inline: var(--container-pad);
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  position: relative;
}
.navbar__logo {
  position: relative;
  display: flex;
  align-items: center;
  height: 36px;
  z-index: 1;
}
.navbar__logo img { height: 58px; width: auto; max-width: 240px; object-fit: contain; }

.navbar__nav { flex: 1; display: flex; justify-content: center; }
.navbar__links {
  display: flex;
  gap: var(--spacing-xl);
  align-items: center;
}
.nav-link {
  font-size: 0.825rem;
  font-weight: 400;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: rgba(237,236,226,0.85);
  transition: color var(--transition);
  position: relative;
}
.nav-link::after {
  content: '';
  position: absolute;
  bottom: -4px; left: 0; right: 0;
  height: 1px;
  background: var(--gz-red);
  transform: scaleX(0);
  transform-origin: left;
  transition: transform var(--transition);
}
.nav-link:hover { color: var(--gz-cream); }
.nav-link:hover::after { transform: scaleX(1); }

.navbar__actions { display: flex; align-items: center; gap: var(--spacing-md); }

/* Navbar siempre blanca: los logos PNG tienen fondo sólido */
.navbar:not(.scrolled) .btn-whatsapp {
  color: var(--gz-black);
  border-color: rgba(32,32,32,0.2);
}
.navbar:not(.scrolled) .btn-whatsapp:hover {
  color: var(--gz-cream);
  border-color: var(--gz-black);
}

/* Hamburger */
.navbar__hamburger {
  display: none;
  flex-direction: column;
  gap: 5px;
  width: 24px;
  padding: 4px;
}
.navbar__hamburger span {
  display: block;
  width: 100%; height: 1.5px;
  background: var(--gz-black);
  transition: all var(--transition);
}
.navbar__hamburger.active span:nth-child(1) { transform: translateY(6.5px) rotate(45deg); }
.navbar__hamburger.active span:nth-child(2) { opacity: 0; }
.navbar__hamburger.active span:nth-child(3) { transform: translateY(-6.5px) rotate(-45deg); }

/* Mobile Menu */
.mobile-menu {
  display: none;
  position: fixed;
  inset: 0;
  background: #1a1a1a;
  z-index: 9999;
  flex-direction: column;
  justify-content: center;
  padding: 80px var(--container-pad) var(--spacing-3xl);
  opacity: 0;
  transform: translateX(100%);
  transition: opacity var(--transition-slow), transform var(--transition-slow);
}
.mobile-menu.open {
  display: flex;
  opacity: 1;
  transform: translateX(0);
}
/* Botón cerrar dentro del menú */
.mobile-menu__close {
  position: absolute;
  top: 20px;
  right: 20px;
  width: 44px; height: 44px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(237,236,226,0.08);
  border: 1px solid rgba(237,236,226,0.15);
  border-radius: 50%;
  color: var(--gz-cream);
  cursor: pointer;
  transition: background var(--transition), border-color var(--transition);
}
.mobile-menu__close:hover {
  background: rgba(159,32,25,0.3);
  border-color: var(--gz-red);
}
.mobile-menu ul { display: flex; flex-direction: column; gap: var(--spacing-lg); }
.mobile-menu a {
  font-family: var(--font-heading);
  font-size: clamp(1.6rem, 7vw, 2.4rem);
  font-weight: 400;
  color: var(--gz-cream);
  letter-spacing: -0.02em;
  transition: color var(--transition);
  display: inline-block;
}
.mobile-menu a:hover,
.mobile-menu a:focus { color: var(--gz-red); outline: none; }

/* ────────────────────────────────────────
   HERO
──────────────────────────────────────── */
.hero {
  position: relative;
  min-height: 100svh;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  padding-bottom: clamp(60px, 10vh, 100px);
  overflow: hidden;
}
.hero__bg {
  position: absolute;
  inset: 0;
  background: var(--gz-black-deep);
  z-index: 0;
}
/* Video de fondo */
.hero__video {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  opacity: 0.38;
  z-index: 0;
}
/* Overlay sobre el video para mantener legibilidad */
.hero__video-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(160deg, rgba(10,10,10,0.55) 0%, rgba(20,20,20,0.45) 100%);
  z-index: 1;
}
/* Gradiente editorial: negro profundo con toque cálido */
.hero__bg::before {
  content: '';
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse 80% 60% at 70% 30%, rgba(159,32,25,0.08) 0%, transparent 60%),
    radial-gradient(ellipse 60% 80% at 20% 80%, rgba(122,121,96,0.06) 0%, transparent 50%),
    linear-gradient(180deg, #141414 0%, #1a1a1a 50%, #0f0f0f 100%);
  z-index: 0;
}
/* Dotwork texture */
.hero__dots {
  position: absolute;
  inset: 0;
  background-image: radial-gradient(circle, rgba(237,236,226,0.055) 1px, transparent 1px);
  background-size: 20px 20px;
}
/* Degradado inferior para legibilidad del search */
.hero__bg::after {
  content: '';
  position: absolute;
  bottom: 0; left: 0; right: 0;
  height: 40%;
  background: linear-gradient(to top, rgba(10,10,10,0.7) 0%, transparent 100%);
}
.hero__content {
  position: relative;
  z-index: 2;
  max-width: var(--container-max);
  margin-inline: auto;
  padding-inline: var(--container-pad);
  width: 100%;
  padding-top: var(--navbar-h);
  padding-top: calc(var(--navbar-h) + 40px);
}
.hero__badge {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: 0.72rem;
  font-weight: 400;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: rgba(237,236,226,0.55);
  margin-bottom: var(--spacing-xl);
}
.hero__badge::before {
  content: '';
  display: block;
  width: 24px; height: 1px;
  background: var(--gz-red);
}
.hero__title {
  color: var(--gz-cream);
  font-weight: 400;
  margin-bottom: var(--spacing-xl);
  max-width: 820px;
}
.hero__subtitle {
  font-size: clamp(0.95rem, 1.5vw, 1.1rem);
  font-weight: 300;
  color: rgba(237,236,226,0.6);
  max-width: 520px;
  margin-bottom: var(--spacing-3xl);
  line-height: 1.8;
}

/* Search Bar */
.hero__search { max-width: 720px; }
.search-tabs {
  display: flex;
  gap: 0;
  margin-bottom: 0;
}
.search-tab {
  font-size: 0.8rem;
  font-weight: 500;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  padding: 10px 20px;
  color: rgba(237,236,226,0.5);
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(237,236,226,0.1);
  border-bottom: none;
  transition: all var(--transition);
  cursor: pointer;
}
.search-tab:first-child { border-radius: var(--radius-sm) 0 0 0; }
.search-tab:last-child  { border-radius: 0 var(--radius-sm) 0 0; }
.search-tab.active {
  background: rgba(237,236,226,0.08);
  color: var(--gz-cream);
  border-color: rgba(237,236,226,0.2);
}
.search-form {
  display: flex;
  gap: 0;
  background: rgba(237,236,226,0.06);
  border: 1px solid rgba(237,236,226,0.15);
  backdrop-filter: blur(8px);
}
.search-input-group {
  flex: 1;
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 0 20px;
  border-right: 1px solid rgba(237,236,226,0.1);
  position: relative;
}
.search-icon { color: rgba(237,236,226,0.35); flex-shrink: 0; }
.search-input {
  flex: 1;
  background: none;
  border: none;
  color: var(--gz-cream);
  font-size: 0.9rem;
  font-weight: 300;
  padding: 18px 0;
}
.search-input::placeholder { color: rgba(237,236,226,0.35); }
.search-select-group {
  position: relative;
  display: flex;
  align-items: center;
  min-width: 200px;
  border-right: 1px solid rgba(237,236,226,0.1);
}
.search-select {
  appearance: none;
  background: none;
  border: none;
  color: rgba(237,236,226,0.7);
  font-size: 0.875rem;
  font-weight: 300;
  padding: 18px 44px 18px 20px;
  width: 100%;
  cursor: pointer;
}
.search-select option { background: var(--gz-black); color: var(--gz-cream); }
.chevron {
  position: absolute;
  right: 14px;
  color: rgba(237,236,226,0.4);
  pointer-events: none;
}
.search-btn {
  border-radius: 0;
  padding: 18px 28px;
}

/* Scroll indicator */
.hero__scroll {
  position: absolute;
  bottom: var(--spacing-xl);
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  z-index: 2;
}
.scroll-line {
  display: block;
  width: 1px; height: 40px;
  background: linear-gradient(to bottom, rgba(237,236,226,0.4), transparent);
  animation: scrollLine 2s ease-in-out infinite;
}
@keyframes scrollLine {
  0%, 100% { transform: scaleY(1); opacity: 0.5; }
  50%       { transform: scaleY(0.6); opacity: 0.2; }
}
.scroll-text {
  font-size: 0.65rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: rgba(237,236,226,0.3);
}

/* ────────────────────────────────────────
   SECCIÓN: SERVICIOS
──────────────────────────────────────── */
.section-servicios {
  padding: var(--spacing-4xl) 0;
}
.servicios-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--spacing-lg);
}
.servicio-card {
  display: flex;
  flex-direction: column;
  padding: var(--spacing-2xl) var(--spacing-xl);
  background: var(--gz-white);
  border: 1px solid rgba(32,32,32,0.08);
  border-radius: var(--radius-md);
  transition: all var(--transition);
  position: relative;
  overflow: hidden;
}
.servicio-card::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 2px;
  background: var(--gz-red);
  transform: scaleX(0);
  transform-origin: left;
  transition: transform var(--transition-slow);
}
.servicio-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-lg);
  border-color: transparent;
}
.servicio-card:hover::before { transform: scaleX(1); }
.servicio-card__icon {
  width: 60px; height: 60px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(159,32,25,0.06);
  border-radius: var(--radius-md);
  margin-bottom: var(--spacing-xl);
  color: var(--gz-red);
  transition: background var(--transition);
}
.servicio-card:hover .servicio-card__icon { background: rgba(159,32,25,0.1); }
.servicio-card__content { flex: 1; display: flex; flex-direction: column; }
.servicio-card__tag {
  font-size: 0.68rem;
  font-weight: 500;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--gz-red);
  margin-bottom: var(--spacing-md);
}
.servicio-card h3 {
  font-size: 1.25rem;
  margin-bottom: var(--spacing-md);
  color: var(--gz-black);
}
.servicio-card p {
  font-size: 0.9rem;
  color: rgba(32,32,32,0.6);
  flex: 1;
  margin-bottom: var(--spacing-xl);
}
.servicio-card__cta {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 0.8rem;
  font-weight: 500;
  letter-spacing: 0.06em;
  color: var(--gz-red);
  transition: gap var(--transition);
  margin-top: auto;
}
.servicio-card__cta svg { transition: transform var(--transition); }
.servicio-card:hover .servicio-card__cta gap { gap: 12px; }
.servicio-card:hover .servicio-card__cta svg { transform: translateX(4px); }

/* ────────────────────────────────────────
   SECCIÓN: PROPIEDADES DESTACADAS
──────────────────────────────────────── */
.section-propiedades {
  padding: var(--spacing-4xl) 0;
  background: var(--gz-red);
}
.propiedades-filtros {
  display: flex;
  gap: var(--spacing-xs);
  margin-bottom: var(--spacing-2xl);
  flex-wrap: wrap;
}
.filtro-btn {
  font-size: 0.78rem;
  font-weight: 400;
  letter-spacing: 0.06em;
  padding: 9px 18px;
  border-radius: 100px;
  border: 1px solid rgba(32,32,32,0.15);
  color: rgba(32,32,32,0.5);
  transition: all var(--transition);
}
.filtro-btn:hover {
  border-color: var(--gz-red);
  color: var(--gz-red);
}
.filtro-btn.active {
  background: var(--gz-black);
  border-color: var(--gz-black);
  color: var(--gz-cream);
}

/* Filtros sobre fondo rojo */
.section-propiedades .section-header h2,
.section-propiedades .section-header .eyebrow,
.section-propiedades .section-subtitle { color: var(--gz-cream); }
.section-propiedades .section-header .eyebrow { opacity: 0.75; }
.section-propiedades .section-subtitle { opacity: 0.7; }
.section-propiedades .filtro-btn {
  border-color: rgba(237,236,226,0.35);
  color: rgba(237,236,226,0.75);
}
.section-propiedades .filtro-btn:hover {
  border-color: var(--gz-cream);
  color: var(--gz-cream);
}
.section-propiedades .filtro-btn.active {
  background: var(--gz-cream);
  border-color: var(--gz-cream);
  color: var(--gz-black);
}
.section-propiedades .btn-outline {
  border-color: var(--gz-cream);
  color: var(--gz-cream);
}
.section-propiedades .btn-outline:hover {
  background: var(--gz-cream);
  color: var(--gz-black);
}

.propiedades-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--spacing-xl);
  margin-bottom: var(--spacing-2xl);
}
.section-cta { text-align: center; }

/* Property Card */
.prop-card {
  background: var(--gz-white);
  border-radius: var(--radius-md);
  overflow: hidden;
  box-shadow: var(--shadow-card);
  transition: all var(--transition);
  display: flex;
  flex-direction: column;
  opacity: 1;
}
.prop-card.hidden { display: none; }
.prop-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-lg);
}
.prop-card__image {
  position: relative;
  height: 420px;
  background-size: cover;
  background-position: center;
  overflow: hidden;
  transition: transform var(--transition-slow);
}
.prop-card:hover .prop-card__image {
  transform: scale(1.02);
}
.prop-card__image::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(0,0,0,0.18) 0%, transparent 40%);
}
.prop-card__badges {
  position: absolute;
  top: 16px; left: 16px;
  display: flex;
  gap: 6px;
  z-index: 2;
}
.prop-badge {
  font-size: 0.65rem;
  font-weight: 500;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  padding: 5px 10px;
  border-radius: 2px;
}
.prop-badge--venta   { background: var(--gz-red);   color: var(--gz-cream); }
.prop-badge--alquiler{ background: var(--gz-black);  color: var(--gz-cream); }
/* sobre imagen de card: glassmorphism */
.prop-card .prop-badge--dest { background: rgba(255,255,255,0.18); color: var(--gz-cream); border: 1px solid rgba(255,255,255,0.3); backdrop-filter: blur(4px); }
/* sobre fondo blanco (propiedad.html) */
.prop-badge--dest { background: var(--gz-black); color: var(--gz-cream); border: none; }

/* Price overlay — removed, price now lives in footer */
.prop-card__price-overlay { display: none; }
.prop-card__price {
  font-family: var(--font-heading);
  font-size: 1.35rem;
  font-weight: 500;
  color: var(--gz-black);
  letter-spacing: -0.02em;
  line-height: 1;
}

.prop-card__content {
  padding: 20px 22px 22px;
  flex: 1;
  display: flex;
  flex-direction: column;
}
.prop-card__meta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 6px;
}
.prop-card__barrio {
  font-size: 0.85rem;
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--gz-red);
}
.prop-card__tipo {
  font-size: 0.68rem;
  font-weight: 400;
  letter-spacing: 0.06em;
  color: rgba(32,32,32,0.4);
  text-transform: uppercase;
}
.prop-card__title {
  font-family: var(--font-heading);
  font-size: 1rem;
  font-weight: 400;
  letter-spacing: -0.01em;
  color: var(--gz-black);
  margin-bottom: 10px;
  line-height: 1.3;
}
.prop-card__specs {
  display: flex;
  gap: var(--spacing-md);
  flex-wrap: wrap;
}
.prop-spec {
  display: flex;
  align-items: center;
  gap: 5px;
  font-size: 0.78rem;
  font-weight: 400;
  color: rgba(32,32,32,0.45);
}
.prop-spec svg { color: rgba(32,32,32,0.3); flex-shrink: 0; }
.prop-card__footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-top: 14px;
  padding-top: 14px;
  border-top: 1px solid rgba(32,32,32,0.06);
}
.prop-card__cta {
  font-size: 0.78rem;
  font-weight: 500;
  color: var(--gz-red);
  display: flex;
  align-items: center;
  gap: 4px;
  transition: gap var(--transition);
}
.prop-card:hover .prop-card__cta { gap: 8px; }
.prop-card__cta svg { transition: transform var(--transition); }
.prop-card:hover .prop-card__cta svg { transform: translateX(3px); }

/* ────────────────────────────────────────
   SECCIÓN: NOSOTROS
──────────────────────────────────────── */
.section-nosotros {
  padding: var(--spacing-4xl) 0;
  position: relative;
  overflow: hidden;
}
.section-nosotros::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image: radial-gradient(circle, rgba(237,236,226,0.04) 1px, transparent 1px);
  background-size: 20px 20px;
}

/* Intro heading */
.nosotros-intro {
  max-width: 640px;
  margin-bottom: var(--spacing-3xl);
  position: relative;
  z-index: 1;
}
.nosotros-intro h2 {
  color: var(--gz-cream);
  margin-bottom: var(--spacing-lg);
}
.nosotros-intro p {
  color: rgba(237,236,226,0.6);
  font-size: 1rem;
}

/* Timeline */
.trayectoria-timeline {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 0;
  border-top: 1px solid rgba(237,236,226,0.12);
}
.trayectoria-item {
  padding: var(--spacing-xl) var(--spacing-2xl) var(--spacing-2xl) 0;
  border-right: 1px solid rgba(237,236,226,0.1);
}
.trayectoria-item:not(:first-child) {
  padding-left: var(--spacing-2xl);
}
.trayectoria-item:last-child {
  border-right: none;
  padding-right: 0;
}
.trayectoria-year {
  font-family: var(--font-heading);
  font-size: clamp(2.6rem, 4vw, 3.8rem);
  font-weight: 500;
  color: var(--gz-red);
  letter-spacing: -0.04em;
  line-height: 1;
  margin-bottom: var(--spacing-lg);
  display: block;
}
.trayectoria-content p {
  font-size: 0.85rem;
  font-weight: 300;
  color: rgba(237,236,226,0.55);
  line-height: 1.75;
}
.trayectoria-item--hoy .trayectoria-year {
  color: var(--gz-cream);
  opacity: 0.9;
}
.trayectoria-item--hoy .trayectoria-content p {
  color: rgba(237,236,226,0.72);
}

/* Legacy stat styles (kept for possible reuse) */
.nosotros-stats {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--spacing-lg);
}
.stat-card {
  padding: var(--spacing-xl) var(--spacing-xl);
  border: 1px solid rgba(237,236,226,0.1);
  background: rgba(237,236,226,0.03);
  display: flex;
  flex-direction: column;
  gap: 6px;
  transition: border-color var(--transition);
}
.stat-card:hover { border-color: rgba(159,32,25,0.4); }
.stat-number {
  font-family: var(--font-heading);
  font-size: 2.8rem;
  font-weight: 500;
  color: var(--gz-red);
  letter-spacing: -0.04em;
  line-height: 1;
}
.stat-label {
  font-size: 0.75rem;
  font-weight: 300;
  color: rgba(237,236,226,0.5);
  letter-spacing: 0.08em;
}

/* ────────────────────────────────────────
   SECCIÓN: VALORES
──────────────────────────────────────── */
.section-valores {
  padding: var(--spacing-4xl) 0;
}
.valores-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--spacing-lg);
}
.valor-card {
  padding: var(--spacing-xl) var(--spacing-lg);
  position: relative;
}
.valor-card::after {
  content: '';
  position: absolute;
  top: 0; left: 0;
  width: 1px; height: 100%;
  background: rgba(32,32,32,0.12);
}
.valor-card:first-child::after { display: none; }
.valor-card__icon {
  color: var(--gz-red);
  margin-bottom: var(--spacing-lg);
}
.valor-tag {
  display: block;
  font-size: 0.68rem;
  font-weight: 500;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: rgba(32,32,32,0.4);
  margin-bottom: var(--spacing-sm);
}
.valor-card h3 {
  font-size: 1.1rem;
  margin-bottom: var(--spacing-md);
  color: var(--gz-black);
}
.valor-card p {
  font-size: 0.875rem;
  color: rgba(32,32,32,0.55);
  line-height: 1.7;
}

/* ────────────────────────────────────────
   SECCIÓN: BARRIOS
──────────────────────────────────────── */
.section-barrios {
  padding: var(--spacing-4xl) 0;
  position: relative;
  overflow: hidden;
}
.section-barrios::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image: radial-gradient(circle, rgba(237,236,226,0.07) 1px, transparent 1px);
  background-size: 18px 18px;
  pointer-events: none;
}
.barrios-header {
  position: relative;
  z-index: 1;
  max-width: 640px;
  margin-bottom: var(--spacing-3xl);
}
.barrios-header h2 { color: var(--gz-cream); margin-bottom: var(--spacing-lg); }
.barrios-header p  { color: rgba(237,236,226,0.65); font-size: 0.95rem; }
.barrios-grid {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 1px;
  background: rgba(237,236,226,0.15);
  border: 1px solid rgba(237,236,226,0.15);
  position: relative;
  z-index: 1;
}
.barrio-item {
  display: flex;
  flex-direction: column;
  gap: 6px;
  padding: var(--spacing-xl) var(--spacing-lg);
  background: var(--gz-red);
  transition: background var(--transition);
  cursor: default;
}
.barrio-item:hover { background: var(--gz-red-dark); }
.barrio-nombre {
  font-family: var(--font-heading);
  font-size: 1.05rem;
  font-weight: 500;
  color: var(--gz-cream);
  letter-spacing: -0.01em;
}
.barrio-desc {
  font-size: 0.75rem;
  color: rgba(237,236,226,0.6);
  line-height: 1.4;
}

/* ────────────────────────────────────────
   SECCIÓN: PROPIETARIOS CTA
──────────────────────────────────────── */
.section-propietarios {
  padding: var(--spacing-4xl) 0;
  position: relative;
  overflow: hidden;
}
.section-propietarios::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image: radial-gradient(circle, rgba(237,236,226,0.04) 1px, transparent 1px);
  background-size: 20px 20px;
}
.section-propietarios .container {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: var(--spacing-3xl);
  align-items: center;
  position: relative;
  z-index: 1;
}
.propietarios-content h2 {
  color: var(--gz-cream);
  max-width: 640px;
  margin-bottom: var(--spacing-xl);
}
.propietarios-content p {
  color: rgba(237,236,226,0.6);
  max-width: 540px;
  margin-bottom: var(--spacing-2xl);
}
.propietarios-ctas { display: flex; gap: var(--spacing-md); flex-wrap: wrap; }
.propietarios-visual {
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
}
.gz-monogram {
  font-family: var(--font-heading);
  font-size: clamp(6rem, 10vw, 10rem);
  font-weight: 700;
  color: rgba(159,32,25,0.12);
  line-height: 1;
  letter-spacing: -0.04em;
  user-select: none;
  pointer-events: none;
  position: relative;
}
.gz-monogram span { font-size: 0.3em; vertical-align: super; }

/* ────────────────────────────────────────
   SECCIÓN: BLOG
──────────────────────────────────────── */
.section-blog {
  padding: var(--spacing-4xl) 0;
  background: var(--gz-white);
}
.blog-grid {
  display: grid;
  grid-template-columns: 1.4fr 1fr 1fr;
  gap: var(--spacing-lg);
}
.blog-card {
  display: flex;
  flex-direction: column;
  border-radius: var(--radius-md);
  overflow: hidden;
  background: var(--gz-white);
  border: 1px solid rgba(32,32,32,0.08);
  transition: all var(--transition);
}
.blog-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-md);
  border-color: transparent;
}
.blog-card__image {
  position: relative;
  height: 220px;
}
.blog-card--featured .blog-card__image { height: 280px; }
.blog-card__image--1 { background: linear-gradient(135deg, var(--gz-slate) 0%, var(--gz-black) 100%); }
.blog-card__image--2 { background: linear-gradient(135deg, var(--gz-olive) 0%, var(--gz-olive-dark) 100%); }
.blog-card__image--3 { background: linear-gradient(135deg, var(--gz-red) 0%, var(--gz-red-dark) 100%); }
.blog-card__category {
  position: absolute;
  top: 14px; left: 14px;
  font-size: 0.68rem;
  font-weight: 500;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--gz-cream);
  background: rgba(0,0,0,0.4);
  padding: 5px 10px;
  border-radius: var(--radius-sm);
  backdrop-filter: blur(4px);
}
.blog-card__content {
  padding: var(--spacing-xl);
  flex: 1;
  display: flex;
  flex-direction: column;
}
.blog-card__date {
  font-size: 0.72rem;
  color: rgba(32,32,32,0.4);
  letter-spacing: 0.06em;
  margin-bottom: var(--spacing-sm);
}
.blog-card h3 {
  font-size: 1.05rem;
  font-weight: 400;
  margin-bottom: var(--spacing-md);
  color: var(--gz-black);
  line-height: 1.35;
}
.blog-card p {
  font-size: 0.875rem;
  color: rgba(32,32,32,0.55);
  flex: 1;
  margin-bottom: var(--spacing-lg);
}
.blog-card__link {
  font-size: 0.8rem;
  font-weight: 500;
  color: var(--gz-red);
  letter-spacing: 0.04em;
  transition: letter-spacing var(--transition);
  margin-top: auto;
}
.blog-card:hover .blog-card__link { letter-spacing: 0.08em; }

/* ────────────────────────────────────────
   SECCIÓN: CONTACTO
──────────────────────────────────────── */
.section-contacto { padding: var(--spacing-4xl) 0; }
.contacto-grid {
  display: grid;
  grid-template-columns: 1fr 1.2fr;
  gap: var(--spacing-4xl);
  align-items: start;
}
.contacto-info h2 { margin-bottom: var(--spacing-lg); }
.contacto-info > p {
  color: rgba(32,32,32,0.6);
  margin-bottom: var(--spacing-2xl);
}
.contacto-data {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-lg);
  margin-bottom: var(--spacing-2xl);
}
.contacto-item {
  display: flex;
  align-items: flex-start;
  gap: var(--spacing-md);
  transition: opacity var(--transition);
}
a.contacto-item:hover { opacity: 0.75; }
.contacto-item__icon {
  width: 40px; height: 40px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(159,32,25,0.06);
  border-radius: var(--radius-sm);
  color: var(--gz-red);
  flex-shrink: 0;
}
.contacto-item__label {
  display: block;
  font-size: 0.7rem;
  font-weight: 500;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: rgba(32,32,32,0.4);
  margin-bottom: 2px;
}
.contacto-item__value {
  display: block;
  font-size: 0.9rem;
  font-weight: 400;
  color: var(--gz-black);
}
.contacto-social {
  display: flex;
  gap: var(--spacing-md);
}
.social-link {
  width: 40px; height: 40px;
  display: flex;
  align-items: center;
  justify-content: center;
  border: 1px solid rgba(32,32,32,0.15);
  border-radius: var(--radius-sm);
  color: rgba(32,32,32,0.5);
  transition: all var(--transition);
}
.social-link:hover {
  background: var(--gz-black);
  border-color: var(--gz-black);
  color: var(--gz-cream);
}

/* Formulario */
.contacto-form {
  background: var(--gz-white);
  padding: var(--spacing-2xl);
  border: 1px solid rgba(32,32,32,0.08);
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-sm);
}
.form-group {
  margin-bottom: var(--spacing-lg);
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.form-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--spacing-lg);
}
label {
  font-size: 0.78rem;
  font-weight: 500;
  letter-spacing: 0.06em;
  color: rgba(32,32,32,0.6);
}
input, select, textarea {
  padding: 13px 16px;
  border: 1px solid rgba(32,32,32,0.15);
  border-radius: var(--radius-sm);
  font-size: 0.9rem;
  font-weight: 300;
  color: var(--gz-black);
  background: var(--gz-white);
  transition: border-color var(--transition), box-shadow var(--transition);
  width: 100%;
}
input:focus, select:focus, textarea:focus {
  border-color: var(--gz-red);
  box-shadow: 0 0 0 3px rgba(159,32,25,0.08);
}
input::placeholder, textarea::placeholder { color: rgba(32,32,32,0.3); }
textarea { resize: vertical; min-height: 120px; }
select { appearance: none; cursor: pointer; }
.form-success {
  display: none;
  text-align: center;
  padding: var(--spacing-2xl);
  color: var(--gz-black);
}
.form-success.visible { display: block; }
.form-success svg { color: var(--gz-red); margin: 0 auto var(--spacing-md); }

/* ────────────────────────────────────────
   FOOTER
──────────────────────────────────────── */
.footer {
  padding: var(--spacing-3xl) 0 var(--spacing-xl);
}
.footer__top {
  display: grid;
  grid-template-columns: 1fr 2fr;
  gap: var(--spacing-4xl);
  margin-bottom: var(--spacing-3xl);
  padding-bottom: var(--spacing-3xl);
  border-bottom: 1px solid rgba(237,236,226,0.08);
}
.footer__brand {}
.footer__logo { height: 40px; width: auto; max-width: 200px; object-fit: contain; margin-bottom: var(--spacing-lg); }
.footer__brand p {
  font-size: 0.875rem;
  color: rgba(237,236,226,0.45);
  line-height: 1.7;
  margin-bottom: var(--spacing-xl);
}
.footer__social { display: flex; gap: var(--spacing-md); }
.footer__social a {
  width: 36px; height: 36px;
  display: flex;
  align-items: center;
  justify-content: center;
  border: 1px solid rgba(237,236,226,0.15);
  border-radius: var(--radius-sm);
  color: rgba(237,236,226,0.45);
  transition: all var(--transition);
}
.footer__social a:hover {
  border-color: rgba(159,32,25,0.6);
  color: var(--gz-red);
}
.footer__nav {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--spacing-xl);
}
.footer__col h4 {
  font-size: 0.72rem;
  font-weight: 500;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: rgba(237,236,226,0.5);
  margin-bottom: var(--spacing-lg);
}
.footer__col ul { display: flex; flex-direction: column; gap: 10px; }
.footer__col a {
  font-size: 0.875rem;
  color: rgba(237,236,226,0.45);
  transition: color var(--transition);
}
.footer__col a:hover { color: var(--gz-cream); }
.footer__bottom {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: var(--spacing-md);
  flex-wrap: wrap;
}
.footer__bottom p {
  font-size: 0.78rem;
  color: rgba(237,236,226,0.25);
}

/* ────────────────────────────────────────
   ANIMACIONES DE SCROLL
──────────────────────────────────────── */
[data-animate] {
  opacity: 0;
  transform: translateY(24px);
  transition: opacity 0.7s cubic-bezier(0.25,0.46,0.45,0.94), transform 0.7s cubic-bezier(0.25,0.46,0.45,0.94);
}
[data-animate].animated {
  opacity: 1;
  transform: translateY(0);
}
[data-delay="100"] { transition-delay: 0.1s; }
[data-delay="200"] { transition-delay: 0.2s; }
[data-delay="300"] { transition-delay: 0.3s; }
[data-delay="400"] { transition-delay: 0.4s; }
[data-delay="500"] { transition-delay: 0.5s; }

/* ────────────────────────────────────────
   RESPONSIVE
──────────────────────────────────────── */
@media (max-width: 1100px) {
  .valores-grid        { grid-template-columns: repeat(2, 1fr); }
  .barrios-grid        { grid-template-columns: repeat(3, 1fr); }
  .propiedades-grid    { grid-template-columns: repeat(2, 1fr); }
  .servicios-grid      { gap: var(--spacing-md); }
}
@media (max-width: 900px) {
  .blog-grid           { grid-template-columns: 1fr; }
  .nosotros-grid       { grid-template-columns: 1fr; gap: var(--spacing-2xl); }
  .trayectoria-timeline { grid-template-columns: repeat(2, 1fr); }
  .trayectoria-item:nth-child(odd) { padding-left: 0 !important; }
  .trayectoria-item:nth-child(2) { border-right: none; }
  .trayectoria-item:nth-child(4) { border-right: none; }
  .footer__top         { grid-template-columns: 1fr; }
  .footer__nav         { grid-template-columns: repeat(2, 1fr); }
  .section-propietarios .container { grid-template-columns: 1fr; }
  .propietarios-visual { display: none; }
  .contacto-grid       { grid-template-columns: 1fr; }
  .servicios-grid      { grid-template-columns: 1fr; }
}
@media (max-width: 768px) {
  :root { --spacing-4xl: 72px; --spacing-3xl: 56px; }
  .navbar__nav   { display: none; }
  .navbar__hamburger { display: flex; }
  .propiedades-grid  { grid-template-columns: 1fr; }
  .prop-card__image  { height: 300px; }
  .prop-card__price  { font-size: 1.4rem; }
  .barrios-grid      { grid-template-columns: repeat(2, 1fr); }
  .valores-grid      { grid-template-columns: 1fr; }
  .hero__search      { max-width: 100%; }
  .search-form       { flex-direction: column; border: none; }
  .search-input-group,
  .search-select-group {
    border: 1px solid rgba(237,236,226,0.15);
    border-right: 1px solid rgba(237,236,226,0.15);
    border-bottom: none;
    background: rgba(237,236,226,0.06);
  }
  .search-btn        { width: 100%; justify-content: center; border-radius: 0 0 var(--radius-sm) var(--radius-sm); }
  .form-row          { grid-template-columns: 1fr; gap: var(--spacing-md); }
  .blog-grid         { grid-template-columns: 1fr; }
  .footer__nav       { grid-template-columns: 1fr; }
  .propietarios-ctas { flex-direction: column; }
}
@media (max-width: 480px) {
  .barrios-grid { grid-template-columns: 1fr; }
  .trayectoria-timeline { grid-template-columns: 1fr; }
  .trayectoria-item { border-right: none; border-bottom: 1px solid rgba(237,236,226,0.08); padding-bottom: var(--spacing-xl); padding-left: 0 !important; }
  .trayectoria-item:last-child { border-bottom: none; }
  .nosotros-stats { grid-template-columns: 1fr 1fr; }
  .stat-number { font-size: 2.2rem; }
  .stat-card { padding: var(--spacing-lg) var(--spacing-md); }
  /* Navbar: logo más chico, ocultar texto del botón WA */
  .navbar__logo img { max-width: 140px; height: 36px; }
  .btn-whatsapp > span { display: none; }
  .btn-whatsapp { padding: 8px 12px; min-width: unset; }
  /* Hero badge: reducir letter-spacing en mobile */
  .hero__badge { letter-spacing: 0.1em; font-size: 0.65rem; }
  /* Autocomplete: no desbordar el viewport */
  .search-autocomplete { left: 0; width: 100%; max-width: 100%; }
  /* Nosotros: asegurar que el texto no desborde */
  .nosotros-content h2 { font-size: clamp(1.6rem, 7vw, 2.4rem); }
  /* Page header breadcrumb: más visible */
  .page-header__breadcrumb { font-size: 0.7rem; }
}

/* ════════════════════════════════════════
   SEARCH AUTOCOMPLETE
════════════════════════════════════════ */
.search-autocomplete {
  position: absolute;
  top: calc(100% + 2px);
  left: -21px;
  width: calc(100% + 42px);
  max-width: calc(100vw - 48px);
  background: #1c1c1c;
  border: 1px solid rgba(237,236,226,0.18);
  border-top: none;
  max-height: 260px;
  overflow-y: auto;
  z-index: 300;
  display: none;
  scrollbar-width: thin;
  scrollbar-color: rgba(159,32,25,0.4) transparent;
}
.search-autocomplete.open { display: block; }
.autocomplete-item {
  padding: 11px 20px;
  font-size: 0.875rem;
  color: rgba(237,236,226,0.7);
  cursor: pointer;
  display: flex;
  align-items: center;
  gap: 10px;
  transition: background var(--transition), color var(--transition);
  border-bottom: 1px solid rgba(237,236,226,0.05);
}
.autocomplete-item:last-child { border-bottom: none; }
.autocomplete-item:hover,
.autocomplete-item.focused {
  background: rgba(159,32,25,0.14);
  color: var(--gz-cream);
}
.autocomplete-icon { color: rgba(159,32,25,0.55); flex-shrink: 0; }
.autocomplete-type {
  font-size: 0.66rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: rgba(237,236,226,0.3);
  margin-left: auto;
  white-space: nowrap;
}

/* Light-theme autocomplete (propiedades page) */
.autocomplete-light {
  background: var(--gz-white);
  border-color: rgba(32,32,32,0.15);
  border-top: none;
  top: calc(100%);
  left: 0;
  width: 100%;
}
.autocomplete-light .autocomplete-item { color: rgba(32,32,32,0.75); border-color: rgba(32,32,32,0.06); }
.autocomplete-light .autocomplete-item:hover,
.autocomplete-light .autocomplete-item.focused {
  background: rgba(159,32,25,0.06);
  color: var(--gz-black);
}
.autocomplete-light .autocomplete-icon { color: rgba(159,32,25,0.45); }
.autocomplete-light .autocomplete-type { color: rgba(32,32,32,0.35); }

/* ════════════════════════════════════════
   FLOATING WHATSAPP BUTTON
════════════════════════════════════════ */
.whatsapp-float {
  position: fixed;
  bottom: 32px;
  right: 32px;
  z-index: 500;
  display: flex;
  align-items: center;
  gap: 10px;
  background: var(--gz-black);
  color: var(--gz-cream);
  padding: 14px 20px 14px 16px;
  border-radius: 100px;
  box-shadow: 0 8px 32px rgba(0,0,0,0.3);
  transition: background var(--transition), transform var(--transition), box-shadow var(--transition);
  text-decoration: none;
  overflow: hidden;
}
.whatsapp-float:hover {
  background: var(--gz-black-deep);
  transform: translateY(-3px);
  box-shadow: 0 16px 48px rgba(0,0,0,0.35);
}
.whatsapp-float svg { flex-shrink: 0; }
.whatsapp-float__label {
  font-size: 0.82rem;
  font-weight: 500;
  letter-spacing: 0.04em;
  white-space: nowrap;
}
.whatsapp-float__pulse {
  position: absolute;
  inset: 0;
  border-radius: 100px;
  background: var(--gz-red);
  opacity: 0;
  animation: waPulse 4s ease-in-out infinite;
  animation-delay: 3s;
  pointer-events: none;
}
@keyframes waPulse {
  0%   { transform: scale(1);    opacity: 0; }
  50%  { transform: scale(1.06); opacity: 0.1; }
  100% { transform: scale(1),   opacity: 0; }
}
@media (max-width: 480px) {
  .whatsapp-float { padding: 14px; border-radius: 50%; }
  .whatsapp-float__label { display: none; }
}

/* ════════════════════════════════════════
   PAGE HEADER (propiedades / propiedad)
════════════════════════════════════════ */
.page-header {
  padding: calc(var(--navbar-h) + 52px) 0 44px;
  background: var(--gz-black);
  color: var(--gz-cream);
  position: relative;
  overflow: hidden;
}
.page-header::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image: radial-gradient(circle, rgba(237,236,226,0.04) 1px, transparent 1px);
  background-size: 20px 20px;
}
.page-header::after {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse 70% 80% at 80% 50%, rgba(159,32,25,0.07) 0%, transparent 60%);
}
.page-header .container { position: relative; z-index: 1; }
.page-header__breadcrumb {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 0.76rem;
  color: rgba(237,236,226,0.65);
  margin-bottom: 16px;
  letter-spacing: 0.04em;
  flex-wrap: wrap;
}
.page-header__breadcrumb a {
  color: rgba(237,236,226,0.65);
  transition: color var(--transition);
}
.page-header__breadcrumb a:hover { color: var(--gz-red); }
.page-header__breadcrumb .sep { opacity: 0.3; }
.page-header h1 {
  font-size: clamp(2rem, 4vw, 2.8rem);
  color: var(--gz-cream);
  font-weight: 400;
  margin-bottom: 10px;
}
.page-header p {
  color: rgba(237,236,226,0.5);
  font-size: 1rem;
}

/* ════════════════════════════════════════
   PROPIEDADES PAGE: FILTER BAR
════════════════════════════════════════ */
.pf-searchbar {
  background: var(--gz-cream);
  padding: 18px 0;
  border-bottom: 1px solid rgba(32,32,32,0.1);
  position: sticky;
  top: var(--navbar-h);
  z-index: 50;
}
.pf-bar {
  display: flex;
  gap: 10px;
  align-items: center;
  flex-wrap: wrap;
}
.pf-tabs {
  display: flex;
  background: rgba(32,32,32,0.1);
  border-radius: 100px;
  padding: 3px;
  flex-shrink: 0;
}
.pf-tab {
  font-size: 0.78rem;
  font-weight: 500;
  letter-spacing: 0.06em;
  padding: 8px 18px;
  border-radius: 100px;
  color: rgba(32,32,32,0.5);
  transition: all var(--transition);
  white-space: nowrap;
}
.pf-tab.active {
  background: var(--gz-black);
  color: var(--gz-cream);
}
.pf-input-wrap {
  position: relative;
  flex: 1;
  min-width: 200px;
}
.pf-input-icon {
  position: absolute;
  left: 12px;
  top: 50%;
  transform: translateY(-50%);
  color: rgba(32,32,32,0.35);
  pointer-events: none;
}
.pf-input {
  width: 100%;
  padding: 11px 16px 11px 38px;
  border: 1px solid rgba(32,32,32,0.15);
  border-radius: var(--radius-sm);
  font-size: 0.875rem;
  background: var(--gz-white);
  color: var(--gz-black);
  transition: border-color var(--transition);
}
.pf-input:focus { border-color: var(--gz-red); box-shadow: 0 0 0 3px rgba(159,32,25,0.08); }
.pf-select-wrap { position: relative; }
.pf-select-wrap::after {
  content: '';
  position: absolute;
  right: 12px;
  top: 50%;
  transform: translateY(-50%);
  width: 0; height: 0;
  border-left: 4px solid transparent;
  border-right: 4px solid transparent;
  border-top: 5px solid rgba(32,32,32,0.4);
  pointer-events: none;
}
.pf-select {
  padding: 11px 36px 11px 14px;
  border: 1px solid rgba(32,32,32,0.15);
  border-radius: var(--radius-sm);
  font-size: 0.875rem;
  background: var(--gz-white);
  color: var(--gz-black);
  appearance: none;
  cursor: pointer;
  min-width: 150px;
  transition: border-color var(--transition);
}
.pf-select:focus { border-color: var(--gz-red); box-shadow: 0 0 0 3px rgba(159,32,25,0.08); }
.pf-search-btn {
  background: var(--gz-red);
  color: var(--gz-cream);
  padding: 11px 24px;
  border-radius: var(--radius-sm);
  font-size: 0.875rem;
  font-weight: 500;
  display: flex;
  align-items: center;
  gap: 8px;
  white-space: nowrap;
  transition: background var(--transition), transform var(--transition), box-shadow var(--transition);
  cursor: pointer;
  border: none;
  font-family: inherit;
}
.pf-search-btn:hover {
  background: var(--gz-red-dark);
  transform: translateY(-1px);
  box-shadow: 0 6px 20px rgba(159,32,25,0.3);
}
.pf-active-filters {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  margin-top: 12px;
  min-height: 0;
}
.filter-chip {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 5px 10px 5px 12px;
  background: rgba(159,32,25,0.08);
  border: 1px solid rgba(159,32,25,0.2);
  border-radius: 100px;
  font-size: 0.75rem;
  font-weight: 500;
  color: var(--gz-red);
  cursor: pointer;
  transition: all var(--transition);
  font-family: inherit;
}
.filter-chip:hover { background: rgba(159,32,25,0.15); }
.filter-chip__remove {
  width: 16px; height: 16px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(159,32,25,0.15);
  border-radius: 50%;
  color: var(--gz-red);
  font-size: 11px;
  line-height: 1;
  font-style: normal;
}

/* ════════════════════════════════════════
   PROPIEDADES PAGE: MAIN CONTENT
════════════════════════════════════════ */
.propiedades-page-main {
  padding: var(--spacing-3xl) 0 var(--spacing-4xl);
  background: #f8f8f6;
  min-height: 60vh;
}
.results-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: var(--spacing-xl);
  gap: var(--spacing-md);
  flex-wrap: wrap;
  padding-bottom: var(--spacing-lg);
  border-bottom: 1px solid rgba(32,32,32,0.08);
}
.results-count {
  font-size: 0.875rem;
  color: rgba(32,32,32,0.55);
}
.results-count strong { color: var(--gz-black); font-weight: 600; }
.sort-select {
  padding: 8px 30px 8px 12px;
  border: 1px solid rgba(32,32,32,0.15);
  border-radius: var(--radius-sm);
  font-size: 0.825rem;
  background: var(--gz-white);
  color: var(--gz-black);
  appearance: none;
  cursor: pointer;
  font-family: inherit;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23666' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 10px center;
}
.no-results {
  text-align: center;
  padding: var(--spacing-4xl) var(--spacing-xl);
  color: rgba(32,32,32,0.5);
}
.no-results svg { margin: 0 auto var(--spacing-lg); color: rgba(32,32,32,0.15); }
.no-results h3 { font-size: 1.3rem; color: var(--gz-black); margin-bottom: var(--spacing-md); }
.no-results p  { margin-bottom: var(--spacing-xl); }
.propiedades-page-main .propiedades-grid { grid-template-columns: repeat(2, 1fr); gap: var(--spacing-xl); }
@media (max-width: 760px)  { .propiedades-page-main .propiedades-grid { grid-template-columns: 1fr; } }

/* ════════════════════════════════════════
   PROPERTY GALLERY (propiedad.html)
════════════════════════════════════════ */
.prop-gallery {
  height: 56vh;
  min-height: 380px;
  max-height: 620px;
  position: relative;
  overflow: hidden;
  background: var(--gz-black);
  margin-top: var(--navbar-h);
}
.gallery-slide {
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center;
  opacity: 0;
  transition: opacity 0.65s ease;
}
.gallery-slide.active { opacity: 1; }
.gallery-nav {
  /* estilos visuales comunes — el posicionamiento va en .gallery-prev / .gallery-next */
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  z-index: 3;
  width: 48px; height: 48px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(0,0,0,0.45);
  border: 1px solid rgba(255,255,255,0.12);
  color: var(--gz-cream);
  border-radius: var(--radius-sm);
  transition: all var(--transition);
  backdrop-filter: blur(4px);
  cursor: pointer;
}
.gallery-dot {
  width: 6px; height: 6px;
  border-radius: 50%;
  background: rgba(237,236,226,0.35);
  cursor: pointer;
  transition: all var(--transition);
  border: none;
}
.gallery-dot.active {
  background: var(--gz-cream);
  width: 22px;
  border-radius: 3px;
}
.gallery-prev,
.gallery-next {
  /* hereda .gallery-nav; solo sobreescribe posición horizontal */
}
.gallery-prev { left: 20px; }
.gallery-next { right: 20px; }
.gallery-prev:hover,
.gallery-next:hover {
  background: rgba(159,32,25,0.85);
  border-color: var(--gz-red);
}
/* Contenedor de los puntos de paginación */
.gallery-dots {
  position: absolute;
  bottom: 20px;
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  gap: 8px;
  align-items: center;
  z-index: 3;
  background: rgba(0,0,0,0.3);
  padding: 6px 10px;
  border-radius: 20px;
  backdrop-filter: blur(4px);
}
.gallery-count {
  position: absolute;
  top: 20px; right: 20px;
  background: rgba(0,0,0,0.5);
  color: var(--gz-cream);
  font-size: 0.78rem;
  letter-spacing: 0.06em;
  padding: 6px 12px;
  border-radius: var(--radius-sm);
  backdrop-filter: blur(4px);
  z-index: 3;
}
.gallery-placeholder-label {
  position: absolute;
  bottom: 52px;
  left: 50%;
  transform: translateX(-50%);
  font-size: 0.72rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: rgba(237,236,226,0.4);
  z-index: 3;
  pointer-events: none;
  white-space: nowrap;
}

/* Cursor pointer en slides clickeables */
.gallery-slide[data-img-idx] { cursor: zoom-in; }

/* Hint "clic para ampliar" */
.gallery-zoom-hint {
  position: absolute;
  bottom: 58px;
  left: 20px;
  display: flex;
  align-items: center;
  gap: 6px;
  background: rgba(0,0,0,0.55);
  color: rgba(237,236,226,0.85);
  font-size: 0.72rem;
  letter-spacing: 0.06em;
  padding: 6px 12px;
  border-radius: 20px;
  backdrop-filter: blur(4px);
  z-index: 4;
  pointer-events: none;
  transition: opacity 0.6s ease;
}
.gallery-zoom-hint.hide { opacity: 0; }

/* ════════════════════════════════════════
   LIGHTBOX
════════════════════════════════════════ */
.lightbox {
  position: fixed;
  inset: 0;
  z-index: 99999;
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  transition: opacity 0.28s ease;
}
.lightbox.open    { opacity: 1; }
.lightbox.closing { opacity: 0; pointer-events: none; }

.lightbox__backdrop {
  position: absolute;
  inset: 0;
  background: rgba(8,8,8,0.94);
  backdrop-filter: blur(8px);
  cursor: zoom-out;
}

/* Imagen principal */
.lightbox__stage {
  position: relative;
  z-index: 2;
  max-width: 90vw;
  max-height: 82vh;
  display: flex;
  align-items: center;
  justify-content: center;
}
.lightbox__img {
  max-width: 90vw;
  max-height: 82vh;
  object-fit: contain;
  border-radius: 4px;
  opacity: 0;
  transition: opacity 0.3s ease;
  box-shadow: 0 24px 80px rgba(0,0,0,0.6);
  display: block;
  user-select: none;
}
.lightbox__img.loaded { opacity: 1; }

/* Spinner de carga */
.lightbox__spinner {
  position: absolute;
  width: 36px; height: 36px;
  border: 2px solid rgba(237,236,226,0.15);
  border-top-color: var(--gz-red);
  border-radius: 50%;
  animation: lbSpin 0.7s linear infinite;
}
@keyframes lbSpin { to { transform: rotate(360deg); } }

/* Botón cerrar */
.lightbox__close {
  position: absolute;
  top: 20px; right: 20px;
  z-index: 3;
  width: 44px; height: 44px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(237,236,226,0.08);
  border: 1px solid rgba(237,236,226,0.18);
  border-radius: 50%;
  color: rgba(237,236,226,0.8);
  cursor: pointer;
  transition: background var(--transition), border-color var(--transition), color var(--transition);
}
.lightbox__close:hover {
  background: rgba(159,32,25,0.5);
  border-color: var(--gz-red);
  color: var(--gz-cream);
}

/* Flechas prev/next */
.lightbox__nav {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  z-index: 3;
  width: 52px; height: 52px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(237,236,226,0.07);
  border: 1px solid rgba(237,236,226,0.14);
  border-radius: 50%;
  color: rgba(237,236,226,0.8);
  cursor: pointer;
  transition: background var(--transition), border-color var(--transition), color var(--transition), transform var(--transition);
}
.lightbox__nav:hover {
  background: rgba(159,32,25,0.5);
  border-color: var(--gz-red);
  color: var(--gz-cream);
  transform: translateY(-50%) scale(1.06);
}
.lightbox__prev { left: 20px; }
.lightbox__next { right: 20px; }

/* Contador */
.lightbox__counter {
  position: absolute;
  top: 24px;
  left: 50%;
  transform: translateX(-50%);
  z-index: 3;
  font-size: 0.78rem;
  letter-spacing: 0.1em;
  color: rgba(237,236,226,0.55);
  background: rgba(0,0,0,0.35);
  padding: 5px 14px;
  border-radius: 20px;
  backdrop-filter: blur(4px);
  white-space: nowrap;
}

/* Thumbnails */
.lightbox__thumbs {
  position: absolute;
  bottom: 20px;
  left: 50%;
  transform: translateX(-50%);
  z-index: 3;
  display: flex;
  gap: 6px;
  max-width: 90vw;
  overflow-x: auto;
  padding: 6px 8px;
  background: rgba(0,0,0,0.4);
  border-radius: 10px;
  backdrop-filter: blur(4px);
  scrollbar-width: none;
}
.lightbox__thumbs::-webkit-scrollbar { display: none; }
.lb-thumb {
  flex-shrink: 0;
  width: 54px; height: 40px;
  border-radius: 4px;
  overflow: hidden;
  border: 2px solid transparent;
  cursor: pointer;
  transition: border-color var(--transition), opacity var(--transition);
  opacity: 0.5;
  padding: 0;
  background: none;
}
.lb-thumb img { width: 100%; height: 100%; object-fit: cover; display: block; pointer-events: none; }
.lb-thumb:hover { opacity: 0.8; }
.lb-thumb.active { border-color: var(--gz-red); opacity: 1; }

@media (max-width: 600px) {
  .lightbox__prev { left: 8px; }
  .lightbox__next { right: 8px; }
  .lightbox__nav  { width: 40px; height: 40px; }
  .lightbox__img  { max-height: 70vh; }
  .lightbox__thumbs { bottom: 10px; }
}

/* ════════════════════════════════════════
   PROPERTY DETAIL LAYOUT
════════════════════════════════════════ */
.prop-detail-section {
  padding: var(--spacing-3xl) 0;
  background: var(--gz-white);
}
.prop-detail-grid {
  display: grid;
  grid-template-columns: 1fr 360px;
  gap: var(--spacing-3xl);
  align-items: start;
}
.prop-detail-breadcrumb {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 0.76rem;
  color: rgba(32,32,32,0.4);
  margin-bottom: var(--spacing-xl);
  flex-wrap: wrap;
}
.prop-detail-breadcrumb a { color: rgba(32,32,32,0.4); transition: color var(--transition); }
.prop-detail-breadcrumb a:hover { color: var(--gz-red); }
.prop-detail__badges { display: flex; gap: 8px; margin-bottom: var(--spacing-lg); flex-wrap: wrap; }
.prop-detail__barrio {
  font-size: 0.7rem;
  font-weight: 500;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--gz-red);
  margin-bottom: 8px;
}
.prop-detail__title {
  font-size: clamp(1.6rem, 3vw, 2.2rem);
  font-weight: 400;
  letter-spacing: -0.02em;
  color: var(--gz-black);
  margin-bottom: var(--spacing-xl);
  line-height: 1.15;
}
.prop-detail__specs-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1px;
  background: rgba(32,32,32,0.08);
  border: 1px solid rgba(32,32,32,0.08);
  border-radius: var(--radius-sm);
  overflow: hidden;
  margin-bottom: var(--spacing-2xl);
}
.prop-detail__spec-item {
  padding: var(--spacing-lg);
  background: var(--gz-white);
  display: flex;
  flex-direction: column;
  gap: 3px;
}
.spec-item-label {
  font-size: 0.66rem;
  font-weight: 500;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: rgba(32,32,32,0.4);
}
.spec-item-value {
  font-family: var(--font-heading);
  font-size: 1.4rem;
  font-weight: 500;
  color: var(--gz-black);
  line-height: 1.1;
}
.spec-item-unit {
  font-size: 0.72rem;
  color: rgba(32,32,32,0.4);
}
.prop-detail__section-title {
  font-size: 1rem;
  font-weight: 500;
  letter-spacing: -0.01em;
  margin-bottom: var(--spacing-lg);
  color: var(--gz-black);
  padding-bottom: 10px;
  border-bottom: 1px solid rgba(32,32,32,0.08);
}
.prop-detail__description {
  margin-bottom: var(--spacing-2xl);
}
.prop-detail__description p {
  font-size: 0.925rem;
  color: rgba(32,32,32,0.65);
  line-height: 1.85;
  white-space: pre-line;
}
.amenities-list {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--spacing-sm);
  margin-bottom: var(--spacing-2xl);
}
.amenity-row {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 11px 14px;
  background: rgba(32,32,32,0.03);
  border-radius: var(--radius-sm);
  border: 1px solid rgba(32,32,32,0.06);
  color: rgba(32,32,32,0.65);
  font-size: 0.85rem;
  transition: border-color var(--transition);
}
.amenity-row:hover { border-color: rgba(159,32,25,0.2); }
.amenity-row svg { color: var(--gz-red); flex-shrink: 0; }
.prop-map {
  width: 100%;
  height: 320px;
  border-radius: var(--radius-md);
  overflow: hidden;
  border: 1px solid rgba(32,32,32,0.1);
  margin-bottom: 10px;
}
.prop-map-notice {
  padding: 10px 14px;
  background: rgba(32,32,32,0.04);
  border-radius: var(--radius-sm);
  font-size: 0.76rem;
  color: rgba(32,32,32,0.45);
  display: flex;
  align-items: center;
  gap: 6px;
}

/* Sidebar */
.prop-sidebar {
  position: sticky;
  top: calc(var(--navbar-h) + 24px);
  display: flex;
  flex-direction: column;
  gap: var(--spacing-lg);
}
.prop-sidebar__price-card {
  background: var(--gz-white);
  border: 1px solid rgba(32,32,32,0.1);
  border-radius: var(--radius-md);
  padding: var(--spacing-xl);
  box-shadow: var(--shadow-card);
}
.prop-sidebar__operation {
  font-size: 0.66rem;
  font-weight: 500;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: rgba(32,32,32,0.4);
  margin-bottom: 6px;
}
.prop-sidebar__price {
  font-family: var(--font-heading);
  font-size: 2rem;
  font-weight: 500;
  color: var(--gz-black);
  letter-spacing: -0.03em;
  margin-bottom: var(--spacing-lg);
  line-height: 1;
}
.prop-sidebar__wa-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  width: 100%;
  padding: 14px 20px;
  background: var(--gz-black);
  color: var(--gz-cream);
  border-radius: 100px;
  font-size: 0.875rem;
  font-weight: 500;
  transition: all var(--transition);
  margin-bottom: 10px;
  text-decoration: none;
  letter-spacing: 0.02em;
  border: 1.5px solid var(--gz-black);
}
.prop-sidebar__wa-btn:hover {
  background: var(--gz-black-deep);
  border-color: var(--gz-black-deep);
  transform: translateY(-1px);
  box-shadow: 0 8px 24px rgba(20,20,20,0.25);
}
.prop-sidebar__contact-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  width: 100%;
  padding: 13px;
  background: transparent;
  border: 1.5px solid var(--gz-black);
  color: var(--gz-black);
  border-radius: 100px;
  font-size: 0.875rem;
  font-weight: 500;
  transition: all var(--transition);
  cursor: pointer;
  font-family: inherit;
  letter-spacing: 0.02em;
}
.prop-sidebar__contact-btn:hover {
  background: var(--gz-black);
  color: var(--gz-cream);
}
.prop-sidebar__form-card {
  background: var(--gz-cream);
  border-radius: var(--radius-md);
  padding: var(--spacing-xl);
  border: 1px solid rgba(32,32,32,0.08);
}
.prop-sidebar__form-card h4 {
  font-size: 1rem;
  font-weight: 500;
  letter-spacing: -0.01em;
  margin-bottom: var(--spacing-lg);
  color: var(--gz-black);
}
.prop-sidebar__form-card .form-group { margin-bottom: var(--spacing-md); }
.prop-sidebar__form-card input,
.prop-sidebar__form-card textarea,
.prop-sidebar__form-card select {
  background: var(--gz-white);
  font-size: 0.85rem;
  padding: 11px 14px;
}
.prop-sidebar__form-card textarea { min-height: 80px; }

/* Similar Properties */
.similar-props {
  padding: var(--spacing-3xl) 0 var(--spacing-4xl);
  background: #f8f8f6;
}
.similar-props .section-header { margin-bottom: var(--spacing-2xl); }

/* Responsive: detail page */
@media (max-width: 1000px) {
  .prop-detail-grid { grid-template-columns: 1fr; }
  .prop-sidebar { position: static; }
}
@media (max-width: 768px) {
  .prop-gallery { height: 44vh; min-height: 260px; }
  .amenities-list { grid-template-columns: 1fr 1fr; }
  .prop-detail__specs-grid { grid-template-columns: repeat(2, 1fr); }
  .pf-bar { gap: 8px; }
}
