.section-header {
  max-width: var(--container-width);
  margin: 0 auto var(--space-16);
}

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

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

.section-footer-links {
  margin-top: var(--space-16);
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-6);
}

.characters-hero {
  display: grid;
  grid-template-columns: minmax(0, 1.5fr) minmax(0, 1.2fr);
  gap: var(--space-16);
  align-items: center;
  padding-top: var(--space-32);
  padding-bottom: var(--space-32);
}

.characters-hero__content p {
  max-width: 60ch;
}

.characters-hero__actions {
  margin-top: var(--space-8);
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-6);
}

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

.characters-hero__image-frame {
  padding: var(--space-4);
}

.characters-hero__image img {
  border-radius: var(--radius-lg);
}

.characters-classes-grid {
  margin-top: var(--space-8);
}

.characters-list {
  display: grid;
  gap: var(--space-3);
  font-size: var(--fs-sm);
  color: var(--color-text-muted);
}

.characters-factions-grid {
  margin-top: var(--space-8);
}

.characters-progression-grid {
  gap: var(--space-12);
}

.characters-progress-steps {
  display: grid;
  gap: var(--space-8);
  margin-top: var(--space-6);
}

.characters-progress-step {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: var(--space-6);
  align-items: flex-start;
}

.characters-progress-step__badge {
  width: 2.25rem;
  height: 2.25rem;
  border-radius: 999px;
  background: var(--gradient-primary);
  color: #020617;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 700;
  font-family: var(--font-display);
  box-shadow: var(--shadow-glow-primary);
}

.characters-progression__panel,
.characters-skilltree__panel {
  padding: var(--space-16);
}

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

.characters-skilltree-grid {
  margin-top: var(--space-6);
  display: grid;
  gap: var(--space-8);
}

.characters-signature-card {
  grid-column: 1 / -1;
}

.characters-customization-grid {
  gap: var(--space-16);
  align-items: center;
}

.characters-customization__image .glass-panel {
  padding: var(--space-4);
}

.characters-customization__content .characters-customization-features {
  display: grid;
  gap: var(--space-8);
}

.characters-society-grid {
  margin-top: var(--space-8);
  gap: var(--space-10);
}

.characters-tips-grid {
  margin-top: var(--space-8);
  gap: var(--space-10);
}

.characters-advanced-grid {
  margin-top: var(--space-8);
  gap: var(--space-10);
}

.characters-story-grid {
  gap: var(--space-16);
  align-items: center;
}

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

.characters-story__image .glass-panel {
  padding: var(--space-4);
}

.characters-gallery-intro {
  padding: var(--space-16);
  margin-bottom: var(--space-12);
}

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

.characters-gallery-grid {
  gap: var(--space-8);
}

.characters-crosslinks {
  padding-bottom: var(--space-32);
}

.characters-crosslinks__panel {
  padding: var(--space-16);
  display: grid;
  grid-template-columns: minmax(0, 1.2fr) minmax(0, 1.5fr);
  gap: var(--space-12);
  align-items: center;
}

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

.characters-crosslinks__grid .card {
  height: 100%;
}

.characters-crosslinks__grid .card p {
  font-size: var(--fs-sm);
}

@media (max-width: 1023px) {
  .characters-hero {
    grid-template-columns: minmax(0, 1.6fr) minmax(0, 1.2fr);
  }

  .characters-progression__panel,
  .characters-skilltree__panel,
  .characters-story__content,
  .characters-gallery-intro,
  .characters-crosslinks__panel {
    padding: var(--space-12);
  }
}

@media (max-width: 767px) {
  .characters-hero {
    grid-template-columns: 1fr;
    padding-top: var(--space-24);
    padding-bottom: var(--space-24);
  }

  .characters-hero__image {
    order: -1;
  }

  .characters-progress-step {
    grid-template-columns: auto minmax(0, 1fr);
  }

  .characters-customization-grid,
  .characters-story-grid {
    grid-template-columns: 1fr;
  }

  .characters-crosslinks__panel {
    grid-template-columns: 1fr;
  }

  .characters-crosslinks__grid {
    grid-template-columns: 1fr;
  }
}

@media (prefers-reduced-motion: reduce) {
  .characters-hero__image,
  .float-soft {
    animation: none !important;
  }
}
