/* styles/style.css */
:root {
    --rojo-principal: #D32F2F;
    --rojo-oscuro: #B71C1C;
    --rojo-claro: #F44336;
    --rojo-brillante: #FF5252;
    --rojo-neon: #FF1744;
    --negro: #000000;
    --negro-suave: #1a1a1a;
    --negro-carbon: #0d0d0d;
    --gris-oscuro: #2b2b2b;
    --gris: #666666;
    --gris-claro: #a6a6a6;
    --blanco: #FFFFFF;
    --blanco-hueso: #f8f9fa;
    --blanco-perla: #f5f5f7;
    --dorado: #FFD700;
    --plateado: #C0C0C0;
    --bronce: #CD7F32;
    
    --sombra-intensa: 0 20px 40px rgba(0, 0, 0, 0.6);
    --sombra-media: 0 15px 30px rgba(0, 0, 0, 0.4);
    --sombra-suave: 0 8px 20px rgba(0, 0, 0, 0.3);
    --sombra-neon: 0 0 20px var(--rojo-neon), 0 0 40px var(--rojo-neon);
    
    --radio-xl: 20px;
    --radio-lg: 16px;
    --radio-md: 12px;
    --radio-sm: 8px;
    
    --gradiente-rojo: linear-gradient(135deg, var(--rojo-principal) 0%, var(--rojo-oscuro) 100%);
    --gradiente-rojo-hover: linear-gradient(135deg, var(--rojo-brillante) 0%, var(--rojo-principal) 100%);
    --gradiente-dorado: linear-gradient(135deg, var(--dorado) 0%, #FFA500 100%);
    --gradiente-negro: linear-gradient(135deg, var(--negro) 0%, var(--negro-suave) 100%);
    
    --transicion-rapida: all 0.4s cubic-bezier(0.25, 0.46, 0.45, 0.94);
    --transicion-media: all 0.6s cubic-bezier(0.25, 0.46, 0.45, 0.94);
    --transicion-lenta: all 0.8s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}

/* ANIMACIONES PREMIUM */
@keyframes latido-corazon {
    0% { transform: scale(1); }
    25% { transform: scale(1.08); }
    50% { transform: scale(1.05); }
    75% { transform: scale(1.03); }
    100% { transform: scale(1); }
}

@keyframes brillo-neon {
    0%, 100% { 
        box-shadow: 0 0 5px var(--rojo-neon), 0 0 10px var(--rojo-neon);
        filter: brightness(1);
    }
    50% { 
        box-shadow: 0 0 20px var(--rojo-neon), 0 0 40px var(--rojo-neon), 0 0 60px var(--rojo-neon);
        filter: brightness(1.3);
    }
}

@keyframes flotar-3d {
    0%, 100% { 
        transform: translateY(0px) rotateX(0deg);
    }
    50% { 
        transform: translateY(-15px) rotateX(5deg);
    }
}

@keyframes entrada-espectacular {
    0% {
        opacity: 0;
        transform: translateY(100px) scale(0.8) rotateX(45deg);
        filter: blur(10px);
    }
    100% {
        opacity: 1;
        transform: translateY(0) scale(1) rotateX(0);
        filter: blur(0);
    }
}

@keyframes rotar-infinito {
    0% { transform: rotate(0deg); }
    100% { transform: rotate(360deg); }
}

@keyframes texto-brillante {
    0%, 100% { 
        text-shadow: 0 0 10px var(--rojo-brillante), 0 0 20px var(--rojo-brillante);
    }
    50% { 
        text-shadow: 0 0 20px var(--rojo-neon), 0 0 40px var(--rojo-neon), 0 0 60px var(--rojo-neon);
    }
}

@keyframes onda-expansiva {
    0% {
        transform: scale(0.8);
        opacity: 1;
    }
    100% {
        transform: scale(2.5);
        opacity: 0;
    }
}

@keyframes slideIn {
    from { 
        transform: translateX(100%); 
        opacity: 0; 
    }
    to { 
        transform: translateX(0); 
        opacity: 1; 
    }
}

@keyframes pulso-tiempo {
    0%, 100% { 
        opacity: 1;
        transform: scale(1);
    }
    50% { 
        opacity: 0.7;
        transform: scale(0.95);
    }
}

/* RESET PREMIUM */
* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

html {
    scroll-behavior: smooth;
    font-size: 16px;
}

body {
    font-family: 'Montserrat', 'Poppins', 'Arial', sans-serif;
    line-height: 1.6;
    color: var(--blanco);
    background: var(--negro-carbon);
    overflow-x: hidden;
    background-image: 
        radial-gradient(circle at 20% 80%, rgba(211, 47, 47, 0.1) 0%, transparent 50%),
        radial-gradient(circle at 80% 20%, rgba(255, 82, 82, 0.05) 0%, transparent 50%);
    position: relative;
}

body::before {
    content: '';
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: 
        linear-gradient(45deg, transparent 48%, rgba(255, 23, 68, 0.03) 49%, rgba(255, 23, 68, 0.03) 51%, transparent 52%),
        linear-gradient(-45deg, transparent 48%, rgba(255, 23, 68, 0.03) 49%, rgba(255, 23, 68, 0.03) 51%, transparent 52%);
    background-size: 50px 50px;
    z-index: -1;
    pointer-events: none;
}

.container {
    width: 100%;
    max-width: 1400px;
    margin: 0 auto;
    padding: 0 15px;
}

/* SIDEBAR DE LUJO */
.sidebar-overlay {
    display: none;
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.9);
    backdrop-filter: blur(10px);
    z-index: 9998;
    animation: entrada-espectacular 0.6s ease-out;
}

.sidebar {
    position: fixed;
    top: 0;
    left: -400px;
    width: 100%;
    max-width: 350px;
    height: 100%;
    background: var(--gradiente-negro);
    box-shadow: var(--sombra-intensa);
    z-index: 9999;
    transition: var(--transicion-media);
    border-right: 3px solid var(--rojo-principal);
}

