.hero--lore {
  background: radial-gradient(circle at top, rgba(227, 166, 74, 0.24) 0, #05060a 50%);
}
.hero--lore .hero__background {
  position: absolute;
  inset: 0;
  background: radial-gradient(circle at top left, rgba(227, 166, 74, 0.18) 0, transparent 55%),
    radial-gradient(circle at bottom right, rgba(22, 30, 58, 0.9) 0, #05060a 55%);
  opacity: 0.9;
}
.hero__actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-3);
  margin-top: var(--space-4);
}

.lore-nav {
  border-bottom: 1px solid var(--color-border-subtle);
  background: linear-gradient(180deg, rgba(6, 9, 20, 0.95), #05060a);
}
.lore-nav__inner {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}
.lore-nav__title {
  font-size: var(--font-size-xl);
}
.lore-nav__subtitle {
  color: var(--color-text-muted);
}
.lore-nav__grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: var(--space-4);
}
.lore-nav__item {
  height: 100%;
  cursor: pointer;
  transition: transform var(--transition-base), box-shadow var(--transition-base), border-color var(--transition-base);
}
.lore-nav__item h3 {
  margin-bottom: var(--space-2);
}
.lore-nav__item p {
  margin-bottom: 0;
}
.lore-nav__item:hover {
  transform: translateY(-3px);
  box-shadow: var(--shadow-strong);
  border-color: rgba(227, 166, 74, 0.75);
}

.lore-section-header {
  text-align: left;
  margin-bottom: var(--space-6);
}
.lore-section-header h2 {
  margin-top: var(--space-2);
}

.lore-block {
  background: radial-gradient(circle at top, rgba(227, 166, 74, 0.06) 0, #05060a 60%);
}
.lore-block--alt {
  background: radial-gradient(circle at top left, rgba(88, 110, 189, 0.32) 0, #05060a 60%);
}
.lore-block__grid {
  align-items: center;
  gap: var(--space-6);
}
.lore-block__content {
  z-index: 1;
}
.lore-block__content h2 {
  margin-bottom: var(--space-3);
}
.lore-block__content h3 {
  margin-top: var(--space-4);
}
.lore-block__content-wide {
  max-width: var(--container-max-width);
  margin: 0 auto;
}
.lore-block__cta {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-3);
  margin-top: var(--space-4);
}

.lore-figure {
  border-radius: var(--radius-lg);
  overflow: hidden;
  border: 1px solid var(--color-border-strong);
  box-shadow: var(--shadow-soft);
  background: #05060a;
}
.lore-figure img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.lore-figure figcaption {
  padding: var(--space-3) var(--space-4);
  font-size: var(--font-size-sm);
  color: var(--color-text-muted);
  background: linear-gradient(180deg, rgba(5, 6, 10, 0.9), #05060a);
}

.lore-realms-grid {
  align-items: stretch;
}
.lore-realm--summary {
  border-style: dashed;
}

.lore-timeline {
  background: radial-gradient(circle at center, rgba(23, 32, 80, 0.28) 0, #05060a 65%);
}
.lore-timeline__table {
  margin-top: var(--space-4);
}

.lore-list {
  list-style: disc;
  padding-left: var(--space-5);
  color: var(--color-text-muted);
}
.lore-list li + li {
  margin-top: var(--space-1);
}

.lore-ace-grid,
.lore-shards-grid,
.lore-void-grid,
.lore-path-grid {
  align-items: stretch;
  gap: var(--space-4);
}

.lore-crosslinks h2 {
  margin-bottom: var(--space-3);
}
.lore-crosslinks__grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: var(--space-4);
}
.lore-crosslinks__item {
  padding: var(--space-4);
  border-radius: var(--radius-md);
  border: 1px solid var(--color-border-subtle);
  background: radial-gradient(circle at top, rgba(227, 166, 74, 0.08) 0, rgba(5, 6, 10, 0.98) 55%);
  transition: border-color var(--transition-base), box-shadow var(--transition-base), transform var(--transition-base);
}
.lore-crosslinks__item h3 {
  margin-bottom: var(--space-2);
}
.lore-crosslinks__item p {
  margin-bottom: 0;
}
.lore-crosslinks__item:hover {
  border-color: rgba(227, 166, 74, 0.8);
  box-shadow: var(--shadow-strong);
  transform: translateY(-2px);
}

@media (max-width: 768px) {
  .hero__subtitle {
    font-size: var(--font-size-base);
  }
  .lore-section-header {
    text-align: left;
  }
  .lore-block__cta {
    flex-direction: column;
  }
}
