.hero__inner {
  display: grid;
  grid-template-columns: minmax(0, 3fr) minmax(0, 2.5fr);
  gap: var(--space-20);
  align-items: center;
}

.hero__media {
  max-width: 480px;
  margin-left: auto;
}

.section-header {
  margin-bottom: var(--space-12);
}

.section-header__subtitle {
  max-width: 60ch;
  color: var(--color-text-muted);
}

.section-header--center {
  margin-left: auto;
  margin-right: auto;
  max-width: 64ch;
}

.heroes-grid .hero-card {
  height: 100%;
}

.classes-layout__summary {
  align-self: flex-start;
}

.classes-layout__table {
  align-self: flex-start;
}

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

.abilities-grid .ability-card {
  height: 100%;
}

.companions-layout {
  align-items: stretch;
}

.progression-layout {
  align-items: flex-start;
}

.progression-callouts {
  display: flex;
  flex-direction: column;
  gap: var(--space-10);
}

.team-synergy-layout {
  align-items: flex-start;
}

.team-synergy-callout {
  height: 100%;
}

.hall-layout {
  align-items: center;
  gap: var(--space-20);
}

.hall-cta {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-6);
  margin-top: var(--space-10);
}

.faq-item {
  border-radius: var(--radius-lg);
  border: 1px solid rgba(138, 149, 210, 0.4);
  padding: var(--space-8) var(--space-10);
  background: radial-gradient(circle at top left, rgba(201, 155, 59, 0.06), transparent 60%),
              rgba(6, 10, 32, 0.9);
}

.faq-item + .faq-item {
  margin-top: var(--space-6);
}

.faq-item summary {
  cursor: pointer;
  font-weight: 600;
  letter-spacing: 0.04em;
}

.faq-item[open] {
  box-shadow: var(--shadow-soft);
}

.faq-item p {
  margin-top: var(--space-4);
}

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

  .hero__media {
    order: -1;
    margin-left: 0;
    max-width: 420px;
    justify-self: center;
  }

  .hall-layout {
    grid-template-columns: minmax(0, 1fr);
  }
}

@media (max-width: 640px) {
  .hero__actions {
    flex-direction: column;
    align-items: stretch;
  }

  .hall-cta {
    flex-direction: column;
    align-items: stretch;
  }
}
