        /* ============================================================
           ESTILOS GENERALES
           ============================================================ */
        body {
            margin: 0;
            padding: 0;
            font-family: 'Montserrat', sans-serif; 
            background-color: #f4f4f4;
        }

        a {
            text-decoration: none;
            transition: all 0.3s ease;
        }

        ul {
            list-style: none;
            margin: 0;
            padding: 0;
        }

        /* ============================================================
           NAVBAR
           ============================================================ */
        .navbar {
            background-color: #1c0590; /* Azul marino */
            color: #d4af37; /* Dorado */
            box-shadow: 0 4px 6px rgba(0,0,0,0.1);
            position: relative;
        }

        .nav-top {
            display: flex;
            align-items: center;
            padding: 10px 5%;
            position: relative;
            height: 100px;
        }

        .logo {
            position: absolute;
            left: 50%;
            transform: translateX(-50%);
            height: 80px;
        }
        
        .logo img {
            height: 100%;
            width: auto;
        }

        .top-actions {
            margin-left: auto;
            display: flex;
            align-items: center;
            gap: 15px;
        }

        .cart {
            font-size: 1.5rem;
            color: #d4af37;
            cursor: pointer;
            display: flex;
            align-items: center;
        }

        .menu-toggle {
            display: none; 
            color: #d4af37;
            font-size: 2.5rem;
            cursor: pointer;
        }

        .nav-bottom {
            background-color: rgba(0, 0, 0, 0.1);
            padding: 10px 5%;
        }

        .menu {
            display: flex;
            justify-content: center;
            gap: 30px;
        }

        .menu > li > a {
            color: #d4af37;
            font-weight: bold;
            font-size: 1.1rem;
            padding: 10px 0;
            display: block;
        }

        /* DROPDOWNS */
        .dropdown { position: relative; }

        .dropdown-menu {
            display: none;
            position: absolute;
            top: 100%;
            left: 50%;
            transform: translateX(-50%);
            background-color: #1c0590;
            min-width: 180px;
            box-shadow: 0px 8px 16px rgba(0,0,0,0.2);
            z-index: 1000;
            border-radius: 4px;
            overflow: hidden;
        }

        .menu li:hover > .dropdown-menu { display: block; }

        .dropdown-menu li a {
            color: #ffffff;
            padding: 12px 16px;
            display: block;
            border-bottom: 1px solid rgba(255,255,255,0.1);
        }

        .dropdown-menu li:hover { background-color: #aaaaaa; }
        .dropdown-menu li:hover a { color: white !important; }

        /* ============================================================
           CARRUSEL (Respetando formato original)
           ============================================================ */
        .main-slider-container {
            width: 100%;
            overflow: hidden;
            position: relative;
            background-color: transparent;
        }

        .slides {
            display: flex;
            width: 300%; 
            transition: transform 0.8s cubic-bezier(0.45, 0, 0.55, 1);
            align-items: flex-start;
        }

        .slide {
            width: 100%;
            height: auto;
        }

        .slide img {
            width: 100%;
            height: auto; /* Mantiene proporción original */
            display: block;
            object-fit: contain;
        }

        .arrow {
            position: absolute;
            top: 50%;
            transform: translateY(-50%);
            background: rgba(28, 5, 144, 0.5);
            color: #d4af37;
            border: none;
            padding: 12px;
            cursor: pointer;
            z-index: 100;
            font-size: 1.5rem;
            border-radius: 50%;
            margin: 0 15px;
            transition: 0.3s;
        }

        .arrow:hover { background: rgba(28, 5, 144, 0.8); }
        .next { right: 0; }
        .prev { left: 0; }

        .desktop-only { display: block; }
        .mobile-only { display: none; }

        /* ============================================================
           RESPONSIVE (Móvil)
           ============================================================ */
        @media screen and (max-width: 768px) {
            .menu-toggle { display: block; }

            .nav-top {
                height: 70px;
                justify-content: space-between;
                position: static;
            }

            .logo {
                position: static;
                transform: none;
                height: 50px;
            }

            .menu {
                display: none;
                flex-direction: column;
                width: 100%;
                background-color: #1c0590;
                position: absolute;
                top: 100%;
                left: 0;
                z-index: 999;
                padding-bottom: 15px;
            }

            .menu.active { display: flex; }

            .menu > li > a {
                padding: 15px 5%;
                border-bottom: 1px solid rgba(255,255,255,0.1);
            }

            .dropdown-menu {
                position: static;
                transform: none;
                width: 100%;
                background-color: rgba(255,255,255,0.05);
                box-shadow: none;
            }

            .dropdown.active .dropdown-menu { display: block; }
            .dropdown-menu li a { padding-left: 10%; }

            /* Visibilidad Carrusel Móvil */
            .desktop-only { display: none; }
            .mobile-only { display: block; }
        }

        .seccion-categorias {
            max-width: 1200px; /* Ancho máximo para que no se estire demasiado en pantallas grandes */
            margin: 60px auto; /* Centrado horizontalmente y con espacio arriba/abajo */
            padding: 0 5%; /* Espaciado lateral para que no toque los bordes */
            text-align: center; /* Centra el título y el contenido */
        }

        /* --- Estilo para el título "CATEGORIAS" --- */
        .titulo-categorias {
            color: #0a0f6b; /* Azul marino oscuro de tu logo */
            font-size: 2.5rem; /* Tamaño de letra grande y llamativo */
            font-weight: bold;
            text-transform: uppercase; /* Todo en mayúsculas */
            letter-spacing: 2px; /* Espaciado entre letras premium */
            margin-bottom: 50px; /* Espacio antes de la cuadrícula de imágenes */
        }

        /* --- La cuadrícula (Grid) de categorías --- */
        .grid-categorias {
            display: grid;
            /* Crea 4 columnas iguales en desktop */
            grid-template-columns: repeat(4, 1fr); 
            gap: 30px; /* Espacio entre cada columna de categoría */
            align-items: end; /* Alinea los elementos por la parte inferior */
        }

        /* --- Estilo para cada tarjeta de categoría --- */
        .categoria-item {
            display: flex;
            flex-direction: column; /* Apila imagen y texto verticalmente */
            align-items: center; /* Centra horizontalmente imagen y texto */
            justify-content: flex-end; /* Empuja el contenido hacia abajo */
            cursor: pointer; /* Cambia el cursor a "manita" al pasar sobre el link */
            height: 100%; /* Asegura que todas tengan la misma altura */
        }

        /* --- Estilo para las imágenes --- */
        .categoria-imagen-wrapper {
            width: 100%; /* El contenedor de imagen ocupa todo el ancho de la columna */
            max-width: 200px; /* Ancho máximo de la imagen para que no sea gigante */
            margin-bottom: 20px; /* Espacio antes del texto */
            /* Efecto sutil para que las imágenes destaquen al hover */
            transition: transform 0.3s ease; 
        }

        .categoria-item img {
            width: 100%; /* La imagen ocupa todo el contenedor */
            height: auto; /* Mantiene la proporción original */
            display: block;
        }

        /* --- Estilo para los nombres de las categorías --- */
        .categoria-nombre {
            color: #0a0f6b; /* Azul marino oscuro */
            font-size: 1.2rem; /* Tamaño de letra legible */
            font-weight: bold;
            text-transform: uppercase; /* Mayúsculas */
            letter-spacing: 1px; /* Espaciado sutil */
            margin: 0; /* Quita márgenes por defecto */
        }

        /* --- ⚠️⚠️ EFECTOS HOVER (Al pasar el mouse) ⚠️⚠️ --- */
        
        /* 1. Al pasar el mouse por la tarjeta entera: La imagen sube ligeramente */
        .categoria-item:hover .categoria-imagen-wrapper {
            transform: translateY(-10px); /* Sube 10px suavemente */
        }

        /* 2. Al pasar el mouse por la tarjeta entera: El texto se vuelve dorado */
        .categoria-item:hover .categoria-nombre {
            color: #d4af37; /* Dorado de Gio Experience */
        }

        /* --- RESPONSIVE STYLES (Celulares) --- */
        @media screen and (max-width: 768px) {
            .seccion-categorias {
                margin: 40px auto; /* Menos margen en móvil */
            }

            .titulo-categorias {
                font-size: 2rem; /* Título un poco más pequeño */
                margin-bottom: 30px;
            }

            /* ⚠️ Cambiamos a 2 columnas en móvil ⚠️ */
            .grid-categorias {
                grid-template-columns: repeat(2, 1fr); 
                gap: 20px; /* Menor espacio entre columnas */
            }

            .categoria-imagen-wrapper {
                max-width: 150px; /* Imágenes más pequeñas en móvil */
            }

            .categoria-nombre {
                font-size: 1rem; /* Texto más pequeño */
            }
        }

        /* --- SECCIÓN PRODUCTOS --- */
.productos-destacados {
    max-width: 1200px;
    margin: 80px auto;
    padding: 0 5%;
    text-align: center;
}

.titulo-seccion {
    color: #1c0590; /* Tu azul marino */
    font-size: 2rem;
    margin-bottom: 50px;
    letter-spacing: 1px;
}

/* El Grid: 4 columnas en PC */
.grid-productos {
    display: grid;
    grid-template-columns: repeat(4, 1fr); 
    gap: 30px;
}

.producto-card {
    display: flex;
    flex-direction: column;
    align-items: center;
    transition: transform 0.3s ease;
}

.producto-imagen {
    width: 100%;
    margin-bottom: 15px;
}

.producto-imagen img {
    width: 100%;
    height: auto;
    object-fit: contain;
}

/* Botón Agregar al Carrito */
.btn-agregar {
    background-color: #1c0590;
    color: white;
    border: none;
    padding: 12px 20px;
    width: 100%;
    font-weight: bold;
    font-size: 0.85rem;
    cursor: pointer;
    border-radius: 4px;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    transition: background 0.3s;
    margin-bottom: 15px;
}

.btn-agregar:hover {
    background-color: #d4af37; /* Cambia a dorado al pasar el mouse */
}

.producto-titulo {
    font-size: 0.95rem;
    color: #666;
    font-weight: normal;
    margin: 10px 0;
    min-height: 40px; /* Para que todos los títulos ocupen el mismo espacio */
}

/* Precios */
.producto-precios {
    display: flex;
    flex-direction: column;
    gap: 5px;
}

.precio-antes {
    text-decoration: line-through;
    color: #999;
    font-size: 0.9rem;
}

.precio-ahora {
    color: #333;
    font-weight: bold;
    font-size: 1.1rem;
}

/* ==========================================
   VISTA MÓVIL (2 Columnas)
   ========================================== */
@media screen and (max-width: 768px) {
    .grid-productos {
        grid-template-columns: repeat(2, 1fr); /* 2 columnas en celular */
        gap: 20px;
    }

    .titulo-seccion {
        font-size: 1.5rem;
    }

    .btn-agregar {
        font-size: 0.7rem;
        padding: 10px 5px;
    }
}