
:root {
    --primary: #6a1b9a;
    --primary-light: #9c4dcc;
    --primary-dark: #38006b;
    --secondary: #e1bee7;
    --accent: #ff4081;
}

body {
    font-family: 'Montserrat', sans-serif;
    background-color: #f9f5ff;
}

.hero-gradient {
    background: linear-gradient(135deg, var(--primary-dark), var(--primary), var(--primary-light));
}

.event-card {
    transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.event-card:hover {
    transform: translateY(-5px);
    box-shadow: 0 10px 25px rgba(106, 27, 154, 0.2);
}

.search-results {
    max-height: 400px;
    overflow-y: auto;
}

/* Estilos para los filtros de categoría */
.category-pill.active {
    background-color: white;
    color: var(--primary);
}

/* Estilos para los filtros de eventos en la sección principal */
.event-filter {
    background-color: white;
    color: var(--primary);
    padding: 0.5rem 1.5rem;
    border-radius: 9999px;
    font-weight: 500;
    transition: all 0.3s ease;
    border: 1px solid var(--primary);
}

.event-filter:hover {
    background-color: var(--secondary);
}

.event-filter.active {
    background-color: var(--primary);
    color: white;
}


/* Estilos para la barra de scroll personalizada */
.custom-scrollbar::-webkit-scrollbar {
    width: 6px;
}

.custom-scrollbar::-webkit-scrollbar-track {
    background: #f1f1f1;
}

.custom-scrollbar::-webkit-scrollbar-thumb {
    background: var(--primary-light);
    border-radius: 10px;
}


/* Clases para usar los colores de la paleta directamente */
.text-primary {
    color: var(--primary);
}

.text-primary-light {
    color: var(--primary-light);
}

.text-primary-dark {
    color: var(--primary-dark);
}

.text-secondary {
    color: var(--secondary);
}

.text-accent {
    color: var(--accent);
}

.bg-primary {
    background-color: var(--primary);
}

.bg-primary-light {
    background-color: var(--primary-light);
}

.bg-primary-dark {
    background-color: var(--primary-dark);
}

.bg-secondary {
    background-color: var(--secondary);
}

.bg-accent {
    background-color: var(--accent);
}

.hover\:bg-primary-light:hover {
    background-color: var(--primary-light);
}

.focus\:ring-primary-light:focus {
    --tw-ring-color: var(--primary-light);
}

.focus\:ring-accent:focus {
    --tw-ring-color: var(--accent);
}

.hero-gradient {
    background: linear-gradient(135deg, var(--primary-dark), var(--primary), var(--primary-light));
}

.event-card {
    transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.event-card:hover {
    transform: translateY(-5px);
    box-shadow: 0 10px 25px rgba(106, 27, 154, 0.2);
}

.search-results {
    max-height: 400px;
    overflow-y: auto;
}

/* Estilos para los filtros de categoría en el Hero */
.category-pill.active {
    background-color: white;
    color: var(--primary);
}

/* Estilos para los filtros de eventos en la sección principal */
.event-filter {
    background-color: white;
    color: var(--primary);
    padding: 0.5rem 1.5rem;
    border-radius: 9999px;
    font-weight: 500;
    transition: all 0.3s ease;
    border: 1px solid var(--primary);
}

.event-filter:hover {
    background-color: var(--secondary);
}

.event-filter.active {
    background-color: var(--primary);
    color: white;
}


/* Estilos para la barra de scroll personalizada */
.custom-scrollbar::-webkit-scrollbar {
    width: 6px;
}

.custom-scrollbar::-webkit-scrollbar-track {
    background: #f1f1f1;
}

.custom-scrollbar::-webkit-scrollbar-thumb {
    background: var(--primary-light);
    border-radius: 10px;
}

/* Transiciones suaves para eventos */
#events-grid {
    transition: opacity 0.4s ease, transform 0.4s ease;
}

/* Efecto de desvanecimiento */
.fade-out {
    opacity: 0;
    transform: translateY(10px);
}

/* Mensaje de carga durante transiciones */
.loading-text {
    animation: pulse 1.5s infinite;
}

@keyframes pulse {
    0%, 100% { opacity: 0.5; }
    50% { opacity: 1; }
}

/* ================================================= */
/* ESTILOS MEJORADOS PARA MODO OSCURO         */
/* ================================================= */

/* El color de fondo principal ahora es más suave */
.dark body {
    background-color: #1E1F20;
    color: #e0e0e0;
}

/* Las "superficies" como header, cards y footer usan un negro más profundo */
.dark header,
.dark #search-input,
.dark #search-results,
.dark .bg-white,
.dark .event-card,
.dark .event-filter,
.dark footer.bg-primary-dark {
    background-color: #121212;
}

.dark .bg-gray-50 {
    background-color: #1E1F20; /* Coincide con el nuevo body */
}

.dark header {
    border-bottom: 1px solid #2a2a2a;
}

.dark .text-primary,
.dark .text-primary-dark {
    color: var(--primary-light);
}

.dark nav a {
    color: var(--primary-light);
}

.dark nav a:hover {
    color: white;
}

.dark #search-input {
    border-color: #333;
    color: #e0e0e0;
}

.dark #search-input::placeholder {
    color: #a0a0a0;
}

.dark .text-gray-800 {
    color: #e0e0e0;
}

.dark .text-gray-700,
.dark .text-gray-600,
.dark .text-gray-500 {
    color: #a0a0a0;
}

.dark .event-card {
    border: 1px solid #2a2a2a;
    box-shadow: none; /* Quitamos la sombra por defecto */
}

/* El hover ahora es un resplandor (luz) morado */
.dark .event-card:hover {
    transform: translateY(-5px);
    box-shadow: 0 0 20px rgba(156, 77, 204, 0.4); /* Resplandor morado */
    border-color: var(--primary-light);
}

/* Hover morado para filtros y resultados de búsqueda */
.dark .event-filter:hover,
.dark #search-results .p-4:hover {
    background-color: var(--primary-dark);
}

.dark .event-filter {
    color: var(--primary-light);
    border-color: var(--primary-light);
}

.dark .event-filter.active {
    background-color: var(--primary-light);
    color: #121212;
}

.dark footer .text-gray-300 {
    color: #a0a0a0;
}

.dark footer .text-gray-300:hover {
    color: white;
}

.dark footer .border-gray-700 {
    border-color: #2a2a2a;
}