.sidebar.open {
    left: 0;
    animation: entrada-espectacular 0.8s ease-out;
}

.sidebar-header {
    padding: 1.5rem;
    background: var(--gradiente-rojo);
    display: flex;
    align-items: center;
    justify-content: space-between;
    position: relative;
    overflow: hidden;
}

.sidebar-header::before {
    content: '';
    position: absolute;
    top: -50%;
    left: -50%;
    width: 200%;
    height: 200%;
    background: linear-gradient(45deg, transparent, rgba(255, 255, 255, 0.1), transparent);
    animation: rotar-infinito 10s linear infinite;
}

.sidebar-logo {
    width: 80px;
    height: 80px;
    border-radius: 10px;
    position: relative;
    z-index: 1;
    animation: latido-corazon 3s ease-in-out infinite;
}

.close-sidebar {
    background: none;
    border: none;
    color: var(--blanco);
    font-size: 1.8rem;
    cursor: pointer;
    transition: var(--transicion-rapida);
    position: relative;
    z-index: 1;
}

.close-sidebar:hover {
    transform: rotate(90deg) scale(1.2);
    color: var(--rojo-neon);
}

.sidebar-nav {
    padding: 1.5rem 0;
}

.sidebar-link {
    display: flex;
    align-items: center;
    padding: 1.2rem 1.5rem;
    color: var(--blanco);
    text-decoration: none;
    border-bottom: 1px solid rgba(255, 255, 255, 0.1);
    transition: var(--transicion-rapida);
    position: relative;
    overflow: hidden;
}

.sidebar-link::before {
    content: '';
    position: absolute;
    top: 0;
    left: -100%;
    width: 100%;
    height: 100%;
    background: linear-gradient(90deg, transparent, rgba(255, 23, 68, 0.3), transparent);
    transition: var(--transicion-lenta);
}

.sidebar-link:hover::before {
    left: 100%;
}

.sidebar-link:hover {
    background: rgba(255, 23, 68, 0.1);
    padding-left: 2.5rem;
    color: var(--rojo-neon);
}

.sidebar-link i {
    margin-right: 1rem;
    font-size: 1.3rem;
    color: var(--rojo-brillante);
    transition: var(--transicion-rapida);
    width: 25px;
    text-align: center;
}

.sidebar-link:hover i {
    transform: scale(1.3) rotate(10deg);
    color: var(--rojo-neon);
}

/* HEADER DE LUJO */
header {
    background: var(--gradiente-negro);
    box-shadow: var(--sombra-intensa);
    position: sticky;
    top: 0;
    z-index: 1000;
    border-bottom: 3px solid var(--rojo-principal);
    backdrop-filter: blur(20px);
}

.navbar {
    padding: 1rem 0;
}

.nav-container {
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.nav-left {
    display: flex;
    align-items: center;
    gap: 1rem;
}

.menu-toggle {
    display: none;
    background: none;
    border: 2px solid var(--rojo-principal);
    color: var(--rojo-principal);
    font-size: 1.5rem;
    cursor: pointer;
    padding: 0.7rem;
    border-radius: var(--radio-md);
    transition: var(--transicion-rapida);
    position: relative;
    overflow: hidden;
}

.menu-toggle::before {
    content: '';
    position: absolute;
    top: 0;
    left: -100%;
    width: 100%;
    height: 100%;
    background: var(--gradiente-rojo);
    transition: var(--transicion-media);
    z-index: -1;
}

.menu-toggle:hover::before {
    left: 0;
}

.menu-toggle:hover {
    color: var(--blanco);
    border-color: var(--rojo-neon);
    transform: scale(1.1);
}

.logo {
    display: flex;
    align-items: center;
    gap: 0.8rem;
    text-decoration: none;
    transition: var(--transicion-rapida);
}

.logo:hover {
    transform: translateY(-3px);
}

.logo-img {
    width: 100px;
    height: auto;
    border-radius: 10px;
    transition: var(--transicion-rapida);
}

.logo:hover .logo-img {
    animation: latido-corazon 1s ease-in-out infinite;
}

.nav-menu {
    display: flex;
    list-style: none;
    gap: 0.3rem;
}

.nav-link {
    color: var(--blanco);
    text-decoration: none;
    padding: 0.7rem 1rem;
    border-radius: var(--radio-lg);
    transition: var(--transicion-rapida);
    display: flex;
    align-items: center;
    font-weight: 600;
    position: relative;
    overflow: hidden;
    border: 2px solid transparent;
    background: rgba(255, 255, 255, 0.05);
    backdrop-filter: blur(10px);
    font-size: 0.85rem;
}

.nav-link::before {
    content: '';
    position: absolute;
    top: 0;
    left: -100%;
    width: 100%;
    height: 100%;
    background: var(--gradiente-rojo);
    transition: var(--transicion-media);
    z-index: -1;
}

.nav-link i {
    margin-right: 0.4rem;
    font-size: 1rem;
    transition: var(--transicion-rapida);
}

.nav-link:hover::before,
.nav-link.active::before {
    left: 0;
}

.nav-link:hover,
.nav-link.active {
    color: var(--blanco);
    border-color: var(--rojo-neon);
    transform: translateY(-3px) scale(1.05);
    box-shadow: var(--sombra-neon);
}

.nav-link:hover i,
.nav-link.active i {
    transform: scale(1.3) rotate(15deg);
    color: var(--rojo-neon);
}

/* BARRA DE BÚSQUEDA */
.buscar-container {
    margin-bottom: 2rem;
    text-align: center;
    padding: 0 10px;
}

.buscar-input {
    padding: 1rem 1.5rem;
    border: 2px solid var(--rojo-principal);
    border-radius: var(--radio-lg);
    background: rgba(255, 255, 255, 0.1);
    color: var(--blanco);
    font-size: 1rem;
    width: 100%;
    max-width: 400px;
    backdrop-filter: blur(10px);
    transition: var(--transicion-rapida);
}

.buscar-input::placeholder {
    color: var(--gris-claro);
}

.buscar-input:focus {
    outline: none;
    border-color: var(--rojo-neon);
    box-shadow: var(--sombra-neon);
    background: rgba(255, 255, 255, 0.15);
}

/* SECCIONES PREMIUM */
.section {
    display: none;
    padding: 2rem 0;
    min-height: 100vh;
    position: relative;
    overflow: hidden;
}

.section.active {
    display: block;
    animation: entrada-espectacular 1s ease-out;
}

/* FONDOS ESPECTACULARES PARA CADA SECCIÓN */
#votacion.active {
    background: linear-gradient(135deg, var(--negro-carbon) 0%, var(--negro-suave) 100%);
}

