.concerts-hero {
  position: relative;
  background: radial-gradient(circle at top, rgba(163, 255, 18, 0.16), transparent 55%), var(--color-bg);
}

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

.concerts-hero__lead {
  max-width: 38rem;
}

.concerts-hero__actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-3);
  margin-top: var(--space-4);
}

.concerts-hero__meta {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
  margin-top: var(--space-4);
}

.concerts-hero__media {
  max-width: 32rem;
  margin-inline: auto;
}

.concerts-section-header {
  max-width: 48rem;
  margin-bottom: var(--space-6);
}

.concerts-section-header__actions {
  margin-top: var(--space-4);
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-3);
}

.concerts-agenda {
  margin-top: var(--space-2);
}

.concerts-agenda__meta-row {
  justify-content: space-between;
}

.concerts-agenda__cta {
  text-align: right;
}

.concerts-agenda__footer {
  padding-top: var(--space-4);
  border-top: 1px solid rgba(31, 41, 55, 0.8);
  margin-top: var(--space-4);
}

.btn-sm {
  padding: 0.5rem 1.1rem;
  font-size: var(--font-size-xs);
}

.concerts-past-grid {
  gap: var(--space-6);
  align-items: flex-start;
}

.concerts-past-list .concerts-past-item + .concerts-past-item {
  margin-top: var(--space-4);
}

.concerts-past-media {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}

.concerts-artists-grid {
  margin-top: var(--space-4);
}

.concerts-artists-footer {
  margin-top: var(--space-6);
}

.concerts-format-grid {
  gap: var(--space-6);
}

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

.concerts-venues-media {
  max-width: 28rem;
  margin-inline: auto;
}

.concerts-venues-card {
  margin-top: var(--space-4);
}

.concerts-participation-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.5fr) minmax(0, 1fr);
  gap: var(--space-8);
  align-items: flex-start;
}

.concerts-steps-card {
  margin-top: var(--space-4);
}

.concerts-steps-list {
  counter-reset: concerts-step;
  list-style: none;
  padding-left: 0;
  margin-bottom: var(--space-4);
}

.concerts-steps-list li {
  position: relative;
  padding-left: 2.5rem;
  margin-bottom: var(--space-4);
}

.concerts-steps-list li::before {
  counter-increment: concerts-step;
  content: counter(concerts-step);
  position: absolute;
  left: 0;
  top: 0.1rem;
  width: 1.8rem;
  height: 1.8rem;
  border-radius: 999px;
  border: 1px solid rgba(163, 255, 18, 0.6);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: var(--font-size-xs);
  color: var(--color-primary);
}

.concerts-participation-aside {
  margin-top: var(--space-6);
}

.concerts-testimonials-grid {
  gap: var(--space-6);
}

.concerts-faq-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.6fr) minmax(0, 1fr);
  gap: var(--space-8);
  align-items: flex-start;
}

.concerts-faq-aside {
  margin-top: var(--space-6);
}

.concerts-gallery-grid {
  gap: var(--space-8);
  align-items: center;
}

.concerts-gallery-media {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}

.concerts-gallery-cta {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-3);
}

.faq-question span {
  margin-left: var(--space-3);
  font-size: var(--font-size-lg);
  color: var(--color-primary);
}

.faq-question[aria-expanded="true"] span {
  transform: rotate(45deg);
}

@media (max-width: 960px) {
  .concerts-hero__grid {
    grid-template-columns: minmax(0, 1fr);
  }

  .concerts-hero__media {
    order: -1;
  }

  .concerts-venues-grid,
  .concerts-participation-grid,
  .concerts-faq-grid,
  .concerts-gallery-grid {
    grid-template-columns: minmax(0, 1fr);
  }

  .concerts-agenda__meta-row {
    flex-direction: column;
    align-items: flex-start;
  }

  .concerts-agenda__cta {
    text-align: left;
  }
}

@media (max-width: 640px) {
  .concerts-section-header__actions,
  .concerts-gallery-cta,
  .concerts-hero__actions {
    flex-direction: column;
    align-items: stretch;
  }
}
