.labyrinth-subhero {
  position: relative;
  overflow: hidden;
  background:
    linear-gradient(90deg, rgba(5, 9, 16, 0.96) 0%, rgba(7, 11, 19, 0.86) 52%, rgba(7, 11, 19, 0.58) 100%),
    linear-gradient(180deg, rgba(5, 9, 16, 0.24), rgba(5, 9, 16, 0.98)),
    url("/assets/img/games/labyrinthrpg/web/hero.jpg") center top / cover no-repeat;
}

.update-kicker {
  margin: 0 0 8px;
  color: var(--warn);
  font-size: 13px;
  font-weight: 700;
  text-transform: uppercase;
}

.section-intro,
.page-lead {
  max-width: 760px;
  color: var(--ink-dim);
}

.page-lead {
  font-size: 18px;
}

.update-grid,
.roadmap-grid {
  display: grid;
  gap: 16px;
  grid-template-columns: minmax(0, 1fr);
  margin-top: 18px;
}

.latest-update-card {
  display: grid;
  gap: 14px;
  padding: 18px;
  border-radius: 8px;
  background:
    linear-gradient(135deg, rgba(88, 166, 255, 0.18), rgba(242, 204, 96, 0.1)),
    var(--card);
  border: 1px solid rgba(88, 166, 255, 0.34);
}

.latest-update-card h2,
.latest-update-card p {
  margin: 0;
}

.update-card,
.roadmap-card,
.release-card,
.premise-card {
  border-radius: 8px;
  background:
    linear-gradient(180deg, rgba(17, 26, 43, 0.96), rgba(9, 14, 24, 0.98));
  border: 1px solid var(--muted);
}

.update-card,
.roadmap-card {
  padding: 18px;
}

.update-link-card {
  display: block;
  color: var(--ink);
}

.update-link-card:hover {
  text-decoration: none;
  border-color: rgba(88, 166, 255, 0.72);
}

.update-card h3,
.roadmap-card h2,
.release-card h2,
.release-card h3 {
  margin-top: 0;
}

.update-card p,
.roadmap-card p,
.release-card p,
.premise-card p {
  margin-bottom: 0;
}

.last-updated {
  display: inline-flex;
  width: fit-content;
  max-width: 100%;
  margin: 2px 0 16px;
  color: var(--warn);
  font-size: 14px;
  font-weight: 700;
}

.update-meta,
.roadmap-status {
  display: inline-flex;
  align-items: center;
  width: fit-content;
  max-width: 100%;
  margin-bottom: 10px;
  padding: 4px 9px;
  border-radius: 999px;
  background: rgba(88, 166, 255, 0.14);
  border: 1px solid rgba(88, 166, 255, 0.34);
  color: var(--ink);
  font-size: 13px;
  font-weight: 700;
}

.roadmap-status.later {
  background: rgba(242, 204, 96, 0.12);
  border-color: rgba(242, 204, 96, 0.34);
}

.roadmap-status.experimental {
  background: rgba(46, 160, 67, 0.12);
  border-color: rgba(46, 160, 67, 0.34);
}

.roadmap-status.not-planned {
  background: rgba(179, 194, 217, 0.1);
  border-color: rgba(179, 194, 217, 0.24);
}

.update-list,
.roadmap-list {
  margin: 12px 0 0;
  padding-left: 18px;
  color: var(--ink-dim);
}

.update-list li + li,
.roadmap-list li + li {
  margin-top: 8px;
}

.roadmap-list strong {
  display: block;
  color: var(--ink);
  margin-bottom: 2px;
}

.roadmap-list span {
  display: block;
}

.timeline {
  display: grid;
  gap: 18px;
}

.release-card {
  padding: 22px;
}

.premise-card {
  padding: 22px;
  max-width: 820px;
}

.data-card-grid {
  display: grid;
  gap: 14px;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  margin-top: 18px;
}

.data-card {
  display: grid;
  gap: 8px;
  padding: 16px;
  border: 1px solid var(--muted);
  border-radius: 8px;
  background:
    linear-gradient(180deg, rgba(17, 26, 43, 0.82), rgba(9, 14, 24, 0.92));
  color: var(--ink);
}

.data-card:hover {
  text-decoration: none;
  border-color: rgba(88, 166, 255, 0.54);
}

.data-card-title {
  display: block;
  font-size: 17px;
  font-weight: 700;
}

.data-card-copy {
  display: block;
  color: var(--ink-dim);
  font-size: 14px;
  line-height: 1.45;
}

.data-card-cta {
  display: block;
  margin-top: 4px;
  color: var(--accent);
  font-size: 14px;
  font-weight: 700;
}

.release-header {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: space-between;
  gap: 10px 16px;
}

.release-date {
  color: var(--warn);
  font-size: 14px;
  font-weight: 700;
}

.release-section {
  margin-top: 22px;
}

.back-row {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-top: 18px;
}

@media (min-width: 760px) {
  .update-grid,
  .roadmap-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}
