/* ============================================================
   PRESTADORES — listado y popup del mapa
   Estilos del listado de tarjetas debajo del mapa de prestadores
   y del InfoWindow de Google Maps.
   ------------------------------------------------------------
   Layout objetivo:
     - Desktop (>= 768px): 2 tarjetas por fila
     - Mobile  (<  768px): 1 tarjeta por fila
   ============================================================ */

/* ============================================================
   Contenedor de la lista
   ============================================================ */
#listaPrestadores {
    width: 100%;
    max-width: 1200px;
    margin: 0 auto;
    box-sizing: border-box;
}

.prestadores-lista {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr)); /* 2 columnas, sin overflow */
    gap: 18px;
    margin-top: 14px;
    align-items: stretch;
}

/* Mobile: 1 columna */
@media (max-width: 767.98px) {
    .prestadores-lista {
        grid-template-columns: 1fr;
    }
}

/* ============================================================
   Tarjeta de prestador (listado)
   ============================================================ */
.prestador-card {
    border: 1px solid #e7e7e7;
    border-radius: 14px;
    padding: 14px 16px;
    background: #fff;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.06);
    display: flex;
    flex-direction: column;
    transition: transform 0.2s ease, box-shadow 0.2s ease;
    height: 100%;
    min-width: 0; /* evita que el contenido haga overflow horizontal */
}

.prestador-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 6px 18px rgba(0, 0, 0, 0.12);
}

.prestador-card.is-active {
    border-color: #0b57d0;
    box-shadow: 0 6px 18px rgba(11, 87, 208, 0.18);
}

/* Header de la tarjeta */
.prestador-card__header {
    display: flex;
    justify-content: space-between;
    gap: 10px;
    align-items: flex-start;
    flex-wrap: wrap;
}

.prestador-card__title {
    font-size: 1.2rem;
    font-weight: 800;
    margin: 0;
    word-break: break-word;
}

/* Descripción */
.prestador-card__desc {
    margin: 8px 0 12px;
    color: #444;
    font-size: 14px;
    line-height: 1.45;
    flex-grow: 1; /* mantiene altura pareja entre tarjetas */
}

/* Badges (dirección, teléfono, email) */
.prestador-badges {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    margin-bottom: 12px;
}

.prestador-badge {
    font-size: 12px;
    background: #f5f5f5;
    border: 1px solid #eee;
    padding: 4px 8px;
    border-radius: 999px;
    word-break: break-word;
}

/* Links (Web, IG, FB, TT) */
.prestador-links {
    margin-top: auto;
}

.prestador-links a {
    margin-right: 12px;
    font-size: 13px;
    font-weight: 500;
    color: #0b57d0;
    text-decoration: none;
}

.prestador-links a:hover {
    text-decoration: underline;
}

/* ============================================================
   Imágenes (compartido entre tarjeta y popup)
   ============================================================ */
.prestador-media {
    margin: 0 0 12px;
}

.prestador-media__img {
    width: 100%;
    height: 170px;
    object-fit: cover;
    border-radius: 12px;
    border: 1px solid #eee;
    display: block;
}

.prestador-media__strip {
    display: flex;
    gap: 8px;
    overflow-x: auto;
    padding-bottom: 4px;
}

.prestador-media__thumbLink {
    flex: 0 0 auto;
}

.prestador-media__thumb {
    width: 86px;
    height: 62px;
    object-fit: cover;
    border-radius: 10px;
    border: 1px solid #eee;
    display: block;
}

/* ============================================================
   Botones
   ============================================================ */
.prestador-btn {
    border: 1px solid #ddd;
    background: #fff;
    padding: 7px 10px;
    border-radius: 10px;
    font-size: 13px;
    cursor: pointer;
    line-height: 1.2;
}

.prestador-btn--primary {
    background: #111;
    color: #fff;
    border-color: #111;
}

/* ============================================================
   InfoWindow de Google Maps
   ============================================================ */
