/* ============================================================
   ARRENDAMIENTOS SANTA FE — Template A: Rojo Santa Fe
   Version 1.0 | Bootstrap 2.x base + custom design system
   ============================================================ */

@import url('fonts.css');

/* ---- Variables ------------------------------------------- */
:root {
  --red:        #F42534;
  --red-dark:   #AC162C;
  --red-deeper: #7A232E;
  --black:      #232222;
  --white:      #FFFFFF;
  --g100:       #F8F8F8;
  --g200:       #EFEFEF;
  --g300:       #D9D9D9;
  --g500:       #999999;
  --g600:       #777777;  /* gris medio — entre g500 y g700 */
  --g700:       #555555;
  --text:       #2A2A2A;
  --shadow-xs:  0 1px 3px rgba(0,0,0,.07);
  --shadow-sm:  0 2px 8px rgba(0,0,0,.09);
  --shadow-md:  0 4px 16px rgba(0,0,0,.10);
  --shadow-lg:  0 8px 32px rgba(0,0,0,.13);
  --r-sm:       4px;
  --r-md:       8px;
  --r-lg:       12px;
  --r-xl:       16px;

  /* ── Spacing tokens (4px grid) ── */
  /* Uso: margin/padding semantico en lugar de valores ad-hoc */
  --sp-1:   4px;   /* micro: separadores, gaps minimos */
  --sp-2:   8px;   /* xs: gaps entre elementos relacionados */
  --sp-3:  12px;   /* sm: padding interno de componentes */
  --sp-4:  16px;   /* md: espaciado estandar entre elementos */
  --sp-6:  24px;   /* lg: seccion interna, grupos */
  --sp-8:  32px;   /* xl: entre secciones */
  --sp-12: 48px;   /* 2xl: secciones mayores */
  --sp-16: 64px;   /* 3xl: separacion de bloques grandes */
  --ease:       cubic-bezier(.4,0,.2,1);
  --t:          .22s;
}

/* ---- Reset & Base ---------------------------------------- */
*, *::before, *::after { box-sizing: border-box; }

html { scroll-behavior: smooth; }

body {
  font-family: 'Avenir', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  font-size: 16px;
  line-height: 1.6;
  color: var(--text);
  background: var(--white);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  margin: 0;
  padding: 0;
}

/* Override Bootstrap 2 font */
h1,h2,h3,h4,h5,h6,
.navbar,
button, input, select, textarea {
  font-family: 'Avenir', -apple-system, sans-serif !important;
}

a { color: var(--red); text-decoration: none; transition: color var(--t) var(--ease); }
a:hover { color: var(--red-dark); }

img { max-width: 100%; height: auto; display: block; }

/* ============================================================
   NAVBAR
   ============================================================ */
#sf-nav {
  position: fixed;
  top: 0; left: 0; right: 0;
  z-index: 1000;
  background: var(--white);
  border-bottom: 1px solid var(--g200);
  box-shadow: var(--shadow-sm);
  height: 96px;
  display: flex;
  align-items: center;
}

#sf-nav .sf-nav__inner {
  max-width: 1280px;
  margin: 0 auto;
  padding: 0 24px;
  width: 100%;
  display: flex;
  align-items: center;
  gap: 32px;
}

/* Logo */
.sf-nav__logo {
  display: flex;
  align-items: center;
  flex-shrink: 0;
}
.sf-nav__logo img {
  height: 36px !important;
  width: auto !important;
  display: block !important;
  opacity: 1 !important;
  visibility: visible !important;
  max-width: none !important;
}
.sf-nav__logo-text {
  font-size: 13px;
  font-weight: 700;
  color: var(--black);
  letter-spacing: .03em;
  line-height: 1.2;
}
.sf-nav__logo-text span {
  display: block;
  font-weight: 400;
  font-size: 11px;  /* min 11px para uppercase — sub-11 reduce legibilidad */
  color: var(--g500);
  letter-spacing: .06em;  /* reducir tracking al subir tamaño */
  text-transform: uppercase;
}

/* Nav links */
.sf-nav__links {
  display: flex;
  align-items: center;
  gap: 4px;
  margin: 0;
  padding: 0;
  list-style: none;
  flex: 1;
}
.sf-nav__links a {
  display: block;
  padding: 6px 14px;
  font-size: 14px;
  font-weight: 500;
  color: var(--g700);
  border-radius: var(--r-sm);
  transition: background var(--t) var(--ease), color var(--t) var(--ease);
}
.sf-nav__links a:hover,
.sf-nav__links a.active {
  color: var(--red);
  background: rgba(244,37,52,.06);
}

/* Nav right actions */
.sf-nav__actions {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-left: auto;
  flex-shrink: 0;
}

/* WhatsApp contact btn */
.sf-btn-whatsapp {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  padding: 9px 18px;
  background: #25D366;
  color: #fff !important;
  font-size: 13px;
  font-weight: 700;
  border-radius: 999px;
  border: none;
  cursor: pointer;
  transition: background var(--t) var(--ease), transform var(--t) var(--ease);
  white-space: nowrap;
}
.sf-btn-whatsapp:hover { background: #1ebe5b; transform: translateY(-1px); }
.sf-btn-whatsapp svg { width: 16px; height: 16px; }

/* Primary action */
.sf-btn-primary {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 14px 32px;
  background: var(--red);
  color: #fff !important;
  font-size: 16px;
  font-weight: 700;
  letter-spacing: .01em;
  border-radius: 999px;          /* pill shape — mas atractivo que esquinas cuadradas */
  border: none;
  cursor: pointer;
  text-decoration: none;
  transition: background var(--t) var(--ease), box-shadow var(--t) var(--ease), transform var(--t) var(--ease);
}
.sf-btn-primary svg {
  width: 18px;                   /* proporcional a font-size 16px */
  height: 18px;
  flex-shrink: 0;
  transition: transform .2s ease;
}
.sf-btn-primary:hover {
  background: var(--red-dark);
  box-shadow: 0 6px 20px rgba(244,37,52,.30);
  transform: translateY(-2px);
  color: #fff !important;
}
.sf-btn-primary:hover svg {
  transform: translateX(4px);   /* flecha se mueve a la derecha en hover */
}

/* Mobile hamburger */
.sf-nav__hamburger {
  display: none;
  width: 40px; height: 40px;
  border: none;
  background: none;
  cursor: pointer;
  padding: 10px;
  flex-direction: column;
  justify-content: space-between;
  border-radius: var(--r-sm);
}
.sf-nav__hamburger span {
  display: block;
  height: 2px;
  background: var(--black);
  border-radius: 2px;
  transition: all var(--t) var(--ease);
}

/* Body offset for fixed nav */
html, body { overflow-x: clip; } /* clip: no crea scroll container, preserva sticky */
/* NOTE: overflow-x:hidden en html/body rompe position:sticky — usar clip */
body { padding-top: 96px; }

/* ============================================================
   HERO SECTION
   ============================================================ */
.sf-hero {
  position: relative;
  min-height: 540px;
  display: flex;
  align-items: center;
  overflow: hidden;
  background: var(--black);
}

.sf-hero__bg {
  position: absolute;
  inset: 0;
  background-image: var(--hero-bg, linear-gradient(135deg, #1a1a1a 0%, #3a0a10 100%));
  background-size: cover;
  background-position: center 40%;
  filter: brightness(.55);
}

/* Grain texture overlay for premium feel */
.sf-hero__bg::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg,
    rgba(0,0,0,.05) 0%,
    rgba(0,0,0,.45) 60%,
    rgba(0,0,0,.72) 100%);
}

.sf-hero__content {
  position: relative;
  z-index: 2;
  width: 100%;
  max-width: 1280px;
  margin: 0 auto;
  padding: 72px 24px 56px;
}

.sf-hero__eyebrow {
  display: flex;           /* block-level: alineacion consistente con h1 y subtitle */
  width: fit-content;      /* colapsa al ancho del contenido (como inline-flex) */
  align-items: center;
  gap: 8px;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--red);
  background: rgba(244,37,52,.15);
  border: 1px solid rgba(244,37,52,.3);
  padding: 5px 14px;
  border-radius: 999px;
  margin-bottom: 20px;
  /* Sin margin:auto — debe quedar left-aligned con el titulo */
}
.sf-hero__eyebrow::before {
  content: '';
  width: 6px; height: 6px;
  background: var(--red);
  border-radius: 50%;
}

.sf-hero__title {
  font-size: clamp(32px, 5vw, 56px);
  font-weight: 900;
  color: var(--white);
  line-height: 1.1;
  letter-spacing: -.01em;
  margin-bottom: 16px;
  max-width: 700px;
}
.sf-hero__title em {
  font-style: normal;
  color: var(--red);
}

.sf-hero__subtitle {
  font-size: 17px;
  font-weight: 400;
  color: rgba(255,255,255,.78);
  margin-bottom: 36px;
  max-width: 500px;
  line-height: 1.6;
}

/* ---- Hero search box ---- */
.sf-hero-search {
  background: var(--white);
  border-radius: var(--r-xl);
  padding: 20px;
  box-shadow: var(--shadow-lg);
  max-width: 860px;
}

.sf-hero-search__tabs {
  display: flex;
  gap: 4px;
  margin-bottom: 16px;
  border-bottom: 1px solid var(--g200);
  padding-bottom: 12px;
}
.sf-hero-search__tab {
  padding: 6px 18px;
  font-size: 13px;
  font-weight: 700;
  color: var(--g500);
  border-radius: var(--r-sm);
  cursor: pointer;
  border: none;
  background: none;
  transition: all var(--t) var(--ease);
}
.sf-hero-search__tab.active {
  background: var(--red);
  color: var(--white);
}
.sf-hero-search__tab:hover:not(.active) {
  background: var(--g100);
  color: var(--text);
}

.sf-hero-search__fields {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr auto;
  gap: 10px;
  align-items: end;
}

.sf-search-field {
  display: flex;
  flex-direction: column;
  gap: 5px;
}
.sf-search-field label {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .07em;
  text-transform: uppercase;
  color: var(--g500);
}
.sf-search-field select,
.sf-search-field input[type="text"],
.sf-search-field input[type="number"] {
  width: 100%;
  height: 44px;
  padding: 0 14px;
  border: 1.5px solid var(--g200);
  border-radius: var(--r-md);
  font-family: 'Avenir', sans-serif;
  font-size: 14px;
  font-weight: 500;
  color: var(--text);
  background: var(--g100);
  appearance: none;
  -webkit-appearance: none;
  transition: border-color var(--t) var(--ease), box-shadow var(--t) var(--ease);
}
.sf-search-field select:focus,
.sf-search-field input:focus {
  outline: none;
  border-color: var(--red);
  background: var(--white);
  box-shadow: 0 0 0 3px rgba(244,37,52,.10);
}