#resultados.active {
    background: linear-gradient(135deg, var(--negro-suave) 0%, var(--gris-oscuro) 100%);
}

#ganadores.active {
    background: linear-gradient(135deg, var(--gris-oscuro) 0%, var(--negro-carbon) 100%);
}

#comentarios.active {
    background: linear-gradient(135deg, var(--negro-carbon) 0%, var(--negro-suave) 100%);
}

#patrocinadores.active {
    background: linear-gradient(135deg, var(--negro-suave) 0%, var(--gris-oscuro) 100%);
}

#informacion.active {
    background: linear-gradient(135deg, var(--gris-oscuro) 0%, var(--negro-carbon) 100%);
}

.section h2 {
    font-size: 2.2rem;
    color: transparent;
    margin-bottom: 1.5rem;
    text-align: center;
    font-weight: 900;
    background: linear-gradient(45deg, var(--rojo-principal), var(--rojo-neon), var(--rojo-brillante));
    -webkit-background-clip: text;
    background-clip: text;
    text-shadow: 0 0 30px rgba(255, 23, 68, 0.5);
    position: relative;
    animation: texto-brillante 3s ease-in-out infinite;
    padding: 0 15px;
}

.section h2::after {
    content: '';
    position: absolute;
    bottom: -8px;
    left: 50%;
    transform: translateX(-50%);
    width: 120px;
    height: 3px;
    background: var(--gradiente-rojo);
    border-radius: 2px;
    animation: brillo-neon 3s ease-in-out infinite;
}

.section-description {
    text-align: center;
    color: var(--gris-claro);
    margin-bottom: 2rem;
    font-size: 1rem;
    max-width: 800px;
    margin-left: auto;
    margin-right: auto;
    line-height: 1.6;
    text-shadow: 0 2px 4px rgba(0, 0, 0, 0.5);
    padding: 0 15px;
}

/* CONTENEDOR DE PRODUCTOS PREMIUM - MÁS LARGOS PARA MÓVILES */
.productos-container {
    background: rgba(0, 0, 0, 0.7);
    border-radius: var(--radio-lg);
    padding: 2rem;
    margin: 2rem auto;
    box-shadow: var(--sombra-intensa);
    position: relative;
    border: 2px solid var(--rojo-principal);
    backdrop-filter: blur(20px);
    overflow: hidden;
    width: 100%;
    min-height: 650px;
}

.productos-container::before {
    content: '';
    position: absolute;
    top: -2px;
    left: -2px;
    right: -2px;
    bottom: -2px;
    background: var(--gradiente-rojo);
    border-radius: var(--radio-lg);
    z-index: -1;
    animation: brillo-neon 4s ease-in-out infinite;
}

/* GRID DE PARTICIPANTES PREMIUM - CONTENEDORES MÁS LARGOS */
.participantes-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 2rem;
    width: 100%;
}

.participante-card {
    background: var(--gradiente-negro);
    border-radius: var(--radio-lg);
    overflow: hidden;
    box-shadow: var(--sombra-media);
    transition: var(--transicion-rapida);
    text-align: center;
    padding: 1.5rem;
    position: relative;
    border: 2px solid transparent;
    backdrop-filter: blur(10px);
    min-height: 580px;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    width: 100%;
    margin: 0 auto;
}

/* ORDEN VISUAL PARA PARTICIPANTES */
.participante-card[data-orden="1"] { order: 1; }
.participante-card[data-orden="2"] { order: 2; }
.participante-card[data-orden="3"] { order: 3; }
.participante-card[data-orden="4"] { order: 4; }
.participante-card[data-orden="5"] { order: 5; }
.participante-card[data-orden="6"] { order: 6; }
.participante-card[data-orden="7"] { order: 7; }
.participante-card[data-orden="8"] { order: 8; }
.participante-card[data-orden="9"] { order: 9; }
.participante-card[data-orden="10"] { order: 10; }
.participante-card[data-orden="11"] { order: 11; }
.participante-card[data-orden="12"] { order: 12; }
.participante-card[data-orden="13"] { order: 13; }
.participante-card[data-orden="14"] { order: 14; }
.participante-card[data-orden="15"] { order: 15; }
.participante-card[data-orden="16"] { order: 16; }
.participante-card[data-orden="17"] { order: 17; }
.participante-card[data-orden="18"] { order: 18; }
.participante-card[data-orden="19"] { order: 19; }
.participante-card[data-orden="20"] { order: 20; }

.participante-card::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 3px;
    background: var(--gradiente-rojo);
    transform: scaleX(0);
    transition: var(--transicion-rapida);
}

.participante-card:hover::before {
    transform: scaleX(1);
}

.participante-card:hover {
    transform: translateY(-8px) scale(1.02);
    box-shadow: var(--sombra-intensa), var(--sombra-neon);
    border-color: var(--rojo-principal);
    animation: flotar-3d 3s ease-in-out infinite;
}

.participante-img {
    width: 100%;
    height: 250px;
    object-fit: cover;
    border-radius: var(--radio-md);
    margin-bottom: 1.2rem;
    border: 2px solid var(--rojo-principal);
    transition: var(--transicion-rapida);
    box-shadow: var(--sombra-suave);
}

