.hero--story {
  padding-block: clamp(4rem, 10vh, 6rem);
}

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

.hero-story-content {
  max-width: 640px;
}

.hero-story-lead {
  font-size: var(--font-size-lg);
  color: var(--color-text);
}

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

.hero-story-media {
  justify-self: flex-end;
}

.hero-story-image-frame {
  border-radius: var(--radius-xl);
  overflow: hidden;
  border: 1px solid rgba(196, 154, 58, 0.45);
  box-shadow: var(--shadow-soft);
}

.hero-story-image-frame img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.section--story-intro {
  padding-top: 0;
}

.section-heading--story p {
  max-width: 52rem;
}

.story-grid-intro {
  margin-top: var(--space-6);
}

.story-grid-main,
.story-grid-history,
.story-grid-atmosphere,
.story-grid-puzzles,
.story-grid-endings {
  margin-top: var(--space-6);
}

.story-characters-layout {
  display: grid;
  grid-template-columns: minmax(0, 1.2fr) minmax(0, 1.8fr);
  gap: var(--space-8);
  align-items: start;
}

.story-characters-figure {
  margin: 0;
}

.story-characters-figure img {
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-soft);
}

.story-characters-figure figcaption {
  margin-top: var(--space-3);
  font-size: var(--font-size-sm);
  color: var(--color-text-soft);
}

.story-characters-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: var(--space-5);
}

.story-timeline {
  position: relative;
  margin-top: var(--space-6);
  display: grid;
  gap: var(--space-6);
}

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

.story-timeline-badge {
  width: 2.25rem;
  height: 2.25rem;
  border-radius: 999px;
  border: 1px solid rgba(196, 154, 58, 0.8);
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-heading);
  font-size: var(--font-size-sm);
  color: var(--color-primary-strong);
  background: radial-gradient(circle at 30% 0, rgba(255, 255, 255, 0.18), transparent 55%), linear-gradient(145deg, #111319, #18131a);
  box-shadow: var(--shadow-soft-sm);
}

.story-timeline-content h3 {
  margin-bottom: var(--space-2);
}

.story-locations-layout {
  display: grid;
  grid-template-columns: minmax(0, 1.2fr) minmax(0, 1.8fr);
  gap: var(--space-8);
  align-items: start;
}

.story-locations-figure {
  margin: 0;
}

.story-locations-figure img {
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-soft);
}

.story-locations-figure figcaption {
  margin-top: var(--space-3);
  font-size: var(--font-size-sm);
  color: var(--color-text-soft);
}

.story-moments-grid {
  margin-top: var(--space-6);
}

.story-endings-cta {
  margin-top: var(--space-8);
  text-align: center;
}

.story-endings-cta p {
  margin-inline: auto;
  max-width: 48rem;
}

.story-endings-actions {
  margin-top: var(--space-5);
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  gap: var(--space-4);
}

@media (max-width: 992px) {
  .hero-inner--story {
    grid-template-columns: minmax(0, 1fr);
  }

  .hero-story-media {
    order: -1;
    justify-self: stretch;
  }

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

@media (max-width: 768px) {
  .hero-story-actions {
    flex-direction: column;
    align-items: stretch;
  }

  .story-timeline-step {
    grid-template-columns: minmax(0, 1fr);
  }

  .story-timeline-badge {
    margin-bottom: var(--space-1);
  }
}
