/* ========================================================================
   MENÚ RESPONSIVE COMPLETO - DESKTOP + MÓVIL
   Este archivo maneja el menú en TODAS las resoluciones
   ======================================================================== */

/* ====================
   DESKTOP (> 992px)
   ==================== */
@media screen and (min-width: 993px) {
    /* Ocultar botón hamburguesa en desktop */
    .mobile-menu-toggle {
        display: none !important;
    }
    
    /* Menú horizontal normal en desktop */
    .nav-menu {
        display: flex !important;
        flex-direction: row !important;
        position: static !important;
        background: transparent !important;
        box-shadow: none !important;
        padding: 0 !important;
        margin: 0 !important;
        width: auto !important;
        height: auto !important;
        overflow: visible !important;
    }
    
    .nav-menu > li {
        display: inline-block !important;
        width: auto !important;
        margin: 0 !important;
        border: none !important;
    }
    
    .nav-menu > li > a {
        display: block !important;
        padding: 10px 15px !important;
        color: inherit !important;
    }
}

/* ====================
   MÓVIL (≤ 992px)
   ==================== */
@media screen and (max-width: 992px) {
    
    /* BOTÓN HAMBURGUESA */
    .mobile-menu-toggle {
        display: flex !important;
        flex-direction: column !important;
        justify-content: space-between !important;
        width: 30px !important;
        height: 24px !important;
        background: transparent !important;
        border: none !important;
        cursor: pointer !important;
        padding: 0 !important;
        z-index: 100000 !important;
        position: relative !important;
    }
    
    .mobile-menu-toggle span {
        display: block !important;
        width: 100% !important;
        height: 3px !important;
        background: var(--color-primary, #1B3A5C) !important;
        border-radius: 3px !important;
        transition: all 0.3s ease !important;
    }
    
    /* Animación X cuando está activo */
    .mobile-menu-toggle.active span:nth-child(1) {
        transform: translateY(10.5px) rotate(45deg) !important;
    }
    
    .mobile-menu-toggle.active span:nth-child(2) {
        opacity: 0 !important;
    }
    
    .mobile-menu-toggle.active span:nth-child(3) {
        transform: translateY(-10.5px) rotate(-45deg) !important;
    }
    
    /* MENÚ MÓVIL - MÚLTIPLES SELECTORES PARA COMPATIBILIDAD */
    .nav-menu,
    #navMenu,
    ul.nav-menu,
    nav .nav-menu,
    .navbar .nav-menu,
    header .navbar .nav-menu {
        /* Posición fija */
        position: fixed !important;
        top: 0 !important;
        right: -100% !important;
        bottom: 0 !important;
        left: auto !important;
        
        /* Tamaño - FORZAR contenedor más pequeño que el contenido */
        width: 85vw !important;
        max-width: 320px !important;
        height: 100vh !important;
        max-height: 100vh !important;
        min-height: 100vh !important;
        
        /* Fondo */
        background: #ffffff !important;
        box-shadow: -5px 0 20px rgba(0,0,0,0.3) !important;
        
        /* Layout - CRÍTICO para scroll */
        display: block !important;
        
        /* Padding - Reducir para forzar más contenido */
        padding: 60px 0 100px 0 !important;
        margin: 0 !important;
        
        /* SCROLL - FORZAR SIEMPRE */
        overflow-y: scroll !important;
        overflow-x: hidden !important;
        overscroll-behavior: contain !important;
        -webkit-overflow-scrolling: touch !important;
        
        /* Z-index */
        z-index: 99999 !important;
        
        /* Transición */
        transition: right 0.3s cubic-bezier(0.4, 0, 0.2, 1) !important;
        
        /* Performance */
        transform: translateZ(0) !important;
        will-change: right !important;
    }
    
    /* Menú ABIERTO */
    .nav-menu.active,
    #navMenu.active,
    ul.nav-menu.active,
    nav .nav-menu.active,
    .navbar .nav-menu.active,
    header .navbar .nav-menu.active {
        right: 0 !important;
    }
    
    /* ITEMS del menú */
    .nav-menu > li,
    #navMenu > li,
    ul.nav-menu > li,
    nav .nav-menu > li,
    .navbar .nav-menu > li {
        display: block !important;
        width: 100% !important;
        min-height: 48px !important;
        flex-shrink: 0 !important;
        margin: 0 !important;
        padding: 0 !important;
        border-bottom: 1px solid #e5e7eb !important;
        pointer-events: auto !important;
    }
    
    /* ENLACES principales */
    .nav-menu > li > a,
    #navMenu > li > a,
    ul.nav-menu > li > a,
    nav .nav-menu > li > a,
    .navbar .nav-menu > li > a {
        display: block !important;
        width: 100% !important;
        padding: 15px 20px !important;
        margin: 0 !important;
        color: #1e293b !important;
        font-size: 15px !important;
        font-weight: 500 !important;
        text-decoration: none !important;
        box-sizing: border-box !important;
        pointer-events: auto !important;
        cursor: pointer !important;
        touch-action: manipulation !important;
        transition: all 0.2s !important;
    }
    
    .nav-menu > li > a:hover,
    .nav-menu > li > a:active,
    #navMenu > li > a:hover,
    #navMenu > li > a:active {
        background: #f1f5f9 !important;
        color: #0ea5e9 !important;
        padding-left: 25px !important;
    }
    
    /* DROPDOWNS */
    .nav-menu .has-dropdown > a::after,
    #navMenu .has-dropdown > a::after {
        content: '▼' !important;
        float: right !important;
        font-size: 12px !important;
        transition: transform 0.3s !important;
    }
    
    .nav-menu .has-dropdown.active > a::after,
    #navMenu .has-dropdown.active > a::after {
        transform: rotate(180deg) !important;
    }
    
    .nav-menu .dropdown-menu,
    #navMenu .dropdown-menu {
        position: static !important;
        display: none !important;
        width: 100% !important;
        background: #f8f9fb !important;
        padding: 0 !important;
        margin: 0 !important;
        max-height: 0 !important;
        overflow: hidden !important;
        transition: max-height 0.3s ease !important;
    }
    
    .nav-menu .has-dropdown.active .dropdown-menu,
    #navMenu .has-dropdown.active .dropdown-menu {
        display: block !important;
        max-height: 600px !important;
    }
    
    .nav-menu .dropdown-menu li,
    #navMenu .dropdown-menu li {
        display: block !important;
        width: 100% !important;
    }
    
    .nav-menu .dropdown-menu li a,
    #navMenu .dropdown-menu li a {
        display: block !important;
        width: 100% !important;
        padding: 12px 20px 12px 40px !important;
        color: #475569 !important;
        font-size: 14px !important;
        text-decoration: none !important;
        pointer-events: auto !important;
        cursor: pointer !important;
        touch-action: manipulation !important;
        transition: all 0.2s !important;
    }
    
    .nav-menu .dropdown-menu li a:hover,
    .nav-menu .dropdown-menu li a:active,
    #navMenu .dropdown-menu li a:hover,
    #navMenu .dropdown-menu li a:active {
        background: #e2e8f0 !important;
        color: #0ea5e9 !important;
        padding-left: 45px !important;
    }
    
    /* BODY cuando menú abierto */
    body.menu-open {
        overflow: hidden !important;
        height: 100vh !important;
    }
    
    /* OVERLAY */
    body.menu-open::before {
        content: '' !important;
        position: fixed !important;
        top: 0 !important;
        left: 0 !important;
        right: 0 !important;
        bottom: 0 !important;
        background: rgba(0, 0, 0, 0.5) !important;
        z-index: 99998 !important;
        animation: fadeIn 0.3s !important;
        pointer-events: auto !important;
    }
    
    /* ASEGURAR que el menú esté ENCIMA del overlay */
    .nav-menu.active,
    #navMenu.active,
    ul.nav-menu.active {
        z-index: 99999 !important;
    }
    
    /* ASEGURAR que los enlaces sean clickeables */
    .nav-menu a,
    #navMenu a,
    .nav-menu li,
    #navMenu li {
        pointer-events: auto !important;
        cursor: pointer !important;
    }
    
    @keyframes fadeIn {
        from { opacity: 0; }
        to { opacity: 1; }
    }
}

/* Móvil muy pequeño */
@media screen and (max-width: 480px) {
    .nav-menu,
    #navMenu {
        width: 90vw !important;
        max-width: 280px !important;
    }
}