.sf-hero-search__submit {
  height: 44px;
  padding: 0 28px;
  background: var(--red);
  color: var(--white);
  font-family: 'Avenir', sans-serif;
  font-size: 15px;
  font-weight: 700;
  border: none;
  border-radius: var(--r-md);
  cursor: pointer;
  display: flex;
  align-items: center;
  gap: 8px;
  white-space: nowrap;
  transition: background var(--t) var(--ease), box-shadow var(--t) var(--ease), transform var(--t) var(--ease);
}
.sf-hero-search__submit:hover {
  background: var(--red-dark);
  box-shadow: 0 4px 16px rgba(244,37,52,.4);
  transform: translateY(-1px);
}

/* Hero stats bar */
.sf-hero-stats {
  display: flex;
  align-items: center;
  gap: 32px;
  margin-top: 28px;
  flex-wrap: wrap;
}
.sf-hero-stat {
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.sf-hero-stat__num {
  font-size: 22px;
  font-weight: 900;
  color: var(--white);
  line-height: 1;
}
.sf-hero-stat__label {
  font-size: 12px;
  font-weight: 400;
  color: rgba(255,255,255,.65);
  letter-spacing: .03em;
}
.sf-hero-stat-divider {
  width: 1px;
  height: 36px;
  background: rgba(255,255,255,.2);
}

/* ============================================================
   SEARCH FILTER BAR (results page)
   ============================================================ */
.sf-filter-bar {
  position: sticky;
  top: 64px;
  z-index: 100;
  background: var(--white);
  border-bottom: 1px solid var(--g200);
  box-shadow: var(--shadow-xs);
}
.sf-filter-bar__inner {
  max-width: 1280px;
  margin: 0 auto;
  padding: 10px 24px;
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}
.sf-filter-select {
  height: 38px;
  padding: 0 32px 0 12px;
  border: 1.5px solid var(--g200);
  border-radius: var(--r-md);
  font-family: 'Avenir', sans-serif;
  font-size: 13px;
  font-weight: 500;
  color: var(--text);
  background: var(--g100);
  appearance: none;
  -webkit-appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23999' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 10px center;
  cursor: pointer;
  transition: border-color var(--t) var(--ease);
  min-width: 0;
  width: 100%;
}
.sf-filter-select:focus {
  outline: none;
  border-color: var(--red);
}
.sf-filter-select:hover { border-color: var(--g300); }

/* Resultado counter badge */
.sf-results-count {
  margin-left: auto;
  font-size: 13px;
  font-weight: 700;
  color: var(--g700);
  white-space: nowrap;
}
.sf-results-count span {
  color: var(--red);
}

/* View toggle */
.sf-view-toggle {
  display: flex;
  border: 1.5px solid var(--g200);
  border-radius: var(--r-md);
  overflow: hidden;
}
.sf-view-btn {
  width: 38px; height: 36px;
  display: flex;
  align-items: center;
  justify-content: center;
  border: none;
  background: none;
  cursor: pointer;
  color: var(--g500);
  transition: background var(--t) var(--ease), color var(--t) var(--ease);
}
.sf-view-btn.active,
.sf-view-btn:hover {
  background: var(--red);
  color: var(--white);
}

/* ============================================================
   PROPERTY CARD — ratio 3:4 portrait, specs bar, responsive
   Desktop(>1100): 4 cols | Laptop(>720): 3 cols | Tablet: 2 cols | Mobile: scroll-snap 1 col
   ============================================================ */

/* ── Grid contenedor ───────────────────────────────────────── */
.sf-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 18px;
  padding: 0;
  margin: 0;
  list-style: none;
}

/* ── La tarjeta ────────────────────────────────────────────── */
.sf-card {
  background: var(--white);
  border-radius: var(--r-lg);
  border: 1.5px solid var(--g200);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  position: relative;
  /* Estado inicial para animacion de entrada */
  opacity: 0;
  transform: translateY(20px);
  transition:
    opacity .4s ease,
    transform .4s ease,
    box-shadow .25s ease,
    border-color .25s ease;
}
/* Tarjeta visible (activada por IntersectionObserver) */
.sf-card--visible {
  opacity: 1;
  transform: translateY(0);
}
/* Tarjeta oculta hasta "Ver mas" */
.sf-card--hidden {
  display: none;
}
.sf-card:hover {
  box-shadow: 0 8px 32px rgba(0,0,0,.10);
  transform: translateY(-3px);
  border-color: var(--g300);
}
.sf-card:not(.sf-card--visible):hover {
  transform: translateY(0);
}

/* ── Imagen: ratio 3:4 (133.33%) ───────────────────────────── */
/* 81.3% de imagenes del portal son 3:4 portrait (analisis 320k imgs). */
/* object-position: center top ancla al techo, minimiza crop en 4:3.  */
.sf-card__img-wrap {
  position: relative;
  width: 100%;
  padding-top: 133.33%; /* 3:4 portrait — ratio nativo del 81.3% de fotos */
  overflow: hidden;
  flex-shrink: 0;
  background: var(--g200);
  display: block;
}
.sf-card__img-wrap img {
  position: absolute;
  top: 0; left: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center top; /* portrait: ancla al techo del interior, evita cortar cabezas */
  transition: transform .45s ease;
}
.sf-card:hover .sf-card__img-wrap img {
  transform: scale(1.05);
}

/* Placeholder sin imagen
 * RATIO: se mantiene 133.33% (3:4) igual que las cards con foto.
 * RAZON: grid uniforme — mezclar alturas rompe la alineacion visual del grid.
 *        El 81.3% de imagenes del portal son 3:4 portrait (analisis 320k imgs).
 *        El placeholder respeta este decision de disenio.
 * MEJORA: shimmer sutil + icono + texto "Sin foto disponible". */
.sf-card__img-wrap--empty {
  /* NO override de padding-top — hereda 133.33% del padre .sf-card__img-wrap */
  background: linear-gradient(270deg, var(--g100) 0%, var(--g200) 50%, var(--g100) 100%);
  background-size: 200% 100%;
  animation: sf-shimmer 2.2s ease-in-out infinite;
}
/* Icono de camara centrado + texto "Sin foto" */
.sf-card__img-wrap--empty::before {
  content: '';
  position: absolute;
  inset: 0;
  background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='32' height='32' viewBox='0 0 24 24' fill='none' stroke='%23bbb' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M23 19a2 2 0 0 1-2 2H3a2 2 0 0 1-2-2V8a2 2 0 0 1 2-2h4l2-3h6l2 3h4a2 2 0 0 1 2 2z'/%3E%3Ccircle cx='12' cy='13' r='4'/%3E%3C/svg%3E") center 40% / 32px no-repeat;
}
.sf-card__img-wrap--empty::after {
  content: 'Sin foto disponible';
  position: absolute;
  bottom: 16px;
  left: 0; right: 0;
  text-align: center;
  font-size: 11px;
  font-weight: 500;
  color: var(--g500);
  letter-spacing: .03em;
}
/* Shimmer animation — movimiento sutil de izq a der */
@keyframes sf-shimmer {
  0%   { background-position: 200% 0; }
  100% { background-position: -200% 0; }
}

/* Badges sobre la imagen */
.sf-card__badges {
  position: absolute;
  top: 10px; left: 10px;
  display: flex;
  flex-direction: column;
  gap: 5px;
  z-index: 2;
}

