/* Estilo del botón de Municipios KML */
/* Mismo estilo que farmacias, gasolineras, etc. */
.leaflet-control-municipios-kml.leaflet-bar {
    background-color: #fff;
    border: 2px solid rgba(0,0,0,0.2);
    width: 33px;
    height: 33px;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: all 0.12s ease;
    user-select: none;
    -webkit-user-select: none;
    border-radius: 4px;
    position: relative;
    z-index: 1000;
}

.leaflet-control-municipios-kml.leaflet-bar:hover {
    background-color: #f2f8fc;
    border-color: rgba(0,0,0,0.3);
}

.leaflet-control-municipios-kml.leaflet-bar:active {
    transform: scale(0.98);
}

.leaflet-control-municipios-kml.leaflet-bar.activa,
.leaflet-control-municipios-kml.leaflet-bar.tiene-activos {
    background-color: #FF7B00 !important;
    border-color: #cc6200;
}

.leaflet-control-municipios-kml.leaflet-bar.submenu-open {
    background-color: #DD90E2 !important;
}

/* Submenú */
#municipios-kml-submenu {
    position: absolute;
    display: flex;
    flex-direction: column;
    gap: 8px;
    padding: 8px;
    background: rgba(255,255,255,0.10);
    border-radius: 10px;
    box-shadow: 0 4px 10px rgba(0,0,0,0.08);
    backdrop-filter: blur(6px);
    -webkit-backdrop-filter: blur(6px);
    border: 1px solid rgba(0,0,0,0.06);
    z-index: 999999;
    min-width: 170px;
    opacity: 0;
    transform: translateX(8px);
    transition: opacity 0.18s ease, transform 0.18s ease;
    pointer-events: none;
}

#municipios-kml-submenu.visible {
    opacity: 1;
    transform: translateX(0);
    pointer-events: auto;
}

#municipios-kml-submenu button {
    border: 1px solid #ccc;
    background: #9CE500;
    color: #954800 !important;
    padding: 8px 10px;
    border-radius: 4px;
    cursor: pointer;
    font: 700 13px system-ui, -apple-system, 'Segoe UI', Roboto, Arial;
    text-align: center;
    width: 100%;
    transition: filter 0.12s, transform 0.08s;
}

#municipios-kml-submenu button:hover {
    filter: brightness(0.97);
    transform: translateY(-1px);
}

#municipios-kml-submenu button.activo {
    background: #FCBC04 !important;
}

/* Tooltip en el mapa (para mostrar nombre al hacer click en layer) */
#municipios-kml-tooltip {
    position: absolute;
    background: rgba(0,0,0,0.9);
    color: #fff;
    padding: 8px 14px;
    border-radius: 8px;
    font: 700 14px system-ui;
    pointer-events: none;
    z-index: 999999;
    white-space: nowrap;
    opacity: 0;
    transition: opacity 0.2s ease;
    box-shadow: 0 3px 10px rgba(0,0,0,0.3);
}

#municipios-kml-tooltip.visible {
    opacity: 1;
}

/* Tooltip touch para móviles */
.leaflet-control-municipios-kml-tooltip-touch {
    position: fixed;
    background: rgba(0,0,0,0.88);
    color: #fff;
    padding: 6px 8px;
    border-radius: 6px;
    font-size: 0.78rem;
    white-space: nowrap;
    opacity: 0;
    transition: opacity 0.12s ease;
    z-index: 100000;
    pointer-events: none;
    transform-origin: right center;
}

.leaflet-control-municipios-kml-tooltip-touch.visible {
    opacity: 1;
}

@media (max-width: 360px) {
    .leaflet-control-municipios-kml-tooltip-touch {
        font-size: 0.72rem;
        padding: 5px 7px;
    }
}