.prestador-popup {
    font-family: system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
    max-width: 320px;
}

.prestador-popup__title {
    font-size: 1.4em;
    font-weight: 700;
    margin: 0 0 6px;
}

.prestador-popup__desc {
    margin: 0 0 10px;
    color: #444;
    font-size: 13px;
    line-height: 1.35;
    font-weight: normal;
}

.prestador-popup__meta {
    display: grid;
    gap: 6px;
    font-size: 13px;
}

.prestador-popup__row {
    display: flex;
    gap: 8px;
}

.prestador-popup__label {
    min-width: 78px;
    color: #666;
    font-weight: 600;
}

.prestador-popup__value a {
    color: #0b57d0;
    text-decoration: none;
}

.prestador-popup__value a:hover {
    text-decoration: underline;
}

.prestador-popup__actions {
    display: flex;
    gap: 8px;
    margin-top: 10px;
}

/* Iconos sociales */
.prestador-popup__socials {
    display: flex;
    gap: 10px;
    margin-top: 10px;
    align-items: center;
    flex-wrap: wrap;
}

.prestador-social {
    width: 34px;
    height: 34px;
    border-radius: 999px;
    border: 1px solid #e7e7e7;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    text-decoration: none;
    background: #fff;
    color: #111;
    box-shadow: 0 1px 5px rgba(0, 0, 0, 0.06);
    transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.prestador-social:hover {
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.12);
}

/* ============================================================
   Atributos del prestador (chips con icono FA)
   Se muestran tanto en la tarjeta del listado como en el modal.
   ============================================================ */
.prestador-attrs {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    margin: 0 0 12px;
}

.prestador-attr {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    background: #f6f6fb;
    border: 1px solid #e7e7ee;
    color: #333;
    padding: 4px 10px;
    border-radius: 999px;
    font-size: 12px;
    line-height: 1.2;
    word-break: break-word;
}

.prestador-attr i {
    color: #e2127e;
    font-size: 13px;
    line-height: 1;
}

/* Hace clickeable visualmente el nombre del prestador en la tarjeta. */
.prestador-card__title-link {
    color: inherit;
    text-decoration: none;
    cursor: pointer;
}

.prestador-card__title-link:hover,
.prestador-card__title-link:focus {
    color: #0b57d0;
    text-decoration: underline;
}

/* ============================================================
   Modal de detalle del prestador (nombre clickeable → modal)
   ============================================================ */
.prestador-modal__media,
.prestador-modal__carousel {
    margin-bottom: 16px;
    border-radius: 10px;
    overflow: hidden;
}

.prestador-modal__media--single img,
.prestador-modal__slide img {
    width: 100%;
    max-height: 420px;
    object-fit: cover;
    display: block;
    border-radius: 10px;
}

.prestador-modal__slide {
    padding: 0 4px;
}

/* Slick: aseguramos contraste de las flechas y bullets sobre el fondo blanco
   del modal — sin esto a veces las flechas “desaparecen” según el theme. */
#modalPrestadorCarousel .slick-prev,
#modalPrestadorCarousel .slick-next {
    z-index: 2;
}
#modalPrestadorCarousel .slick-prev:before,
#modalPrestadorCarousel .slick-next:before {
    color: #111;
    font-size: 26px;
    opacity: 0.8;
}
#modalPrestadorCarousel .slick-dots li button:before {
    color: #111;
    opacity: 0.5;
}
#modalPrestadorCarousel .slick-dots li.slick-active button:before {
    color: #e2127e;
    opacity: 1;
}

.prestador-modal__desc {
    color: #444;
    font-size: 14px;
    line-height: 1.5;
    margin: 0 0 12px;
}

/* Re-aprovechamos .prestador-popup__meta y .prestador-popup__row para
   mostrar dirección/tel/email dentro del modal. */
#modalPrestador .prestador-popup__meta {
    margin-bottom: 12px;
}
#modalPrestador .prestador-popup__socials {
    margin-top: 10px;
}