.participante-card:hover .participante-img {
    border-color: var(--rojo-neon);
    transform: scale(1.05);
    box-shadow: var(--sombra-neon);
}

.participante-local {
    color: var(--rojo-brillante);
    font-weight: 700;
    margin-bottom: 1rem;
    font-size: 1rem;
    text-transform: uppercase;
    letter-spacing: 1px;
    text-shadow: 0 2px 4px rgba(0, 0, 0, 0.5);
}

.participante-card h3 {
    color: var(--blanco);
    margin-bottom: 1rem;
    font-size: 1.4rem;
    font-weight: 800;
    background: linear-gradient(45deg, var(--blanco), var(--rojo-brillante));
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
    line-height: 1.3;
    min-height: 50px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.participante-precio {
    font-size: 1.6rem;
    font-weight: 900;
    color: var(--dorado);
    margin-bottom: 1rem;
    text-shadow: 0 2px 4px rgba(0, 0, 0, 0.5);
    animation: latido-corazon 2s ease-in-out infinite;
    min-height: 40px;
    display: flex;
    align-items: center;
    justify-content: center;
}

/* NUEVOS ESTILOS PARA INFORMACIÓN ADICIONAL - MÁS ESPACIOSOS */
.participante-descripcion {
    color: var(--gris-claro);
    margin-bottom: 1rem;
    font-style: italic;
    line-height: 1.5;
    font-size: 0.95rem;
    flex-grow: 1;
    min-height: 60px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.participante-ingredientes {
    color: var(--gris-claro);
    margin-bottom: 1.2rem;
    font-size: 1rem;
    line-height: 1.5;
    min-height: 70px;
    flex-grow: 1;
    display: flex;
    align-items: center;
    justify-content: center;
}

.participante-info-adicional {
    margin-bottom: 1.2rem;
    text-align: left;
    min-height: 80px;
}

.participante-info-adicional div {
    color: var(--gris);
    font-size: 0.9rem;
    margin-bottom: 0.5rem;
    display: flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.3rem 0;
}

.participante-info-adicional div i {
    color: var(--rojo-brillante);
    width: 18px;
    text-align: center;
    font-size: 1rem;
}

.participante-votos {
    font-weight: 700;
    margin-bottom: 1.2rem;
    color: var(--rojo-neon);
    font-size: 1.2rem;
    text-shadow: 0 0 10px rgba(255, 23, 68, 0.5);
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    min-height: 40px;
}

/* BOTÓN DE VOTAR MÁS GRANDE */
.votar-btn {
    background: var(--gradiente-rojo);
    color: var(--blanco);
    border: none;
    padding: 1.2rem 2rem;
    border-radius: var(--radio-lg);
    font-weight: 700;
    cursor: pointer;
    transition: var(--transicion-rapida);
    width: 100%;
    font-size: 1rem;
    text-transform: uppercase;
    letter-spacing: 1.5px;
    position: relative;
    overflow: hidden;
    border: 2px solid transparent;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    min-height: 60px;
}

.votar-btn::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: var(--transicion-media);
}

.votar-btn:hover::before {
    left: 100%;
}

.votar-btn:hover {
    background: var(--gradiente-rojo-hover);
    transform: translateY(-3px) scale(1.05);
    box-shadow: var(--sombra-neon);
    border-color: var(--rojo-neon);
}

/* RESULTADOS PREMIUM - ESTILOS MEJORADOS */
.resultados-content {
    background: rgba(0, 0, 0, 0.7);
    padding: 2rem;
    border-radius: var(--radio-xl);
    box-shadow: var(--sombra-intensa);
    border: 2px solid var(--rojo-principal);
    backdrop-filter: blur(20px);
    position: relative;
    overflow: hidden;
}

.resultados-content::before {
    content: '';
    position: absolute;
    top: -2px;
    left: -2px;
    right: -2px;
    bottom: -2px;
    background: var(--gradiente-rojo);
    border-radius: var(--radio-xl);
    z-index: -1;
    animation: brillo-neon 4s ease-in-out infinite;
}

.resultado-item {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 1.5rem;
    margin-bottom: 1rem;
    background: var(--gradiente-negro);
    border-radius: var(--radio-lg);
    box-shadow: var(--sombra-suave);
    transition: var(--transicion-rapida);
    border-left: 4px solid var(--rojo-principal);
    position: relative;
    overflow: hidden;
}

.resultado-item::before {
    content: '';
    position: absolute;
    top: 0;
    left: -100%;
    width: 100%;
    height: 100%;
    background: linear-gradient(90deg, transparent, rgba(255, 23, 68, 0.1), transparent);
    transition: var(--transicion-lenta);
}

.resultado-item:hover::before {
    left: 100%;
}

.resultado-item:hover {
    transform: translateX(8px);
    border-left-color: var(--rojo-neon);
    box-shadow: var(--sombra-media);
}

.resultado-info {
    flex: 1;
    min-width: 0;
}

.resultado-info strong {
    color: var(--rojo-brillante);
    display: block;
    font-size: 1.2rem;
    margin-bottom: 0.5rem;
    font-weight: 700;
}

.resultado-votos {
    color: var(--dorado);
    font-weight: 600;
    font-size: 1.1rem;
    margin-right: 1.5rem;
    min-width: 80px;
    text-align: center;
}

.barra-container {
    display: flex;
    align-items: center;
    gap: 1rem;
    width: 100%;
    max-width: 400px;
}

.barra-votos {
    flex: 1;
    height: 20px;
    background: var(--gris-oscuro);
    border-radius: var(--radio-lg);
    overflow: hidden;
    position: relative;
    box-shadow: inset 0 2px 4px rgba(0, 0, 0, 0.3);
}

.barra-progreso {
    height: 100%;
    background: var(--gradiente-rojo);
    border-radius: var(--radio-lg);
    transition: width 1.5s cubic-bezier(0.25, 0.46, 0.45, 0.94);
    position: relative;
    overflow: hidden;
    display: flex;
    align-items: center;
    justify-content: flex-end;
    padding-right: 10px;
    font-size: 0.8rem;
    font-weight: 700;
    color: var(--blanco);
    text-shadow: 0 1px 2px rgba(0, 0, 0, 0.5);
}

.barra-progreso::after {
    content: '';
    position: absolute;
    top: 0;
    left: -100%;
    width: 100%;
    height: 100%;
    background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.4), transparent);
    animation: onda-expansiva 3s ease-in-out infinite;
}

