/* Home / public pages — dark theme with Merriweather */
.home-page {
  background-color: #000;
  color: #fefffe;
  font-family: "Merriweather", serif;
  font-weight: 400;
  min-height: 100vh;
}
.home-page .title,
.home-page .subtitle { color: #fefffe !important; }
.home-page a { color: #fff; text-decoration: underline; }
.home-page a:hover { color: #fff; }

/* Title block */
.home-page .home-subtitle { font-style: italic; font-size: 0.7em; }
.home-page .home-director { font-size: 0.5em; margin-top: 0.4em; display: block; clear: both; }

/* Contact box */
.home-page .home-contact {
  border-left: 1px solid #515151;
  border-bottom: 1px solid #515151;
  padding: 0 1rem 0.5rem;
  font-size: 0.9em;
}
.home-page .home-contact .title { margin-top: 0 !important; }
@media (min-width: 769px) {
  .home-page .home-columns { flex-direction: row-reverse; }
}

/* Body text */
.home-page .home-text .content p { font-size: 1.1em; text-align: justify; }

/* Video embed */
.home-page .video-container {
  position: relative; width: 100%; max-width: 800px;
  margin: 20px auto; padding-top: 56.25%;
}
.home-page .video-container iframe {
  position: absolute; top: 0; left: 0;
  width: 100%; height: 100%; border: none;
}

/* Cover image */
.home-page .home-cover { width: 100%; height: auto; display: block; }
.home-page .home-cover-banner { max-width: 900px; width: 100%; height: auto; display: block; margin: 0 auto; }

/* Shared page elements */
.home-page .home-footer { border-top: 1px solid #515151; }

/* Event cards */
.home-page .event-card { border: 1px solid #515151; }
.home-page .event-date { font-size: 0.85em; text-transform: uppercase; letter-spacing: 0.1em; color: #b0b0b0; }
.home-page .event-location { color: #ccc; }

/* Year tabs */
.home-page .year-tab { color: #888; text-decoration: none; padding-bottom: 0.2em; }
.home-page .year-tab.is-active { color: #fff; border-bottom: 2px solid #fff; font-weight: 700; }

/* Locale buttons */
.home-page .locale-btn { text-decoration: none; font-size: 0.85em; padding: 0.3em 0.8em; border: 1px solid #515151; color: #888; }
.home-page .locale-btn.is-active { border-color: #fff; color: #fff; }

/* Locale / year tab groups */
.home-page .locale-group { display: flex; gap: 0.5em; }
.home-page .year-group { display: flex; gap: 1.5em; }

/* Empty state */
.home-page .empty-state { color: #999; }
