.volver {
  display: inline-flex; align-items: center; gap: var(--space-1);
  color: var(--color-text-secondary); font-weight: var(--font-weight-semibold);
  margin-bottom: var(--space-4);
}
.volver:hover { color: var(--color-primary-dark); }
.volver .ic { width: 18px; height: 18px; }

.ev-cabecera { margin-bottom: var(--space-6); }
.ev-cabecera h1 { margin: 0 0 var(--space-2); }
.ev-meta { display: flex; flex-wrap: wrap; gap: var(--space-2) var(--space-6); color: var(--color-text-secondary); font-weight: var(--font-weight-medium); }
.ev-meta-item { display: inline-flex; align-items: center; gap: 6px; }
.ev-meta-item .ic { width: 16px; height: 16px; color: var(--color-primary); }

.ev-desc { white-space: pre-wrap; line-height: 1.7; color: var(--color-text-primary); margin-bottom: var(--space-8); }

.ev-seccion { margin-top: var(--space-8); }

/* Asistentes */
.asis-grid { display: flex; flex-wrap: wrap; gap: var(--space-3); }
.asis-chip {
  display: inline-flex; align-items: center; gap: var(--space-2);
  background: var(--color-surface); border: 1px solid var(--color-border);
  border-radius: var(--radius-full); padding: 4px 14px 4px 4px; cursor: pointer;
  box-shadow: var(--shadow-xs); transition: transform var(--transition-base), box-shadow var(--transition-base);
}
.asis-chip:hover { transform: translateY(-2px); box-shadow: var(--shadow-card); }
.asis-chip:focus-visible { outline: none; box-shadow: var(--ring-focus); }
.asis-chip img { width: 34px; height: 34px; border-radius: var(--radius-full); object-fit: cover; border: 1.5px solid var(--color-accent); }
.asis-chip span { font-weight: var(--font-weight-semibold); color: var(--color-text-primary); }

/* Galería */
.galeria-grid { display: grid; gap: var(--space-3); grid-template-columns: repeat(auto-fill, minmax(180px, 1fr)); }
.media-foto { padding: 0; border: none; cursor: pointer; background: none; border-radius: var(--radius-md); overflow: hidden; box-shadow: var(--shadow-card); }
.media-foto img { width: 100%; aspect-ratio: 1 / 1; object-fit: cover; display: block; transition: transform var(--transition-base); }
.media-foto:hover img { transform: scale(1.04); }
.media-video { width: 100%; aspect-ratio: 1 / 1; object-fit: cover; border-radius: var(--radius-md); box-shadow: var(--shadow-card); background: #000; grid-column: span 2; aspect-ratio: 16 / 10; }

/* Lightbox */
.lightbox { border: none; background: transparent; max-width: 92vw; max-height: 92vh; padding: 0; overflow: visible; }
.lightbox::backdrop { background: rgba(20,14,10,.85); }
.lightbox img { max-width: 92vw; max-height: 88vh; border-radius: var(--radius-md); display: block; box-shadow: var(--shadow-elevated); }
.lb-cerrar {
  position: absolute; top: -14px; right: -14px; width: 40px; height: 40px; border-radius: var(--radius-full);
  background: var(--color-surface); color: var(--color-primary-dark); border: 1px solid var(--color-border);
  display: inline-flex; align-items: center; justify-content: center; cursor: pointer; box-shadow: var(--shadow-elevated);
}

@media (max-width: 600px) {
  .media-video { grid-column: span 1; aspect-ratio: 1 / 1; }
}

/* ===== Captions de galería + procesando + lightbox texto ===== */
.galeria-item { margin: 0; }
.galeria-cap { margin-top: var(--space-1); display: flex; flex-direction: column; gap: 2px; }
.galeria-cap strong { color: var(--color-ink); font-size: var(--font-size-sm); }
.galeria-cap span { color: var(--color-text-secondary); font-size: var(--font-size-sm); }
.media-procesando {
  width: 100%; aspect-ratio: 1 / 1; border-radius: var(--radius-md);
  display: flex; flex-direction: column; align-items: center; justify-content: center; gap: var(--space-2);
  background: var(--color-bg-tint); color: var(--color-text-soft); border: 1px dashed var(--color-border-strong);
  font-size: var(--font-size-sm); font-weight: var(--font-weight-semibold);
}
.media-procesando .ic { width: 30px; height: 30px; color: var(--color-gold-deep); }
.lb-cap { margin-top: var(--space-3); text-align: center; color: #fff; display: flex; flex-direction: column; gap: 4px; }
.lb-cap strong { font-size: var(--font-size-lg); }
.lb-cap span { color: rgba(255,255,255,.85); }
