/*=============================================
MENÚ MÓVIL - CSS PERSONALIZADO LIMPIO
Sin conflicto con Bootstrap
=============================================*/

/* Contenedor principal del menú móvil */
.menu-movil-container {
    position: fixed;
    top: 50px; /* Se ajusta dinámicamente con JS */
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 999999;
    transform: translateX(-100%);
    transition: top 0.3s ease-in-out, transform 0.3s ease-in-out;
}

/* Menú abierto */
.menu-movil-container.menu-abierto {
    transform: translateX(0);
}

/* Overlay oscuro - DEBAJO del menú blanco */
.menu-overlay {
    position: absolute;
    inset: 0;
    background: rgba(0, 0, 0, 0.7);
    z-index: 0;
}

/* Contenido del menú - ENCIMA del overlay */
.menu-movil-content {
    position: relative;
    z-index: 10;
    top: 0;
    left: 0;
    height: 100%;
    width: 85%;
    max-width: 320px;
    background: #ffffff;
    box-shadow: 2px 0 20px rgba(0, 0, 0, 0.5);
    overflow-y: auto;
    overflow-x: hidden;
    padding-top: 0;
    padding-bottom: 80px;
    -webkit-overflow-scrolling: touch;
}

/* Logo en el menú */
.menu-logo {
    padding: 20px;
    border-bottom: 1px solid #e5e7eb;
    text-align: center;
}

.menu-logo img {
    height: 48px;
    width: auto;
    max-width: 100%;
}

/* Lista de categorías */
.menu-categorias-list {
    padding: 0;
    margin: 0;
    list-style: none;
}

/* Item de categoría */
.menu-categoria-item {
    border-bottom: 1px solid #e5e7eb;
}

/* Link directo de categoría (sin subcategorías) - MISMO estilo que el botón */
.menu-categoria-link {
    display: block;
    padding: 18px 20px;
    background-color: #f9fafb; /* MISMO color que .menu-categoria-btn */
    font-weight: 600;
    color: #1f2937; /* MISMO color que .menu-categoria-btn */
    text-decoration: none;
    transition: all 0.2s;
    border-left: 4px solid transparent;
    width: 100%;
    text-align: left;
}

.menu-categoria-link:hover {
    background-color: #f3f4f6; /* MISMO color que .menu-categoria-btn:hover */
    border-left-color: #47bac1;
    color: #47bac1;
    padding-left: 25px;
}

/* Botón de categoría */
.menu-categoria-btn {
    width: 100%;
    text-align: left;
    padding: 18px 20px;
    background-color: #f9fafb;
    font-weight: 600;
    color: #1f2937;
    border: none;
    cursor: pointer;
    display: flex;
    justify-content: space-between;
    align-items: center;
    transition: background-color 0.2s;
}

.menu-categoria-btn:hover {
    background-color: #f3f4f6;
}

/* Flecha de categoría */
.menu-categoria-btn i {
    transition: transform 0.3s;
    font-size: 14px;
    color: #6b7280;
}

.menu-categoria-btn.expanded i {
    transform: rotate(180deg);
}

/* Submenú */
.menu-submenu {
    max-height: 0;
    overflow: hidden;
    transition: max-height 0.3s ease-out;
    background-color: #ffffff;
}

.menu-submenu.expanded {
    max-height: 1000px;
}

/* Links del submenú */
.menu-submenu li {
    margin: 0;
    border-bottom: 1px solid #f3f4f6;
}

.menu-submenu li:last-child {
    border-bottom: none;
}

.menu-submenu a {
    display: block;
    padding: 14px 20px 14px 35px;
    font-size: 14px;
    color: #4b5563;
    text-decoration: none;
    transition: all 0.2s;
    border-left: 4px solid transparent;
}

.menu-submenu a:hover {
    background-color: #f9fafb;
    border-left-color: #47bac1;
    color: #47bac1;
    padding-left: 40px;
}

/* Ocultar en desktop */
@media (min-width: 992px) {
    .menu-movil-container {
        display: none;
    }
}

/* Prevenir scroll del body cuando el menú está abierto */
body.menu-open {
    overflow: hidden;
}
