/* Estilos globales para el sitio */

/* Variables de colores */
:root {
    --primary-color: #6366F1;
    --primary-darker: #4F46E5;
    --accent-color: #8B5CF6;
    --accent-darker: #7C3AED;
    --success-color: #10B981;
    --warning-color: #F59E0B;
    --danger-color: #EF4444;
}

/* Estilos específicos para cards de productos */
.product-card:hover {
    transform: translateY(-5px);
    box-shadow: 0 10px 25px -5px rgba(0, 0, 0, 0.1), 0 10px 10px -5px rgba(0, 0, 0, 0.04);
}

/* Efecto de transición para todos los enlaces e interacciones */
a, button, .transition {
    transition: all 0.3s ease;
}

/* Estilos para badges y etiquetas especiales */
.sale-badge {
    position: absolute;
    top: 10px;
    right: 10px;
    background-color: var(--danger-color);
    color: white;
    padding: 4px 8px;
    border-radius: 9999px;
    font-size: 0.75rem;
    font-weight: bold;
    z-index: 10;
}

/* Estilos para imágenes de productos */
.product-image-container {
    overflow: hidden;
}

.product-image {
    transition: transform 0.5s ease;
}

.product-image-container:hover .product-image {
    transform: scale(1.1);
}

/* Estilos para el carrito */
.cart-counter {
    transition: opacity 0.3s ease, transform 0.3s ease;
}

.cart-counter.hidden {
    opacity: 0;
    transform: scale(0.5);
}

/* Animaciones */
@keyframes pulse {
    0%, 100% {
        opacity: 1;
    }
    50% {
        opacity: 0.7;
    }
}

.animate-pulse {
    animation: pulse 2s cubic-bezier(0.4, 0, 0.6, 1) infinite;
}

/* Personalización de formularios */
input:focus, select:focus, textarea:focus {
    border-color: var(--primary-color);
    box-shadow: 0 0 0 3px rgba(99, 102, 241, 0.2);
}

/* Estilos específicos para el menú de usuario */
#user-menu {
    z-index: 50;
    transition: opacity 0.2s ease, visibility 0.2s ease;
}

#user-menu.hidden {
    display: none !important;
    visibility: hidden !important;
    opacity: 0 !important;
}

#user-menu:not(.hidden) {
    display: block !important;
    visibility: visible !important;
    opacity: 1 !important;
}

/* Media queries para responsividad */
@media (max-width: 768px) {
    .container {
        padding-left: 1rem;
        padding-right: 1rem;
    }
}