.porcentaje {
    color: var(--blanco);
    font-weight: 700;
    font-size: 1rem;
    min-width: 50px;
    text-align: right;
    text-shadow: 0 0 10px rgba(255, 23, 68, 0.5);
}

/* GANADORES PREMIUM */
.ganadores-content {
    background: rgba(0, 0, 0, 0.7);
    padding: 2rem;
    border-radius: var(--radio-xl);
    box-shadow: var(--sombra-intensa);
    border: 2px solid var(--rojo-principal);
    backdrop-filter: blur(20px);
}

.ganadores-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 2rem;
}

.ganadores-grid .participante-card {
    position: relative;
    border: 2px solid transparent;
    min-height: 620px;
}

.ganadores-grid .participante-card:nth-child(1) {
    border-color: var(--dorado);
    box-shadow: 0 0 30px rgba(255, 215, 0, 0.5);
}

.ganadores-grid .participante-card:nth-child(2) {
    border-color: var(--plateado);
    box-shadow: 0 0 30px rgba(192, 192, 192, 0.5);
}

.ganadores-grid .participante-card:nth-child(3) {
    border-color: var(--bronce);
    box-shadow: 0 0 30px rgba(205, 127, 50, 0.5);
}

.medalla {
    font-size: 3rem;
    margin-bottom: 1rem;
    animation: flotar-3d 3s ease-in-out infinite;
}

.votos-ganador {
    font-size: 1.6rem;
    font-weight: 900;
    color: var(--rojo-neon);
    margin: 1rem 0;
    text-shadow: 0 0 20px rgba(255, 23, 68, 0.7);
    animation: latido-corazon 1.5s ease-in-out infinite;
}

/* COMENTARIOS PREMIUM */
.comentarios-content {
    display: grid;
    grid-template-columns: 1fr;
    gap: 1.5rem;
}

.comentario-form {
    background: rgba(0, 0, 0, 0.7);
    padding: 1.5rem;
    border-radius: var(--radio-lg);
    box-shadow: var(--sombra-intensa);
    border: 2px solid var(--rojo-principal);
    backdrop-filter: blur(20px);
}

.comentario-form h3 {
    color: var(--rojo-brillante);
    margin-bottom: 1.5rem;
    font-size: 1.3rem;
    text-align: center;
    animation: texto-brillante 3s ease-in-out infinite;
}

.form-group {
    margin-bottom: 1.5rem;
    position: relative;
}

.form-group label {
    display: block;
    margin-bottom: 0.5rem;
    color: var(--gris-claro);
    font-weight: 600;
}

.form-group input,
.form-group textarea,
.form-group select {
    width: 100%;
    padding: 0.8rem;
    border: 2px solid var(--gris-oscuro);
    border-radius: var(--radio-md);
    font-size: 0.9rem;
    transition: var(--transicion-rapida);
    background: rgba(255, 255, 255, 0.05);
    color: var(--blanco);
    backdrop-filter: blur(10px);
}

.form-group input:focus,
.form-group textarea:focus,
.form-group select:focus {
    outline: none;
    border-color: var(--rojo-principal);
    box-shadow: 0 0 20px rgba(255, 23, 68, 0.3);
    background: rgba(255, 255, 255, 0.1);
}

.form-group input::placeholder,
.form-group textarea::placeholder {
    color: var(--gris-claro);
}

.submit-btn {
    background: var(--gradiente-rojo);
    color: var(--blanco);
    border: none;
    padding: 1rem 1.5rem;
    border-radius: var(--radio-lg);
    font-size: 1rem;
    font-weight: 700;
    cursor: pointer;
    transition: var(--transicion-rapida);
    width: 100%;
    text-transform: uppercase;
    letter-spacing: 1px;
    position: relative;
    overflow: hidden;
    border: 2px solid transparent;
}

.submit-btn::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: var(--transicion-media);
}

.submit-btn:hover::before {
    left: 100%;
}

.submit-btn:hover {
    background: var(--gradiente-rojo-hover);
    transform: translateY(-3px) scale(1.02);
    box-shadow: var(--sombra-neon);
    border-color: var(--rojo-neon);
}

.comentarios-list {
    max-height: 500px;
    overflow-y: auto;
    padding-right: 0.5rem;
}

.comentarios-list::-webkit-scrollbar {
    width: 6px;
}

.comentarios-list::-webkit-scrollbar-track {
    background: var(--gris-oscuro);
    border-radius: var(--radio-sm);
}

.comentarios-list::-webkit-scrollbar-thumb {
    background: var(--gradiente-rojo);
    border-radius: var(--radio-sm);
}

.comentarios-list::-webkit-scrollbar-thumb:hover {
    background: var(--rojo-neon);
}

.comentario-card {
    background: var(--gradiente-negro);
    padding: 1.2rem;
    margin-bottom: 1rem;
    border-radius: var(--radio-md);
    box-shadow: var(--sombra-suave);
    border-left: 3px solid var(--rojo-principal);
    transition: var(--transicion-rapida);
    backdrop-filter: blur(10px);
}

.comentario-card:hover {
    transform: translateX(5px);
    border-left-color: var(--rojo-neon);
    box-shadow: var(--sombra-media);
}

.comentario-card h4 {
    color: var(--rojo-brillante);
    margin-bottom: 0.3rem;
    font-size: 1rem;
}

.comentario-calificacion {
    color: var(--dorado);
    margin: 0.5rem 0;
    font-size: 0.9rem;
    letter-spacing: 1px;
}

