/* ==========================================================
   EVENTS PAGE
   ========================================================== */

.events-layout {
  display: grid;
  grid-template-columns: 1fr 300px;
  gap: var(--sp-10);
  align-items: start;
}

/* Events list */
.events-list { display: flex; flex-direction: column; gap: var(--sp-4); }

/* Section heading inside list */
.events-section-label {
  font-family: var(--font-head);
  font-size: var(--text-sm);
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--gray-500);
  padding: var(--sp-3) 0 var(--sp-3);
  border-bottom: 1px solid var(--gray-200);
  margin-bottom: var(--sp-2);
  margin-top: var(--sp-8);
}
.events-section-label:first-child { margin-top: 0; }

/* Past events fade */
.event-card--past {
  opacity: 0.7;
  border-left-color: var(--gray-400) !important;
}
.event-card--past:hover { opacity: 1; }

/* Sidebar */
.events-sidebar { position: sticky; top: calc(var(--nav-h) + var(--sp-6)); }

/* Mini calendar (decorative) */
.mini-cal {
  font-size: var(--text-sm);
  width: 100%;
}
.mini-cal__header {
  display: flex; align-items: center; justify-content: space-between;
  font-family: var(--font-head);
  font-size: var(--text-base);
  font-weight: 700;
  text-transform: uppercase;
  color: var(--navy);
  margin-bottom: var(--sp-4);
}
.mini-cal__grid {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: 2px;
  text-align: center;
}
.mini-cal__day-name {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--gray-400);
  padding-block: var(--sp-2);
}
.mini-cal__day {
  font-size: var(--text-xs);
  font-weight: 500;
  color: var(--gray-700);
  padding: 5px 2px;
  border-radius: var(--r-sm);
}
.mini-cal__day--other { color: var(--gray-400); }
.mini-cal__day--event {
  background: var(--red-subtle);
  color: var(--red);
  font-weight: 700;
  cursor: pointer;
}
.mini-cal__day--today {
  background: var(--navy);
  color: var(--white);
  font-weight: 700;
}

/* No events placeholder */
.no-events {
  text-align: center;
  padding: var(--sp-16) 0;
  color: var(--gray-400);
}
.no-events svg { width: 48px; height: 48px; margin: 0 auto var(--sp-4); }
.no-events p { font-size: var(--text-md); }

@media (max-width: 900px) {
  .events-layout { grid-template-columns: 1fr; }
  .events-sidebar { position: static; }
}
