/* ============================================================
   SECTION: Events & Workshops
   Edit: mockup/css/sections/events.css
   ============================================================ */

.events {
  --section-bg: var(--color-surface);
  --section-accent: var(--color-malt);
}

.events__filters {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-sm);
  margin-bottom: var(--space-xl);
  padding: var(--space-md);
  background: var(--color-white);
  border-radius: var(--radius-md);
  border: 1px solid var(--color-stone);
}

.filter-group {
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
  min-width: 8rem;
}

.filter-group label {
  font-family: var(--font-data);
  font-size: var(--text-xs);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--color-ink-muted);
}

.filter-group select {
  font-family: var(--font-body);
  font-size: var(--text-sm);
  padding: 0.4rem 0.6rem;
  border: 1px solid var(--color-stone);
  border-radius: var(--radius-sm);
  background: var(--color-white);
  color: var(--color-ink);
}

.events__grid {
  display: grid;
  gap: var(--space-lg);
}

@media (min-width: 48rem) {
  .events__grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (min-width: 64rem) {
  .events__grid {
    grid-template-columns: repeat(3, 1fr);
  }
}

.event-card {
  display: flex;
  flex-direction: column;
}

.event-card.is-hidden {
  display: none;
}

.event-card__type {
  position: absolute;
  top: var(--space-sm);
  left: var(--space-sm);
  z-index: 1;
}

.event-card__image-wrap {
  position: relative;
}

.event-card__details {
  display: grid;
  gap: var(--space-xs);
  margin: var(--space-md) 0;
  font-size: var(--text-sm);
}

.event-card__detail {
  display: flex;
  gap: var(--space-sm);
}

.event-card__detail dt {
  font-family: var(--font-data);
  font-size: var(--text-xs);
  color: var(--color-ink-muted);
  min-width: 4.5rem;
  flex-shrink: 0;
}

.event-card__detail dd {
  color: var(--color-ink);
  margin: 0;
}

.event-card__footer {
  margin-top: auto;
  padding-top: var(--space-md);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-sm);
}

.event-card__price {
  font-family: var(--font-data);
  font-weight: 500;
  font-size: var(--text-sm);
}

.availability-cue {
  font-family: var(--font-data);
  font-size: var(--text-xs);
  color: var(--color-copper);
}

.events__empty {
  display: none;
  text-align: center;
  padding: var(--space-2xl);
  color: var(--color-ink-muted);
}

.events__empty.is-visible {
  display: block;
}
