/**
 * minisite-styles.css — v3
 *
 * Todos los selectores prefijados con .minisite- o .listar-minisite
 * para aislamiento total del tema padre.
 *
 * Secciones:
 *   1.  Variables locales
 *   2.  Header: cover, logo, título, stats
 *   3.  Zoom controls (fix definitivo)
 *   4.  Mapa: wrapper Listar, filtros, ícono de pin, popup
 *   5.  Tarjetas: grid fix para desktop maximizado
 *   6.  Contacto rápido
 *   7.  Blog
 *   8.  Tipografía general (escalado)
 *   9.  Responsive
 */

/* ============================================================
   1. VARIABLES LOCALES
   ============================================================ */
:root {
  /* Colores (hereda del tema si las variables existen, fallback propio) */
  --ms-primary:     var(--listar-primary,      #ff5a00);
  --ms-primary-dk:  var(--listar-primary-dark, #e04e00);
  --ms-text:        #333333;
  --ms-text-muted:  #666666;
  --ms-border:      #e2e2e2;
  --ms-bg-light:    #f7f7f7;
  --ms-white:       #ffffff;
  --ms-wa:          #25d366;
  --ms-shadow-sm:   0 2px 8px rgba(0,0,0,.08);
  --ms-shadow-md:   0 4px 20px rgba(0,0,0,.12);
  --ms-radius:      8px;

  /* Tipografía — escalada para legibilidad cómoda */
  --ms-font-base:   1rem;       /* 16px */
  --ms-font-md:     1.2rem;    /* ~17px */
  --ms-font-lg:     1.45rem;     /* ~19px */
  --ms-font-xl:     1.75rem;     /* 24px */
  --ms-font-2xl:    2.25rem;       /* 32px */
  --ms-font-3xl:    3rem;     /* ~45px */
  --ms-line-height: 1.65;
}

/* ============================================================
   2. HEADER: COVER, LOGO, TÍTULO, STATS
   ============================================================ */

.minisite-header {
  position: relative;
  width: 100%;
  margin-bottom: 48px;
}

/* Cover */
.minisite-cover {
  width: 100%;
  height: 300px;
  max-height: 300px;          /* evita agrandamiento en desktop */
  background-size: cover;
  background-position: center center;
  background-repeat: no-repeat;
  position: relative;
  overflow: hidden;
  border-radius: 0;
}

.minisite-cover--no-image {
  background: linear-gradient(135deg, var(--ms-primary) 0%, #ff8c42 60%, #ffb347 100%);
}

.minisite-cover-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(
    to bottom,
    rgba(0,0,0,.15) 0%,
    rgba(0,0,0,.55) 100%
  );
}

/* Título sobre el cover */
.minisite-cover-title {
  position: absolute;
  bottom: 70px;
  left: 0;
  right: 0;
  text-align: center;
  padding: 0 20px;
  z-index: 2;
}

.minisite-title {
  font-size: var(--ms-font-3xl);   /* ~45px */
  font-weight: 800;
  color: var(--ms-white);
  margin: 0 0 8px;
  letter-spacing: .3px;
  text-shadow: 0 3px 10px rgba(0,0,0,.65);
  line-height: 1.1;
}

.minisite-tagline {
  display: inline-block;
  font-size: var(--ms-font-lg);    /* ~19px */
  font-weight: 600;
  color: var(--ms-white);
  background: rgba(0,0,0,.55);
  padding: 5px 14px;
  border-radius: 4px;
  text-shadow: 0 1px 4px rgba(0,0,0,.5);
}

/* Logo sobre el borde del cover */
.minisite-logo {
  position: absolute;
  top: 240px;         /* cover-height(300) - logo-size/2(60) */
  left: 50%;
  transform: translateX(-50%);
  width: 120px;
  height: 120px;
  border-radius: 50%;
  overflow: hidden;
  border: 4px solid var(--ms-white);
  box-shadow: var(--ms-shadow-md);
  background: var(--ms-white);
  z-index: 10;
}

.minisite-logo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

/* Logo placeholder (inicial) */
.minisite-logo--initial {
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--ms-primary);
}

.minisite-logo--initial span {
  color: var(--ms-white);
  font-size: 2.5rem;
  font-weight: 700;
  text-transform: uppercase;
  line-height: 1;
}

/* Info debajo del logo */
.minisite-header-inner {
  max-width: 1140px;
  margin: 80px auto 0;    /* espacio para el logo solapado */
  padding: 0 20px 24px;
  text-align: center;
}
/* ── Bio / Descripción ──────────────────────────────────────── */
.minisite-bio {
  width: 100%;
  max-width: 560px;
  background: var(--ms-bg);
  border-left: 3px solid var(--ms-primary);
  border-radius: 0 var(--ms-radius) var(--ms-radius) 0;
  padding: 14px 18px;
  margin-bottom: 20px;
  text-align: left;
}

.minisite-bio p {
  font-size: var(--ms-f-md);    /* 17px */
  line-height: var(--ms-lh);
  color: var(--ms-text);
  margin: 0;
}
/* Stats badges */
.minisite-stats {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  justify-content: center;
  margin-top: 8px;
}

.minisite-stat-badge {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  font-size: var(--ms-font-lg);   /* ~19px */
  color: var(--ms-text-muted);
  background: var(--ms-bg-light);
  border: 1px solid var(--ms-border);
  border-radius: 20px;
  padding: 5px 14px;
  font-weight: 500;
}

.minisite-stat-badge i {
  color: var(--ms-primary);
  font-size: 1rem;
}

.minisite-stat-badge strong {
  color: var(--ms-text);
  font-weight: 700;
}

/* ============================================================
   3. ZOOM CONTROLS — FIX DEFINITIVO
   (los controles del tema Listar interfieren con Leaflet)
   ============================================================ */

/*
 * El problema: el CSS del tema aplica flex o transiciones a todos los
 * elementos .leaflet-bar a, lo que causa que los botones de zoom titilen
 * y cambien de tamaño al hover.
 *
 * Solución: sobreescribir dentro del scope .listar-minisite con !important
 * para garantizar que ninguna regla del tema se aplique.
 */

.listar-minisite .leaflet-control-zoom {
  display: block !important;
  position: absolute !important;
}

.listar-minisite .leaflet-bar {
  display: block !important;
  box-shadow: 0 1px 5px rgba(0,0,0,.3) !important;
  border-radius: 4px !important;
}

.listar-minisite .leaflet-control-zoom a,
.listar-minisite .leaflet-control-zoom a:link,
.listar-minisite .leaflet-control-zoom a:visited {
  display: block !important;
  width: 30px !important;
  height: 30px !important;
  line-height: 30px !important;
  text-align: center !important;
  box-sizing: border-box !important;
  padding: 0 !important;
  margin: 0 !important;
  border: 1px solid #ccc !important;
  border-radius: 0 !important;
  background: #fff !important;
  color: #333 !important;
  font-size: 16px !important;
  font-weight: 700 !important;
  text-decoration: none !important;
  /* Cero animaciones que alteren geometría */
  transition: none !important;
  transform: none !important;
  box-shadow: none !important;
  outline: none !important;
  /* Evitar que el tema aplique flex */
  flex: unset !important;
  float: none !important;
}

.listar-minisite .leaflet-control-zoom a:hover,
.listar-minisite .leaflet-control-zoom a:focus,
.listar-minisite .leaflet-control-zoom a:active {
  background: #f4f4f4 !important;
  color: #111 !important;
  border-color: #ccc !important;
  transform: none !important;
  transition: none !important;
  box-shadow: none !important;
  outline: none !important;
}

/* Separador entre + y - */
.listar-minisite .leaflet-bar a:first-child {
  border-radius: 4px 4px 0 0 !important;
}
.listar-minisite .leaflet-bar a:last-child {
  border-radius: 0 0 4px 4px !important;
  border-top: 0 !important;
}

/* ============================================================
   4. MAPA: WRAPPER, FILTROS, ÍCONO, POPUP
   ============================================================ */

/* Sección completa */
.minisite-map-section {
  margin-bottom: 48px;
}

/* El mapa en sí */
#minisite-map.minisite-map {
  width: 100%;
  height: 420px;
  display: block;
  z-index: 1;
}