.sf-badge {
  display: inline-flex;
  align-items: center;
  padding: 3px 10px;
  border-radius: 999px;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .04em;
  line-height: 1.5;
  white-space: nowrap;
}
.sf-badge--rent     { background: var(--red);        color: #fff; }
.sf-badge--sale     { background: #1D6FC8;            color: #fff; }
.sf-badge--featured { background: #F59E0B;            color: #fff; }
.sf-badge--type     { background: rgba(0,0,0,.55);   color: #fff; backdrop-filter: blur(4px); }

/* Boton favorito */
.sf-card__fav {
  position: absolute;
  top: 10px; right: 10px;
  width: 34px; height: 34px;
  border-radius: 50%;
  background: rgba(255,255,255,.92);
  backdrop-filter: blur(4px);
  border: none;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  z-index: 3;
  transition: background .15s, transform .15s;
}
.sf-card__fav:hover      { background: #fff; transform: scale(1.12); }
.sf-card__fav svg        { width: 16px; height: 16px; color: var(--g500); transition: color .15s, fill .15s; }
.sf-card__fav.active     { background: #FFF0F1; }
.sf-card__fav.active svg { color: var(--red); fill: var(--red); }

/* Link overlay */
.sf-card__link-overlay {
  position: absolute;
  inset: 0;
  z-index: 1;
  display: block;
}

/* ── Cuerpo ─────────────────────────────────────────────────── */
.sf-card__body {
  padding: 12px 13px 14px;
  display: flex;
  flex-direction: column;
  gap: 6px;
  flex: 1;
}

/* Precio */
.sf-card__price {
  font-size: 18px;
  font-weight: 900;
  color: var(--black);
  line-height: 1;
  letter-spacing: -.01em;
}
.sf-card__price small {
  font-size: 12px;
  font-weight: 500;
  color: var(--g500);
  margin-left: 3px;
}

/* Tipo + Estrato */
.sf-card__meta {
  display: flex;
  align-items: center;
  gap: 7px;
  flex-wrap: wrap;
}
.sf-card__tipo {
  font-size: 12px;
  font-weight: 600;
  color: var(--g500);
}
.sf-card__estrato {
  font-size: 11px;
  font-weight: 700;
  color: var(--g500);
  background: var(--g100);
  border-radius: 4px;
  padding: 2px 7px;
  letter-spacing: .03em;
}

/* Titulo / direccion */
.sf-card__title {
  font-size: 13.5px;
  font-weight: 700;
  color: var(--text);
  line-height: 1.4;
  margin: 0;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.sf-card__title a         { color: inherit; text-decoration: none; }
.sf-card__title a:hover   { color: var(--red); }

/* ── Specs bar: habs / banos / area / parq ─────────────────── */
/* Iconos SVG con valor + unidad. Solo se renderizan desde PHP
   las specs que tienen valor real (no vacio ni "0"). */
.sf-card__specs {
  display: flex;
  align-items: stretch;
  border-top: 1px solid var(--g200);
  padding-top: 10px;
  margin-top: 4px;
  gap: 0;
}
.sf-spec {
  display: flex;
  align-items: center;
  gap: 4px;
  font-size: 12px;
  color: var(--g600);
  flex: 1;
  justify-content: center;
  padding: 0 4px;
  min-width: 0;
}
.sf-spec + .sf-spec { border-left: 1px solid var(--g200); }
.sf-spec svg        { width: 16px; height: 16px; color: var(--red); flex-shrink: 0; } /* min 16px — sub-16 dificulta lectura */
.sf-spec strong     { font-weight: 800; color: var(--text); }
.sf-spec span       { color: var(--g500); white-space: nowrap; }

/* ── CTA "ver todas" ────────────────────────────────────────── */
.sf-section-cta {
  text-align: center;
  margin-top: 44px;
  padding-top: 12px;
  border-top: 1px solid var(--g150, #f0f0f0); /* linea separadora sutil */
}

/* ── Boton "Ver mas propiedades" ────────────────────────────── */
.sf-load-more {
  text-align: center;
  margin: 28px 0 4px;
  transition: opacity .3s, transform .3s;
}
.sf-load-more__btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 11px 24px;
  border: 2px solid var(--g200);
  border-radius: 999px;
  background: #fff;
  color: var(--g700);
  font-family: inherit;
  font-size: 14px;
  font-weight: 600;
  cursor: pointer;
  transition: border-color .15s, color .15s, box-shadow .15s;
}
.sf-load-more__btn:hover {
  border-color: var(--red);
  color: var(--red);
  box-shadow: 0 2px 12px rgba(244,37,52,.12);
}
.sf-load-more__btn svg            { width: 16px; height: 16px; transition: transform .3s; }
.sf-load-more__btn:hover svg      { transform: translateY(2px); }
.sf-load-more__count              { font-size: 12px; color: var(--g400); font-weight: 500; }

/* ── Responsive tablet ──────────────────────────────────────── */
@media (max-width: 1100px) {
  .sf-grid {
    grid-template-columns: repeat(3, 1fr);
    gap: 16px;
  }
}
@media (max-width: 720px) {
  .sf-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 14px;
  }
}

/* ── Mobile: carrusel horizontal scroll-snap ────────────────── */
/* Una tarjeta a la vez al 85% del ancho.
   El 15% restante muestra el borde de la siguiente como hint.
   Todas las tarjetas son visibles (display:flex !important)
   porque en el carrusel no aplica el patron "ver mas". */
@media (max-width: 600px) {
  .sf-grid {
    display: flex;
    flex-direction: row;
    overflow-x: auto;
    overflow-y: hidden;
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
    gap: 14px;
    /* Sin margenes negativos — evita bleed horizontal al arrastrar la pagina */
    padding: 4px 4px 16px;
    scrollbar-width: none;
    -ms-overflow-style: none;
  }
  .sf-grid::-webkit-scrollbar { display: none; }

  .sf-card {
    flex: 0 0 85%;
    min-width: 0;
    scroll-snap-align: start;
    display: flex !important;  /* mostrar todas aunque tengan --hidden */
    opacity: 1 !important;
    transform: none !important;
  }

  .sf-grid-dots { display: flex !important; }
  .sf-load-more { display: none; }

  .sf-card__price { font-size: 18px; }
  .sf-spec        { font-size: 11px; }
}

/* ── Dots indicadores de posicion — solo mobile ─────────────── */
.sf-grid-dots {
  display: none;
  justify-content: center;
  gap: 6px;
  margin-top: 14px;
}
.sf-grid-dot {
  width: 7px; height: 7px;
  border-radius: 50%;
  background: var(--g300);
  transition: background .2s, transform .2s;
  cursor: pointer;
  border: none;
  padding: 0;
}
.sf-grid-dot.active {
  background: var(--red);
  transform: scale(1.3);
}


/* ============================================================
   LAYOUT DE RESULTADOS — lista + mapa
   ============================================================ */
.sf-results-layout {
  display: grid;
  grid-template-columns: 1fr 420px;
  gap: 0;
  min-height: calc(100vh - 96px - 58px);
}

/* Panel de resultados (izquierda) */
.sf-results-panel {
  overflow-y: auto;
  padding: 20px 24px 32px;
  max-height: calc(100vh - 122px);
  position: sticky;
  top: 122px;
}

/* Mapa (derecha) */
.sf-map-panel {
  position: sticky;
  top: 122px;
  height: calc(100vh - 122px);
  overflow: hidden;
}
.sf-map-panel #wrap-map,
.sf-map-panel #map {
  width: 100%;
  height: 100%;
}

/* ============================================================
   SECCIÓN HOMEPAGE — Propiedades recientes
   ============================================================ */
.sf-section {
  padding: 64px 0;
}
.sf-section--gray { background: var(--g100); }

.sf-section__header {
  max-width: 1280px;
  margin: 0 auto;
  padding: 0 24px 32px;
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 16px;
}

.sf-section__title {
  font-size: clamp(22px, 3vw, 32px);
  font-weight: 900;
  color: var(--black);
  letter-spacing: -.01em;
  margin: 0;
  line-height: 1.2;
}
.sf-section__title span {
  color: var(--red);
}

.sf-section__subtitle {
  font-size: 15px;
  color: var(--g500);
  margin-top: 6px;
  font-weight: 400;
}

.sf-section__link {
  font-size: 14px;
  font-weight: 700;
  color: var(--red);
  display: flex;
  align-items: center;
  gap: 5px;
  white-space: nowrap;
}
.sf-section__link:hover { color: var(--red-dark); }
.sf-section__link svg { width: 16px; height: 16px; }

.sf-section__content {
  max-width: 1280px;
  margin: 0 auto;
  padding: 0 24px;
}

/* ============================================================
   CATEGORÍAS (homepage)
   ============================================================ */
.sf-category-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
  gap: 12px;
}

.sf-category-card {
  position: relative;
  border-radius: var(--r-lg);
  overflow: hidden;
  aspect-ratio: 4/3;
  cursor: pointer;
  transition: transform var(--t) var(--ease);
}
.sf-category-card:hover { transform: scale(1.02); }
.sf-category-card img {
  width: 100%; height: 100%;
  object-fit: cover;
}
.sf-category-card__label {
  position: absolute;
  bottom: 0; left: 0; right: 0;
  padding: 20px 14px 12px;
  background: linear-gradient(0deg, rgba(0,0,0,.72) 0%, transparent 100%);
  color: #fff;
  font-size: 14px;
  font-weight: 700;
}
.sf-category-card__count {
  font-size: 11px;
  font-weight: 400;
  opacity: .8;
  display: block;
  margin-top: 2px;
}

/* ============================================================
   TRUST STRIP (why choose us)
   ============================================================ */
.sf-trust-strip {
  background: var(--black);
  padding: 48px 0;
}
.sf-trust-strip__inner {
  max-width: 1280px;
  margin: 0 auto;
  padding: 0 24px;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 24px;
}
@media (max-width: 720px) {
  .sf-trust-strip__inner { grid-template-columns: repeat(2, 1fr); gap: 16px; }
}
@media (max-width: 420px) {
  .sf-trust-strip__inner { grid-template-columns: 1fr 1fr; gap: 12px; padding: 0 16px; }
}
.sf-trust-item {
  text-align: center;
  color: var(--white);
}
.sf-trust-item__icon {
  width: 48px; height: 48px;
  background: rgba(244,37,52,.15);
  border: 1px solid rgba(244,37,52,.25);
  border-radius: var(--r-md);
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto 14px;
}
.sf-trust-item__icon svg { width: 22px; height: 22px; color: var(--red); }
.sf-trust-item__num {
  font-size: 32px;
  font-weight: 900;
  line-height: 1;
  letter-spacing: -.02em;
}
.sf-trust-item__label {
  font-size: 13px;
  color: rgba(255,255,255,.6);
  margin-top: 6px;
}

/* ============================================================
   FOOTER
   ============================================================ */
#sf-footer {
  background: var(--black);
  color: rgba(255,255,255,.7);
  padding: 56px 0 24px;
  border-top: 3px solid var(--red);
}
.sf-footer__inner {
  max-width: 1280px;
  margin: 0 auto;
  padding: 0 24px;
  display: grid;
  grid-template-columns: 2fr 1fr 1fr 1fr;
  gap: 40px;
  margin-bottom: 48px;
}
.sf-footer__brand .sf-nav__logo-text { color: var(--white); }
.sf-footer__brand .sf-nav__logo-text span { color: rgba(255,255,255,.4); }
.sf-footer__desc {
  font-size: 13.5px;
  line-height: 1.7;
  color: rgba(255,255,255,.5);
  margin-top: 14px;
  margin-bottom: 20px;
}
.sf-footer__col h4 {
  font-size: 12px;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: rgba(255,255,255,.4);
  margin-bottom: 16px;
}
.sf-footer__col ul { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 10px; }
.sf-footer__col a {
  font-size: 13.5px;
  color: rgba(255,255,255,.65);
  transition: color var(--t) var(--ease);
}
.sf-footer__col a:hover { color: var(--white); }

.sf-footer__bottom {
  max-width: 1280px;
  margin: 0 auto;
  padding: 20px 24px 0;
  border-top: 1px solid rgba(255,255,255,.08);
  display: flex;
  align-items: center;
  justify-content: space-between;
  font-size: 12px;
  color: rgba(255,255,255,.3);
}

/* ================================================================
   PROPERTY DETAIL PAGE — estilos específicos
   Afecta: sf-page-property (body class)
   ================================================================ */

/* ── Breadcrumb ─────────────────────────────────────────────────── */
.sf-breadcrumb {
  padding: 12px 0 20px;
}
.sf-breadcrumb ol {
  display: flex;
  align-items: center;
  gap: 6px;
  list-style: none;
  padding: 0;
  margin: 0;
  font-size: 13px;
  color: var(--g400);
  flex-wrap: wrap;
}
.sf-breadcrumb a {
  color: var(--red);
  text-decoration: none;
  transition: opacity .15s;
}
.sf-breadcrumb a:hover { opacity: .75; }
.sf-breadcrumb svg { color: var(--g300); flex-shrink: 0; }
.sf-breadcrumb [aria-current] {
  color: var(--g600);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  max-width: 220px;
}

/* ── Layout principal (2 columnas) ─────────────────────────────── */
.sf-property-page {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 20px 40px;
}

.sf-property-layout {
  display: grid;
  grid-template-columns: 1fr 360px;
  gap: 40px;
  align-items: start;
}
.sf-property-main { min-width: 0; }

/* ── Galería ────────────────────────────────────────────────────── */
.sf-gallery { margin-bottom: 28px; }
.sf-gallery__main {
  position: relative;
  border-radius: 14px;
  overflow: hidden;
  background: var(--g100);
  aspect-ratio: 16/10;
}
.sf-gallery__main img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: opacity .2s;
}
.sf-gallery__count {
  position: absolute;
  bottom: 12px;
  right: 12px;
  background: rgba(0,0,0,.55);
  color: #fff;
  font-size: 12px;
  font-weight: 700;
  padding: 5px 10px;
  border-radius: 20px;
  display: flex;
  align-items: center;
  gap: 5px;
  backdrop-filter: blur(4px);
}
.sf-gallery__thumbs {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(100px, 1fr));
  gap: 8px;
  margin-top: 10px;
}
.sf-gallery__thumb {
  border-radius: 8px;
  overflow: hidden;
  border: 2.5px solid transparent;
  background: none;
  padding: 0;
  cursor: pointer;
  transition: border-color .15s, transform .15s;
  aspect-ratio: 16/10;
}
.sf-gallery__thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.sf-gallery__thumb.active { border-color: var(--red); }
.sf-gallery__thumb:hover { transform: scale(1.03); border-color: var(--red); }
.sf-gallery__thumb--more {
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--g100);
  color: var(--g500);
  font-size: 13px;
  font-weight: 700;
  border-radius: 8px;
  aspect-ratio: 16/10;
}
.sf-gallery--empty {
  border-radius: 14px;
  background: var(--g100);
  height: 320px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 12px;
  color: var(--g400);
  font-size: 14px;
  margin-bottom: 28px;
}