.comentario-card p {
    color: var(--gris-claro);
    line-height: 1.4;
    margin-bottom: 0.8rem;
    font-size: 0.9rem;
}

.comentario-card small {
    color: var(--gris);
    font-size: 0.8rem;
}

/* PATROCINADORES PREMIUM - MEJORADO */
.patrocinadores-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 1.5rem;
}

.patrocinador-card {
    background: var(--gradiente-negro);
    border-radius: var(--radio-lg);
    padding: 1.5rem;
    text-align: center;
    box-shadow: var(--sombra-media);
    transition: var(--transicion-rapida);
    border: 2px solid transparent;
    backdrop-filter: blur(10px);
    position: relative;
    min-height: 250px;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
}

.patrocinador-card:hover {
    transform: translateY(-8px) scale(1.03);
    border-color: var(--rojo-principal);
    box-shadow: var(--sombra-intensa), var(--sombra-neon);
}

.patrocinador-img {
    width: 90px;
    height: 90px;
    border-radius: 8px;
    object-fit: cover;
    margin: 0 auto 1rem;
    border: 2px solid var(--rojo-principal);
    transition: var(--transicion-rapida);
}

.patrocinador-card:hover .patrocinador-img {
    border-color: var(--rojo-neon);
    transform: scale(1.1) rotate(5deg);
}

.patrocinador-card h3 {
    color: var(--blanco);
    margin-bottom: 0.8rem;
    font-size: 1.1rem;
}

/* ESTILOS PARA NIVELES DE PATROCINIO */
.nivel-patrocinio {
    position: absolute;
    top: 15px;
    right: 15px;
    padding: 0.4rem 0.8rem;
    border-radius: var(--radio-md);
    font-size: 0.7rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 1px;
    z-index: 2;
}