/* Wrapper Listar: estilos del padding interno del mapa */
.listar-minisite .listar-listing-data.listar-listing-data-map {
  padding: 0 !important;
  overflow: hidden;
  border-radius: var(--ms-radius);
  border: 1px solid var(--ms-border);
  box-shadow: var(--ms-shadow-sm);
}

/* Header del wrapper (contiene filtros) */
.minisite-map-filters-bar {
  padding: 12px 16px !important;
  border-bottom: 1px solid var(--ms-border);
  display: flex;
  flex-wrap: wrap;
  gap: 10px 20px;
  align-items: center;
  background: var(--ms-white);
}

.minisite-map-filter-group {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 6px;
}

.minisite-map-filter-label {
  font-size: var(--ms-font-lg);  /* ~19px */
  font-weight: 600;
  color: var(--ms-text-muted);
  display: flex;
  align-items: center;
  gap: 5px;
  white-space: nowrap;
}

.minisite-map-filter-label i {
  color: var(--ms-primary);
}

/* Botones de filtro */
.minisite-filter-btn {
  font-size: var(--ms-font-lg);   /* ~19px */
  font-weight: 500;
  color: var(--ms-text);
  background: var(--ms-bg-light);
  border: 1px solid var(--ms-border);
  border-radius: 20px;
  padding: 4px 14px;
  cursor: pointer;
  transition: background .15s, color .15s, border-color .15s;
  white-space: nowrap;
}