/* ── Property header ────────────────────────────────────────────── */
.sf-property-header { margin-bottom: 24px; }
.sf-property-header__top {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 12px;
  flex-wrap: wrap;
}
.sf-property-header__badges { display: flex; gap: 7px; flex-wrap: wrap; }

.sf-badge {
  display: inline-flex;
  align-items: center;
  padding: 4px 11px;
  border-radius: 20px;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: .03em;
  text-transform: uppercase;
}
.sf-badge--rent  { background: #FFF0F1; color: var(--red); }
.sf-badge--type  { background: #F0F4FF; color: #3B5BDB; }
.sf-badge--code  { background: var(--g100); color: var(--g500); font-weight: 500; text-transform: none; font-size: 11px; }

.sf-property-price {
  font-size: 28px;
  font-weight: 900;
  color: var(--red);
  line-height: 1;
  white-space: nowrap;
}
.sf-property-price small {
  font-size: 14px;
  font-weight: 500;
  color: var(--g500);
}
.sf-property-title {
  font-size: 22px;
  font-weight: 800;
  color: var(--g800);
  line-height: 1.3;
  margin: 0 0 8px;
}
.sf-property-location {
  display: flex;
  align-items: center;
  gap: 5px;
  font-size: 14px;
  color: var(--g500);
  font-style: normal;
}
.sf-property-location svg { color: var(--red); flex-shrink: 0; }

/* ── KPIs (specs rápidos) ───────────────────────────────────────── */
.sf-kpis {
  display: flex;
  gap: 0;
  background: #fff;
  border: 1.5px solid var(--g200);
  border-radius: 14px;
  overflow: hidden;
  margin-bottom: 28px;
}
.sf-kpi {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 4px;
  padding: 18px 10px;
  text-align: center;
  border-right: 1.5px solid var(--g200);
  transition: background .15s;
}
.sf-kpi:last-child { border-right: none; }
.sf-kpi:hover { background: var(--g100); }
.sf-kpi__icon { color: var(--red); line-height: 0; }
.sf-kpi__val {
  font-size: 20px;
  font-weight: 800;
  color: var(--g800);
  line-height: 1;
}
.sf-kpi__label {
  font-size: 11px;
  font-weight: 600;
  color: var(--g400);
  text-transform: uppercase;
  letter-spacing: .04em;
}

/* ── Secciones internas de la propiedad ─────────────────────────── */
.sf-page-property .sf-section {
  padding: 0;
  background: none;
  margin-bottom: 36px;
}
.sf-page-property .sf-section__title {
  font-size: 17px;
  font-weight: 800;
  color: var(--g800);
  margin: 0 0 16px;
  padding-bottom: 10px;
  border-bottom: 2px solid var(--g100);
  display: flex;
  align-items: center;
  gap: 8px;
}
.sf-page-property .sf-section__title::before {
  content: '';
  width: 4px;
  height: 18px;
  background: var(--red);
  border-radius: 2px;
  display: inline-block;
  flex-shrink: 0;
}

/* ── Descripción ────────────────────────────────────────────────── */
.sf-desc-body {
  font-size: 15px;
  line-height: 1.75;
  color: var(--g600);
}

/* ── Ficha técnica (detalles) ───────────────────────────────────── */
.sf-ficha-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0;
  border: 1.5px solid var(--g200);
  border-radius: 12px;
  overflow: hidden;
}
.sf-ficha-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 13px 18px;
  border-bottom: 1px solid var(--g100);
  background: #fff;
  transition: background .12s;
}
.sf-ficha-row:nth-child(odd) { background: #FAFAFA; }
.sf-ficha-row:hover { background: #FFF5F5; }
/* Quitar borde inferior de los dos últimos si son par */
.sf-ficha-grid .sf-ficha-row:last-child,
.sf-ficha-grid .sf-ficha-row:nth-last-child(2):nth-child(odd) {
  border-bottom: none;
}
.sf-ficha-row__label {
  display: flex;
  align-items: center;
  gap: 7px;
  font-size: 13px;
  font-weight: 600;
  color: var(--g500);
  white-space: nowrap;
}
.sf-ficha-row__icon { color: var(--red); line-height: 0; flex-shrink: 0; }
.sf-ficha-row__val {
  font-size: 14px;
  font-weight: 700;
  color: var(--g800);
  text-align: right;
}

/* ── Chips de características ───────────────────────────────────── */
.sf-chips-grid {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}
.sf-chip {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 9px 16px;
  background: #fff;
  border: 1.5px solid var(--g200);
  border-radius: 10px;
  font-size: 13px;
  font-weight: 600;
  color: var(--g700);
  transition: border-color .15s, background .15s, color .15s;
}
.sf-chip:hover {
  border-color: var(--red);
  background: #FFF0F1;
  color: var(--red);
}
.sf-chip__icon {
  color: var(--red);
  line-height: 0;
  flex-shrink: 0;
}
.sf-chip__label { white-space: nowrap; }

/* ── Mapa ───────────────────────────────────────────────────────── */
.sf-property-map {
  height: 360px;
  border-radius: 12px;
  overflow: hidden;
  border: 1.5px solid var(--g200);
  background: var(--g100);
}

.sf-map-note {
  display: flex;
  align-items: center;
  gap: 5px;
  font-size: 12px;
  color: var(--g400);
  margin-top: 10px;
}
.sf-map-note svg { color: var(--g400); flex-shrink: 0; }

/* ── Sidebar contact card ───────────────────────────────────────── */
.sf-property-sidebar { position: sticky; top: 108px; }

.sf-contact-card {
  background: #fff;
  border: 1.5px solid var(--g200);
  border-radius: 16px;
  padding: 28px;
  box-shadow: 0 4px 28px rgba(0,0,0,.07);
}
.sf-contact-card__head {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  margin-bottom: 20px;
  color: var(--red);
}
.sf-contact-card__title {
  font-size: 16px;
  font-weight: 800;
  color: var(--g800);
  margin: 0 0 3px;
}
.sf-contact-card__sub {
  font-size: 13px;
  color: var(--g400);
  margin: 0;
}

.sf-contact-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 9px;
  width: 100%;
  padding: 13px 16px;
  border-radius: 10px;
  font-size: 14px;
  font-weight: 700;
  cursor: pointer;
  text-decoration: none;
  border: none;
  transition: opacity .15s, transform .1s;
  margin-bottom: 10px;
}
.sf-contact-btn:hover { opacity: .88; transform: translateY(-1px); }
.sf-contact-btn:active { transform: translateY(0); }
.sf-contact-btn--whatsapp { background: #25D366; color: #fff; }
.sf-contact-btn--primary  { background: var(--red); color: #fff; }

.sf-contact-divider {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 12px;
  color: var(--g400);
  margin: 14px 0;
}
.sf-contact-divider::before,
.sf-contact-divider::after {
  content: '';
  flex: 1;
  height: 1px;
  background: var(--g200);
}

.sf-field { margin-bottom: 14px; }
.sf-field__label {
  display: flex;
  align-items: center;
  gap: 5px;
  font-size: 12px;
  font-weight: 700;
  color: var(--g600);
  letter-spacing: .02em;
  margin-bottom: 6px;
}
.sf-field__label svg { color: var(--g400); }
.sf-contact-card .sf-field__input,
.sf-contact-card .sf-field__textarea,
.sf-page-property .sf-field__input,
.sf-page-property .sf-field__textarea {
  width: 100% !important;
  padding: 12px 16px !important;
  border: 1.5px solid var(--g200) !important;
  border-radius: 10px !important;
  font-family: inherit !important;
  font-size: 15px !important;
  line-height: 1.5 !important;
  color: var(--g800) !important;
  background: #F8F8F8 !important;
  transition: border-color .18s, background .18s, box-shadow .18s;
  box-sizing: border-box !important;
  -webkit-appearance: none;
  display: block;
  margin: 0;
  box-shadow: none;
}
.sf-contact-card .sf-field__input:focus,
.sf-contact-card .sf-field__textarea:focus,
.sf-page-property .sf-field__input:focus,
.sf-page-property .sf-field__textarea:focus {
  outline: none !important;
  border-color: var(--red) !important;
  background: #fff !important;
  box-shadow: 0 0 0 3px rgba(244,37,52,.10) !important;
}
.sf-contact-card .sf-field__input,
.sf-page-property .sf-field__input { height: 48px !important; }
.sf-contact-card .sf-field__textarea,
.sf-page-property .sf-field__textarea { resize: vertical; min-height: 90px; }

.sf-share-row { margin-top: 18px; padding-top: 14px; border-top: 1px solid var(--g100); }
.sf-share-row__label {
  font-size: 11px;
  font-weight: 700;
  color: var(--g400);
  text-transform: uppercase;
  letter-spacing: .05em;
  margin: 0 0 9px;
}
.sf-share-row__btns { display: flex; gap: 8px; }
.sf-share-btn {
  width: 38px;
  height: 38px;
  border-radius: 9px;
  display: flex;
  align-items: center;
  justify-content: center;
  text-decoration: none;
  border: none;
  cursor: pointer;
  transition: opacity .15s, transform .1s;
}
.sf-share-btn:hover { opacity: .82; transform: scale(1.06); }
.sf-share-btn--wa   { background: #25D366; color: #fff; }
.sf-share-btn--copy { background: var(--g100); color: var(--g600); }
.sf-share-btn.copied { background: #E8F5E9; color: #2E7D32; }

/* ── Responsive ─────────────────────────────────────────────────── */
@media (max-width: 900px) {
  .sf-property-page { padding: 0 12px 32px; }
  .sf-property-layout {
    grid-template-columns: 1fr;
    gap: 28px;
  }
  .sf-property-sidebar {
    position: static;
    order: 2; /* móvil: contacto siempre debajo del contenido */
  }
  .sf-kpis { flex-wrap: wrap; }
  .sf-kpi  { flex: 0 0 calc(50% - 1px); min-width: 0; }
  .sf-ficha-grid { grid-template-columns: 1fr; }
  .sf-property-price { font-size: 24px; }
}
@media (max-width: 480px) {
  .sf-property-page { padding: 0 10px 28px; }
  .sf-kpi  { flex: 0 0 calc(50% - 1px); padding: 14px 8px; }
  .sf-kpi__val { font-size: 18px; }
  .sf-property-title { font-size: 19px; }
  .sf-gallery__thumbs { grid-template-columns: repeat(4, 1fr); }
  .sf-chips-grid { gap: 8px; }
  .sf-chip { padding: 8px 12px; font-size: 12px; }
  .sf-contact-card { padding: 20px; }
}


/* ================================================================
   HERO SECTION — map_and_search.php
   Imagen de fondo configurable desde Admin → Settings → hero_bg
   ================================================================ */

/* ── Contenedor principal ──────────────────────────────────────── */
.sf-hero {
  position: relative;
  width: 100%;
  min-height: 520px;
  display: flex;
  align-items: center;
  overflow: hidden;
  background: #1a1a2e; /* fallback si no hay imagen */
}

/* ── Imagen de fondo (picture element) ────────────────────────── */
.sf-hero__bg {
  position: absolute;
  inset: 0;
  z-index: 0;
  display: block;
  width: 100%;
  height: 100%;
}
.sf-hero__bg img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  /* Ancla el foco en tercio superior para no cortar cabezas */
  object-position: center 25%;
  display: block;
}

/* ── Overlay gradiente para contraste del texto ───────────────── */
.sf-hero__overlay {
  position: absolute;
  inset: 0;
  z-index: 1;
  background: linear-gradient(
    135deg,
    rgba(0,0,0,.72) 0%,
    rgba(0,0,0,.45) 60%,
    rgba(0,0,0,.25) 100%
  );
}

/* ── Contenido centrado sobre la imagen ───────────────────────── */
.sf-hero__content {
  position: relative;
  z-index: 2;
  width: 100%;
  max-width: 900px;
  margin: 0 auto;
  padding: 64px 32px;
  color: #fff;
}

/* ── Eyebrow (texto pequeño sobre el h1) ──────────────────────── */
.sf-hero__eyebrow {
  display: flex;           /* block-level: alineado con h1 (mismo que instancia principal) */
  width: fit-content;
  align-items: center;
  gap: 6px;
  font-size: 13px;
  font-weight: 600;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: rgba(255,255,255,.8);
  margin: 0 0 14px;
  background: rgba(255,255,255,.12);
  padding: 6px 14px;
  border-radius: 20px;
  backdrop-filter: blur(4px);
}

/* ── Título principal h1 ───────────────────────────────────────── */
.sf-hero__title {
  font-size: clamp(32px, 5vw, 52px);
  font-weight: 900;
  line-height: 1.15;
  margin: 0 0 16px;
  color: #fff;
  text-shadow: 0 2px 12px rgba(0,0,0,.35);
}
.sf-hero__title em {
  font-style: normal;
  color: var(--red);
}

/* ── Subtítulo ─────────────────────────────────────────────────── */
.sf-hero__subtitle {
  font-size: 16px;
  color: rgba(255,255,255,.8);
  margin: 0 0 28px;
  max-width: 560px;
  line-height: 1.6;
}

/* ── Search box ────────────────────────────────────────────────── */
.sf-hero-search {
  background: rgba(255,255,255,.97);
  border-radius: 16px;
  padding: 18px 18px 16px;
  box-shadow: 0 8px 40px rgba(0,0,0,.22);
  margin-bottom: 28px;
}
.sf-search-form { width: 100%; }
.sf-hero-search__fields {
  display: grid;
  grid-template-columns: 1fr 1.4fr 0.8fr auto;
  gap: 10px;
  align-items: end;
}

.sf-search-field { display: flex; flex-direction: column; gap: 4px; }
.sf-search-field label {
  display: flex;
  align-items: center;
  gap: 5px;
  font-size: 11px;
  font-weight: 700;
  color: var(--g500);
  text-transform: uppercase;
  letter-spacing: .05em;
}
.sf-filter-select,
.sf-search-field input[type="text"],
.sf-search-field select {
  height: 44px;
  padding: 0 12px;
  border: 1.5px solid var(--g200);
  border-radius: 10px;
  font-family: inherit;
  font-size: 14px;
  color: var(--g700);
  background: #fff;
  transition: border-color .15s;
  width: 100%;
  box-sizing: border-box;
}
.sf-filter-select:focus,
.sf-search-field input[type="text"]:focus,
.sf-search-field select:focus {
  outline: none;
  border-color: var(--red);
  box-shadow: 0 0 0 3px rgba(244,37,52,.12);
}

.sf-hero-search__submit {
  height: 44px;
  padding: 0 24px;
  background: var(--red);
  color: #fff;
  border: none;
  border-radius: 10px;
  font-family: inherit;
  font-size: 15px;
  font-weight: 700;
  cursor: pointer;
  display: flex;
  align-items: center;
  gap: 8px;
  white-space: nowrap;
  transition: opacity .15s, transform .1s;
}
.sf-hero-search__submit:hover { opacity: .88; transform: translateY(-1px); }
.sf-hero-search__submit:active { transform: translateY(0); }

/* ── Stats bar ─────────────────────────────────────────────────── */
.sf-hero-stats {
  display: flex;
  align-items: center;
  gap: 0;
  flex-wrap: wrap;
}
.sf-hero-stat {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 2px;
  padding-right: 28px;
}
.sf-hero-stat__num {
  font-size: 26px;
  font-weight: 900;
  color: #fff;
  line-height: 1;
}
.sf-hero-stat__label {
  font-size: 12px;
  font-weight: 500;
  color: rgba(255,255,255,.65);
  text-transform: uppercase;
  letter-spacing: .05em;
}
.sf-hero-stat-divider {
  width: 1px;
  height: 36px;
  background: rgba(255,255,255,.25);
  margin-right: 28px;
  flex-shrink: 0;
}

/* ── Responsive hero ───────────────────────────────────────────── */
@media (max-width: 900px) {
  .sf-hero__content { padding: 48px 24px; }
  .sf-hero-search__fields {
    grid-template-columns: 1fr 1fr;
  }
  .sf-hero-search__submit { width: 100%; justify-content: center; }
  .sf-hero-search__fields > *:last-child { grid-column: 1 / -1; }
}
@media (max-width: 600px) {
  .sf-hero {
    min-height: 480px;
    /* En mobile la imagen portrait ocupa más altura */
    align-items: flex-start;
    padding-top: 0;
  }
  .sf-hero__bg img {
    /* En portrait la imagen tiene su propio focal point */
    object-position: center top;
  }
  .sf-hero__content { padding: 40px 16px 32px; }
  .sf-hero__title { font-size: 28px; }
  .sf-hero__subtitle { font-size: 14px; }
  .sf-hero-search { padding: 14px 14px 12px; border-radius: 12px; }
  .sf-hero-search__fields {
    grid-template-columns: 1fr;
  }
  .sf-hero-stats { gap: 16px; flex-wrap: wrap; }
  .sf-hero-stat-divider { display: none; }
  .sf-hero-stat { padding-right: 0; }
  .sf-hero-stat__num { font-size: 22px; }
}

/* ================================================================
   MOBILE STICKY CTA BAR — property.php
   Visible solo en mobile (<900px) donde el sidebar no es sticky.
   Patron: Finca Raiz, Metrocuadrado, Airbnb — CTA siempre visible.
   Se oculta automaticamente al llegar al formulario de contacto.
   ================================================================ */
.sf-mobile-cta {
  display: none; /* solo visible via media query */
}
@media (max-width: 900px) {
  .sf-mobile-cta {
    display: flex;
    position: fixed;
    bottom: 0;
    left: 0; right: 0;
    z-index: 200;
    background: #fff;
    border-top: 1px solid var(--g200);
    box-shadow: 0 -4px 20px rgba(0,0,0,.10);
    padding: 10px 16px calc(10px + env(safe-area-inset-bottom));
    gap: 10px;
    align-items: center;
    transition: transform .3s ease, opacity .3s ease;
  }
  .sf-mobile-cta.sf-mobile-cta--hidden {
    transform: translateY(100%);
    opacity: 0;
    pointer-events: none;
  }
  .sf-mobile-cta__btn {
    flex: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 12px 8px;
    border-radius: 10px;
    font-family: inherit;
    font-size: 14px;
    font-weight: 700;
    cursor: pointer;
    border: none;
    text-decoration: none;
    transition: opacity .15s, transform .1s;
  }
  .sf-mobile-cta__btn:active { transform: scale(.97); opacity: .88; }
  .sf-mobile-cta__btn svg { width: 18px; height: 18px; flex-shrink: 0; }

  /* WhatsApp — verde */
  .sf-mobile-cta__btn--wa {
    background: #25D366;
    color: #fff;
  }
  /* Solicitar info — rojo primario */
  .sf-mobile-cta__btn--contact {
    background: var(--red);
    color: #fff;
  }
  .sf-mobile-cta__btn--contact:hover { background: var(--red-dark); color: #fff; }

  /* Compensar el espacio que ocupa la barra fija al pie */
  .sf-property-page {
    padding-bottom: calc(64px + env(safe-area-inset-bottom) + 20px) !important;
  }
}
/* ================================================================
   GALERIA PRO — .sf-gallery-pro + .sf-lightbox
   Desktop: hero 60% + grid 2x2 40%  |  Mobile: carrusel 3:4
   Lightbox: pantalla completa, object-fit:contain, strip thumbs
   Ratio 3:4 (133.33%) — refleja 81.3% del inventario portrait
   ================================================================ */

/* ── Variables locales ─────────────────────────────────────── */
.sf-gallery-pro {
  --gal-radius: 10px;
  --gal-gap: 6px;
  --gal-hero-h: 480px;  /* altura desktop hero */
  margin-bottom: 28px;
  border-radius: var(--gal-radius);
  overflow: hidden;
}

/* ── DESKTOP GRID: hero + 2x2 ──────────────────────────────── */
.sf-gallery-pro__grid {
  display: grid;
  grid-template-columns: 60% 40%;
  gap: var(--gal-gap);
  height: var(--gal-hero-h);
}

.sf-gallery-pro__hero {
  position: relative;
  border: none;
  padding: 0;
  background: #111;
  cursor: pointer;
  overflow: hidden;
  border-radius: var(--gal-radius) 0 0 var(--gal-radius);
}
.sf-gallery-pro__hero img {
  width: 100%; height: 100%;
  object-fit: cover;
  object-position: center 15%;
  transition: transform 0.3s ease;
  display: block;
}
.sf-gallery-pro__hero:hover img { transform: scale(1.03); }

.sf-gallery-pro__thumbgrid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  grid-template-rows: 1fr 1fr;
  gap: var(--gal-gap);
}

.sf-gallery-pro__cell {
  position: relative;
  border: none;
  padding: 0;
  background: #111;
  cursor: pointer;
  overflow: hidden;
}
.sf-gallery-pro__cell:last-child {
  border-radius: 0 0 var(--gal-radius) 0;
}
.sf-gallery-pro__cell:nth-child(2) {
  border-radius: 0 var(--gal-radius) 0 0;
}
.sf-gallery-pro__cell img {
  width: 100%; height: 100%;
  object-fit: cover;
  object-position: center 15%;
  transition: transform 0.3s ease;
  display: block;
}
.sf-gallery-pro__cell:hover img { transform: scale(1.04); }
.sf-gallery-pro__cell--empty { background: #1a1a1a; cursor: default; }

/* Overlay '+N fotos' en última celda */
.sf-gallery-pro__more-overlay {
  position: absolute; inset: 0;
  background: rgba(0,0,0,0.52);
  display: flex; flex-direction: column;
  align-items: center; justify-content: center;
  gap: 6px;
  color: #fff;
  font-size: 0.85rem; font-weight: 600;
  pointer-events: none;
}

/* ── MOBILE CAROUSEL (hidden on desktop) ─────────────────── */
.sf-gallery-pro__carousel {
  display: none;  /* Mostrado en media query mobile */
  position: relative;
}
.sf-gallery-pro__track {
  display: flex;
  overflow-x: scroll;
  scroll-snap-type: x mandatory;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
}
.sf-gallery-pro__track::-webkit-scrollbar { display: none; }
.sf-gallery-pro__slide {
  flex: 0 0 100%;
  scroll-snap-align: start;
  /* Ratio 3:4 portrait — coincide con 81.3% del inventario */
  padding-top: 133.33%;
  position: relative;
  background: #111;
  cursor: pointer;
}
.sf-gallery-pro__slide img {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  object-fit: cover;
  object-position: center 15%;
  display: block;
}

/* Pill contador '1 / N' */
.sf-gallery-pro__pill {
  position: absolute; bottom: 12px; right: 14px;
  background: rgba(0,0,0,0.55);
  color: #fff;
  font-size: 0.78rem; font-weight: 600;
  padding: 3px 10px;
  border-radius: 999px;
  pointer-events: none;
  backdrop-filter: blur(4px);
}

/* Dots navegación */
.sf-gallery-pro__dots {
  position: absolute; bottom: 12px; left: 50%; transform: translateX(-50%);
  display: flex; gap: 5px;
  pointer-events: none;
}
.sf-gallery-pro__dot {
  width: 6px; height: 6px;
  border-radius: 50%;
  background: rgba(255,255,255,0.5);
  transition: background 0.2s, transform 0.2s;
}
.sf-gallery-pro__dot.active {
  background: #fff;
  transform: scale(1.3);
}

/* Placeholder sin fotos */
.sf-gallery-pro--empty {
  display: flex; align-items: center; justify-content: center;
  min-height: 220px;
  background: #f5f5f5;
  border-radius: var(--gal-radius);
}
.sf-gallery-pro__placeholder {
  display: flex; flex-direction: column;
  align-items: center; gap: 10px;
  color: #bbb;
  font-size: 0.9rem;
}

/* ── LIGHTBOX ───────────────────────────────────────────────── */
.sf-lightbox {
  position: fixed; inset: 0; z-index: 9999;
  display: flex; align-items: stretch;
}
.sf-lightbox[hidden] { display: none; }

.sf-lightbox__overlay {
  position: absolute; inset: 0;
  background: rgba(0,0,0,0.92);
  cursor: pointer;
}

.sf-lightbox__content {
  position: relative; z-index: 1;
  display: flex; flex-direction: column;
  width: 100%; max-height: 100vh;
  overflow: hidden;
}

.sf-lightbox__header {
  display: flex; align-items: center; gap: 12px;
  padding: 10px 16px;
  background: rgba(0,0,0,0.7);
  backdrop-filter: blur(6px);
  flex-shrink: 0;
}
.sf-lightbox__title {
  flex: 1;
  color: #fff;
  font-size: 0.9rem; font-weight: 600;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.sf-lightbox__counter {
  color: rgba(255,255,255,0.7);
  font-size: 0.82rem;
  white-space: nowrap;
}
.sf-lightbox__close {
  border: none; background: transparent;
  color: #fff; cursor: pointer;
  padding: 4px; border-radius: 4px;
  display: flex; align-items: center; justify-content: center;
  opacity: 0.8;
  transition: opacity 0.2s;
  flex-shrink: 0;
}
.sf-lightbox__close:hover { opacity: 1; }

.sf-lightbox__stage {
  flex: 1;
  position: relative;
  display: flex; align-items: center; justify-content: center;
  overflow: hidden;
  min-height: 0;
}
.sf-lightbox__img {
  /* object-fit:contain para no recortar — especialmente en 3:4 portrait */
  max-width: 100%; max-height: 100%;
  object-fit: contain;
  display: block;
  user-select: none;
}

.sf-lightbox__arrow {
  position: absolute; top: 50%; transform: translateY(-50%);
  border: none; background: rgba(0,0,0,0.45);
  color: #fff; cursor: pointer;
  width: 44px; height: 44px;
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  backdrop-filter: blur(4px);
  transition: background 0.2s, opacity 0.2s;
  z-index: 2;
}
.sf-lightbox__arrow:hover { background: rgba(0,0,0,0.75); }
.sf-lightbox__arrow--prev { left: 14px; }
.sf-lightbox__arrow--next { right: 14px; }

/* Strip de miniaturas inferior */
.sf-lightbox__strip {
  display: flex; gap: 5px;
  overflow-x: auto; scrollbar-width: none;
  padding: 8px 12px;
  background: rgba(0,0,0,0.7);
  backdrop-filter: blur(6px);
  flex-shrink: 0;
}
.sf-lightbox__strip::-webkit-scrollbar { display: none; }
.sf-lightbox__strip-thumb {
  flex: 0 0 60px;
  height: 44px;
  border: 2px solid transparent;
  border-radius: 4px;
  overflow: hidden;
  cursor: pointer;
  padding: 0;
  background: #333;
  transition: border-color 0.15s, opacity 0.15s;
  opacity: 0.6;
}
.sf-lightbox__strip-thumb img {
  width: 100%; height: 100%;
  object-fit: cover;
  display: block;
}
.sf-lightbox__strip-thumb.active {
  border-color: var(--red, #c0392b);
  opacity: 1;
}
.sf-lightbox__strip-thumb:hover { opacity: 0.9; }

/* ── RESPONSIVE: mobile <900px ─────────────────────────────── */
@media (max-width: 900px) {
  .sf-gallery-pro__grid    { display: none; }      /* ocultar desktop grid */
  .sf-gallery-pro__carousel{ display: block; }     /* mostrar carrusel */
  .sf-lightbox__arrow      { width: 36px; height: 36px; }
  .sf-lightbox__strip-thumb{ flex: 0 0 50px; height: 37px; }
}

/* ═══════════════════════════════════════════════
   MAP FAB + DIRECTIONS MODAL
═══════════════════════════════════════════════ */

.sf-map-wrapper { position: relative; }

/* FAB pill */
.sf-map-fab {
  position: absolute;
  bottom: 16px;
  right: 12px;
  z-index: 999;
  display: inline-flex;
  align-items: center;
  gap: 7px;
  padding: 9px 16px 9px 12px;
  background: #fff;
  color: #F42534;
  border: none;
  border-radius: 999px;
  font-size: 13.5px;
  font-weight: 600;
  letter-spacing: -.01em;
  cursor: pointer;
  box-shadow: 0 2px 12px rgba(0,0,0,.22), 0 1px 3px rgba(0,0,0,.14);
  transition: transform .15s ease, box-shadow .15s ease;
  user-select: none;
}
.sf-map-fab:hover {
  transform: translateY(-1px);
  box-shadow: 0 4px 18px rgba(0,0,0,.28);
  background: #fff9f9;
}
.sf-map-fab:active { transform: translateY(0); }
.sf-map-fab svg { flex-shrink: 0; stroke: #F42534; }

/* Modal overlay */
.sf-nav-modal {
  position: fixed;
  inset: 0;
  z-index: 9999;
  display: flex;
  align-items: center;
  justify-content: center;
}
.sf-nav-modal[hidden] { display: none; }

.sf-nav-modal__backdrop {
  position: absolute;
  inset: 0;
  background: rgba(15,15,25,.55);
  backdrop-filter: blur(3px);
  -webkit-backdrop-filter: blur(3px);
}

/* Card */
.sf-nav-modal__card {
  position: relative;
  z-index: 1;
  background: #fff;
  border-radius: 22px;
  padding: 36px 32px 32px;
  width: min(360px, calc(100vw - 32px));
  text-align: center;
  box-shadow: 0 24px 64px rgba(0,0,0,.2), 0 4px 16px rgba(0,0,0,.1);
  transform: scale(.92) translateY(10px);
  opacity: 0;
  transition: transform .26s cubic-bezier(.34,1.56,.64,1), opacity .2s ease;
}
.sf-nav-modal--in .sf-nav-modal__card {
  transform: scale(1) translateY(0);
  opacity: 1;
}

/* Close */
.sf-nav-modal__close {
  position: absolute;
  top: 14px;
  right: 14px;
  width: 32px;
  height: 32px;
  border: none;
  background: #f1f1f3;
  border-radius: 50%;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #555;
  padding: 0;
  transition: background .15s;
}
.sf-nav-modal__close:hover { background: #e3e3e6; }

/* Icon */
.sf-nav-modal__icon {
  width: 62px;
  height: 62px;
  border-radius: 50%;
  background: linear-gradient(135deg, #fff0f1, #ffe4e6);
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto 18px;
}
.sf-nav-modal__icon svg { stroke: #F42534; }

.sf-nav-modal__title {
  font-size: 20px;
  font-weight: 700;
  color: #111;
  margin: 0 0 6px;
  letter-spacing: -.02em;
}
.sf-nav-modal__sub {
  font-size: 14px;
  color: #999;
  margin: 0 0 26px;
}

.sf-nav-modal__btns { display: flex; flex-direction: column; gap: 12px; }

/* Base button */
.sf-nav-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  padding: 15px 20px;
  border-radius: 14px;
  font-size: 15px;
  font-weight: 600;
  text-decoration: none;
  transition: transform .15s ease, box-shadow .15s ease, filter .15s ease;
  cursor: pointer;
  letter-spacing: -.01em;
}
.sf-nav-btn:hover { transform: translateY(-2px); text-decoration: none; }
.sf-nav-btn:active { transform: translateY(0); }

/* Google Maps */
.sf-nav-btn--gmaps {
  background: #fff;
  color: #3c4043;
  border: 2px solid #e0e0e0;
}
.sf-nav-btn--gmaps:hover { border-color: #bbb; color: #3c4043; background: #fafafa; box-shadow: 0 6px 20px rgba(0,0,0,.1); }

/* Waze */
.sf-nav-btn--waze {
  background: linear-gradient(135deg, #33ccff, #05b8e8);
  color: #fff;
  border: 2px solid transparent;
  box-shadow: 0 2px 10px rgba(5,184,232,.35);
}
.sf-nav-btn--waze:hover { color: #fff; filter: brightness(1.06); box-shadow: 0 6px 22px rgba(5,184,232,.45); }

body.sf-modal-open { overflow: hidden; }

@media (max-width: 480px) {
  .sf-nav-modal__card { padding: 30px 20px 24px; border-radius: 18px; }
  .sf-nav-modal__title { font-size: 18px; }
  .sf-nav-btn { font-size: 14.5px; padding: 13px 16px; }
}


/* ============================================================
   NAV DROPDOWNS — 5 secciones
   ============================================================ */

/* Item con dropdown */
.sf-nav__item { position: relative; list-style: none; }

.sf-nav__item-link {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 6px 14px;
  font-size: 14px;
  font-weight: 500;
  color: var(--g700);
  border-radius: var(--r-sm);
  transition: background var(--t) var(--ease), color var(--t) var(--ease);
  white-space: nowrap;
  text-decoration: none;
}
.sf-nav__item-link:hover,
.sf-nav__item--dd.active > .sf-nav__item-link {
  color: var(--red);
  background: rgba(244,37,52,.06);
}

/* Caret icon */
.sf-nav__caret {
  width: 10px; height: 6px;
  flex-shrink: 0;
  transition: transform .15s ease;
}
.sf-nav__item--dd:hover .sf-nav__caret,
.sf-nav__item--dd:focus-within .sf-nav__caret {
  transform: rotate(180deg);
}

/* Dropdown panel */
.sf-nav__dropdown {
  position: absolute;
  top: calc(100% + 6px);
  left: 0;
  min-width: 220px;
  background: var(--white);
  border: 1px solid var(--g200);
  border-radius: 10px;
  box-shadow: 0 8px 24px rgba(0,0,0,.10);
  padding: 6px;
  list-style: none;
  margin: 0;
  opacity: 0;
  visibility: hidden;
  transform: translateY(-6px);
  transition: opacity .15s ease, transform .15s ease, visibility .15s;
  z-index: 200;
}
.sf-nav__item--dd:hover .sf-nav__dropdown,
.sf-nav__item--dd:focus-within .sf-nav__dropdown {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}
.sf-nav__dropdown a {
  display: block;
  padding: 9px 14px;
  font-size: 13.5px;
  color: var(--g700);
  border-radius: 7px;
  white-space: nowrap;
  text-decoration: none;
  transition: background .1s, color .1s;
}
.sf-nav__dropdown a:hover {
  background: rgba(244,37,52,.07);
  color: var(--red);
}

/* ============================================================
   MENÚ MÓVIL — acordeón
   ============================================================ */

.sf-mobile-menu {
  display: none;
  position: fixed;
  top: 96px; left: 0; right: 0;
  background: var(--white);
  border-bottom: 1px solid var(--g200);
  box-shadow: 0 8px 24px rgba(0,0,0,.10);
  z-index: 999;
  max-height: calc(100vh - 96px);
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
}
/* FIX: JS usa clase 'open', no 'sf-mobile-menu--open' */
.sf-mobile-menu.open { display: block; }

/* Cabecera del panel móvil */
.sf-mm__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 14px 16px 10px;
  border-bottom: 1px solid var(--g100);
}
.sf-mm__title {
  font-size: 13px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .08em;
  color: var(--g400);
}
.sf-mm__close {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 36px; height: 36px;
  background: none;
  border: none;
  cursor: pointer;
  color: var(--g500);
  border-radius: 50%;
  transition: background var(--t) var(--ease), color var(--t) var(--ease);
}
.sf-mm__close:hover { background: var(--g100); color: var(--red); }

/* Quick actions — 3 CTAs primarios */
.sf-mm__quickactions {
  display: flex;
  flex-direction: column;
  gap: 8px;
  padding: 14px 16px;
  border-bottom: 2px solid var(--g100);
}
.sf-mm__qa {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 13px 16px;
  border-radius: var(--r-md);
  font-size: 15px;
  font-weight: 600;
  text-decoration: none;
  min-height: 48px;
  transition: opacity var(--t) var(--ease), transform var(--t) var(--ease);
}
.sf-mm__qa:active { opacity: .85; transform: scale(.98); }
.sf-mm__qa--primary {
  background: var(--red);
  color: #fff;
}
.sf-mm__qa--primary:hover { background: var(--red-dark); color: #fff; }
.sf-mm__qa--secondary {
  background: var(--g50, #f8f8f8);
  color: var(--black);
  border: 1px solid var(--g200);
}
.sf-mm__qa--secondary:hover { background: var(--g100); color: var(--red); border-color: var(--red); }

/* Acordeones */
.sf-mm__nav {
  padding: 4px 16px 16px;
  display: flex;
  flex-direction: column;
  gap: 0;
}
.sf-mm__section { border-bottom: 1px solid var(--g100); }
.sf-mm__section:last-child { border-bottom: none; }

.sf-mm__toggle {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 13px 4px;
  background: none;
  border: none;
  cursor: pointer;
  font-size: 15px;
  font-weight: 600;
  color: var(--black);
  text-align: left;
  min-height: 48px;
}
.sf-mm__arrow {
  width: 10px; height: 6px;
  flex-shrink: 0;
  transition: transform .2s ease;
}
.sf-mm__toggle[aria-expanded="true"] .sf-mm__arrow { transform: rotate(180deg); }

.sf-mm__sub {
  display: none;
  flex-direction: column;
  gap: 0;
  padding-bottom: 6px;
}
.sf-mm__sub.open { display: flex; }
.sf-mm__sub a {
  padding: 10px 14px;
  font-size: 14px;
  color: var(--g600);
  border-radius: 7px;
  text-decoration: none;
  display: block;
  min-height: 44px;
  display: flex;
  align-items: center;
}
.sf-mm__sub a:hover { background: rgba(244,37,52,.06); color: var(--red); }

/* Footer con WhatsApp */
.sf-mm__footer {
  padding: 12px 16px 20px;
  border-top: 1px solid var(--g100);
}
.sf-mm__wa {
  justify-content: center;
  width: 100%;
  min-height: 48px;
}

/* Hamburger → X cuando open */
.sf-nav__hamburger[aria-expanded="true"] span:nth-child(1) { transform: translateY(9px) rotate(45deg); }
.sf-nav__hamburger[aria-expanded="true"] span:nth-child(2) { opacity: 0; }
.sf-nav__hamburger[aria-expanded="true"] span:nth-child(3) { transform: translateY(-9px) rotate(-45deg); }

/* Hide desktop nav on mobile */
@media (max-width: 900px) {
  .sf-nav__links { display: none; }
  .sf-nav__hamburger { display: flex; }
}
@media (min-width: 901px) {
  .sf-mobile-menu { display: none !important; }
  .sf-nav__hamburger { display: none; }
}

@media (max-width: 900px) {
  #sf-nav .sf-nav__inner { padding: 0 28px 0 12px; gap: 8px; }
  .sf-nav__actions { gap: 0; }
}

/* ============================================================
   HERO SEARCH — Tabs Simple / Inteligente
   ============================================================ */

/* Tab switcher */
.sf-hero-search__tab {
  background: rgba(255,255,255,0.15);
  border: 1px solid rgba(255,255,255,0.3);
  color: rgba(255,255,255,0.8);
  padding: 7px 16px;
  border-radius: 20px;
  font-size: 0.82rem;
  font-weight: 500;
  cursor: pointer;
  transition: background 0.2s, color 0.2s, border-color 0.2s;
  display: inline-flex;
  align-items: center;
  gap: 4px;
}
.sf-hero-search__tab.active,
.sf-hero-search__tab:hover {
  background: rgba(255,255,255,0.95);
  color: var(--primary, #c0392b);
  border-color: transparent;
}

/* Smart search panel in hero */
.sf-smart-search {
  padding: 20px 0 4px;
}
.sf-smart-search__input-wrap {
  display: flex;
  align-items: center;
  background: #fff;
  border-radius: 12px;
  padding: 6px 6px 6px 16px;
  gap: 10px;
  box-shadow: 0 4px 24px rgba(0,0,0,0.18);
}
.sf-smart-search__icon {
  color: var(--primary, #c0392b);
  flex-shrink: 0;
}
.sf-smart-search__input {
  flex: 1;
  border: none;
  outline: none;
  font-size: 1rem;
  background: transparent;
  color: var(--g900, #1a1a1a);
  min-width: 0;
}
.sf-smart-search__input::placeholder {
  color: var(--g400, #9ca3af);
  font-size: 0.9rem;
}
.sf-smart-search__btn {
  background: var(--primary, #c0392b);
  color: #fff;
  border: none;
  border-radius: 8px;
  padding: 10px 20px;
  font-size: 0.9rem;
  font-weight: 600;
  cursor: pointer;
  transition: background 0.2s;
  white-space: nowrap;
}
.sf-smart-search__btn:hover { background: var(--primary-dark, #a93226); }
.sf-smart-search__btn:disabled { opacity: 0.7; cursor: wait; }

/* Ejemplos de queries */
.sf-smart-examples {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 6px;
  margin-top: 10px;
}
.sf-smart-examples__label {
  font-size: 0.75rem;
  color: rgba(255,255,255,0.7);
}
.sf-smart-example {
  background: rgba(255,255,255,0.15);
  border: 1px solid rgba(255,255,255,0.35);
  color: rgba(255,255,255,0.9);
  border-radius: 20px;
  padding: 4px 12px;
  font-size: 0.75rem;
  cursor: pointer;
  transition: background 0.15s;
}
.sf-smart-example:hover {
  background: rgba(255,255,255,0.3);
}

/* Status de búsqueda inteligente */
.sf-smart-status {
  margin-top: 10px;
  font-size: 0.83rem;
  color: rgba(255,255,255,0.95);
  background: rgba(255,255,255,0.12);
  border-radius: 8px;
  padding: 8px 14px;
}

/* ============================================================
   SMART BAR — Barra inteligente en página de resultados
   ============================================================ */
.sf-smart-bar {
  background: var(--g50, #f9fafb);
  border-bottom: 1px solid var(--g100, #f3f4f6);
  padding: 10px 0;
}
.sf-smart-bar__inner {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 20px;
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
}
.sf-smart-bar__input-wrap {
  flex: 1;
  min-width: 280px;
  display: flex;
  align-items: center;
  background: #fff;
  border: 1.5px solid var(--g200, #e5e7eb);
  border-radius: 10px;
  padding: 6px 6px 6px 14px;
  gap: 8px;
  transition: border-color 0.2s;
}
.sf-smart-bar__input-wrap:focus-within {
  border-color: var(--primary, #c0392b);
}
.sf-smart-bar__icon {
  color: var(--primary, #c0392b);
  flex-shrink: 0;
}
.sf-smart-bar__input {
  flex: 1;
  border: none;
  outline: none;
  font-size: 0.88rem;
  background: transparent;
  color: var(--g900, #1a1a1a);
  min-width: 0;
}
.sf-smart-bar__input::placeholder { color: var(--g400, #9ca3af); }
.sf-smart-bar__btn {
  background: var(--primary, #c0392b);
  color: #fff;
  border: none;
  border-radius: 7px;
  padding: 7px 16px;
  font-size: 0.82rem;
  font-weight: 600;
  cursor: pointer;
  transition: background 0.2s;
  display: flex;
  align-items: center;
  gap: 6px;
  white-space: nowrap;
}
.sf-smart-bar__btn:hover { background: var(--primary-dark, #a93226); }
.sf-smart-bar__btn:disabled { opacity: 0.6; cursor: wait; }

.sf-smart-bar__geohint {
  font-size: 0.8rem;
  color: var(--primary, #c0392b);
  display: flex;
  align-items: center;
  gap: 5px;
  font-weight: 500;
  white-space: nowrap;
}

/* ============================================================
   FILTROS EXTENDIDOS
   ============================================================ */
.sf-more-filters-btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: #fff;
  border: 1.5px solid var(--g200, #e5e7eb);
  border-radius: 8px;
  padding: 6px 14px;
  font-size: 0.82rem;
  font-weight: 500;
  color: var(--g700, #374151);
  cursor: pointer;
  transition: border-color 0.2s, background 0.2s;
  position: relative;
}
.sf-more-filters-btn:hover,
.sf-more-filters-btn.active {
  border-color: var(--primary, #c0392b);
  color: var(--primary, #c0392b);
}
.sf-more-filters-btn.has-active {
  background: var(--primary, #c0392b);
  border-color: var(--primary, #c0392b);
  color: #fff;
}

.sf-active-badge {
  background: var(--primary, #c0392b);
  color: #fff;
  border-radius: 10px;
  font-size: 0.7rem;
  font-weight: 700;
  padding: 1px 6px;
  min-width: 18px;
  text-align: center;
}
.sf-more-filters-btn.has-active .sf-active-badge {
  background: rgba(255,255,255,0.3);
}

/* Panel extendido */
.sf-extended-filters {
  background: #fff;
  border-bottom: 1px solid var(--g100, #f3f4f6);
  box-shadow: 0 4px 12px rgba(0,0,0,0.06);
}
.sf-extended-filters__inner {
  max-width: 1200px;
  margin: 0 auto;
  padding: 20px 20px 16px;
  display: flex;
  flex-wrap: wrap;
  gap: 16px;
  align-items: flex-start;
}

.sf-ext-field {
  display: flex;
  flex-direction: column;
  gap: 5px;
  min-width: 140px;
}
.sf-ext-field label {
  font-size: 0.75rem;
  font-weight: 600;
  color: var(--g500, #6b7280);
  text-transform: uppercase;
  letter-spacing: 0.04em;
}
.sf-ext-field select,
.sf-ext-field input[type=text] {
  border: 1.5px solid var(--g200, #e5e7eb);
  border-radius: 8px;
  padding: 7px 10px;
  font-size: 0.85rem;
  color: var(--g900, #1a1a1a);
  background: #fff;
  outline: none;
  transition: border-color 0.2s;
}
.sf-ext-field select:focus,
.sf-ext-field input[type=text]:focus {
  border-color: var(--primary, #c0392b);
}

/* Checkboxes */
.sf-ext-field--checks { min-width: 260px; }
.sf-ext-checks__label {
  font-size: 0.75rem;
  font-weight: 600;
  color: var(--g500, #6b7280);
  text-transform: uppercase;
  letter-spacing: 0.04em;
}
.sf-ext-checks {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 2px;
}
.sf-ext-check {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 0.83rem;
  color: var(--g700, #374151);
  cursor: pointer;
  background: var(--g50, #f9fafb);
  border: 1.5px solid var(--g200, #e5e7eb);
  border-radius: 20px;
  padding: 4px 12px;
  transition: border-color 0.15s, background 0.15s;
}
.sf-ext-check:has(input:checked) {
  border-color: var(--primary, #c0392b);
  background: #fff0ee;
  color: var(--primary, #c0392b);
  font-weight: 600;
}
.sf-ext-check input { display: none; }

/* Acciones del panel extendido */
.sf-ext-actions {
  display: flex;
  align-items: flex-end;
  gap: 8px;
  padding-top: 18px;
  margin-left: auto;
}
.sf-btn-primary {
  background: var(--primary, #c0392b);
  color: #fff;
  border: none;
  border-radius: 8px;
  padding: 9px 20px;
  font-size: 0.85rem;
  font-weight: 600;
  cursor: pointer;
  transition: background 0.2s;
}
.sf-btn-primary:hover { background: var(--primary-dark, #a93226); }
.sf-btn-ghost {
  background: transparent;
  color: var(--g500, #6b7280);
  border: 1.5px solid var(--g200, #e5e7eb);
  border-radius: 8px;
  padding: 9px 16px;
  font-size: 0.85rem;
  cursor: pointer;
  transition: border-color 0.2s;
}
.sf-btn-ghost:hover { border-color: var(--g400, #9ca3af); }

/* Mobile ajustes */
@media (max-width: 600px) {
  .sf-smart-bar__inner { flex-direction: column; align-items: stretch; }
  .sf-smart-bar__input-wrap { min-width: 0; }
  .sf-extended-filters__inner { flex-direction: column; }
  .sf-ext-actions { margin-left: 0; }
  .sf-smart-search__input-wrap { flex-wrap: wrap; }
  .sf-smart-search__btn { width: 100%; justify-content: center; }
}

/* ============================================================
   OP-TABS: Arriendo / Venta
   ============================================================ */
.sf-op-tabs {
  background: var(--white, #fff);
  border-bottom: 1px solid var(--g200, #e5e7eb);
}
.sf-op-tabs__inner {
  max-width: 1280px;
  margin: 0 auto;
  padding: 0 24px;
  display: flex;
  gap: 0;
}
.sf-op-tab {
  padding: 14px 28px;
  font-family: 'Avenir', sans-serif;
  font-size: 14px;
  font-weight: 600;
  color: var(--text-light, #6b7280);
  background: none;
  border: none;
  border-bottom: 3px solid transparent;
  cursor: pointer;
  transition: color 0.2s, border-color 0.2s;
  letter-spacing: 0.01em;
}
.sf-op-tab:hover {
  color: var(--primary, #c0392b);
}
.sf-op-tab.active {
  color: var(--primary, #c0392b);
  border-bottom-color: var(--primary, #c0392b);
}

/* Smart bar - sin wrapper extra */
.sf-smart-bar__inner {
  max-width: 1280px;
  margin: 0 auto;
  padding: 12px 24px;
  display: flex;
  gap: 10px;
  align-items: center;
}

/* Ajuste de sticky para nueva altura de tabs (42px) + smart-bar (60px) */
.sf-filter-bar {
  top: 106px; /* header 64px + op-tabs 42px */
}
.sf-results-panel,
.sf-map-panel {
  top: 212px; /* header 64px + tabs 42px + smart-bar 60px + filter-bar 58px - aprox */
  max-height: calc(100vh - 212px);
  height: calc(100vh - 212px);
}

/* Fix: el panel extendido no debe usar position absolute */
.sf-extended-filters[hidden] { display: none !important; }
.sf-extended-filters:not([hidden]) { display: block; }

/* Checkboxes en filtros extendidos */
.sf-ext-checks {
  display: flex;
  flex-wrap: wrap;
  gap: 12px 20px;
  align-items: center;
  padding-top: 8px;
}
.sf-check-label {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 13px;
  font-weight: 500;
  color: var(--text, #111827);
  cursor: pointer;
  white-space: nowrap;
}
.sf-check-label input[type=checkbox] {
  width: 16px;
  height: 16px;
  accent-color: var(--primary, #c0392b);
  cursor: pointer;
}

/* Resultados count */
.sf-results-count {
  font-size: 13px;
  color: var(--text-light, #6b7280);
  white-space: nowrap;
  margin-left: auto;
}

/* Loading spinner simple */
.sf-loading {
  padding: 32px;
  text-align: center;
  color: var(--text-light, #6b7280);
  font-size: 14px;
}

@media (max-width: 768px) {
  .sf-results-layout {
    grid-template-columns: 1fr;
  }
  .sf-map-panel {
    height: 300px;
    position: relative;
    top: auto;
  }
  .sf-results-panel {
    max-height: none;
    position: relative;
    top: auto;
  }
  .sf-op-tab { padding: 12px 18px; font-size: 13px; }
}
