/* --- Media Queries para Dispositivos Móviles --- */

/* Anulamos el padding del contenedor principal en móvil para que las secciones ocupen todo el ancho */
.container {
    padding: 0;
}

@media (max-width: 1320px) {
    /* --- Header Fijo en Móvil --- */
    .main-header {
        position: fixed;
        top: 0;
        left: 0;
        width: 100%;
        height: 80px; /* Altura reducida para móvil */
        padding: 0 20px;
        border-radius: 0; /* Sin bordes redondeados cuando es fijo */
        justify-content: flex-start; /* Alinea el contenido (logo) a la izquierda */
        align-items: center; /* Centra verticalmente el logo */
    }

    /* Espacio para el header fijo en el contenido principal */
    main {
        padding-top: 80px; /* Espacio para el header fijo */
    }
    /* --- Botón de Hamburguesa --- */
    .hamburger-button {
        display: flex;
        flex-direction: column;
        justify-content: center;
        align-items: center;
        width: 50px;
        height: 50px;
        background: transparent;
        border: none;
        cursor: pointer;
        padding: 0;
        position: absolute; /* Ahora es relativo al header */
        top: 50%;
        right: 40px;
        transform: translateY(-50%); /* Centrado verticalmente */
        z-index: 1001; /* Debe estar sobre el nav */
    }

    .hamburger-button .bar {
        width: 28px;
        height: 3px;
        background: var(--text-color);
        display: block;
        border-radius: 3px;
        transition: transform 0.3s ease-in-out, top 0.3s ease-in-out;
        position: relative;
    }

    .hamburger-button .bar:first-child {
        top: -4px;
    }

    .hamburger-button .bar:last-child {
        top: 4px;
    }

    /* --- Estado Activo del Menú (cuando se abre) --- */
    .main-header.menu-open .hamburger-button .bar {
        background: var(--text-color);
    }

    .main-header.menu-open .hamburger-button .bar:first-child {
        transform: rotate(45deg);
        top: 0;
    }

    .main-header.menu-open .hamburger-button .bar:last-child {
        transform: rotate(-45deg);
        top: -3px;
    }

    /* --- Estilos de la Navegación Principal en Móvil --- */
    .main-nav {
        position: fixed;
        top: 0;
        left: 0;
        width: 100vw;
        height: 100vh;
        visibility: hidden;
        pointer-events: none;
        z-index: 1000;
    }

    /* Paneles de la cortina */
    .main-nav::before,
    .main-nav::after {
        content: '';
        position: absolute;
        top: 0;
        width: 50vw;
        height: 100vh;
        background: var(--primary-color);
        transform: scaleY(0);
        transition: transform 0.5s cubic-bezier(0.86, 0, 0.07, 1);
    }

    .main-nav::before {
        left: 0;
        transform-origin: bottom;
    }

    .main-nav::after {
        right: 0;
        transform-origin: top;
        transition-delay: 0.1s;
    }

    .main-header.menu-open .main-nav {
        visibility: visible;
        pointer-events: auto;
    }

    .main-header.menu-open .main-nav::before,
    .main-header.menu-open .main-nav::after {
        transform: scaleY(1);
    }

    .main-nav ul {
        flex-direction: column;
        justify-content: center;
        text-align: center;
        padding: 0;
        margin: 0;
        list-style: none;
        position: relative;
        z-index: 1001;
        height: 100%;
        display: flex;
        align-items: center;
    }

    .main-nav li {
        margin: 10px 0;
        opacity: 0;
        transform: translateY(20px);
        transition: opacity 0.4s ease, transform 0.4s ease;
        visibility: hidden;
    }

    .main-header.menu-open .main-nav li {
        visibility: visible;
        opacity: 1;
        transform: translateY(0);
    }    

    /* Animación escalonada para los items del menú (empezando desde el 2do item) */
    .main-header.menu-open .main-nav li:nth-child(2) { transition-delay: 0.40s; } .main-header.menu-open .main-nav li:nth-child(3) { transition-delay: 0.45s; } .main-header.menu-open .main-nav li:nth-child(4) { transition-delay: 0.50s; } .main-header.menu-open .main-nav li:nth-child(5) { transition-delay: 0.55s; } .main-header.menu-open .main-nav li:nth-child(6) { transition-delay: 0.60s; } .main-header.menu-open .main-nav li:nth-child(7) { transition-delay: 0.65s; } .main-header.menu-open .main-nav li:nth-child(8) { transition-delay: 0.70s; }

    .hamburger-menu {
        display: none; /* Ocultamos el botón antiguo */
    }

    .main-nav a {
        color: var(--text-color); /* Texto oscuro sobre fondo amarillo */
        font-size: clamp(1.5rem, 5vw, 2.5rem); /* Tamaño de fuente adaptable */
        font-weight: 700;
        text-decoration: none;
    }

    .main-nav .dropdown > a::after {
        content: '▼';
        display: inline-block;
        font-size: 0.5em;
        margin-left: 8px;
        transition: transform 0.3s ease;
        vertical-align: middle;
    }

    .main-nav .dropdown.is-open-mobile > a::after {
        transform: rotate(180deg);
    }
    
    .dropdown-wrapper {
        /* Estilo de acordeón: oculto por defecto y se expande con JS */
        max-height: 0;
        overflow: hidden;
        transition: max-height 0.4s ease-in-out;
    }

    .dropdown-content {
        position: static; /* Anulamos el posicionamiento absoluto en móvil */
        visibility: visible; /* Siempre visible para el cálculo de altura */
        opacity: 1; /* Siempre opaco */
        background-color: transparent; /* Sin fondo */
        box-shadow: none;
        /* width: 100%; */ /* Eliminamos el ancho fijo */
        padding: 5px 0;
        margin-top: 5px;
        border-radius: 0;
        list-style: none;
        /* Centramos el contenedor del submenú */
        margin: 5px auto 0 auto;
    }
    
    .dropdown-content a {
        font-size: 0.8em; /* Aumentamos el tamaño para mejor legibilidad */
        color: #000000; /* Cambiado a negro para máximo contraste */
        padding: 5px 20px; /* Espaciado reducido */
        font-weight: 400; /* Peso de fuente normal para diferenciarlo del padre */
        display: block;
        text-align: center; /* Centramos el texto del submenú */
    }

    .megamenu .dropdown-content {
        transform: none; /* Anulamos cualquier transformación del megamenu */
        /* Anulamos los estilos de escritorio para que se comporte como un dropdown normal */
        left: auto;
        padding: 5px 0;
        white-space: normal;
    }

    /* --- Banner de 3 imágenes en vertical --- */
    .multi-image-banner-section {
        flex-direction: column;
    }

    .multi-image-banner-section img {
        width: 100%; /* Cada imagen ocupa el ancho completo */
    }

    /* --- Secciones --- */
    .ribbon-title {
        /* Tamaño de fuente fluido para adaptarse a cualquier pantalla */
        font-size: clamp(28px, 8vw, 36px);
    }

    .download-menu-link {
        font-size: clamp(18px, 5vw, 24px);
    }

    .newsletter-section h2 {
        font-size: 36px;
    }

    .newsletter-section p {
        font-size: clamp(16px, 4vw, 18px);
    }

    .newsletter-form {
        flex-direction: column;
        align-items: center;
        gap: 10px;
    }

    .newsletter-form input,
    .newsletter-form button {
        width: 100%;
        max-width: 400px;
        border-radius: 25px; /* Bordes redondeados completos en móvil */
        margin-bottom: 10px;
    }

    /* Estilos para el botón Order Online en móvil */
    .order-online-sticky {
        /* Reiniciamos y transformamos en un botón circular en la esquina inferior izquierda */
        animation: none;
        transform: translateY(0) rotate(0); /* Reiniciamos transformaciones */
        transform-origin: center;
        top: auto;
        right: auto;
        bottom: 20px;
        left: 20px;
        width: 60px; /* Tamaño del círculo */
        height: 60px;
        border-radius: 50%;
        padding: 0 5px; /* Pequeño padding para que el texto no toque los bordes */
        font-size: 13px; /* Tamaño de fuente para "Order Online" */
        line-height: 1.2;
        text-align: center;
        opacity: 1;
        display: flex;
        justify-content: center;
        align-items: center;
    }

    /* --- NUEVOS ESTILOS PARA EL LOGO --- */
    .mobile-nav-logo-li {
        display: list-item; /* Hacemos que sea visible en el menú móvil */
        margin-top: -15px; /* Lo subimos 15px */
        margin-bottom: 15px; /* Separación de 15px sobre "Home" */
        padding-bottom: 15px; /* Espacio extra para que no se vea pegado */
    }

    .mobile-nav-logo-li img {
        max-height: 55px; /* Aumentamos el tamaño del logo */
    }

    /* Hacemos visible el logo principal en el header en móvil */
    .logo {
        position: static; /* Anulamos el posicionamiento absoluto */
        transform: none; /* Reiniciamos cualquier transformación */
    }
}