.minisite-filter-btn:hover {
  background: var(--ms-border);
}

.minisite-filter-btn--active {
  background: var(--ms-primary);
  color: var(--ms-white);
  border-color: var(--ms-primary);
  font-weight: 700;
}

/* Contador de locales en el título */
.minisite-map-count {
  font-size: 1rem;
  font-weight: 400;
  color: var(--ms-text-muted);
  margin-left: 6px;
}

/* ── Ícono del marcador (sin distorsión) ──────────────────────────────── */
/*
 * DISEÑO CORRECTO:
 * – .ms-pin-outer: wrapper Leaflet, sin estilos propios
 * – .ms-pin-wrap: forma de pin con border-radius 50% 50% 50% 0 + rotate(-45deg)
 *   Tamaño fijo 34×34 (cuadrado antes de rotar → diagonal ≈ 48px)
 *   iconAnchor en JS: [17, 44] = mitad del ancho, altura total con punta
 * – i dentro: rotate(45deg) para compensar → ícono siempre derecho
 * – ::after: eliminar la pseudo-punta (el rotate ya crea la punta del globo)
 *
 * NO se usa ::after con background-inherit (causaba la segunda "punta" extraña).
 */
.ms-pin-icon {
  /* contenedor Leaflet → debe ser transparent */
  background: transparent !important;
  border: none !important;
}

.ms-pin-outer {
  /* Wrapper que asegura que el ícono Leaflet tenga las dimensiones correctas */
  width: 34px;
  height: 44px;
  position: relative;
}

.ms-pin-wrap {
  --pin-c: rgba(255, 90, 0, 0.95); /* sobreescrito inline desde JS */
  width: 34px;
  height: 34px;
  background: var(--pin-c);
  border-radius: 50% 50% 50% 0;
  transform: rotate(-45deg);
  transform-origin: center center;
  position: absolute;
  top: 0;
  left: 0;
  box-shadow: 0 4px 12px rgba(0,0,0,.3);
  display: flex;
  align-items: center;
  justify-content: center;
}

.ms-pin-wrap i {
  transform: rotate(45deg); /* compensa el giro del contenedor */
  color: #fff;
  font-size: 14px;
  line-height: 1;
  display: block;
  text-align: center;
  /* Fuerza que FA no aplique su propio transform */
  -webkit-transform: rotate(45deg);
}

/* Asegurar que FA no sobre-escale el ícono */
.ms-pin-wrap .fa,
.ms-pin-wrap [class^="fa-"],
.ms-pin-wrap [class*=" fa-"] {
  font-size: 14px !important;
  width: auto !important;
  height: auto !important;
}

/* ── Popup: dos áreas ─────────────────────────────────────────────────── */

.minisite-leaflet-popup .leaflet-popup-content-wrapper {
  padding: 0 !important;
  border-radius: var(--ms-radius) !important;
  overflow: hidden !important;
  background: var(--ms-white) !important;
  box-shadow: var(--ms-shadow-md) !important;
  min-width: 220px;
  max-width: 280px;
}

.minisite-leaflet-popup .leaflet-popup-content {
  margin: 0 !important;
  padding: 0 !important;
  width: 100% !important;
  white-space: normal !important;
  overflow-wrap: break-word !important;
  word-break: break-word !important;
}

.minisite-leaflet-popup .leaflet-popup-tip {
  background: var(--ms-white) !important;
}

/* Contenedor del popup */
.ms-popup {
  font-family: inherit;
  font-size: var(--ms-font-lg);  /* ~19px */
  color: var(--ms-text);
}