.nivel-oro {
    background: linear-gradient(135deg, #FFD700, #FFA500);
    color: #000;
}

.nivel-plata {
    background: linear-gradient(135deg, #C0C0C0, #A0A0A0);
    color: #000;
}

.nivel-bronce {
    background: linear-gradient(135deg, #CD7F32, #B56C28);
    color: #FFF;
}

.patrocinador-link {
    display: inline-flex;
    align-items: center;
    gap: 0.3rem;
    color: var(--rojo-brillante);
    text-decoration: none;
    margin-top: 0.8rem;
    font-weight: 600;
    transition: var(--transicion-rapida);
    font-size: 0.9rem;
}

.patrocinador-link:hover {
    color: var(--rojo-neon);
    transform: translateX(3px);
}

/* Efectos especiales para cards de patrocinadores */
.patrocinador-card.nivel-oro {
    box-shadow: 0 0 20px rgba(255, 215, 0, 0.3);
}

.patrocinador-card.nivel-plata {
    box-shadow: 0 0 20px rgba(192, 192, 192, 0.3);
}

.patrocinador-card.nivel-bronce {
    box-shadow: 0 0 20px rgba(205, 127, 50, 0.3);
}

/* INFORMACIÓN PREMIUM */
.info-content {
    background: rgba(0, 0, 0, 0.7);
    border-radius: var(--radio-lg);
    padding: 1.5rem;
    box-shadow: var(--sombra-intensa);
    border: 2px solid var(--rojo-principal);
    backdrop-filter: blur(20px);
    width: 100%;
}

.info-hero {
    text-align: center;
    margin-bottom: 2rem;
    padding-bottom: 1.5rem;
    border-bottom: 2px solid var(--rojo-principal);
}

.info-hero h3 {
    font-size: 1.5rem;
    color: var(--rojo-brillante);
    margin-bottom: 1rem;
    animation: texto-brillante 3s ease-in-out infinite;
}

.info-hero p {
    font-size: 1rem;
    color: var(--gris-claro);
    line-height: 1.6;
}

.info-details {
    display: grid;
    grid-template-columns: 1fr;
    gap: 1.2rem;
    margin-bottom: 2rem;
}

.info-item {
    background: var(--gradiente-negro);
    padding: 1.2rem;
    border-radius: var(--radio-md);
    text-align: center;
    transition: var(--transicion-rapida);
    border: 2px solid transparent;
}

.info-item:hover {
    transform: translateY(-3px);
    border-color: var(--rojo-principal);
    box-shadow: var(--sombra-media);
}

.info-item h4 {
    color: var(--rojo-brillante);
    margin-bottom: 0.8rem;
    font-size: 1rem;
}

.info-item h4 i {
    margin-right: 0.3rem;
}

.info-item p {
    font-size: 0.9rem;
    color: var(--blanco);
    margin-bottom: 0.3rem;
}

.info-item small {
    color: var(--gris-claro);
    font-size: 0.8rem;
}

.info-features {
    background: var(--gradiente-negro);
    padding: 1.5rem;
    border-radius: var(--radio-md);
}

.info-features h4 {
    color: var(--rojo-brillante);
    margin-bottom: 1rem;
    font-size: 1.1rem;
    text-align: center;
}

.info-features ul {
    list-style: none;
    display: grid;
    grid-template-columns: 1fr;
    gap: 0.8rem;
}

.info-features li {
    display: flex;
    align-items: center;
    padding: 0.8rem;
    background: rgba(255, 255, 255, 0.05);
    border-radius: var(--radio-sm);
    transition: var(--transicion-rapida);
}

.info-features li:hover {
    background: rgba(255, 23, 68, 0.1);
    transform: translateX(3px);
}

.info-features li i {
    color: var(--rojo-brillante);
    margin-right: 0.8rem;
    font-size: 1rem;
    width: 20px;
}

/* FOOTER AUMENTADO */
footer {
    background: var(--gradiente-negro);
    color: var(--blanco);
    padding: 2rem 0 1rem;
    border-top: 3px solid var(--rojo-principal);
    position: relative;
    overflow: hidden;
}

footer::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: 
        radial-gradient(circle at 20% 80%, rgba(255, 23, 68, 0.1) 0%, transparent 50%),
        radial-gradient(circle at 80% 20%, rgba(255, 82, 82, 0.05) 0%, transparent 50%);
    z-index: 0;
}

.footer-content {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    margin-bottom: 1.5rem;
    position: relative;
    z-index: 1;
    gap: 1.5rem;
    text-align: center;
}

.footer-info {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    width: 100%;
}

.footer-logo-simple {
    width: 100px;
    height: auto;
    border-radius: 8px;
    margin-bottom: 0.8rem;
}

.footer-info h3 {
    color: var(--rojo-brillante);
    margin-bottom: 0.8rem;
    font-size: 1.3rem;
    animation: texto-brillante 4s ease-in-out infinite;
}

.footer-info p {
    color: var(--gris-claro);
    margin-bottom: 1.5rem;
    font-size: 0.9rem;
    max-width: 300px;
}

.social-links {
    margin-top: 0.8rem;
}

.social-icons {
    display: flex;
    gap: 0.8rem;
    justify-content: center;
}

.social-icon {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 40px;
    height: 40px;
    background: var(--gradiente-rojo);
    color: var(--blanco);
    border-radius: 50%;
    text-decoration: none;
    transition: var(--transicion-rapida);
    font-size: 1.1rem;
    position: relative;
    overflow: hidden;
}

.social-icon::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: var(--transicion-media);
}

.social-icon:hover::before {
    left: 100%;
}

.social-icon:hover {
    background: var(--gradiente-rojo-hover);
    transform: translateY(-3px) scale(1.1);
    box-shadow: var(--sombra-neon);
}

.footer-contact-simple {
    display: flex;
    flex-direction: column;
    align-items: center;
    width: 100%;
}

.footer-contact-simple p {
    display: flex;
    align-items: center;
    color: var(--gris-claro);
    font-size: 0.9rem;
    margin: 0.5rem 0;
    justify-content: center;
}

.footer-contact-simple p i {
    color: var(--rojo-brillante);
    margin-right: 0.5rem;
    font-size: 1rem;
}

.footer-bottom {
    border-top: 1px solid var(--gris-oscuro);
    padding-top: 1rem;
    text-align: center;
    position: relative;
    z-index: 1;
}

.footer-copy {
    color: var(--gris-claro);
    font-size: 0.8rem;
}

/* NOTIFICACIONES PREMIUM MEJORADAS */
.notificacion {
    position: fixed;
    top: 15px;
    right: 15px;
    left: 15px;
    padding: 1rem 1.2rem;
    border-radius: var(--radio-md);
    color: var(--blanco);
    z-index: 10000;
    animation: slideIn 0.5s cubic-bezier(0.25, 0.46, 0.45, 0.94);
    backdrop-filter: blur(20px);
    border: 2px solid transparent;
    box-shadow: var(--sombra-intensa);
    font-weight: 600;
    display: flex;
    align-items: center;
    gap: 0.5rem;
    font-size: 0.9rem;
    text-align: center;
    justify-content: center;
}

.notificacion.success {
    background: linear-gradient(135deg, #27ae60, #2ecc71);
    border-color: #2ecc71;
}

.notificacion.error {
    background: linear-gradient(135deg, #e74c3c, #c0392b);
    border-color: #c0392b;
}

.notificacion.info {
    background: linear-gradient(135deg, #3498db, #2980b9);
    border-color: #2980b9;
}

/* LOADING Y ERRORES PREMIUM */
.loading, .error {
    text-align: center;
    padding: 1.5rem 1rem;
    font-size: 1rem;
    border-radius: var(--radio-lg);
    margin: 1rem 0;
}

.loading {
    color: var(--rojo-brillante);
    background: rgba(0, 0, 0, 0.7);
    border: 2px solid var(--rojo-principal);
    animation: latido-corazon 2s ease-in-out infinite, brillo-neon 3s ease-in-out infinite;
    backdrop-filter: blur(10px);
}

.error {
    color: var(--rojo-neon);
    background: rgba(255, 23, 68, 0.1);
    border: 2px solid var(--rojo-neon);
    text-shadow: 0 0 10px rgba(255, 23, 68, 0.5);
}

/* MODAL PREMIUM */
.modal {
    display: none;
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.9);
    backdrop-filter: blur(10px);
    z-index: 10000;
    animation: entrada-espectacular 0.6s ease-out;
}

.modal-content {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    background: var(--gradiente-negro);
    padding: 1.5rem;
    border-radius: var(--radio-lg);
    max-width: 90%;
    width: 400px;
    box-shadow: var(--sombra-intensa);
    border: 2px solid var(--rojo-principal);
    animation: brillo-neon 3s ease-in-out infinite;
}

.close-modal {
    position: absolute;
    top: 0.8rem;
    right: 1rem;
    font-size: 1.8rem;
    cursor: pointer;
    color: var(--rojo-principal);
    transition: var(--transicion-rapida);
    background: none;
    border: none;
    width: 35px;
    height: 35px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
}

.close-modal:hover {
    color: var(--rojo-neon);
    transform: rotate(90deg) scale(1.1);
    background: rgba(255, 23, 68, 0.1);
}

/* RESPONSIVE PREMIUM - MEJORADO PARA MÓVILES */
@media (min-width: 768px) {
    .container {
        padding: 0 20px;
    }
    
    .section {
        padding: 2.5rem 0;
    }
    
    .section h2 {
        font-size: 2.5rem;
        padding: 0;
    }
    
    .participantes-grid {
        grid-template-columns: repeat(2, 1fr);
        gap: 1.8rem;
    }
    
    .patrocinadores-grid {
        grid-template-columns: repeat(2, 1fr);
        gap: 1.8rem;
    }
    
    .ganadores-grid {
        grid-template-columns: repeat(2, 1fr);
        gap: 1.8rem;
    }
    
    .comentarios-content {
        grid-template-columns: 1fr 2fr;
        gap: 2rem;
    }
    
    .info-details {
        grid-template-columns: repeat(2, 1fr);
        gap: 1.5rem;
    }
    
    .info-features ul {
        grid-template-columns: repeat(2, 1fr);
    }
    
    .footer-content {
        flex-direction: row;
        justify-content: space-between;
        text-align: left;
    }
    
    .footer-info {
        align-items: flex-start;
        text-align: left;
        max-width: 300px;
    }
    
    .footer-contact-simple {
        align-items: flex-end;
        text-align: right;
    }
    
    .footer-contact-simple p {
        justify-content: flex-end;
    }
    
    .social-icons {
        justify-content: flex-start;
    }
    
    .notificacion {
        right: 20px;
        left: auto;
        max-width: 350px;
    }
    
    .nav-menu {
        gap: 0.5rem;
    }
    
    .nav-link {
        padding: 0.8rem 1.2rem;
        font-size: 0.9rem;
    }
    
    .logo-img {
        width: 120px;
    }
}

@media (min-width: 992px) {
    .container {
        max-width: 1200px;
        padding: 0 20px;
    }
    
    .participantes-grid {
        grid-template-columns: repeat(3, 1fr);
        gap: 2rem;
    }
    
    .patrocinadores-grid {
        grid-template-columns: repeat(3, 1fr);
        gap: 2rem;
    }
    
    .ganadores-grid {
        grid-template-columns: repeat(3, 1fr);
        gap: 2rem;
    }
    
    .productos-container {
        padding: 2rem;
    }
    
    .participante-card {
        padding: 1.5rem;
        min-height: 550px;
    }
    
    .participante-img {
        height: 200px;
    }
    
    .nav-menu {
        gap: 0.5rem;
    }
    
    .nav-link {
        padding: 0.8rem 1.5rem;
        font-size: 0.9rem;
    }
}

@media (min-width: 1200px) {
    .container {
        max-width: 1400px;
    }
    
    .participantes-grid {
        grid-template-columns: repeat(3, 1fr);
    }
    
    .section h2 {
        font-size: 2.8rem;
    }
}

@media (max-width: 767px) {
    .menu-toggle {
        display: block;
    }
    
    .nav-menu {
        display: none;
    }
    
    .sidebar-overlay.active {
        display: block;
    }
}

@media (max-width: 480px) {
    .container {
        padding: 0 10px;
    }
    
    .section {
        padding: 1.5rem 0;
    }
    
    .section h2 {
        font-size: 1.8rem;
        margin-bottom: 1rem;
    }
    
    .section-description {
        font-size: 0.9rem;
        margin-bottom: 1.5rem;
    }
    
    .productos-container {
        padding: 1rem;
        margin: 1rem auto;
    }
    
    .participante-card {
        padding: 1rem;
    }
    
    .participante-img {
        height: 200px;
    }
    
    .participante-card h3 {
        font-size: 1.2rem;
    }
    
    .participante-precio {
        font-size: 1.3rem;
    }
    
    .logo-img {
        width: 80px;
    }
    
    .nav-left {
        gap: 0.8rem;
    }
    
    .menu-toggle {
        padding: 0.5rem;
        font-size: 1.2rem;
    }
    
    .footer-logo-simple {
        width: 80px;
    }
    
    .footer-info h3 {
        font-size: 1.1rem;
    }
    
    .modal-content {
        padding: 1.2rem;
        width: 95%;
    }
    
    /* RESULTADOS RESPONSIVE */
    .resultado-item {
        flex-direction: column;
        text-align: center;
        gap: 1rem;
        padding: 1.2rem;
    }
    
    .barra-container {
        flex-direction: column;
        gap: 0.8rem;
        max-width: 100%;
    }
    
    .barra-votos {
        width: 100%;
    }
    
    .resultado-votos {
        margin-right: 0;
        order: -1;
    }
    
    .porcentaje {
        text-align: center;
        min-width: auto;
    }
}

/* EFECTOS ESPECIALES ADICIONALES */
.participante-card::after {
    content: '🌭';
    position: absolute;
    top: -15px;
    right: -15px;
    font-size: 2rem;
    opacity: 0.1;
    z-index: 0;
    animation: flotar-3d 5s ease-in-out infinite;
}

.ganadores-grid .participante-card:nth-child(1)::after {
    content: '🥇';
    opacity: 0.3;
}

.ganadores-grid .participante-card:nth-child(2)::after {
    content: '🥈';
    opacity: 0.3;
}

.ganadores-grid .participante-card:nth-child(3)::after {
    content: '🥉';
    opacity: 0.3;
}

/* SCROLLBAR PERSONALIZADO */
::-webkit-scrollbar {
    width: 8px;
}

::-webkit-scrollbar-track {
    background: var(--negro-suave);
}

::-webkit-scrollbar-thumb {
    background: var(--gradiente-rojo);
    border-radius: var(--radio-sm);
}

::-webkit-scrollbar-thumb:hover {
    background: var(--rojo-neon);
}

/* SELECTION PERSONALIZADO */
::selection {
    background: var(--rojo-principal);
    color: var(--blanco);
    text-shadow: none;
}

::-moz-selection {
    background: var(--rojo-principal);
    color: var(--blanco);
}

/* FOCUS VISIBLE */
button:focus-visible,
a:focus-visible,
input:focus-visible,
textarea:focus-visible,
select:focus-visible {
    outline: 2px solid var(--rojo-neon);
    outline-offset: 1px;
}

/* REDUCIR ANIMACIONES PARA PREFERENCIAS */
@media (prefers-reduced-motion: reduce) {
    * {
        animation-duration: 0.01ms !important;
        animation-iteration-count: 1 !important;
        transition-duration: 0.01ms !important;
    }
}

/* MODO ALTO CONTRASTE */
@media (prefers-contrast: high) {
    :root {
        --rojo-principal: #FF0000;
        --rojo-neon: #FF4444;
        --negro: #000000;
        --blanco: #FFFFFF;
    }
    
    body {
        background: var(--negro);
    }
}