.hero-characters {
  padding-block: var(--space-16);
}

.hero-characters-inner {
  display: grid;
  grid-template-columns: minmax(0, 1.1fr) minmax(0, 0.9fr);
  gap: var(--space-8);
  align-items: center;
}

.hero-characters-copy h1 {
  max-width: 18ch;
}

.hero-characters-intro {
  max-width: 46ch;
  color: var(--color-text-muted);
}

.hero-characters-cta {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-4);
  margin-top: var(--space-6);
}

.hero-characters-figure {
  border-radius: var(--radius-lg);
  overflow: hidden;
  box-shadow: var(--shadow-strong);
}

.hero-characters-figcaption,
.section-figcaption,
.character-figcaption {
  padding: var(--space-3) var(--space-4);
  font-size: var(--font-size-sm);
  color: var(--color-text-muted);
  background: linear-gradient(135deg, rgba(0, 0, 0, 0.9), rgba(24, 26, 34, 0.95));
}

.section-claude-grid,
.section-leone-inner,
.section-legacy-inner {
  align-items: center;
  gap: var(--space-8);
}

.section-claude-image,
.section-leone-figure,
.section-legacy-visual {
  align-self: stretch;
  display: flex;
  align-items: center;
}

.character-figure,
.section-leone-figure,
.legacy-figure,
.antagonists-figure {
  width: 100%;
  border-radius: var(--radius-lg);
  overflow: hidden;
  box-shadow: var(--shadow-soft);
}

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

.section-subtitle {
  max-width: 52ch;
  margin-inline: auto;
}

.antagonists-figure {
  margin-top: var(--space-8);
}

.section-leone-inner,
.section-legacy-inner {
  display: grid;
  grid-template-columns: minmax(0, 1.1fr) minmax(0, 0.9fr);
}

.section-leone-content,
.section-legacy-content {
  height: 100%;
}

.allies-grid,
.yakuza-grid,
.police-grid,
.inhabitants-grid {
  gap: var(--space-6);
}

.side-characters-grid,
.dynamics-grid,
.antagonists-grid {
  align-items: stretch;
}

.section-legacy-cta,
.section-cta-bottom-actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-4);
  margin-top: var(--space-6);
}

.section-cta-bottom-inner {
  background: radial-gradient(circle at top left, rgba(215, 38, 56, 0.18), transparent 55%),
    radial-gradient(circle at bottom right, rgba(56, 182, 255, 0.16), transparent 55%),
    linear-gradient(135deg, rgba(0, 0, 0, 0.96), rgba(15, 17, 24, 0.98));
}

.section-cta-bottom-content {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-6);
}

.section-cta-bottom-content p {
  max-width: 40ch;
  color: var(--color-text-muted);
}

@media (max-width: 960px) {
  .hero-characters-inner,
  .section-leone-inner,
  .section-legacy-inner {
    grid-template-columns: minmax(0, 1fr);
  }

  .hero-characters-art {
    order: -1;
  }
}

@media (max-width: 720px) {
  .hero-characters {
    padding-block: var(--space-12);
  }

  .section {
    padding-block: var(--space-12);
  }

  .hero-characters-cta,
  .section-legacy-cta,
  .section-cta-bottom-actions {
    flex-direction: column;
    align-items: flex-start;
  }

  .section-cta-bottom-content {
    align-items: flex-start;
  }
}