/* Área genérica (compartida por listing y address) */
.ms-popup-area {
  display: block;
  text-decoration: none;
  color: inherit;
}

/* Área 1: Anuncio (imagen + título + categoría) */
.ms-popup-listing {
  cursor: pointer;
  transition: background .1s;
}

.ms-popup-listing:hover {
  background: var(--ms-bg-light);
}

.ms-popup-img {
  width: 100%;
  height: 130px;
  background-size: cover;
  background-position: center;
  background-color: var(--ms-border);
  display: block;
}

.ms-popup-meta {
  padding: 10px 12px 8px;
  border-bottom: 1px solid var(--ms-border);
}

.ms-popup-title {
  display: block;
  font-size: var(--ms-font-lg);  /* ~19px */
  font-weight: 700;
  color: var(--ms-text);
  line-height: 1.25;
  margin-bottom: 4px;
}

.ms-popup-cat {
  display: inline-block;
  font-size: .82rem;
  background: var(--ms-bg-light);
  border: 1px solid var(--ms-border);
  border-radius: 4px;
  padding: 1px 7px;
  color: var(--ms-text-muted);
}

/* Área 2: Dirección → Google Maps */
.ms-popup-address {
  display: flex !important;
  align-items: flex-start;
  gap: 8px;
  padding: 10px 12px;
  font-size: var(--ms-font-lg);   /* ~19px */
  color: var(--ms-text-muted);
  line-height: 1.4;
  text-decoration: none;
  transition: background .1s;
}

.ms-popup-address:hover {
  background: #fff8f5;
  color: var(--ms-primary);
}

.ms-popup-address i {
  color: var(--ms-primary);
  font-size: 1rem;
  flex-shrink: 0;
  margin-top: 2px;
}

.ms-popup-address span {
  flex: 1;
  overflow-wrap: break-word;
  word-break: break-word;
}

/* ============================================================
   5. TARJETAS — GRID FIX PARA DESKTOP MAXIMIZADO
   ============================================================ */

/*
 * PROBLEMA:
 * Al maximizar la ventana, las tarjetas se estrechan porque el tema Listar
 * añade un container con max-width menor al esperado en este contexto, o
 * porque .listar-grid aplica algún grid/flex que reduce las columnas.
 *
 * SOLUCIÓN:
 * – Usar exactamente las mismas clases que el loop del buscador del tema
 *   (col-xs-12 col-sm-6 col-md-4 listar-grid-design-2 listar-listing-card)
 * – Dentro de .minisite-listings-section, neutralizar cualquier regla
 *   que el tema aplique al .row que no aplica en el buscador
 * – Asegurar que el .container del minisite usa el mismo max-width que el tema
 *
 * NO usar max-width propio: heredar del tema (Bootstrap .container).
 */

.minisite-listings-section .listar-grid.listar-results-container {
  /* Anular cualquier grid/flex del tema que no aplica en el buscador */
  display: -webkit-box !important;
  display: -ms-flexbox !important;
  display: flex !important;
  -ms-flex-wrap: wrap !important;
  flex-wrap: wrap !important;
  /* Respetar márgenes negativos de Bootstrap */
  margin-left:  -10px !important;
  margin-right: -10px !important;
}

.minisite-listings-section .listar-listing-card {
  /* Anular floats y grids que el contexto pueda sobreponer */
  float: none !important;
  clear: none !important;
  box-sizing: border-box !important;
  padding-left:  10px !important;
  padding-right: 10px !important;
  margin-bottom: 20px !important;
  /* Tamaños exactos de Bootstrap col-md-4 */
  flex: 1 1 33.3333% !important;
  min-width: 350px;
  max-width: 33.3333% !important;
  min-height: 500px;
  /* Anular display:grid si el tema lo usa */
  display: block !important;
}

/* Tablet: 2 columnas exactas */
@media (min-width: 768px) and (max-width: 991px) {
  .minisite-listings-section .listar-listing-card {
    flex: 0 0 50% !important;
    max-width: 50% !important;
  }
}

/* Mobile: 1 columna */
@media (max-width: 767px) {
  .minisite-listings-section .listar-listing-card {
    flex: 0 0 100% !important;
    max-width: 100% !important;
  }
}

/* Mensaje sin resultados */
.minisite-no-filter-results {
  width: 100%;
  padding: 32px 0;
  color: var(--ms-text-muted);
  font-size: var(--ms-font-lg);
}

