/* ============================================
   ESTILOS TEMÁTICOS DEL CATÁLOGO
   ============================================ */

/* TEMA: CLÁSICO */
.catalog-theme-default .catalog-page {
    background: linear-gradient(135deg, #667eea 0%, #764ba2 100%);
    position: relative;
    overflow: hidden;
}

.catalog-theme-default .catalog-page::before {
    content: '';
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: 
        radial-gradient(circle at 20% 30%, rgba(255,255,255,0.15) 0%, transparent 50%),
        radial-gradient(circle at 80% 70%, rgba(255,255,255,0.15) 0%, transparent 50%),
        radial-gradient(circle at 50% 50%, rgba(139,92,246,0.1) 0%, transparent 60%);
    animation: gentlePulse 8s ease-in-out infinite;
    pointer-events: none;
    z-index: 0;
}

.catalog-theme-default .category-card,
.catalog-theme-default .product-card {
    animation: elegantFloat 4s ease-in-out infinite;
    animation-delay: calc(var(--card-index, 0) * 0.15s);
    transition: all 0.3s ease;
}

.catalog-theme-default .category-card:hover,
.catalog-theme-default .product-card:hover {
    transform: translateY(-8px) scale(1.02);
    box-shadow: 0 12px 30px rgba(99, 102, 241, 0.4);
}

.catalog-theme-default .btn-view,
.catalog-theme-default .btn-add-cart {
    background: linear-gradient(135deg, #6366f1 0%, #8b5cf6 100%);
    box-shadow: 0 4px 15px rgba(99, 102, 241, 0.4);
    transition: all 0.3s ease;
    position: relative;
    overflow: hidden;
}

.catalog-theme-default .btn-view::before,
.catalog-theme-default .btn-add-cart::before {
    content: '';
    position: absolute;
    top: 0;
    left: -100%;
    width: 100%;
    height: 100%;
    background: linear-gradient(90deg, transparent, rgba(255,255,255,0.3), transparent);
    transition: left 0.5s;
}

.catalog-theme-default .btn-view:hover::before,
.catalog-theme-default .btn-add-cart:hover::before {
    left: 100%;
}

.catalog-theme-default .btn-view:hover,
.catalog-theme-default .btn-add-cart:hover {
    transform: translateY(-2px);
    box-shadow: 0 6px 25px rgba(99, 102, 241, 0.6);
}

/* TEMA: NAVIDAD */
.catalog-theme-christmas .catalog-page {
    background: linear-gradient(135deg, #dc2626 0%, #16a34a 100%);
    position: relative;
    overflow: hidden;
}

.catalog-theme-christmas .catalog-page::before {
    content: '';
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    pointer-events: none;
    z-index: 0;
    background-image: 
        radial-gradient(circle at 10% 20%, rgba(255,255,255,0.8) 1px, transparent 1px),
        radial-gradient(circle at 30% 40%, rgba(255,255,255,0.6) 1px, transparent 1px),
        radial-gradient(circle at 50% 10%, rgba(255,255,255,0.7) 1px, transparent 1px),
        radial-gradient(circle at 70% 60%, rgba(255,255,255,0.5) 1px, transparent 1px),
        radial-gradient(circle at 90% 30%, rgba(255,255,255,0.8) 1px, transparent 1px);
    background-size: 200px 200px, 150px 150px, 180px 180px, 160px 160px, 190px 190px;
    animation: snowFall 15s linear infinite;
}

.catalog-theme-christmas .catalog-page::after {
    content: '❄️ ❄️ ❄️';
    position: fixed;
    font-size: 1.5rem;
    color: rgba(255,255,255,0.8);
    animation: snowFloat 15s linear infinite;
    pointer-events: none;
    z-index: 0;
    white-space: nowrap;
    top: -50px;
    left: 0;
    width: 100%;
    text-align: center;
}

.catalog-theme-christmas .category-card,
.catalog-theme-christmas .product-card {
    border: 2px solid rgba(255,255,255,0.3);
    box-shadow: 0 8px 25px rgba(220, 38, 38, 0.3), 
                0 0 20px rgba(255,255,255,0.2) inset;
    animation: christmasGlow 2s ease-in-out infinite;
    position: relative;
}

.catalog-theme-christmas .category-card::before,
.catalog-theme-christmas .product-card::before {
    content: '✨';
    position: absolute;
    top: -10px;
    right: -10px;
    font-size: 1.5rem;
    animation: sparkle 1.5s ease-in-out infinite;
    pointer-events: none;
    z-index: 10;
}

.catalog-theme-christmas .category-card::after,
.catalog-theme-christmas .product-card::after {
    content: '🎄';
    position: absolute;
    bottom: -15px;
    left: -15px;
    font-size: 1.2rem;
    animation: christmasTree 3s ease-in-out infinite;
    pointer-events: none;
    z-index: 10;
    opacity: 0.6;
}

.catalog-theme-christmas .btn-view,
.catalog-theme-christmas .btn-add-cart {
    background: linear-gradient(135deg, #dc2626 0%, #16a34a 100%);
    box-shadow: 0 4px 15px rgba(220, 38, 38, 0.5);
    position: relative;
    overflow: hidden;
}

.catalog-theme-christmas .btn-view::before,
.catalog-theme-christmas .btn-add-cart::before {
    content: '';
    position: absolute;
    top: -50%;
    left: -50%;
    width: 200%;
    height: 200%;
    background: linear-gradient(45deg, transparent, rgba(255,255,255,0.3), transparent);
    animation: shimmer 2s infinite;
}

@keyframes snowFall {
    0% { transform: translateY(-100vh) translateX(0); }
    100% { transform: translateY(100vh) translateX(100px); }
}

@keyframes snowFloat {
    0% { 
        transform: translateY(-100px) translateX(0) rotate(0deg);
        opacity: 0;
    }
    10% { opacity: 1; }
    90% { opacity: 1; }
    100% { 
        transform: translateY(100vh) translateX(200px) rotate(360deg);
        opacity: 0;
    }
}

@keyframes christmasGlow {
    0%, 100% { 
        box-shadow: 0 8px 25px rgba(220, 38, 38, 0.3), 
                    0 0 20px rgba(255,255,255,0.2) inset;
    }
    50% { 
        box-shadow: 0 8px 35px rgba(220, 38, 38, 0.5), 
                    0 0 30px rgba(255,255,255,0.4) inset;
    }
}

@keyframes sparkle {
    0%, 100% { transform: scale(1) rotate(0deg); opacity: 0.7; }
    50% { transform: scale(1.4) rotate(180deg); opacity: 1; }
}

@keyframes christmasTree {
    0%, 100% { transform: scale(1) rotate(0deg); }
    25% { transform: scale(1.1) rotate(-5deg); }
    75% { transform: scale(1.1) rotate(5deg); }
}

@keyframes shimmer {
    0% { transform: translateX(-100%) translateY(-100%) rotate(45deg); }
    100% { transform: translateX(100%) translateY(100%) rotate(45deg); }
}

/* TEMA: CARNAVALES */
.catalog-theme-carnival .catalog-page {
    background: linear-gradient(135deg, #f59e0b 0%, #ec4899 100%);
    position: relative;
    overflow: hidden;
}

.catalog-theme-carnival .catalog-page::before {
    content: '';
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    pointer-events: none;
    z-index: 0;
    background-image: 
        radial-gradient(circle at 15% 25%, rgba(245,158,11,0.6) 3px, transparent 3px),
        radial-gradient(circle at 85% 45%, rgba(236,72,153,0.6) 3px, transparent 3px),
        radial-gradient(circle at 45% 65%, rgba(245,158,11,0.5) 2px, transparent 2px),
        radial-gradient(circle at 75% 15%, rgba(236,72,153,0.5) 2px, transparent 2px);
    background-size: 80px 80px, 100px 100px, 90px 90px, 110px 110px;
    animation: confettiFall 12s linear infinite;
}

.catalog-theme-carnival .category-card,
.catalog-theme-carnival .product-card {
    background: linear-gradient(135deg, rgba(255,255,255,0.95) 0%, rgba(255,255,255,0.9) 100%);
    border: 3px solid transparent;
    background-clip: padding-box;
    box-shadow: 0 8px 25px rgba(245, 158, 11, 0.4);
    animation: carnivalBounce 2s ease-in-out infinite;
    position: relative;
}

.catalog-theme-carnival .category-card::after,
.catalog-theme-carnival .product-card::after {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    border-radius: inherit;
    padding: 3px;
    background: linear-gradient(45deg, #f59e0b, #ec4899, #f59e0b, #f59e0b);
    background-size: 200% 200%;
    -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
    -webkit-mask-composite: xor;
    mask-composite: exclude;
    animation: borderRotate 3s linear infinite;
    pointer-events: none;
    z-index: 1;
}

.catalog-theme-carnival .category-card::before,
.catalog-theme-carnival .product-card::before {
    content: '🎉';
    position: absolute;
    top: -12px;
    right: -12px;
    font-size: 1.8rem;
    animation: confettiBurst 2s ease-in-out infinite;
    pointer-events: none;
    z-index: 10;
}

.catalog-theme-carnival .btn-view,
.catalog-theme-carnival .btn-add-cart {
    background: linear-gradient(135deg, #f59e0b 0%, #ec4899 100%);
    box-shadow: 0 4px 20px rgba(245, 158, 11, 0.5);
    animation: carnivalPulse 1.5s ease-in-out infinite;
}

@keyframes confettiFall {
    0% { transform: translateY(-100vh) rotate(0deg); }
    100% { transform: translateY(100vh) rotate(720deg); }
}

@keyframes carnivalBounce {
    0%, 100% { transform: translateY(0); }
    50% { transform: translateY(-5px); }
}

@keyframes borderRotate {
    0% { background-position: 0% 50%; }
    100% { background-position: 200% 50%; }
}

@keyframes confettiBurst {
    0%, 100% { transform: scale(1) rotate(0deg); }
    25% { transform: scale(1.2) rotate(15deg); }
    50% { transform: scale(1.1) rotate(-15deg); }
    75% { transform: scale(1.2) rotate(10deg); }
}

@keyframes carnivalPulse {
    0%, 100% { transform: scale(1); box-shadow: 0 4px 20px rgba(245, 158, 11, 0.5); }
    50% { transform: scale(1.05); box-shadow: 0 6px 30px rgba(245, 158, 11, 0.7); }
}

/* TEMA: SEMANA SANTA */
.catalog-theme-easter .catalog-page {
    background: linear-gradient(135deg, #fbbf24 0%, #a78bfa 100%);
    position: relative;
    overflow: hidden;
}

.catalog-theme-easter .catalog-page::before {
    content: '';
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    pointer-events: none;
    z-index: 0;
    background-image: 
        radial-gradient(circle at 20% 30%, rgba(251,191,36,0.3) 4px, transparent 4px),
        radial-gradient(circle at 60% 50%, rgba(167,139,250,0.3) 4px, transparent 4px),
        radial-gradient(circle at 80% 20%, rgba(251,191,36,0.2) 3px, transparent 3px);
    background-size: 150px 150px, 120px 120px, 180px 180px;
    animation: easterFloat 20s ease-in-out infinite;
}

.catalog-theme-easter .category-card,
.catalog-theme-easter .product-card {
    background: linear-gradient(135deg, rgba(255,255,255,0.95) 0%, rgba(255,248,220,0.9) 100%);
    border: 2px dashed rgba(167,139,250,0.4);
    box-shadow: 0 8px 25px rgba(251, 191, 36, 0.3);
    animation: easterBounce 3s ease-in-out infinite;
}

.catalog-theme-easter .category-icon,
.catalog-theme-easter .product-image {
    animation: easterHop 2s ease-in-out infinite;
}

.catalog-theme-easter .category-card::before,
.catalog-theme-easter .product-card::before {
    content: '🥚';
    position: absolute;
    top: -10px;
    left: -10px;
    font-size: 1.3rem;
    animation: eggBounce 2.5s ease-in-out infinite;
    pointer-events: none;
    z-index: 10;
}

.catalog-theme-easter .category-card::after,
.catalog-theme-easter .product-card::after {
    content: '🐰';
    position: absolute;
    bottom: -12px;
    right: -12px;
    font-size: 1.2rem;
    animation: bunnyHop 3s ease-in-out infinite;
    pointer-events: none;
    z-index: 10;
    opacity: 0.7;
}

.catalog-theme-easter .btn-view,
.catalog-theme-easter .btn-add-cart {
    background: linear-gradient(135deg, #fbbf24 0%, #a78bfa 100%);
    box-shadow: 0 4px 15px rgba(251, 191, 36, 0.4);
}

@keyframes easterFloat {
    0%, 100% { transform: translateY(0) translateX(0); }
    33% { transform: translateY(-20px) translateX(20px); }
    66% { transform: translateY(20px) translateX(-20px); }
}

@keyframes easterBounce {
    0%, 100% { transform: translateY(0) rotate(0deg); }
    25% { transform: translateY(-3px) rotate(1deg); }
    75% { transform: translateY(-3px) rotate(-1deg); }
}

@keyframes easterHop {
    0%, 100% { transform: translateY(0) scale(1); }
    50% { transform: translateY(-8px) scale(1.05); }
}

@keyframes eggBounce {
    0%, 100% { transform: translateY(0) rotate(0deg); }
    50% { transform: translateY(-5px) rotate(10deg); }
}

@keyframes bunnyHop {
    0%, 100% { transform: translateY(0) scaleX(1); }
    25% { transform: translateY(-4px) scaleX(-1); }
    75% { transform: translateY(-4px) scaleX(1); }
}

/* TEMA: VACACIONES */
.catalog-theme-vacation .catalog-page {
    background: linear-gradient(135deg, #06b6d4 0%, #3b82f6 100%);
    position: relative;
    overflow: hidden;
}

.catalog-theme-vacation .catalog-page::before {
    content: '';
    position: fixed;
    bottom: 0;
    left: 0;
    width: 100%;
    height: 30%;
    background: linear-gradient(to top, rgba(6,182,212,0.3) 0%, transparent 100%);
    animation: wave 8s ease-in-out infinite;
    pointer-events: none;
    z-index: 0;
}

.catalog-theme-vacation .catalog-page::after {
    content: '☀️';
    position: fixed;
    top: 10%;
    right: 10%;
    font-size: 4rem;
    animation: sunRotate 10s linear infinite;
    pointer-events: none;
    z-index: 0;
    opacity: 0.6;
}

.catalog-theme-vacation .category-card,
.catalog-theme-vacation .product-card {
    background: linear-gradient(135deg, rgba(255,255,255,0.95) 0%, rgba(224,242,254,0.9) 100%);
    box-shadow: 0 8px 25px rgba(6, 182, 212, 0.3);
    animation: vacationSway 4s ease-in-out infinite;
    position: relative;
}

.catalog-theme-vacation .category-card::before,
.catalog-theme-vacation .product-card::before {
    content: '🌊';
    position: absolute;
    bottom: -15px;
    left: 50%;
    transform: translateX(-50%);
    font-size: 1.5rem;
    animation: waveIcon 2s ease-in-out infinite;
    pointer-events: none;
    z-index: 10;
    opacity: 0.6;
}

.catalog-theme-vacation .btn-view,
.catalog-theme-vacation .btn-add-cart {
    background: linear-gradient(135deg, #06b6d4 0%, #3b82f6 100%);
    box-shadow: 0 4px 15px rgba(6, 182, 212, 0.4);
}

@keyframes wave {
    0%, 100% { transform: translateX(0) translateY(0); }
    50% { transform: translateX(-50px) translateY(-10px); }
}

@keyframes sunRotate {
    0% { transform: rotate(0deg) scale(1); }
    50% { transform: rotate(180deg) scale(1.1); }
    100% { transform: rotate(360deg) scale(1); }
}

@keyframes vacationSway {
    0%, 100% { transform: translateX(0) rotate(0deg); }
    25% { transform: translateX(3px) rotate(1deg); }
    75% { transform: translateX(-3px) rotate(-1deg); }
}

@keyframes waveIcon {
    0%, 100% { transform: translateX(-50%) translateY(0) rotate(0deg); }
    50% { transform: translateX(-50%) translateY(-3px) rotate(5deg); }
}

/* TEMA: HALLOWEEN */
.catalog-theme-halloween .catalog-page {
    background: linear-gradient(135deg, #f97316 0%, #7c3aed 100%);
    position: relative;
    overflow: hidden;
}

.catalog-theme-halloween .catalog-page::before {
    content: '';
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: 
        radial-gradient(circle at 20% 30%, rgba(0,0,0,0.1) 2px, transparent 2px),
        radial-gradient(circle at 80% 70%, rgba(0,0,0,0.1) 2px, transparent 2px);
    background-size: 100px 100px, 150px 150px;
    animation: fogMove 15s ease-in-out infinite;
    pointer-events: none;
    z-index: 0;
}

.catalog-theme-halloween .category-card,
.catalog-theme-halloween .product-card {
    background: linear-gradient(135deg, rgba(255,255,255,0.95) 0%, rgba(254,243,199,0.9) 100%);
    border: 2px solid rgba(249,115,22,0.3);
    box-shadow: 0 8px 25px rgba(249, 115, 22, 0.4), 
                0 0 15px rgba(124, 58, 237, 0.2) inset;
    animation: halloweenGlow 3s ease-in-out infinite;
    position: relative;
}

.catalog-theme-halloween .category-card::before,
.catalog-theme-halloween .product-card::before {
    content: '🦇';
    position: absolute;
    top: -15px;
    right: -15px;
    font-size: 1.2rem;
    animation: batFly 4s ease-in-out infinite;
    pointer-events: none;
    opacity: 0.7;
}

.catalog-theme-halloween .btn-view,
.catalog-theme-halloween .btn-add-cart {
    background: linear-gradient(135deg, #f97316 0%, #7c3aed 100%);
    box-shadow: 0 4px 20px rgba(249, 115, 22, 0.5),
                0 0 10px rgba(124, 58, 237, 0.3);
    animation: halloweenPulse 2s ease-in-out infinite;
}

@keyframes fogMove {
    0%, 100% { transform: translateX(0) translateY(0); opacity: 0.3; }
    50% { transform: translateX(50px) translateY(-30px); opacity: 0.5; }
}

@keyframes halloweenGlow {
    0%, 100% { 
        box-shadow: 0 8px 25px rgba(249, 115, 22, 0.4), 
                    0 0 15px rgba(124, 58, 237, 0.2) inset;
    }
    50% { 
        box-shadow: 0 8px 35px rgba(249, 115, 22, 0.6), 
                    0 0 25px rgba(124, 58, 237, 0.4) inset;
    }
}

@keyframes batFly {
    0%, 100% { transform: translate(0, 0) rotate(0deg); }
    25% { transform: translate(10px, -10px) rotate(15deg); }
    50% { transform: translate(5px, -15px) rotate(0deg); }
    75% { transform: translate(-5px, -10px) rotate(-15deg); }
}

@keyframes halloweenPulse {
    0%, 100% { transform: scale(1); opacity: 1; }
    50% { transform: scale(1.02); opacity: 0.9; }
}

/* Animaciones generales */
@keyframes gentlePulse {
    0%, 100% { opacity: 0.3; }
    50% { opacity: 0.6; }
}

@keyframes elegantFloat {
    0%, 100% { transform: translateY(0); }
    50% { transform: translateY(-3px); }
}

/* Asegurar que el contenido esté por encima de los efectos */
.catalog-container,
.catalog-header,
.catalog-main {
    position: relative;
    z-index: 1;
}

/* Mejoras adicionales para todos los temas */
.catalog-theme-default .category-icon,
.catalog-theme-christmas .category-icon,
.catalog-theme-carnival .category-icon,
.catalog-theme-easter .category-icon,
.catalog-theme-vacation .category-icon,
.catalog-theme-halloween .category-icon {
    transition: transform 0.3s ease;
}

.catalog-theme-default .category-card:hover .category-icon,
.catalog-theme-christmas .category-card:hover .category-icon,
.catalog-theme-carnival .category-card:hover .category-icon,
.catalog-theme-easter .category-card:hover .category-icon,
.catalog-theme-vacation .category-card:hover .category-icon,
.catalog-theme-halloween .category-card:hover .category-icon {
    transform: scale(1.1) rotate(5deg);
}

/* Efectos de hover mejorados para productos */
.catalog-theme-default .product-card:hover,
.catalog-theme-christmas .product-card:hover,
.catalog-theme-carnival .product-card:hover,
.catalog-theme-easter .product-card:hover,
.catalog-theme-vacation .product-card:hover,
.catalog-theme-halloween .product-card:hover {
    transform: translateY(-8px) scale(1.02);
    transition: all 0.3s ease;
}

/* Efectos de botones mejorados por tema */
.catalog-theme-christmas .btn-view:hover,
.catalog-theme-christmas .btn-add-cart:hover {
    box-shadow: 0 6px 25px rgba(220, 38, 38, 0.6),
                0 0 20px rgba(22, 163, 74, 0.4);
}

.catalog-theme-carnival .btn-view:hover,
.catalog-theme-carnival .btn-add-cart:hover {
    box-shadow: 0 6px 30px rgba(245, 158, 11, 0.7),
                0 0 15px rgba(236, 72, 153, 0.5);
}

.catalog-theme-easter .btn-view:hover,
.catalog-theme-easter .btn-add-cart:hover {
    box-shadow: 0 6px 25px rgba(251, 191, 36, 0.5),
                0 0 15px rgba(167, 139, 250, 0.4);
}

.catalog-theme-vacation .btn-view:hover,
.catalog-theme-vacation .btn-add-cart:hover {
    box-shadow: 0 6px 25px rgba(6, 182, 212, 0.5),
                0 0 15px rgba(59, 130, 246, 0.4);
}

.catalog-theme-halloween .btn-view:hover,
.catalog-theme-halloween .btn-add-cart:hover {
    box-shadow: 0 6px 30px rgba(249, 115, 22, 0.6),
                0 0 20px rgba(124, 58, 237, 0.5);
}

