.section-hero-concerts {
  padding-top: var(--space-40);
  padding-bottom: var(--space-32);
}

.hero-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.2fr) minmax(0, 1fr);
  gap: var(--space-20);
  align-items: center;
}

@media (max-width: 900px) {
  .hero-grid {
    grid-template-columns: 1fr;
  }
}

.hero-text-block h1 {
  margin-bottom: var(--space-8);
}

.hero-kicker {
  font-size: var(--font-size-sm);
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--color-primary);
  margin-bottom: var(--space-4);
}

.hero-actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-6);
  margin-top: var(--space-8);
  margin-bottom: var(--space-6);
}

.hero-meta {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-4);
}

.hero-media-block .media-placeholder {
  box-shadow: var(--shadow-md);
}

.section-kicker {
  font-size: var(--font-size-sm);
  text-transform: uppercase;
  letter-spacing: 0.14em;
  color: var(--color-accent-blue);
  margin-bottom: var(--space-4);
}

.section-intro-grid {
  align-items: stretch;
}

.section-locations .locations-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.2fr) minmax(0, 1fr);
  gap: var(--space-20);
  align-items: center;
}

@media (max-width: 900px) {
  .section-locations .locations-grid {
    grid-template-columns: 1fr;
  }
}

.locations-cta {
  margin-top: var(--space-10);
}

.ticket-grid {
  align-items: stretch;
}

.section-gallery .gallery-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.2fr) minmax(0, 1fr);
  gap: var(--space-20);
  align-items: center;
}

@media (max-width: 900px) {
  .section-gallery .gallery-grid {
    grid-template-columns: 1fr;
  }
}

.section-gallery .gallery-media .media-placeholder {
  box-shadow: var(--shadow-md);
}

.section-community .community-grid {
  align-items: stretch;
}

.ticket-cta {
  margin-top: var(--space-8);
}

.section-faq .section-header {
  max-width: 44rem;
  margin-bottom: var(--space-16);
}

.faq-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: var(--space-8);
}

@media (max-width: 900px) {
  .faq-grid {
    grid-template-columns: 1fr;
  }
}

.faq-toggle-button {
  border: none;
  background: transparent;
  color: var(--color-text-muted);
  font-size: var(--font-size-lg);
  line-height: 1;
  padding: 0 var(--space-2);
  cursor: pointer;
}

.faq-more {
  margin-top: var(--space-12);
  max-width: 40rem;
}

.section-faq .faq-item {
  transition: background-color var(--transition-base), border-color var(--transition-base), box-shadow var(--transition-base);
}

.section-faq .faq-item[aria-expanded="true"],
.section-faq .faq-item.is-open {
  background-color: var(--color-surface);
  border-color: rgba(0, 194, 168, 0.5);
  box-shadow: var(--shadow-sm);
}