.minisite-no-listings {
  padding: 40px 0;
  font-size: var(--ms-font-lg);
  color: var(--ms-text-muted);
}

/* ============================================================
   6. CONTACTO RÁPIDO
   ============================================================ */

.minisite-contact-section {
  background: var(--ms-bg-light);
  padding: 0 0 48px;
}

/* Lista: una fila por local */
.minisite-contact-list {
  display: flex;
  flex-direction: column;
  gap: 0;
  border: 1px solid var(--ms-border);
  border-radius: var(--ms-radius);
  overflow: hidden;
  background: var(--ms-white);
  box-shadow: var(--ms-shadow-sm);
}

.minisite-contact-row {
  display: flex;
  align-items: center;
  gap: 16px;
  padding: 16px 20px;
  border-bottom: 1px solid var(--ms-border);
  transition: background .15s;
  flex-wrap: wrap;
}

.minisite-contact-row:last-child {
  border-bottom: none;
}

.minisite-contact-row:hover {
  background: var(--ms-bg-light);
}

/* Info del local (nombre, ubicación, categoría) */
.minisite-contact-info {
  flex: 1;
  min-width: 160px;
}

.minisite-contact-name {
  display: block;
  font-size: var(--ms-font-lg);   /* ~19px */
  font-weight: 700;
  color: var(--ms-text);
  text-decoration: none;
  line-height: 1.25;
  margin-bottom: 3px;
}

.minisite-contact-name:hover {
  color: var(--ms-primary);
}

.minisite-contact-location {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-size: var(--ms-font-lg);   /* ~19px */
  color: var(--ms-text-muted);
}

.minisite-contact-location i {
  color: var(--ms-primary);
  font-size: 1.5rem;
}

.minisite-contact-cat {
  display: inline-block;
  font-size: 1.05rem;
  background: var(--ms-bg-light);
  border: 1px solid var(--ms-border);
  border-radius: 4px;
  padding: 1px 7px;
  color: var(--ms-text-muted);
  margin-left: 8px;
}

/* Botones de contacto */
.minisite-contact-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  flex-shrink: 0;
}

.minisite-cta-btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: var(--ms-font-md);   /* ~19px */
  font-weight: 600;
  padding: 7px 14px;
  border-radius: 6px;
  text-decoration: none;
  color: var(--ms-white) !important;
  transition: opacity .15s;
  white-space: nowrap;
  border: none;
  cursor: pointer;
}

.minisite-cta-btn:hover { opacity: .88; }

