/* =========================================
   STYLE.CSS — Estilos exclusivos de la HOME
   (Mapa Google Maps, filtros, fullscreen)
   ========================================= */

/* Body background solo para la home */
body {
    background: linear-gradient(135deg, var(--azul-principal) 0%, var(--acento-turquesa) 100%);
}

/* ---- Filtros del mapa ---- */
.bloque-filtros-mapa {
    border: 1px solid rgba(30,41,59,.06);
}

.bloque-filtros-mapa .form-select {
    min-height: 48px;
    border-radius: 12px;
    border-color: rgba(30,41,59,.12);
}

.bloque-filtros-mapa .form-select:focus {
    border-color: var(--acento-turquesa);
    box-shadow: 0 0 0 0.2rem var(--turquesa-suave);
}

.estado-filtros-mapa {
    background: linear-gradient(135deg, rgba(30,41,59,.04), rgba(78,205,196,.1));
    border: 1px solid rgba(30,41,59,.06);
    border-radius: 16px;
    padding: 14px 16px;
}

/* ---- Mapa Google Maps ---- */
.mapa-google {
    position: relative;
    width: 100%;
    min-height: 500px;
    border-radius: 12px;
    overflow: hidden;
    background: linear-gradient(180deg, #dceef5 0%, #ffffff 100%);
    border: 1px solid rgba(30,41,59,.06);
}

/* Overlay en mapa de la home */
.capa-mapa {
    position: absolute;
    top: 16px;
    left: 16px;
    z-index: 500;
    pointer-events: none;
}

.estado-mapa {
    position: absolute;
    left: 50%;
    bottom: 20px;
    transform: translateX(-50%);
    background: rgba(30,41,59,.92);
    color: white;
    padding: 10px 16px;
    border-radius: 999px;
    font-size: 0.9rem;
    z-index: 500;
    box-shadow: 0 6px 20px rgba(0,0,0,.15);
}

.estado-mapa--error { background: rgba(214,40,57,.95); }
.estado-mapa--info  { background: rgba(30,41,59,.92); }

/* ---- Fullscreen del mapa ---- */
.contenedor-mapa:fullscreen {
    width: 100vw;
    height: 100vh;
    margin: 0;
    padding: 24px;
    border-radius: 0;
    box-sizing: border-box;
}

.contenedor-mapa:fullscreen .mapa-google {
    min-height: calc(100vh - 120px);
}

/* ---- Responsive Home ---- */
@media (max-width: 991.98px) {
    .mapa-google { min-height: 420px; }
}

@media (max-width: 767.98px) {
    .estado-filtros-mapa { min-height: auto; }
    .mapa-google { min-height: 340px; }
}

/* ---- Sección Propósito ---- */
.seccion-proposito {
    background: var(--gris-claro);
}

.tarjeta-proposito {
    background: white;
    border: 1px solid rgba(0,0,0,.06);
    border-top: 3px solid var(--acento-turquesa);
    box-shadow: 0 2px 12px rgba(30,41,59,.05);
}

html.modo-oscuro .seccion-proposito {
    background: #161b28;
}

html.modo-oscuro .tarjeta-proposito {
    background: #1e2433;
    border-color: rgba(255,255,255,.06);
    border-top-color: var(--acento-turquesa);
}

/* ---- Sección Impacto ---- */
.tarjeta-impacto {
    background: rgba(255,255,255,.05);
    border: 1px solid rgba(78,205,196,.12);
}

/* ---- Sección Blog ---- */
.seccion-blog {
    background: var(--gris-claro);
}

.tarjeta-blog {
    background: white;
    box-shadow: 0 2px 12px rgba(30,41,59,.05);
}

html.modo-oscuro .seccion-blog {
    background: #161b28;
}

html.modo-oscuro .tarjeta-blog {
    background: #1e2433 !important;
    box-shadow: 0 2px 12px rgba(0,0,0,.2);
}
