/*
 * Villa Pojana — pagina "Calendario"
 * ------------------------------------------------------------------
 * Stili specifici della pagina con slug "calendario": barra filtri per
 * categoria, evento in evidenza, variante della card evento (titolo
 * 24px + prezzo), mostra in corso e box "in arrivo". Caricato solo su
 * questa pagina, vedi villa_pojana_enqueue_assets() in functions.php.
 *
 * Variabili, reset, header/topbar, navigazione, .section base e griglia
 * eventi condivisa (.events-grid, .event-card, .event-image,
 * .event-content, .event-date-row, .event-date, .event-tag,
 * .event-meta) sono in main.css. L'intestazione (.page-hero) è in
 * page-hero.css.
 */

/* BARRA FILTRI (vp/eventi-grid) */
.filter-bar {
  background: var(--paper);
  border-bottom: 1px solid var(--line);
  position: sticky;
  top: 80px;
  z-index: 50;
}
.filter-inner {
  max-width: 1440px;
  margin: 0 auto;
  padding: 0 48px;
  display: flex;
  align-items: center;
  gap: 0;
  overflow-x: auto;
}
.filter-label {
  font-size: 11px;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--stone);
  font-weight: 600;
  margin-right: 28px;
  white-space: nowrap;
  flex-shrink: 0;
}
.filter-btn {
  font-size: 13px;
  font-weight: 500;
  padding: 18px 20px;
  border-bottom: 2px solid transparent;
  white-space: nowrap;
  transition: color 0.2s, border-color 0.2s;
  flex-shrink: 0;
}
.filter-btn:hover { color: var(--terracotta); }
.filter-btn.active {
  color: var(--terracotta);
  border-bottom-color: var(--terracotta);
}
.filter-sep {
  width: 1px;
  height: 20px;
  background: var(--line-strong);
  margin: 0 8px;
  flex-shrink: 0;
}

/* SEZIONE GRIGLIA */
.cal-section {
  max-width: 1440px;
  margin: 0 auto;
  padding: 72px 48px 100px;
}

/* PAGINAZIONE */
.cal-pagination {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 4px;
  margin-top: 64px;
  flex-wrap: wrap;
}
.cal-pagination .page-numbers {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 40px;
  height: 40px;
  padding: 0 8px;
  font-size: 14px;
  font-weight: 500;
  color: var(--stone);
  border: 1px solid var(--line);
  transition: color 0.2s, border-color 0.2s, background 0.2s;
}
.cal-pagination .page-numbers:hover {
  color: var(--ink);
  border-color: var(--ink);
}
.cal-pagination .page-numbers.current {
  background: var(--ink);
  color: var(--paper);
  border-color: var(--ink);
}
.cal-pagination .page-numbers.dots {
  border-color: transparent;
  pointer-events: none;
}

/* CARD EVENTO — variante "Calendario". Il resto della
   card (.events-grid, .event-card, .event-image, .event-content,
   .event-date-row, .event-date, .event-tag, .event-meta) è in main.css. */
.event-title {
  font-family: var(--font-display);
  font-size: 24px;
  line-height: 1.15;
  font-weight: 400;
  letter-spacing: -0.015em;
  margin-bottom: 12px;
  font-variation-settings: 'opsz' 36, 'SOFT' 30;
}
.event-price { color: var(--terracotta); font-weight: 600; }

/* Riempitivo per le card senza immagine in evidenza. */
.event-image-placeholder {
  width: 100%;
  height: 100%;
  background: linear-gradient(135deg, var(--olive) 0%, #8C8842 100%);
}

/* Messaggio quando non ci sono eventi futuri in programma. */
.events-empty {
  grid-column: 1 / -1;
  text-align: center;
  font-size: 15px;
  color: var(--stone);
  padding: 40px 0;
}

/* RESPONSIVE */
@media (max-width: 1100px) {
  .cal-section { padding-left: 32px; padding-right: 32px; }
  .events-grid { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 640px) {
  .cal-section { padding-left: 20px; padding-right: 20px; padding-top: 48px; }
  .events-grid { grid-template-columns: 1fr; }
}