.minisite-cta-whatsapp { background: var(--ms-wa); }
.minisite-cta-phone    { background: var(--ms-primary); }
.minisite-cta-email    { background: #4a90d9; }
.minisite-cta-directions    { background: #3d9970; }

.minisite-cta-view {
  background: var(--ms-bg-light) !important;
  color: var(--ms-text) !important;
  border: 1px solid var(--ms-border);
}

/* Número de teléfono en texto (en pantallas grandes) */
.minisite-cta-phone-num {
  font-size: .85rem;
  font-weight: 400;
}

/* ============================================================
   7. BLOG DEL USUARIO
   ============================================================ */

.minisite-blog-section { padding-bottom: 48px;}
.minisite-blog-col { margin-bottom: 24px;}

.minisite-blog-article {
  height: 100%;
  display: flex;
  flex-direction: column;
  background: var(--ms-white);
  border: 1px solid var(--ms-border);
  border-radius: var(--ms-radius);
  overflow: hidden;
  box-shadow: var(--ms-shadow-sm);
  transition: box-shadow .2s, transform .2s;
}

.minisite-blog-article:hover {
  box-shadow: var(--ms-shadow-md);
  transform: translateY(-3px);
}

/* Thumbnail */
.minisite-blog-thumb-link { display: block; overflow: hidden; }

.minisite-blog-thumb {
  width: 100%;
  padding-top: 55%;
  background-size: cover;
  background-position: center;
  background-color: var(--ms-border);
  transition: transform .35s;
  position: relative;
}

.minisite-blog-thumb--no-img {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
}

.minisite-blog-thumb--no-img i {
  font-size: 2.5rem;
  color: var(--ms-border);
}

.minisite-blog-thumb-link:hover .minisite-blog-thumb {
  transform: scale(1.04);
}

/* Cuerpo */
.minisite-blog-body {
  padding: 18px 20px;
  display: flex;
  flex-direction: column;
  flex: 1;
}

/* Meta: categoría + fecha + autor */
.minisite-blog-meta {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px 12px;
  margin-bottom: 10px;
}

.minisite-blog-cat-link {
  font-size: 1.05rem;
  font-weight: 600;
  background: var(--ms-primary);
  color: var(--ms-white) !important;
  border-radius: 4px;
  padding: 2px 8px;
  text-decoration: none;
  text-transform: uppercase;
  letter-spacing: .3px;
}

.minisite-blog-cat-link:hover {
  opacity: .85;
}

.minisite-blog-date,
.minisite-blog-author {
  font-size: var(--ms-font-lg);   /* ~19px */
  color: var(--ms-text-muted);
  display: inline-flex;
  align-items: center;
  gap: 4px;
}

.minisite-blog-date i,
.minisite-blog-author i {
  color: var(--ms-primary);
  font-size: .9rem;
}

.minisite-blog-author a {
  color: var(--ms-text-muted);
  text-decoration: none;
}

.minisite-blog-author a:hover {
  color: var(--ms-primary);
}

/* Título */
.minisite-blog-title {
  font-size: var(--ms-font-xl);   /* 24px */
  font-weight: 700;
  line-height: 1.3;
  margin: 0 0 10px;
}

.minisite-blog-title a {
  color: var(--ms-text);
  text-decoration: none;
}

.minisite-blog-title a:hover { color: var(--ms-primary); }

/* Excerpt */
.minisite-blog-excerpt {
  font-size: var(--ms-font-lg);   /* ~19px */
  color: var(--ms-text-muted);
  line-height: var(--ms-line-height);
  flex: 1;
  margin-bottom: 14px;
}

/* Leer más */
.minisite-blog-readmore {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: var(--ms-font-md);
  font-weight: 700;
  color: var(--ms-primary);
  text-decoration: none;
  margin-top: auto;
}

.minisite-blog-readmore:hover { text-decoration: underline; }

/* Botón "Ver todos" */
.minisite-blog-more { padding-top: 8px; }

/* ============================================================
   8. TIPOGRAFÍA GENERAL (escalado para retención)
   ============================================================ */

/*
 * El problema: todo el texto del minisite usa el tamaño base del tema
 * que es pequeño para una landing editorial.
 * Solución: aumentar la base para los elementos del minisite.
 */

/* Párrafos dentro del minisite */
.minisite-header p,
.minisite-map-section p,
.minisite-listings-section p,
.minisite-contact-section p,
.minisite-blog-section p {
  font-size: var(--ms-font-lg);   /* ~19px */
  line-height: var(--ms-line-height);
}

/* Títulos de sección listar-title-with-stripe en minisite */
.minisite-map-section .listar-title-with-stripe,
.minisite-listings-section .listar-title-with-stripe,
.minisite-contact-section .listar-title-with-stripe,
.minisite-blog-section .listar-title-with-stripe {
  font-size: var(--ms-font-2xl) !important; /* 32px */
}

/* ============================================================
   9. RESPONSIVE
   ============================================================ */

@media (max-width: 991px) {
  #minisite-map.minisite-map { height: 360px; }
}

@media (max-width: 767px) {

  .minisite-cover { height: 220px; }

  .minisite-title { font-size: 2.5rem; }
  .minisite-tagline { font-size: 1.5rem; }

  .minisite-logo {
    top: 168px;  /* 220 - 60 + 8 */
    width: 100px;
    height: 100px;
  }

  .minisite-header-inner { margin-top: 66px; }

  .minisite-cover-title { bottom: 60px;  }

  .minisite-map-filters-bar {
    flex-direction: column;
    align-items: flex-start;
    gap: 8px;
  }

  .minisite-contact-row {
    flex-direction: column;
    align-items: flex-start;
  }

  .minisite-contact-actions {
    width: 100%;
  }

  .minisite-cta-btn {
    flex: 1 1 auto;
    justify-content: center;
  }

  /* Ocultar número de teléfono en móvil (queda en botón compacto) */
  .minisite-cta-phone-num { display: none; }

  #minisite-map.minisite-map { height: 300px; }

  .minisite-blog-title { font-size: 1.2rem; }
}

@media (max-width: 480px) {
  .minisite-title { font-size: 2rem; }
  .minisite-filter-btn { font-size: 1.05rem; padding: 3px 10px; }
}
