/* ======================================
   MOBILE MENU ANIMATIONS
   ====================================== */

/* Solo aplicar en pantallas menores a 1024px (tablet y móvil) */
@media (max-width: 1024px) {

    /* Estado inicial de los elementos del menú móvil */
    #mobile-menu a {
        opacity: 0;
        transform: translateY(30px);
        transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1);
    }

    /* Animación stagger al abrir el menú */
    #mobile-menu.active a:nth-child(1) {
        animation: mobileMenuItemSlideUp 0.4s ease-out 0.1s forwards;
    }

    #mobile-menu.active a:nth-child(2) {
        animation: mobileMenuItemSlideUp 0.4s ease-out 0.2s forwards;
    }

    #mobile-menu.active a:nth-child(3) {
        animation: mobileMenuItemSlideUp 0.4s ease-out 0.3s forwards;
    }

    #mobile-menu.active a:nth-child(4) {
        animation: mobileMenuItemSlideUp 0.4s ease-out 0.4s forwards;
    }

    #mobile-menu.active a:nth-child(5) {
        animation: mobileMenuItemSlideUp 0.4s ease-out 0.5s forwards;
    }

    /* Animación de los iconos sociales */
    #mobile-menu.active .mt-8 {
        animation: mobileMenuItemSlideUp 0.4s ease-out 0.6s forwards;
        opacity: 0;
        transform: translateY(30px);
    }

    @keyframes mobileMenuItemSlideUp {
        from {
            opacity: 0;
            transform: translateY(30px);
        }
        to {
            opacity: 1;
            transform: translateY(0);
        }
    }

    /* Efectos de interacción para los enlaces del menú */
    #mobile-menu a {
        position: relative;
        transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
        cursor: pointer;
    }

    /* Efecto hover/tap */
    #mobile-menu a:hover,
    #mobile-menu a:active,
    #mobile-menu a:focus {
        color: #19B7B0 !important; /* accent color */
        transform: scale(1.03);
    }

    /* Efecto de resaltado sutil en el fondo */
    #mobile-menu a::before {
        content: '';
        position: absolute;
        top: 50%;
        left: 50%;
        width: 0;
        height: 0;
        background: rgba(25, 183, 176, 0.08); /* accent con baja opacidad */
        border-radius: 12px;
        transform: translate(-50%, -50%);
        transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
        z-index: -1;
    }

    #mobile-menu a:hover::before,
    #mobile-menu a:active::before,
    #mobile-menu a:focus::before {
        width: 120%;
        height: 140%;
    }

    /* Efectos para los iconos sociales */
    #mobile-menu .w-12 {
        transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    }

    #mobile-menu .w-12:hover,
    #mobile-menu .w-12:active,
    #mobile-menu .w-12:focus {
        transform: scale(1.05);
        box-shadow: 0 4px 12px rgba(25, 183, 176, 0.2);
    }

    /* Reset de animaciones cuando se cierra el menú */
    #mobile-menu:not(.active) a {
        animation: none;
        opacity: 0;
        transform: translateY(30px);
    }

    #mobile-menu:not(.active) .mt-8 {
        animation: none;
        opacity: 0;
        transform: translateY(30px);
    }
}

/* Soporte para dispositivos con modo de movimiento reducido */
@media (prefers-reduced-motion: reduce) and (max-width: 1024px) {
    #mobile-menu a,
    #mobile-menu .mt-8,
    #mobile-menu .w-12 {
        animation: none !important;
        transition: none !important;
        transform: none !important;
        opacity: 1 !important;
    }

    #mobile-menu a::before {
        display: none;
    }
}

/* ======================================
   OPTIMIZACIONES PARA TOUCH DEVICES
   ====================================== */

@media (max-width: 1024px) and (hover: none) and (pointer: coarse) {
    /* En dispositivos touch, aumentar el área de toque */
    #mobile-menu a {
        min-height: 48px;
        display: flex;
        align-items: center;
        justify-content: center;
        padding: 12px 24px;
    }

    /* Efecto de feedback táctil más pronunciado */
    #mobile-menu a:active {
        transform: scale(0.98);
        transition-duration: 0.1s;
    }
}
