/* ============================================================
   AJAL LOL — events.css
   Ruta: assets/css/publicpages/events.css
   Estilos exclusivos de las páginas de eventos por año
   ============================================================ */

/* ─── HERO DE EVENTOS ─── */
.eventos-hero {
  background:
    radial-gradient(ellipse at 70% 50%, rgba(245,198,212,.3) 0%, transparent 60%),
    linear-gradient(145deg, var(--rose-deep) 0%, #5c1438 50%, var(--rose-mid) 100%);
  padding: clamp(4rem, 8vw, 7rem) 0 clamp(3rem, 6vw, 5rem);
  position: relative;
  overflow: hidden;
  text-align: center;
}

.eventos-hero::before {
  content: '';
  position: absolute; inset: 0;
  background-image: radial-gradient(circle at 1px 1px, rgba(255,255,255,.05) 1px, transparent 0);
  background-size: 36px 36px;
}

.eventos-hero-content { position: relative; z-index: 1; }

.eventos-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: .5rem;
  background: rgba(255,255,255,.1);
  border: 1px solid rgba(255,255,255,.2);
  backdrop-filter: blur(8px);
  padding: .4rem 1.2rem;
  border-radius: 99px;
  font-size: .75rem;
  font-weight: 500;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  color: var(--rose-pale);
  margin-bottom: 1.2rem;
}

.eventos-hero-content h1 {
  font-family: var(--font-display);
  font-size: clamp(4rem, 10vw, 7rem);
  font-weight: 700;
  color: var(--white);
  line-height: 1;
  margin-bottom: 1rem;
  letter-spacing: -2px;
}

.eventos-hero-content p {
  font-size: 1.05rem;
  color: rgba(255,255,255,.8);
  max-width: 560px;
  margin-inline: auto;
  line-height: 1.8;
  font-weight: 400;
}

/* ─── NAVEGACIÓN ENTRE AÑOS ─── */
.year-nav {
  display: flex;
  overflow-x: auto;            
  padding: 1rem 1.5rem;        
  gap: .8rem;
  scrollbar-width: none;       
  -ms-overflow-style: none;    
  position: relative;
  z-index: 10;
}

.year-nav::-webkit-scrollbar {
  display: none;               
}

.pocos-anos {
  justify-content: center;
}

.muchos-anos {
  justify-content: flex-start;
}

@media (min-width: 768px) {
  .year-nav {
    justify-content: center;
  }
}

.year-nav-btn {
  padding: .55rem 1.6rem;
  border-radius: 99px;
  border: 1.5px solid rgba(255,255,255,.3);
  background: transparent;
  color: rgba(255,255,255,.7);
  font-family: var(--font-body);
  font-size: .88rem;
  font-weight: 600;
  letter-spacing: .5px;
  transition: var(--transition);
  cursor: pointer; /* Cambié cursor: none por pointer para que indique que es un link */
  text-decoration: none;
  flex-shrink: 0;
  white-space: nowrap;
}

.year-nav-btn:hover {
  border-color: rgba(255,255,255,.7);
  color: var(--white);
  background: rgba(255,255,255,.08);
}

.year-nav-btn.active {
  background: var(--white);
  border-color: var(--white);
  color: var(--rose-deep);
  box-shadow: 0 4px 20px rgba(0,0,0,.2);
}

/* ─── INDICADOR DE DESLIZAMIENTO (SWIPE HINT) ─── */
.swipe-hint {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 0.4rem;
  margin-top: 0.5rem;
  font-size: 0.75rem;
  color: rgba(255, 255, 255, 0.7);
  font-family: var(--font-body);
  letter-spacing: 0.5px;
  position: relative;
  z-index: 10;
  /* Animación de parpadeo suave para llamar la atención */
  animation: pulse-swipe 2s infinite ease-in-out;
}

.swipe-hint i {
  font-size: 0.85rem;
}

@keyframes pulse-swipe {
  0%, 100% { opacity: 0.4; transform: translateX(0); }
  50% { opacity: 1; transform: translateX(3px); }
}

/* Ocultar en pantallas grandes donde los botones están centrados y no hay scroll */
@media (min-width: 768px) {
  .swipe-hint {
    display: none;
  }
}

/* ─── GRID DE EVENTOS ─── */
.eventos-grid-section { padding-top: 0 !important; }

.eventos-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 2rem;
  padding-top: clamp(2.5rem, 5vw, 4rem);
}

/* ─── CARD DE EVENTO ─── */
.evento-card {
  background: var(--white);
  border-radius: var(--radius-lg);
  overflow: hidden;
  border: 1px solid var(--rose-pale);
  box-shadow: var(--shadow-sm);
  transition: var(--transition);
  cursor: none;
  display: flex;
  flex-direction: column;
}

.evento-card:hover {
  transform: translateY(-8px);
  box-shadow: var(--shadow-md);
  border-color: var(--rose-soft);
}

/* Imagen */
.evento-card-img {
  position: relative;
  aspect-ratio: 16/9;
  overflow: hidden;
  background: var(--cream-dark);
}

.evento-card-img img {
  width: 100%; height: 100%;
  object-fit: cover;
  transition: transform .6s ease;
}

.evento-card:hover .evento-card-img img { transform: scale(1.06); }

/* Tag de categoría */
.evento-card-tag {
  position: absolute;
  top: 1rem; left: 1rem;
  padding: .3rem .85rem;
  border-radius: 99px;
  font-size: .72rem;
  font-weight: 600;
  letter-spacing: .8px;
  text-transform: uppercase;
  background: var(--rose-deep);
  color: var(--white);
  backdrop-filter: blur(8px);
  border: 1px solid rgba(255,255,255,.2);
}

.evento-card-tag.coming-soon {
  background: var(--gold);
  color: var(--text-dark);
}

/* Cuerpo */
.evento-card-body {
  padding: 1.6rem 1.8rem 1.8rem;
  display: flex;
  flex-direction: column;
  flex: 1;
}

.evento-card-date {
  display: flex;
  align-items: center;
  gap: .4rem;
  font-size: .78rem;
  font-weight: 500;
  color: var(--rose-mid);
  letter-spacing: .5px;
  text-transform: uppercase;
  margin-bottom: .7rem;
}

.evento-card-date i { font-size: .85rem; }

.evento-card-body h2 {
  font-family: var(--font-display);
  font-size: 1.2rem;
  color: var(--rose-deep);
  font-weight: 700;
  line-height: 1.3;
  margin-bottom: .8rem;
}

.evento-card-body > p {
  font-size: .9rem;
  color: var(--text-mid);
  line-height: 1.75;
  font-weight: 400;
  flex: 1;
  margin-bottom: 1.2rem;
}

/* Meta (ubicación · beneficiarios) */
.evento-card-meta {
  display: flex;
  flex-wrap: wrap;
  gap: .8rem;
  padding-top: 1rem;
  border-top: 1px solid var(--rose-blush);
  margin-top: auto;
}

.evento-card-meta span {
  display: inline-flex;
  align-items: center;
  gap: .35rem;
  font-size: .78rem;
  color: var(--text-light);
  font-weight: 500;
}

.evento-card-meta i { color: var(--rose-soft); font-size: .8rem; }

/* ─── Responsive ─── */
@media (max-width: 1024px) { .eventos-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 600px)  {
  .eventos-grid  { grid-template-columns: 1fr; gap: 1.4rem; }
  .year-nav-btn  { font-size: .8rem; padding: .45rem 1.2rem; }
}