:root {
  --atlas-plum: #62455b;
  --atlas-plum-deep: #4d3747;
  --atlas-plum-dark: #372631;
  --atlas-paper: #f5f0eb;
  --atlas-paper-deep: #ebe2d8;
  --atlas-paper-line: #d9cfbf;
  --atlas-paper-texture: url("./assets/paper-texture.png");
  --atlas-paper-texture-overlay: url("./assets/paper-texture-overlay.png");
  --atlas-paper-texture-contact: url("./assets/contact-texture.png");
  --atlas-paper-texture-socials: url("./assets/socials-texture.png");
  --atlas-paper-surface: #f5f0eb var(--atlas-paper-texture) center / cover no-repeat;
  --atlas-ink: #171313;
  --atlas-ink-soft: #2d2327;
  --atlas-ink-muted: rgba(23, 19, 19, 0.6);
  --atlas-line: rgba(245, 240, 235, 0.12);
  --atlas-terracotta: #c36e62;
  --atlas-terracotta-deep: #aa5b50;
  --atlas-olive: #7e7e55;
  --atlas-olive-deep: #5d5c40;
  --atlas-red: #c02a32;
  --atlas-red-deep: #942832;
  --atlas-shadow: 0 30px 80px rgba(9, 7, 8, 0.24);
  --radius-xl: 1.5rem;
  --radius-lg: 1rem;
  --radius-sm: 0.4rem;
  --transition-smooth: 260ms cubic-bezier(0.16, 1, 0.3, 1);
  --display-font: "Bodoni 72", "Bodoni MT", "Libre Bodoni", Georgia, serif;
  --body-font: "Helvetica Neue", Helvetica, Arial, sans-serif;
  --mono-font: ui-monospace, "SF Mono", Menlo, Consolas, "Liberation Mono", monospace;
  --board-width: 3000px;
  --board-height: 2450px;
  --rail-width: clamp(34rem, 41vw, 38.75rem);
  --rail-track-width: var(--rail-width);
  --rail-content-width: 30rem;
  --rail-menu-width: 16.25rem;
  --rail-collapse-peek: 3rem;
  --site-shell-padding: 0;
  --rail-floating-inset: 1rem;
  --stage-grid-size: 4.4rem;
  --stage-overlay-right-gap: calc(var(--rail-track-width) + var(--rail-floating-inset));
  --rail-shell-padding: clamp(3.25rem, 4vw, 5rem);
  --rail-content-padding-bottom: 6.25rem;
  --rail-media-frame-padding: clamp(0.85rem, 1.2vw, 1.2rem);
  /* Typography scale: compact major-second-ish steps, kept close to the current visual sizes. */
  --type-ratio: 1.125;
  --type-size-2xs: 0.5625rem;
  --type-size-xs: 0.625rem;
  --type-size-sm: 0.75rem;
  --type-size-md: 0.875rem;
  --type-size-base: 1rem;
  --type-size-lg: 1.125rem;
  --type-size-xl: 1.25rem;
  --type-size-2xl: 1.602rem;
  --type-size-3xl: 2.027rem;
  --type-size-4xl: 2.566rem;
  --type-size-5xl: 3.247rem;
  --type-size-6xl: 4.11rem;
  --type-size-7xl: 5.202rem;
  --type-line-tight: 1.05;
  --type-line-snug: 1.18;
  --type-line-normal: 1.3125;
  --type-line-relaxed: 1.45;
  --type-tracking-none: 0;
  --type-tracking-label: 0.16em;
  --type-weight-regular: 400;
  --type-weight-medium: 500;
  --type-weight-bold: 700;
  /* Atlas rail type roles:
     label = section tags and metadata
     display = hero and section heads
     body = narrative copy
     strong = CTA and row titles
     meta = secondary supporting info
     micro = auxiliary labels
  */
  --rail-type-label-size: var(--type-size-xs);
  --rail-type-label-line: 0.9rem;
  --rail-type-label-spacing: 0.16em;
  --rail-type-label-weight: var(--type-weight-bold);
  --rail-type-display-size: var(--type-size-2xl);
  --rail-type-display-line: var(--type-line-tight);
  --rail-type-display-spacing: var(--type-tracking-none);
  --rail-type-display-weight: var(--type-weight-bold);
  --rail-type-body-size: var(--type-size-base);
  --rail-type-body-line: var(--type-line-normal);
  --rail-type-body-spacing: var(--type-tracking-none);
  --rail-type-body-weight: var(--type-weight-medium);
  --rail-type-subhead-size: var(--type-size-xl);
  --rail-type-subhead-line: var(--type-line-snug);
  --rail-type-subhead-spacing: var(--type-tracking-none);
  --rail-type-subhead-weight: var(--type-weight-bold);
  --rail-type-strong-size: var(--type-size-base);
  --rail-type-strong-line: 1.3;
  --rail-type-strong-spacing: var(--type-tracking-none);
  --rail-type-strong-weight: var(--type-weight-bold);
  --rail-type-meta-size: var(--type-size-sm);
  --rail-type-meta-line: 1.0625rem;
  --rail-type-meta-spacing: var(--type-tracking-none);
  --rail-type-meta-weight: var(--type-weight-regular);
  --rail-type-micro-size: var(--type-size-2xs);
  --rail-type-micro-line: 0.9rem;
  --rail-type-micro-spacing: 0.16em;
  --rail-type-micro-weight: var(--type-weight-regular);
  --rail-type-index-size: var(--type-size-2xl);
  --rail-type-index-line: 1.875rem;
  --rail-type-index-spacing: var(--type-tracking-none);
  --rail-type-index-weight: var(--type-weight-bold);
  --rail-title-copy-gap: 1rem;
  --rail-card-title-copy-gap: 0.34rem;
  --rail-surface-texture-image: var(--atlas-paper-texture-overlay);
  --rail-surface-texture-size: cover;
  --rail-surface-texture-position: center;
  --rail-surface-texture-repeat: no-repeat;
}

*,
*::before,
*::after {
  box-sizing: border-box;
}

html,
body {
  margin: 0;
  min-height: 100%;
}

body {
  font-family: var(--body-font);
  color: var(--atlas-paper);
  background: var(--atlas-plum-dark);
  overflow: hidden;
}

a {
  color: inherit;
  text-decoration: none;
}

button,
input {
  font: inherit;
}

button {
  border: 0;
  background: none;
  color: inherit;
  cursor: pointer;
}

[hidden] {
  display: none !important;
}

.site-shell {
  display: block;
  height: 100vh;
  padding: var(--site-shell-padding);
  position: relative;
}

.visual-stage,
.content-panel {
  position: relative;
  min-height: 0;
  border-radius: 0;
}

.visual-stage {
  position: absolute;
  inset: 0;
  z-index: 0;
  overflow: hidden;
  background-color: var(--atlas-plum-deep);
}

.visual-stage.is-panning {
  cursor: grabbing;
}

.visual-stage__backdrop {
  position: absolute;
  inset: 0;
  background: none;
  pointer-events: none;
}

.visual-stage__hud,
.visual-stage__coords {
  position: absolute;
  z-index: 6;
  font-family: var(--mono-font);
  font-size: var(--type-size-xs);
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: rgba(245, 240, 235, 0.56);
}

.visual-stage__hud {
  top: 1.25rem;
  left: 1.25rem;
  display: flex;
  gap: 0.55rem;
  align-items: center;
}

.visual-stage__hud span + span::before {
  content: "/";
  margin-right: 0.55rem;
  opacity: 0.42;
}

.visual-stage__coords {
  top: 1.25rem;
  right: calc(var(--rail-track-width) + var(--rail-floating-inset) + 1.25rem);
}

.visual-stage__viewport {
  position: absolute;
  inset: 0;
  overflow: hidden;
  touch-action: none;
}

.visual-stage__reticle {
  position: absolute;
  inset: 0 var(--stage-overlay-right-gap) 0 0;
  z-index: 1;
  pointer-events: none;
  overflow: hidden;
  opacity: 0;
}

.visual-stage__reticle-orbit,
.visual-stage__reticle-marker {
  position: absolute;
  border-radius: 50%;
}

.visual-stage__reticle-orbit {
  border: 1px solid rgba(245, 240, 235, 0.18);
  filter: drop-shadow(0 0 0.75rem rgba(245, 240, 235, 0.04));
}

.visual-stage__reticle-orbit--primary {
  top: 5%;
  left: 7.5%;
  width: 85%;
  height: 88%;
}

.visual-stage__reticle-orbit--secondary {
  top: 24%;
  left: 31%;
  width: 42%;
  height: 48%;
  border-color: rgba(245, 240, 235, 0.08);
  border-style: dashed;
  opacity: 0.55;
}

.visual-stage__reticle-marker {
  width: 0.5rem;
  height: 0.5rem;
  background: rgba(245, 240, 235, 0.92);
  box-shadow: 0 0 0 1px rgba(23, 19, 19, 0.32);
  transform: translate(-50%, -50%);
}

.visual-stage__reticle-marker--northwest {
  top: 15.3%;
  left: 22.7%;
}

.visual-stage__reticle-marker--east {
  top: 56.6%;
  left: 91.8%;
}

.visual-stage__reticle-marker--southwest {
  top: 87.1%;
  left: 28.8%;
}

.visual-stage__reticle-marker--southeast {
  top: 85%;
  left: 74.4%;
  width: 0.32rem;
  height: 0.32rem;
  opacity: 0.72;
}

.visual-stage__anchor {
  position: absolute;
  top: 50%;
  left: calc((100% - var(--rail-track-width) - var(--rail-floating-inset)) / 2);
  width: var(--board-width);
  height: var(--board-height);
  transform: translate(-50%, -50%);
  z-index: 2;
}

.visual-stage__pan {
  position: absolute;
  inset: 0;
}

.visual-stage__board {
  position: absolute;
  inset: 0;
  transform: scale(var(--board-scale, 1));
  transform-origin: center center;
}

.visual-stage__board::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  background-image:
    linear-gradient(rgba(245, 240, 235, 0.065) 1px, transparent 1px),
    linear-gradient(90deg, rgba(245, 240, 235, 0.065) 1px, transparent 1px);
  background-size: var(--stage-grid-size) var(--stage-grid-size), var(--stage-grid-size) var(--stage-grid-size);
}

.visual-stage__ring,
.visual-stage__lines,
.visual-stage__cards,
.visual-stage__core {
  position: absolute;
}

.visual-stage__lines,
.visual-stage__cards {
  inset: 0;
}

.visual-stage__lines {
  z-index: 1;
}

.visual-stage__cards {
  z-index: 2;
}

.visual-stage__ring {
  display: none;
}

.visual-stage__ring--outer {
  inset: 170px 300px 220px 240px;
}

.visual-stage__ring--inner {
  inset: 340px 620px 430px 610px;
  border-style: dashed;
  opacity: 0.4;
}

.visual-stage__core {
  top: 50%;
  left: 50%;
  z-index: 3;
  width: 15rem;
  height: 15rem;
  display: block;
  transform: translate(-50%, -50%);
  pointer-events: none;
  transition:
    transform 420ms cubic-bezier(0.16, 1, 0.3, 1),
    filter 320ms var(--transition-smooth);
}

.visual-stage__core::before {
  content: none;
}

.visual-stage__core::after {
  content: none;
}

.visual-stage__core-logo {
  position: absolute;
  top: 50%;
  left: 50%;
  display: block;
  width: 88%;
  height: 88%;
  object-fit: contain;
  object-position: center center;
  z-index: 1;
  opacity: 1;
  mix-blend-mode: screen;
  pointer-events: auto;
  cursor: pointer;
  transform: translate(-50%, -47%);
  transition:
    opacity 320ms var(--transition-smooth),
    transform 420ms cubic-bezier(0.16, 1, 0.3, 1);
}

.visual-stage__core.is-related {
  filter: saturate(0.92);
}

.visual-stage__core.is-dim {
  filter: saturate(0.88);
}

.visual-stage__core.is-active {
  transform: translate(-50%, -50%) scale(1.03);
  filter: saturate(1.05);
}

.visual-stage__core.is-active::before,
.visual-stage__core.is-active::after {
  opacity: 1;
}

.visual-stage__core.is-active::before {
  transform: translate(-50%, -50%) scale(1);
}

.visual-stage__core.is-active .visual-stage__core-logo {
  opacity: 1;
  transform: translate(-50%, -47%) scale(1.01);
}

.visual-stage__core.is-dim::before {
  opacity: 0.06;
}

.visual-stage__core.is-dim .visual-stage__core-logo {
  opacity: 1;
  transform: translate(-50%, -47%) scale(0.99);
}

.visual-stage__connections {
  isolation: isolate;
}

.visual-stage__connection {
  opacity: 0.9;
  transition: opacity 320ms var(--transition-smooth);
}

.visual-stage__connection.is-dim {
  opacity: 0.16;
}

.visual-stage__connection.is-active {
  opacity: 1;
}

.visual-stage__connection.is-active .visual-stage__path--base {
  stroke: rgba(245, 240, 235, 0.52);
  stroke-width: 1.55;
}

.visual-stage__connection.is-active .visual-stage__path--ghost {
  stroke: rgba(126, 126, 85, 0.28);
}

.visual-stage__path {
  fill: none;
  stroke-linecap: round;
  vector-effect: non-scaling-stroke;
}

.visual-stage__path--base {
  stroke: rgba(245, 240, 235, 0.1);
  stroke-width: 1.2;
}

.visual-stage__path--ghost {
  stroke: rgba(126, 126, 85, 0.16);
  stroke-width: 0.9;
  stroke-dasharray: 2 18;
}

.visual-stage__path--stream {
  stroke: rgba(245, 240, 235, 0.42);
  stroke-width: 1.35;
  stroke-dasharray: 6 22 2 28;
}

.visual-stage__path--stream-reverse {
  stroke: rgba(195, 110, 98, 0.34);
  stroke-width: 1.1;
  stroke-dasharray: 2 18 7 30;
}

.visual-stage__path--active-wave,
.visual-stage__path--active-wave-reverse {
  opacity: 0;
  transition: opacity 320ms var(--transition-smooth);
}

.visual-stage__path--active-wave {
  stroke: rgba(245, 240, 235, 0.88);
  stroke-width: 1.8;
}

.visual-stage__path--active-wave-reverse {
  stroke: rgba(195, 110, 98, 0.72);
  stroke-width: 1.25;
}

.visual-stage__connection.is-active .visual-stage__path--stream {
  stroke: rgba(245, 240, 235, 0.72);
  opacity: 0.18;
}

.visual-stage__connection.is-active .visual-stage__path--stream-reverse {
  stroke: rgba(195, 110, 98, 0.56);
  opacity: 0.16;
}

.visual-stage__connections[data-motion="active"] .visual-stage__connection.is-active .visual-stage__path--active-wave {
  opacity: 1;
}

.visual-stage__connections[data-motion="active"] .visual-stage__connection.is-active .visual-stage__path--active-wave-reverse {
  opacity: 1;
}

.artifact-card {
  --artifact-card-opacity: 1;
  --artifact-card-filter: none;
  --artifact-card-spotlight-transition: 420ms cubic-bezier(0.22, 1, 0.36, 1);
  position: absolute;
  display: flex;
  flex-direction: column;
  gap: 0.65rem;
  padding: 0.85rem 0.95rem;
  text-align: left;
  color: var(--atlas-ink);
  text-decoration: none;
  background: var(--atlas-paper);
  border: 0;
  transform: rotate(var(--rotation, 0deg));
  opacity: var(--artifact-card-opacity);
  filter: var(--artifact-card-filter);
  transition:
    transform var(--transition-smooth),
    filter var(--artifact-card-spotlight-transition),
    opacity var(--artifact-card-spotlight-transition);
}

.artifact-card::after {
  content: none;
}

.artifact-card:hover,
.artifact-card:focus-visible {
  transform: translateY(-0.35rem) rotate(var(--rotation, 0deg));
  outline: none;
}

.artifact-card.is-outside-spotlight {
  --artifact-card-filter: brightness(0.76) saturate(0.72);
}

.artifact-card.is-dim {
  --artifact-card-opacity: 0.24;
  --artifact-card-filter: brightness(0.64) saturate(0.58);
}

.artifact-card.is-dim.artifact-card--city,
.artifact-card.is-dim.artifact-card--work-teaser {
  --artifact-card-opacity: 0.62;
  --artifact-card-filter: brightness(0.86) saturate(0.84);
}

.artifact-card.is-related {
  --artifact-card-opacity: 0.94;
}

.artifact-card.is-active {
  transform: rotate(var(--rotation, 0deg));
  box-shadow: 0 1rem 2.5rem rgba(9, 7, 8, 0.24);
}

.artifact-card__meta,
.artifact-card__footer,
.artifact-card__media-tag {
  font-family: var(--mono-font);
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
}

.artifact-card__meta {
  display: flex;
  justify-content: space-between;
  gap: 0.8rem;
  font-size: var(--type-size-2xs);
  color: var(--atlas-ink-muted);
}

.artifact-card__title {
  margin: 0;
  font-family: var(--body-font);
  font-size: var(--type-size-base);
  line-height: 1.16;
  font-weight: 700;
  letter-spacing: var(--type-tracking-none);
}

.artifact-card__excerpt {
  margin: 0;
  font-family: var(--body-font);
  font-size: var(--type-size-md);
  line-height: 1.34;
  font-weight: 500;
  letter-spacing: var(--type-tracking-none);
  color: rgba(23, 19, 19, 0.78);
}

.artifact-card__footer {
  display: flex;
  justify-content: space-between;
  gap: 0.9rem;
  font-size: var(--type-size-2xs);
  color: rgba(23, 19, 19, 0.54);
}

.artifact-card__media {
  position: relative;
  min-height: 5.4rem;
  overflow: hidden;
  border: 1px solid rgba(23, 19, 19, 0.12);
  background: var(--media-fill, var(--media-start, var(--atlas-plum)));
  background-position: var(--media-position, center);
  background-repeat: no-repeat;
  background-size: cover;
}

.artifact-card__media::after {
  content: "";
  position: absolute;
  inset: 0;
  background: none;
}

.artifact-card__media-tag {
  position: absolute;
  top: 0.55rem;
  left: 0.55rem;
  z-index: 1;
  padding: 0.24rem 0.4rem;
  background: rgba(23, 19, 19, 0.8);
  color: var(--atlas-paper);
  font-size: var(--type-size-2xs);
}

.artifact-card--theme {
  width: 16rem;
  background: var(--atlas-plum-dark);
  color: var(--atlas-paper);
  border-color: rgba(245, 240, 235, 0.1);
}

.artifact-card--theme .artifact-card__meta,
.artifact-card--theme .artifact-card__footer {
  color: rgba(245, 240, 235, 0.56);
}

.artifact-card--theme .artifact-card__excerpt {
  color: rgba(245, 240, 235, 0.76);
}

.artifact-card--theme .artifact-card__meta::before {
  content: "";
  width: 0.45rem;
  height: 0.45rem;
  align-self: center;
  border-radius: 50%;
  background: var(--atlas-terracotta);
  box-shadow: none;
}

.artifact-card--theme.artifact-card--olive .artifact-card__meta::before {
  background: var(--atlas-olive);
  box-shadow: none;
}

.artifact-card--city {
  width: 12rem;
  padding: 0.62rem 0.62rem 2.35rem;
}

.artifact-card--city .artifact-card__media {
  aspect-ratio: 4 / 5;
}

.artifact-card--city .artifact-card__footer {
  position: absolute;
  left: 0.62rem;
  right: 0.62rem;
  bottom: 0.72rem;
}

.artifact-card--city .artifact-card__title {
  font-size: var(--type-size-base);
  line-height: 1.1;
  letter-spacing: var(--type-tracking-none);
  text-transform: none;
}

.artifact-card--format {
  width: 15rem;
}

.artifact-card--format .artifact-card__title {
  font-size: var(--type-size-lg);
}

.artifact-card--work {
  width: 17rem;
  gap: 0.8rem;
}

.artifact-card--work .artifact-card__title {
  font-size: var(--type-size-lg);
}

.artifact-card--context-work {
  width: clamp(14rem, 15vw, 17rem);
  gap: 0;
  padding: 0;
  overflow: hidden;
  background: var(--atlas-paper);
  box-shadow: 0 0.85rem 1.9rem rgba(9, 7, 8, 0.18);
}

.artifact-card--context-work .artifact-card__work-image {
  display: block;
  width: 100%;
  aspect-ratio: 1;
  overflow: hidden;
  background: rgba(23, 19, 19, 0.08);
}

.artifact-card--context-work .artifact-card__work-image img {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
  filter: saturate(0.94) contrast(1.03);
}

.artifact-card__context-body {
  display: grid;
  gap: 0.5rem;
  padding: 0.78rem 0.84rem 0.86rem;
}

.artifact-card--context-work .artifact-card__meta {
  font-size: var(--type-size-2xs);
}

.artifact-card--context-work .artifact-card__title {
  display: block;
  font-size: var(--type-size-base);
  line-height: 1.16;
}

.artifact-card--context-work .artifact-card__footer {
  font-size: var(--type-size-2xs);
}

.artifact-card--context-essay {
  width: clamp(17rem, 20vw, 22rem);
  background: var(--atlas-paper-deep);
  box-shadow: 0 0.75rem 1.7rem rgba(9, 7, 8, 0.14);
}

.artifact-card--context-essay .artifact-card__title {
  font-size: var(--type-size-lg);
}

.artifact-card--context-essay .artifact-card__excerpt {
  font-size: var(--type-size-sm);
  line-height: 1.42;
}

.artifact-card--group {
  width: 15rem;
  background: var(--atlas-paper-deep);
}

.artifact-card--person {
  width: 11.5rem;
  background: var(--atlas-paper);
}

.artifact-card--person .artifact-card__title {
  font-size: var(--type-size-base);
}

.artifact-card--work-teaser {
  width: clamp(13.5rem, 14vw, 17rem);
  gap: 0;
  padding: 0;
  background: transparent;
  box-shadow: 0 0.75rem 1.8rem rgba(9, 7, 8, 0.16);
}

.artifact-card--work-teaser .artifact-card__work-image {
  display: block;
  width: 100%;
  aspect-ratio: 1;
  overflow: hidden;
  background: transparent;
}

.artifact-card--work-teaser .artifact-card__work-image img {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
  filter: saturate(0.92) contrast(1.04);
}

.artifact-card--plum {
  background: var(--atlas-plum);
  color: var(--atlas-paper);
}

.artifact-card--plum .artifact-card__meta,
.artifact-card--plum .artifact-card__footer {
  color: rgba(245, 240, 235, 0.6);
}

.artifact-card--plum .artifact-card__excerpt {
  color: rgba(245, 240, 235, 0.8);
}

.artifact-card--secondary-nav {
  background: var(--atlas-terracotta);
  color: var(--atlas-paper);
  border-color: rgba(255, 255, 255, 0.16);
}

.artifact-card--secondary-nav .artifact-card__meta,
.artifact-card--secondary-nav .artifact-card__footer {
  color: rgba(245, 240, 235, 0.72);
}

.artifact-card--secondary-nav .artifact-card__excerpt {
  color: rgba(245, 240, 235, 0.9);
}

.artifact-card--tertiary-nav {
  background: var(--atlas-olive);
  color: var(--atlas-paper);
  border-color: rgba(255, 255, 255, 0.16);
}

.artifact-card--tertiary-nav .artifact-card__meta,
.artifact-card--tertiary-nav .artifact-card__footer {
  color: rgba(245, 240, 235, 0.72);
}

.artifact-card--tertiary-nav .artifact-card__excerpt {
  color: rgba(245, 240, 235, 0.88);
}

.artifact-card--quaternary-nav {
  background: var(--atlas-red);
  color: var(--atlas-paper);
  border-color: rgba(255, 255, 255, 0.16);
}

.artifact-card--quaternary-nav .artifact-card__meta,
.artifact-card--quaternary-nav .artifact-card__footer {
  color: rgba(245, 240, 235, 0.72);
}

.artifact-card--quaternary-nav .artifact-card__excerpt {
  color: rgba(245, 240, 235, 0.9);
}

.artifact-card--olive .artifact-card__title-mark,
.artifact-card--olive .artifact-card__meta strong {
  color: var(--atlas-olive);
}

.artifact-card--terracotta .artifact-card__title-mark,
.artifact-card--terracotta .artifact-card__meta strong {
  color: var(--atlas-terracotta);
}

.stage-controls {
  position: absolute;
  bottom: 1.25rem;
  left: 1.25rem;
  z-index: 7;
  display: flex;
  align-items: center;
  gap: 0.25rem;
  padding: 0.35rem;
  background: rgba(23, 19, 19, 0.72);
  border: 1px solid rgba(245, 240, 235, 0.12);
  backdrop-filter: blur(6px);
}

.stage-controls__button {
  width: 1.95rem;
  height: 1.95rem;
  display: grid;
  place-items: center;
  font-size: var(--type-size-base);
  color: var(--atlas-paper);
  transition: background var(--transition-smooth), border-color var(--transition-smooth);
}

.stage-controls__button:hover,
.stage-controls__button:focus-visible {
  background: rgba(245, 240, 235, 0.08);
  outline: none;
}

.stage-controls__readout {
  min-width: 3.2rem;
  font-family: var(--mono-font);
  font-size: var(--type-size-xs);
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: rgba(245, 240, 235, 0.68);
  text-align: center;
}

.floating-panel {
  position: absolute;
  z-index: 7;
  max-width: 18rem;
  padding: 1rem 1.05rem 1.1rem;
  background: rgba(23, 19, 19, 0.8);
  border: 1px solid rgba(245, 240, 235, 0.08);
  color: var(--atlas-paper);
  box-shadow: 0 1rem 2rem rgba(0, 0, 0, 0.26);
  backdrop-filter: blur(8px);
}

.help-panel {
  right: calc(var(--rail-track-width) + var(--rail-floating-inset) + 1.25rem);
  bottom: 4.35rem;
}

.floating-panel__eyebrow {
  margin: 0 0 0.45rem;
  font-family: var(--mono-font);
  font-size: var(--type-size-xs);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: rgba(245, 240, 235, 0.56);
}

.floating-panel h2 {
  margin: 0 0 0.65rem;
  font-size: var(--type-size-base);
  line-height: 1.15;
}

.floating-panel p {
  margin: 0;
  font-size: var(--type-size-sm);
  line-height: 1.5;
  color: rgba(245, 240, 235, 0.78);
}

.floating-panel p + p {
  margin-top: 0.6rem;
}

.visual-stage.is-maps-mode .visual-stage__viewport,
.visual-stage.is-maps-mode .stage-controls,
.visual-stage.is-maps-mode .help-panel,
.visual-stage.is-maps-mode .visual-stage__coords {
  opacity: 0;
  pointer-events: none;
}

.visual-stage.is-maps-mode .visual-stage__viewport {
  filter: saturate(0.72);
}

.maps-stage {
  position: absolute;
  top: 1rem;
  left: 1rem;
  right: calc(var(--rail-track-width) + (var(--rail-floating-inset) * 2));
  bottom: 1rem;
  z-index: 8;
}

.site-shell.is-maps-rail-collapsed .maps-stage {
  right: calc(var(--rail-collapse-peek) + var(--rail-floating-inset));
}

.site-shell.is-maps-mode .maps-stage {
  right: calc(var(--rail-collapse-peek) + var(--rail-floating-inset));
}

.maps-stage__shell {
  position: relative;
  isolation: isolate;
  height: 100%;
  display: grid;
  grid-template-rows: auto minmax(0, 1fr);
  gap: 1rem;
  padding: 1rem;
  background:
    linear-gradient(rgba(245, 240, 235, 0.05) 1px, transparent 1px),
    linear-gradient(90deg, rgba(245, 240, 235, 0.05) 1px, transparent 1px),
    radial-gradient(circle at 16% 18%, rgba(195, 110, 98, 0.17), transparent 0 20rem),
    radial-gradient(circle at 84% 20%, rgba(126, 126, 85, 0.13), transparent 0 19rem),
    linear-gradient(180deg, rgba(104, 76, 98, 0.98) 0%, rgba(82, 58, 75, 0.985) 42%, rgba(43, 31, 39, 0.995) 100%);
  background-size: 4.4rem 4.4rem, 4.4rem 4.4rem, auto, auto, auto;
  border: 1px solid rgba(245, 240, 235, 0.12);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.05),
    0 30px 80px rgba(9, 7, 8, 0.3);
  overflow: hidden;
}

.maps-stage__shell::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 0;
  background:
    radial-gradient(circle at 20% 28%, rgba(245, 240, 235, 0.06), transparent 0 18rem),
    radial-gradient(circle at 58% 58%, rgba(195, 110, 98, 0.12), transparent 0 24rem),
    radial-gradient(circle at 86% 24%, rgba(126, 126, 85, 0.12), transparent 0 16rem);
  pointer-events: none;
}

.maps-stage__shell > * {
  position: relative;
  z-index: 1;
}

.maps-stage__header {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 1rem 1.5rem;
  align-items: end;
  padding-bottom: 0.95rem;
  border-bottom: 1px solid rgba(245, 240, 235, 0.1);
}

.maps-stage__copy {
  display: grid;
  gap: 0.45rem;
  min-width: 0;
}

.maps-stage__eyebrow,
.mobility-lab__eyebrow,
.mobility-chart__eyebrow,
.maps-embed-card__kicker,
.mobility-notes__label,
.mobility-lab__status-eyebrow,
.rail-maps-tool__kind {
  margin: 0;
  font-family: var(--mono-font);
  font-size: var(--type-size-xs);
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

.maps-stage__eyebrow {
  color: rgba(245, 240, 235, 0.54);
}

.maps-stage__title,
.mobility-lab__title,
.maps-embed-card__title {
  margin: 0;
  font-family: var(--body-font);
  font-size: var(--type-size-2xl);
  line-height: 1;
  letter-spacing: var(--type-tracking-none);
  color: var(--atlas-paper);
}

.maps-stage__summary,
.mobility-lab__summary,
.maps-embed-card__copy,
.mobility-notes__body,
.mobility-lab__status-copy {
  margin: 0;
  font-size: var(--type-size-md);
  line-height: 1.5;
}

.maps-stage__summary {
  max-width: 38rem;
  color: rgba(245, 240, 235, 0.78);
}

.maps-stage__topbar {
  display: grid;
  gap: 0.7rem;
  justify-items: end;
}

.maps-stage__tabs {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 0.5rem;
}

.maps-stage__tab,
.maps-stage__open,
.mobility-lab__retry {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 2.3rem;
  padding: 0 0.9rem;
  border: 1px solid rgba(245, 240, 235, 0.16);
  background: rgba(245, 240, 235, 0.04);
  color: var(--atlas-paper);
  transition:
    background var(--transition-smooth),
    border-color var(--transition-smooth),
    transform var(--transition-smooth);
}

.maps-stage__tab span,
.maps-stage__open,
.mobility-lab__retry {
  font-size: var(--type-size-sm);
  font-weight: 600;
  letter-spacing: 0.02em;
}

.maps-stage__tab:hover,
.maps-stage__tab:focus-visible,
.maps-stage__open:hover,
.maps-stage__open:focus-visible,
.mobility-lab__retry:hover,
.mobility-lab__retry:focus-visible {
  background: rgba(245, 240, 235, 0.1);
  border-color: rgba(245, 240, 235, 0.34);
  outline: none;
  transform: translateY(-1px);
}

.maps-stage__tab.is-active {
  background: linear-gradient(180deg, rgba(195, 110, 98, 0.22), rgba(98, 69, 91, 0.2));
  border-color: rgba(195, 110, 98, 0.48);
  box-shadow: inset 0 -2px 0 rgba(245, 240, 235, 0.14);
}

.maps-stage__open {
  background:
    linear-gradient(rgba(243, 238, 231, 0.96), rgba(235, 226, 216, 0.92)),
    url("./assets/paper-texture.png");
  background-size: cover;
  color: var(--atlas-plum-deep);
  border-color: rgba(245, 240, 235, 0.28);
}

.maps-stage__body {
  min-height: 0;
}

.maps-workspace--embed {
  height: 100%;
  min-height: 0;
}

.maps-embed-card,
.mobility-chart,
.mobility-notes__card,
.mobility-lab__control select,
.mobility-lab__status {
  background:
    linear-gradient(rgba(243, 238, 231, 0.96), rgba(235, 226, 216, 0.93)),
    url("./assets/paper-texture.png");
  background-size: cover;
  color: var(--atlas-ink);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.52),
    0 18px 40px rgba(21, 14, 18, 0.12);
}

.maps-embed-card {
  display: grid;
  gap: 0.85rem;
  align-content: start;
  padding: 1rem;
  border: 1px solid rgba(98, 69, 91, 0.18);
}

.maps-embed-card__kicker {
  color: rgba(23, 19, 19, 0.52);
}

.maps-embed-card__title {
  color: var(--atlas-ink);
}

.maps-embed-card__copy {
  color: rgba(23, 19, 19, 0.72);
}

.maps-embed-card__highlights {
  display: grid;
  gap: 0.75rem;
}

.maps-embed-card__highlight {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 0.7rem;
  align-items: start;
}

.maps-embed-card__highlight-index {
  font-family: var(--mono-font);
  font-size: var(--type-size-xs);
  color: rgba(98, 69, 91, 0.7);
}

.maps-embed-card__highlight p {
  margin: 0;
  font-size: var(--type-size-md);
  line-height: 1.45;
  color: rgba(23, 19, 19, 0.76);
}

.maps-embed-frame {
  position: relative;
  height: 100%;
  min-height: 0;
  border: 1px solid rgba(245, 240, 235, 0.16);
  background:
    radial-gradient(circle at 16% 18%, rgba(195, 110, 98, 0.12), transparent 0 18rem),
    radial-gradient(circle at 84% 20%, rgba(126, 126, 85, 0.12), transparent 0 18rem),
    linear-gradient(180deg, rgba(104, 76, 98, 0.94), rgba(59, 41, 52, 0.98));
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.08),
    0 24px 52px rgba(9, 7, 8, 0.18);
  overflow: hidden;
}

.maps-embed-frame--immersive::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 1;
  background:
    linear-gradient(180deg, rgba(55, 38, 49, 0.2) 0%, transparent 24%, transparent 76%, rgba(55, 38, 49, 0.28) 100%),
    radial-gradient(circle at 12% 78%, rgba(23, 19, 19, 0.22), transparent 0 18rem);
  pointer-events: none;
}

.maps-embed-frame iframe {
  position: relative;
  z-index: 0;
  width: 100%;
  height: 100%;
  border: 0;
  display: block;
  background: transparent;
}

.maps-embed-overlay {
  position: absolute;
  left: 1rem;
  bottom: 1rem;
  z-index: 2;
  width: min(22rem, calc(100% - 2rem));
  display: grid;
  gap: 0.7rem;
  pointer-events: none;
}

.maps-embed-overlay__intro,
.maps-embed-overlay__logic {
  background:
    linear-gradient(rgba(243, 238, 231, 0.95), rgba(235, 226, 216, 0.92)),
    url("./assets/paper-texture.png");
  background-size: cover;
  border: 1px solid rgba(98, 69, 91, 0.18);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.52),
    0 18px 40px rgba(21, 14, 18, 0.16);
  color: var(--atlas-ink);
}

.maps-embed-overlay__intro {
  display: grid;
  gap: 0.45rem;
  padding: 0.9rem 0.95rem;
}

.maps-embed-overlay__logic {
  display: grid;
  gap: 0.55rem;
  padding: 0.85rem 0.95rem;
}

.maps-embed-overlay__item {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 0.6rem;
  align-items: start;
}

.maps-embed-overlay__item p {
  margin: 0;
  font-size: var(--type-size-sm);
  line-height: 1.42;
  color: rgba(23, 19, 19, 0.78);
}

.mobility-lab {
  height: 100%;
  display: grid;
  grid-template-rows: auto auto minmax(0, 1fr);
  gap: 1rem;
}

.mobility-lab__mast {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 1rem;
  align-items: start;
}

.mobility-lab__intro {
  display: grid;
  gap: 0.45rem;
}

.mobility-lab__summary {
  max-width: 36rem;
  color: rgba(245, 240, 235, 0.72);
}

.mobility-lab__eyebrow,
.mobility-chart__eyebrow,
.mobility-notes__label,
.mobility-lab__status-eyebrow {
  color: rgba(77, 55, 71, 0.62);
}

.mobility-lab__stats {
  display: flex;
  gap: 0.7rem;
  flex-wrap: wrap;
}

.mobility-lab__stat {
  min-width: 5.2rem;
  padding: 0.8rem 0.9rem;
  border: 1px solid rgba(98, 69, 91, 0.16);
  background:
    linear-gradient(rgba(243, 238, 231, 0.96), rgba(235, 226, 216, 0.92)),
    url("./assets/paper-texture.png");
  background-size: cover;
  color: var(--atlas-plum-deep);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.46);
}

.mobility-lab__stat-value {
  display: block;
  font-family: var(--display-font);
  font-size: var(--type-size-2xl);
  font-weight: 700;
  line-height: 1;
}

.mobility-lab__stat-label {
  display: block;
  margin-top: 0.35rem;
  font-size: var(--type-size-xs);
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: rgba(77, 55, 71, 0.62);
}

.mobility-lab__controls {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 0.9rem;
}

.mobility-lab__control {
  display: grid;
  gap: 0.42rem;
}

.mobility-lab__control span {
  font-size: var(--type-size-xs);
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: rgba(245, 240, 235, 0.58);
}

.mobility-lab__control select {
  width: 100%;
  min-height: 3rem;
  padding: 0 0.9rem;
  border: 1px solid rgba(23, 19, 19, 0.1);
  border-radius: 0;
  appearance: none;
  font-size: var(--type-size-md);
  color: var(--atlas-ink);
}

.mobility-lab__control select:disabled {
  color: rgba(23, 19, 19, 0.4);
  background: rgba(248, 244, 239, 0.74);
}

.mobility-lab__control select:focus-visible {
  outline: 2px solid rgba(195, 110, 98, 0.4);
  outline-offset: 2px;
}

.mobility-lab__workspace {
  min-height: 0;
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(15rem, 19rem);
  gap: 1rem;
}

.mobility-chart {
  min-height: 0;
  display: grid;
  grid-template-rows: auto auto auto minmax(0, 1fr);
  gap: 0.9rem;
  padding: 1.1rem;
  border: 1px solid rgba(98, 69, 91, 0.16);
}

.mobility-chart__insight {
  display: grid;
  gap: 0.45rem;
  padding: 0.95rem 1rem;
  border: 1px solid rgba(98, 69, 91, 0.14);
  background: rgba(98, 69, 91, 0.07);
}

.mobility-chart__insight p {
  margin: 0;
}

.mobility-chart__insight p:last-child {
  max-width: 54rem;
  font-family: var(--display-font);
  font-size: clamp(var(--type-size-xl), 2.2vw, var(--type-size-3xl));
  font-weight: 700;
  line-height: 1.08;
  letter-spacing: var(--type-tracking-none);
  color: rgba(23, 19, 19, 0.94);
}

.mobility-chart__header {
  display: flex;
  justify-content: space-between;
  gap: 1rem;
  align-items: end;
}

.mobility-chart__title {
  margin: 0.2rem 0 0;
  font-size: var(--type-size-xl);
  line-height: 1.08;
  letter-spacing: var(--type-tracking-none);
}

.mobility-chart__scope {
  margin: 0;
  font-size: var(--type-size-md);
  color: rgba(77, 55, 71, 0.58);
}

.mobility-chart__axis {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 0.35rem;
  font-family: var(--mono-font);
  font-size: var(--type-size-xs);
  color: rgba(23, 19, 19, 0.42);
}

.mobility-chart__axis span:last-child {
  text-align: right;
}

.mobility-chart__rows {
  display: grid;
  gap: 0.78rem;
  min-height: 0;
  overflow: auto;
  padding-right: 0.2rem;
}

.mobility-chart__row {
  display: grid;
  grid-template-columns: minmax(11rem, 14rem) minmax(0, 1fr);
  gap: 0.85rem;
  align-items: center;
}

.mobility-chart__row.is-muted .mobility-chart__category,
.mobility-chart__row.is-muted .mobility-chart__count,
.mobility-chart__row.is-muted .mobility-chart__value {
  color: rgba(23, 19, 19, 0.44);
}

.mobility-chart__label-group {
  display: grid;
  gap: 0.18rem;
}

.mobility-chart__category {
  font-size: var(--type-size-md);
  font-weight: 600;
  line-height: 1.3;
}

.mobility-chart__count {
  font-size: var(--type-size-sm);
  color: rgba(23, 19, 19, 0.54);
}

.mobility-chart__track {
  position: relative;
  display: flex;
  align-items: center;
  min-height: 2.1rem;
  padding-right: 0.75rem;
  border: 1px solid rgba(98, 69, 91, 0.1);
  background:
    linear-gradient(to right, rgba(98, 69, 91, 0.06) 1px, transparent 1px),
    linear-gradient(180deg, rgba(255, 255, 255, 0.34), rgba(23, 19, 19, 0.02));
  background-size: 25% 100%, auto;
  overflow: hidden;
}

.mobility-chart__fill {
  position: absolute;
  inset: 0 auto 0 0;
  display: block;
  background: linear-gradient(90deg, rgba(98, 69, 91, 0.94), rgba(195, 110, 98, 0.88) 64%, rgba(126, 126, 85, 0.8));
}

.mobility-chart__value {
  position: relative;
  z-index: 1;
  margin-left: auto;
  font-family: var(--mono-font);
  font-size: var(--type-size-xs);
  color: rgba(23, 19, 19, 0.72);
}

.mobility-notes {
  display: grid;
  gap: 0.85rem;
  align-content: start;
}

.mobility-notes__card {
  display: grid;
  gap: 0.45rem;
  padding: 1rem;
  border: 1px solid rgba(98, 69, 91, 0.14);
}

.mobility-notes__card--accent {
  background:
    linear-gradient(rgba(231, 228, 214, 0.98), rgba(221, 218, 204, 0.94)),
    url("./assets/paper-texture.png");
  background-size: cover;
  border-color: rgba(126, 126, 85, 0.24);
}

.mobility-notes__headline {
  margin: 0;
  font-size: var(--type-size-base);
  line-height: 1.2;
  font-weight: 700;
  color: rgba(23, 19, 19, 0.94);
}

.mobility-notes__body strong {
  color: rgba(23, 19, 19, 0.92);
}

.mobility-notes__sources {
  gap: 0.75rem;
}

.mobility-notes__sources summary {
  cursor: pointer;
  font-weight: 700;
  color: var(--atlas-plum-deep);
}

.mobility-notes__sources summary:focus-visible {
  outline: 2px solid rgba(195, 110, 98, 0.4);
  outline-offset: 0.25rem;
}

.mobility-notes__links,
.rail-maps-documents {
  display: grid;
  gap: 0.5rem;
}

.mobility-notes__link,
.rail-maps-document {
  font-size: var(--type-size-md);
  line-height: 1.4;
  text-decoration: underline;
  text-decoration-thickness: 1px;
  text-underline-offset: 0.18em;
  color: var(--atlas-plum-deep);
}

.mobility-lab--status {
  height: 100%;
  display: grid;
  place-content: center;
  justify-items: start;
  gap: 0.7rem;
  padding: 1.4rem;
  border: 1px solid rgba(98, 69, 91, 0.14);
}

.mobility-lab__retry {
  padding-inline: 1rem;
  border-color: rgba(98, 69, 91, 0.16);
  background:
    linear-gradient(180deg, rgba(98, 69, 91, 0.96), rgba(77, 55, 71, 0.98));
  color: var(--atlas-paper);
}

.rail-maps-tool-grid {
  display: grid;
  gap: 0.7rem;
}

.rail-maps-tool {
  display: grid;
  gap: 0.3rem;
  width: 100%;
  padding: 1rem;
  text-align: left;
  border: 1px solid rgba(98, 69, 91, 0.14);
  background:
    linear-gradient(rgba(255, 252, 248, 0.9), rgba(243, 238, 231, 0.86)),
    url("./assets/paper-texture.png");
  background-size: cover;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.44);
  transition:
    border-color var(--transition-smooth),
    background var(--transition-smooth),
    transform var(--transition-smooth);
}

.rail-maps-tool:hover,
.rail-maps-tool:focus-visible {
  background: rgba(255, 255, 255, 0.96);
  border-color: rgba(170, 91, 80, 0.22);
  outline: none;
  transform: translateY(-1px);
}

.rail-maps-tool.is-active {
  background:
    linear-gradient(rgba(244, 229, 226, 0.96), rgba(240, 228, 223, 0.92)),
    url("./assets/paper-texture.png");
  background-size: cover;
  border-color: rgba(170, 91, 80, 0.3);
}

.rail-maps-tool__kind {
  color: rgba(23, 19, 19, 0.46);
}

.rail-maps-tool__title {
  font-size: var(--type-size-base);
  font-weight: 700;
  color: rgba(23, 19, 19, 0.92);
}

.rail-maps-tool__copy {
  font-size: var(--type-size-sm);
  line-height: 1.5;
  color: rgba(23, 19, 19, 0.68);
}

.rail-inline-workspace {
  display: grid;
  gap: 1rem;
  padding: 1rem;
  background:
    linear-gradient(rgba(103, 75, 96, 0.98) 0%, rgba(81, 58, 74, 0.985) 42%, rgba(43, 31, 39, 0.995) 100%);
  border: 1px solid rgba(98, 69, 91, 0.2);
  box-shadow: 0 24px 48px rgba(21, 14, 18, 0.12);
}

.rail-inline-workspace__header {
  display: grid;
  gap: 0.9rem;
}

.rail-inline-workspace__copy {
  display: grid;
  gap: 0.45rem;
}

.rail-inline-workspace__eyebrow {
  margin: 0;
  font-family: var(--mono-font);
  font-size: var(--type-size-xs);
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: rgba(245, 240, 235, 0.56);
}

.rail-inline-workspace__title {
  margin: 0;
  font-size: var(--type-size-xl);
  line-height: 1;
  letter-spacing: var(--type-tracking-none);
  color: var(--atlas-paper);
}

.rail-inline-workspace__summary {
  margin: 0;
  max-width: 36rem;
  font-size: var(--type-size-md);
  line-height: 1.5;
  color: rgba(245, 240, 235, 0.76);
}

.rail-inline-workspace__open {
  justify-self: start;
}

.rail-inline-workspace__body {
  display: grid;
  gap: 1rem;
}

.rail-inline-workspace__body .maps-workspace--embed {
  height: auto;
}

.rail-inline-workspace__body .maps-embed-frame {
  height: clamp(24rem, 70vh, 42rem);
}

.rail-inline-workspace__body .mobility-lab {
  min-height: auto;
}

.rail-linear-nav {
  display: grid;
  gap: 0.9rem;
  margin: 0 var(--rail-shell-padding) var(--rail-content-padding-bottom);
  padding: 1rem;
  border-top: 1px solid rgba(23, 19, 19, 0.12);
  border-bottom: 1px solid rgba(23, 19, 19, 0.08);
  background:
    linear-gradient(rgba(255, 252, 248, 0.92), rgba(243, 238, 231, 0.86)),
    url("./assets/paper-texture.png");
  background-size: cover;
}

.rail-linear-nav__meta {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 0.75rem;
}

.rail-linear-nav__eyebrow,
.rail-linear-nav__status,
.rail-linear-nav__label {
  margin: 0;
  font-family: var(--mono-font);
  font-size: var(--type-size-xs);
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

.rail-linear-nav__eyebrow,
.rail-linear-nav__label {
  color: rgba(23, 19, 19, 0.48);
}

.rail-linear-nav__status {
  color: rgba(23, 19, 19, 0.7);
}

.rail-linear-nav__actions {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.7rem;
}

.rail-linear-nav--return .rail-linear-nav__actions {
  grid-template-columns: minmax(0, 1fr);
}

.rail-linear-nav__link {
  display: grid;
  gap: 0.32rem;
  width: 100%;
  min-height: 4.8rem;
  padding: 0.95rem 1rem;
  text-align: left;
  border: 1px solid rgba(23, 19, 19, 0.12);
  background: rgba(255, 255, 255, 0.46);
  color: var(--atlas-ink);
  transition:
    background var(--transition-smooth),
    border-color var(--transition-smooth),
    transform var(--transition-smooth);
}

.rail-linear-nav__link .rail-linear-nav__label {
  color: rgba(23, 19, 19, 0.48);
}

.rail-linear-nav__link:hover,
.rail-linear-nav__link:focus-visible {
  border-color: rgba(170, 91, 80, 0.26);
  background: rgba(255, 255, 255, 0.82);
  outline: none;
  transform: translateY(-1px);
}

.rail-linear-nav__link--disabled {
  opacity: 0.46;
  cursor: default;
  pointer-events: none;
}

.rail-linear-nav__title {
  font-size: var(--type-size-base);
  line-height: 1.15;
  letter-spacing: var(--type-tracking-none);
  color: var(--atlas-ink);
}

.content-panel {
  --rail-surface-color: var(--atlas-paper);
  --rail-surface-hover-color: var(--atlas-paper-deep);
  --rail-surface-border: rgba(23, 19, 19, 0.1);
  --rail-surface-shadow: 0 24px 60px rgba(9, 7, 8, 0.2);
  --rail-surface-texture-opacity: 0.24;
  --rail-surface-text: var(--atlas-ink);
  --rail-surface-muted: rgba(23, 19, 19, 0.72);
  --rail-surface-soft: rgba(23, 19, 19, 0.48);
  --rail-surface-divider: rgba(23, 19, 19, 0.16);
  --rail-surface-ui-hover: rgba(23, 19, 19, 0.05);
  --rail-current-accent: var(--atlas-terracotta);
  --rail-current-accent-deep: var(--atlas-terracotta-deep);
  --rail-current-rotate: 0deg;
  --rail-stack-transition: 460ms cubic-bezier(0.22, 1, 0.36, 1);
  position: absolute;
  top: var(--rail-floating-inset);
  right: var(--rail-floating-inset);
  bottom: var(--rail-floating-inset);
  width: var(--rail-track-width);
  z-index: 3;
  background: transparent;
  color: var(--atlas-ink);
  overflow: visible;
  isolation: isolate;
  transition:
    transform var(--rail-stack-transition),
    box-shadow var(--rail-stack-transition);
}

.content-panel__stack {
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: auto;
}

.content-panel__sheet {
  --rail-sheet-color: var(--atlas-paper);
  --rail-sheet-border: rgba(23, 19, 19, 0.08);
  --rail-sheet-texture-opacity: 0.18;
  --rail-sheet-text: rgba(23, 19, 19, 0.8);
  --rail-sheet-soft: rgba(23, 19, 19, 0.46);
  --rail-sheet-divider: rgba(23, 19, 19, 0.18);
  --rail-sheet-offset-x: -0.18rem;
  --rail-sheet-offset-y: 0.14rem;
  --rail-sheet-rotate: 0deg;
  --rail-sheet-scale: 1;
  --rail-sheet-hover-x: 0rem;
  --rail-sheet-hover-y: 0rem;
  --rail-sheet-hover-rotate: 0deg;
  --rail-sheet-hover-scale: 0;
  --rail-sheet-random-rotate: 0deg;
  position: absolute;
  inset: 0.48rem 0.32rem 0.24rem 0.42rem;
  z-index: 0;
  display: block;
  width: auto;
  padding: 0;
  text-align: left;
  cursor: default;
  background-color: var(--rail-sheet-color);
  border: 1px solid var(--rail-sheet-border);
  box-shadow: 0 14px 28px rgba(9, 7, 8, 0.14);
  opacity: 0;
  overflow: hidden;
  pointer-events: none;
  transform: translate3d(
      calc(var(--rail-sheet-offset-x) + var(--rail-sheet-hover-x)),
      calc(var(--rail-sheet-offset-y) + var(--rail-sheet-hover-y)),
      0
    )
    rotate(calc(var(--rail-sheet-rotate) + var(--rail-sheet-hover-rotate)))
    scale(calc(var(--rail-sheet-scale) + var(--rail-sheet-hover-scale)));
  transform-origin: center top;
  backface-visibility: hidden;
  isolation: isolate;
  will-change: transform, opacity;
  transition:
    opacity var(--rail-stack-transition),
    transform var(--rail-stack-transition),
    border-color var(--rail-stack-transition),
    box-shadow var(--rail-stack-transition);
}

.content-panel__sheet[data-clickable="true"] {
  cursor: pointer;
}

.content-panel__sheet[data-clickable="true"]:hover,
.content-panel__sheet[data-clickable="true"]:focus-visible {
  --rail-sheet-hover-x: 0.14rem;
  --rail-sheet-hover-y: -0.08rem;
  --rail-sheet-hover-rotate: 0.2deg;
  --rail-sheet-hover-scale: 0.008;
  outline: none;
}

.content-panel__sheet::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 2;
  background-image: var(--atlas-paper-texture-overlay);
  background-position: center;
  background-repeat: no-repeat;
  background-size: cover;
  opacity: var(--rail-sheet-texture-opacity);
  filter: none;
  mix-blend-mode: normal;
  pointer-events: none;
}

.content-panel__sheet-copy {
  position: absolute;
  inset: 0;
  z-index: 1;
}

.content-panel__sheet-side {
  position: absolute;
  top: 1rem;
  left: 0.68rem;
  display: block;
  max-height: calc(100% - 2rem);
  font-family: var(--mono-font);
  font-size: var(--type-size-2xs);
  letter-spacing: 0.18em;
  text-transform: uppercase;
  writing-mode: vertical-rl;
  transform: rotate(180deg);
  color: var(--rail-sheet-soft);
}

.content-panel__sheet-side--right {
  top: 0.92rem;
  right: 0.64rem;
  left: auto;
  max-height: calc(100% - 1.84rem);
  font-size: var(--type-size-2xs);
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: none;
  transform: none;
}

.content-panel__sheet-lines {
  position: absolute;
  top: 1rem;
  right: 0.95rem;
  width: clamp(4.4rem, 38%, 8.4rem);
  display: grid;
  gap: 0.34rem;
}

.content-panel__sheet-lines span {
  display: block;
  height: 1px;
  background-color: var(--rail-sheet-divider);
}

.content-panel__sheet-lines span:nth-child(1) {
  width: 100%;
}

.content-panel__sheet-lines span:nth-child(2) {
  width: 82%;
}

.content-panel__sheet-lines span:nth-child(3) {
  width: 64%;
}

.content-panel__sheet-footer {
  position: absolute;
  left: 1rem;
  right: 1.1rem;
  bottom: 1rem;
  display: grid;
  gap: 0.28rem;
}

.content-panel__sheet-title,
.content-panel__sheet-meta {
  margin: 0;
}

.content-panel__sheet-title {
  max-width: min(12rem, 64%);
  font-family: var(--body-font);
  font-size: var(--type-size-base);
  font-weight: 700;
  line-height: 0.98;
  letter-spacing: var(--type-tracking-none);
  color: var(--rail-sheet-text);
}

.content-panel__sheet-meta {
  font-family: var(--mono-font);
  font-size: var(--type-size-2xs);
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--rail-sheet-soft);
}

.content-panel__sheet[data-active="true"] {
  opacity: 1;
  pointer-events: auto;
}

.content-panel__sheet[data-stack-sheet="0"][data-active="true"] {
  inset: 0.54rem 0.34rem 0.3rem 0.5rem;
  z-index: 5;
  --rail-sheet-offset-x: -0.72rem;
  --rail-sheet-offset-y: 0.34rem;
  --rail-sheet-rotate: var(--rail-sheet-random-rotate, 0.92deg);
  --rail-sheet-scale: 0.988;
  box-shadow: 0 18px 34px rgba(9, 7, 8, 0.16);
}

.content-panel__sheet[data-stack-sheet="1"][data-active="true"] {
  inset: 0.66rem 0.42rem 0.38rem 0.26rem;
  z-index: 4;
  --rail-sheet-offset-x: -1.22rem;
  --rail-sheet-offset-y: 0.78rem;
  --rail-sheet-rotate: var(--rail-sheet-random-rotate, -0.78deg);
  --rail-sheet-scale: 0.968;
  box-shadow: 0 16px 30px rgba(9, 7, 8, 0.15);
}

.content-panel__sheet[data-stack-sheet="2"][data-active="true"] {
  inset: 0.78rem 0.5rem 0.46rem 0.1rem;
  z-index: 3;
  --rail-sheet-offset-x: -1.74rem;
  --rail-sheet-offset-y: 1.14rem;
  --rail-sheet-rotate: var(--rail-sheet-random-rotate, 1.34deg);
  --rail-sheet-scale: 0.952;
  box-shadow: 0 15px 28px rgba(9, 7, 8, 0.14);
}

.content-panel__sheet[data-stack-sheet="3"][data-active="true"] {
  inset: 0.88rem 0.62rem 0.58rem -0.02rem;
  z-index: 2;
  --rail-sheet-offset-x: -2.18rem;
  --rail-sheet-offset-y: 1.42rem;
  --rail-sheet-rotate: var(--rail-sheet-random-rotate, -1.08deg);
  --rail-sheet-scale: 0.936;
  box-shadow: 0 14px 26px rgba(9, 7, 8, 0.13);
}

.content-panel__sheet[data-stack-sheet="4"][data-active="true"] {
  inset: 1rem 0.72rem 0.7rem -0.12rem;
  z-index: 1;
  --rail-sheet-offset-x: -2.52rem;
  --rail-sheet-offset-y: 1.72rem;
  --rail-sheet-rotate: var(--rail-sheet-random-rotate, 1.52deg);
  --rail-sheet-scale: 0.922;
  box-shadow: 0 13px 24px rgba(9, 7, 8, 0.12);
}

.content-panel[data-stack-state="home"] .content-panel__sheet {
  opacity: 0;
  pointer-events: none;
  --rail-sheet-offset-x: -0.18rem;
  --rail-sheet-offset-y: 0.14rem;
  --rail-sheet-rotate: 0deg;
  --rail-sheet-scale: 1;
}

.content-panel__sheet--ghost {
  pointer-events: none;
  z-index: 12;
}

.content-panel[data-surface="paper"] {
  --rail-surface-color: var(--atlas-paper);
  --rail-surface-hover-color: var(--atlas-paper-deep);
  --rail-surface-border: rgba(23, 19, 19, 0.1);
  --rail-surface-texture-opacity: 0.2;
  --rail-surface-text: var(--atlas-ink);
  --rail-surface-muted: rgba(23, 19, 19, 0.72);
  --rail-surface-soft: rgba(23, 19, 19, 0.48);
  --rail-surface-divider: rgba(23, 19, 19, 0.16);
  --rail-surface-menu-frame: rgba(23, 19, 19, 0.28);
  --rail-surface-ui-hover: rgba(23, 19, 19, 0.05);
}

.content-panel__sheet[data-surface="paper"] {
  --rail-sheet-color: var(--atlas-paper);
  --rail-sheet-border: rgba(23, 19, 19, 0.08);
  --rail-sheet-texture-opacity: 0.16;
  --rail-sheet-text: rgba(23, 19, 19, 0.78);
  --rail-sheet-soft: rgba(23, 19, 19, 0.46);
  --rail-sheet-divider: rgba(23, 19, 19, 0.18);
}

.content-panel[data-surface="terracotta"] {
  --rail-surface-color: var(--atlas-terracotta);
  --rail-surface-hover-color: #b76459;
  --rail-surface-border: rgba(255, 255, 255, 0.18);
  --rail-surface-texture-opacity: 0.26;
  --rail-surface-text: rgba(245, 240, 235, 0.96);
  --rail-surface-muted: rgba(245, 240, 235, 0.76);
  --rail-surface-soft: rgba(245, 240, 235, 0.56);
  --rail-surface-divider: rgba(245, 240, 235, 0.18);
  --rail-surface-menu-frame: rgba(245, 240, 235, 0.42);
  --rail-surface-ui-hover: rgba(245, 240, 235, 0.08);
  --rail-current-accent: var(--atlas-terracotta);
  --rail-current-accent-deep: var(--atlas-terracotta-deep);
}

.content-panel__sheet[data-surface="terracotta"] {
  --rail-sheet-color: var(--atlas-terracotta);
  --rail-sheet-border: rgba(255, 255, 255, 0.16);
  --rail-sheet-texture-opacity: 0.22;
  --rail-sheet-text: rgba(245, 240, 235, 0.74);
  --rail-sheet-soft: rgba(245, 240, 235, 0.48);
  --rail-sheet-divider: rgba(245, 240, 235, 0.18);
}

.content-panel[data-surface="olive"] {
  --rail-surface-color: var(--atlas-olive);
  --rail-surface-hover-color: #6f704c;
  --rail-surface-border: rgba(255, 255, 255, 0.18);
  --rail-surface-texture-opacity: 0.26;
  --rail-surface-text: rgba(245, 240, 235, 0.96);
  --rail-surface-muted: rgba(245, 240, 235, 0.76);
  --rail-surface-soft: rgba(245, 240, 235, 0.56);
  --rail-surface-divider: rgba(245, 240, 235, 0.18);
  --rail-surface-menu-frame: rgba(245, 240, 235, 0.42);
  --rail-surface-ui-hover: rgba(245, 240, 235, 0.08);
  --rail-current-accent: var(--atlas-olive);
  --rail-current-accent-deep: var(--atlas-olive-deep);
}

.content-panel__sheet[data-surface="olive"] {
  --rail-sheet-color: var(--atlas-olive);
  --rail-sheet-border: rgba(255, 255, 255, 0.16);
  --rail-sheet-texture-opacity: 0.22;
  --rail-sheet-text: rgba(245, 240, 235, 0.74);
  --rail-sheet-soft: rgba(245, 240, 235, 0.48);
  --rail-sheet-divider: rgba(245, 240, 235, 0.18);
}

.content-panel[data-surface="plum"] {
  --rail-surface-color: var(--atlas-plum-dark);
  --rail-surface-hover-color: #2f2029;
  --rail-surface-border: rgba(255, 255, 255, 0.16);
  --rail-surface-texture-opacity: 0.28;
  --rail-surface-text: rgba(245, 240, 235, 0.96);
  --rail-surface-muted: rgba(245, 240, 235, 0.76);
  --rail-surface-soft: rgba(245, 240, 235, 0.56);
  --rail-surface-divider: rgba(245, 240, 235, 0.18);
  --rail-surface-menu-frame: rgba(245, 240, 235, 0.42);
  --rail-surface-ui-hover: rgba(245, 240, 235, 0.08);
  --rail-current-accent: var(--atlas-plum);
  --rail-current-accent-deep: var(--atlas-plum-deep);
}

.content-panel__sheet[data-surface="plum"] {
  --rail-sheet-color: var(--atlas-plum-dark);
  --rail-sheet-border: rgba(255, 255, 255, 0.14);
  --rail-sheet-texture-opacity: 0.24;
  --rail-sheet-text: rgba(245, 240, 235, 0.72);
  --rail-sheet-soft: rgba(245, 240, 235, 0.46);
  --rail-sheet-divider: rgba(245, 240, 235, 0.18);
}

.content-panel[data-surface="red"] {
  --rail-surface-color: var(--atlas-red);
  --rail-surface-hover-color: #ac2730;
  --rail-surface-border: rgba(255, 255, 255, 0.16);
  --rail-surface-texture-opacity: 0.28;
  --rail-surface-text: rgba(245, 240, 235, 0.96);
  --rail-surface-muted: rgba(245, 240, 235, 0.76);
  --rail-surface-soft: rgba(245, 240, 235, 0.56);
  --rail-surface-divider: rgba(245, 240, 235, 0.18);
  --rail-surface-menu-frame: rgba(245, 240, 235, 0.42);
  --rail-surface-ui-hover: rgba(245, 240, 235, 0.08);
  --rail-current-accent: var(--atlas-red);
  --rail-current-accent-deep: var(--atlas-red-deep);
}

.content-panel__sheet[data-surface="red"] {
  --rail-sheet-color: var(--atlas-red);
  --rail-sheet-border: rgba(255, 255, 255, 0.14);
  --rail-sheet-texture-opacity: 0.24;
  --rail-sheet-text: rgba(245, 240, 235, 0.72);
  --rail-sheet-soft: rgba(245, 240, 235, 0.46);
  --rail-sheet-divider: rgba(245, 240, 235, 0.18);
}

:where(
  .content-panel[data-surface="terracotta"] .content-panel__inner,
  .content-panel[data-surface="olive"] .content-panel__inner,
  .content-panel[data-surface="plum"] .content-panel__inner,
  .content-panel[data-surface="red"] .content-panel__inner
) :where(h1, h2, h3, h4, h5, p, li, dt, dd, a, button, span, strong, em, small) {
  color: var(--rail-surface-text);
}

:where(
  .content-panel[data-surface="terracotta"] .content-panel__inner,
  .content-panel[data-surface="olive"] .content-panel__inner,
  .content-panel[data-surface="plum"] .content-panel__inner,
  .content-panel[data-surface="red"] .content-panel__inner
) :where(.rail-section-label, .rail-fact dt, .rail-section__head, .rail-link-row__meta, .rail-bullet-item__copy, .rail-menu__label, .rail-menu__item-index, .rail-caption, .rail-contact__label, .rail-contact__meta, .rail-fact__label) {
  color: var(--rail-surface-muted);
}

:where(
  .content-panel[data-surface="terracotta"] .content-panel__inner,
  .content-panel[data-surface="olive"] .content-panel__inner,
  .content-panel[data-surface="plum"] .content-panel__inner,
  .content-panel[data-surface="red"] .content-panel__inner
) :where(.rail-meta-stack--hero, .rail-link-row, .rail-section, .rail-panel-card, .rail-bullet-item, .rail-card, .rail-contact, .rail-facts) {
  border-color: var(--rail-surface-divider);
}

:where(
  .content-panel[data-surface="terracotta"] .content-panel__inner,
  .content-panel[data-surface="olive"] .content-panel__inner,
  .content-panel[data-surface="plum"] .content-panel__inner,
  .content-panel[data-surface="red"] .content-panel__inner
) .rail-about-city-card {
  background: rgba(255, 251, 247, 0.97);
  border-color: rgba(23, 19, 19, 0.14);
  box-shadow: 0 18px 30px rgba(23, 19, 19, 0.08);
}

:where(
  .content-panel[data-surface="terracotta"] .content-panel__inner,
  .content-panel[data-surface="olive"] .content-panel__inner,
  .content-panel[data-surface="plum"] .content-panel__inner,
  .content-panel[data-surface="red"] .content-panel__inner
) .rail-about-city-card__index {
  color: rgba(23, 19, 19, 0.56);
}

:where(
  .content-panel[data-surface="terracotta"] .content-panel__inner,
  .content-panel[data-surface="olive"] .content-panel__inner,
  .content-panel[data-surface="plum"] .content-panel__inner,
  .content-panel[data-surface="red"] .content-panel__inner
) .rail-about-city-card__title {
  color: rgba(23, 19, 19, 0.94);
}

:where(
  .content-panel[data-surface="terracotta"] .content-panel__inner,
  .content-panel[data-surface="olive"] .content-panel__inner,
  .content-panel[data-surface="plum"] .content-panel__inner,
  .content-panel[data-surface="red"] .content-panel__inner
) .rail-about-city-card__copy {
  color: rgba(23, 19, 19, 0.82);
}

.content-panel__collapse {
  position: absolute;
  top: 50%;
  left: 0;
  z-index: 7;
  width: var(--rail-collapse-peek);
  min-height: 8.5rem;
  display: grid;
  justify-items: center;
  align-content: center;
  gap: 0.7rem;
  padding: 0.8rem 0.35rem;
  background-color: var(--rail-surface-color);
  border-right: 1px solid var(--rail-surface-border);
  border-top: 1px solid var(--rail-surface-border);
  border-bottom: 1px solid var(--rail-surface-border);
  color: var(--rail-surface-text);
  box-shadow: 0 0 20px rgba(0, 0, 0, 0.08);
  transform: translateY(-50%);
  transition:
    background-color var(--rail-stack-transition),
    color var(--rail-stack-transition),
    opacity var(--rail-stack-transition);
}

.content-panel__collapse:hover,
.content-panel__collapse:focus-visible {
  background-color: var(--rail-surface-hover-color);
  outline: none;
}

.content-panel__collapse-icon {
  width: 0.72rem;
  height: 0.72rem;
  border-top: 2px solid currentColor;
  border-right: 2px solid currentColor;
  transform: rotate(225deg);
  transition: transform var(--transition-smooth);
}

.content-panel__collapse-label {
  font-family: var(--mono-font);
  font-size: var(--type-size-xs);
  letter-spacing: 0.16em;
  text-transform: uppercase;
  writing-mode: vertical-rl;
  transform: rotate(180deg);
  white-space: nowrap;
}

.content-panel__inner {
  display: flex;
  flex-direction: column;
  min-height: 0;
  position: absolute;
  inset: 0;
  z-index: 1;
  background-color: var(--rail-surface-color);
  border: 1px solid transparent;
  box-shadow: var(--rail-surface-shadow);
  transform-origin: center top;
  overflow: hidden;
  color: var(--rail-surface-text);
  isolation: isolate;
  transition:
    opacity var(--rail-stack-transition),
    inset var(--rail-stack-transition),
    transform var(--rail-stack-transition),
    border-color var(--rail-stack-transition),
    box-shadow var(--rail-stack-transition);
}

.content-panel__inner::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 0;
  background-image: var(--rail-surface-texture-image);
  background-size: var(--rail-surface-texture-size);
  background-position: var(--rail-surface-texture-position);
  background-repeat: var(--rail-surface-texture-repeat);
  opacity: var(--rail-surface-texture-opacity);
  filter: none;
  mix-blend-mode: normal;
  pointer-events: none;
}

.content-panel__inner > * {
  position: relative;
  z-index: 1;
}

.content-panel[data-stack-state="detail"] .content-panel__inner {
  inset: clamp(0.84rem, 1.1vw, 1rem) clamp(0.36rem, 0.72vw, 0.58rem) clamp(0.62rem, 0.96vw, 0.84rem)
    clamp(1.22rem, 1.58vw, 1.42rem);
  border-color: var(--rail-surface-border);
  box-shadow: 0 32px 72px rgba(9, 7, 8, 0.24);
  transform: translate(0, 0.16rem) rotate(var(--rail-current-rotate, 0deg));
}

.content-panel--maps-collapsible.is-collapsed {
  transform: translateX(calc(100% - var(--rail-collapse-peek)));
  box-shadow: 0 18px 40px rgba(9, 7, 8, 0.16);
}

.content-panel--maps-collapsible.is-collapsed .content-panel__inner {
  opacity: 0.01;
  pointer-events: none;
}

.content-panel--maps-collapsible.is-collapsed .content-panel__collapse-icon {
  transform: rotate(45deg);
}

@media (min-width: 981px) {
  .content-panel--maps-mode .content-panel__inner {
    opacity: 0;
    pointer-events: none;
  }
}

.rail-header {
  --rail-header-top: clamp(2.75rem, 5vw, 4.375rem);
  position: absolute;
  top: var(--rail-header-top);
  left: var(--rail-shell-padding);
  z-index: 4;
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: min(var(--rail-content-width), calc(100% - (var(--rail-shell-padding) * 2)));
  height: 2.5rem;
  overflow: visible;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
  isolation: isolate;
}

.rail-header::before {
  content: "";
  position: absolute;
  inset: calc(-1 * var(--rail-header-top)) 0 -0.85rem;
  z-index: 0;
  background-color: var(--rail-surface-color);
  pointer-events: none;
}

.rail-header::after {
  content: "";
  position: absolute;
  inset: calc(-1 * var(--rail-header-top)) 0 -0.85rem;
  z-index: 1;
  background-image: var(--rail-surface-texture-image);
  background-size: var(--rail-surface-texture-size);
  background-position: var(--rail-surface-texture-position);
  background-repeat: var(--rail-surface-texture-repeat);
  opacity: var(--rail-surface-texture-opacity);
  pointer-events: none;
}

.rail-header__home,
.rail-header__back,
.rail-header__brand,
.rail-header__breadcrumb,
.rail-header__menu,
.rail-header__meta {
  position: relative;
  z-index: 2;
}

.rail-header__home {
  display: flex;
  flex: 1 1 auto;
  align-items: center;
  min-width: 0;
  height: 100%;
  padding: 0 0.9375rem;
  border: 1px solid var(--rail-surface-menu-frame, var(--rail-surface-divider));
  border-right: 0;
  background: transparent;
  color: var(--rail-surface-text);
  transition: background-color var(--rail-stack-transition), color var(--rail-stack-transition);
}

.rail-header__home:hover,
.rail-header__home:focus-visible {
  background-color: var(--rail-surface-ui-hover);
  outline: none;
}

.rail-header__back {
  display: flex;
  flex: 0 0 auto;
  align-items: center;
  justify-content: center;
  height: 100%;
  min-width: 3.9rem;
  padding: 0 0.75rem;
  border-right: 1px solid var(--rail-surface-divider);
  background: transparent;
  color: var(--rail-surface-text);
  font-size: var(--rail-type-meta-size);
  line-height: var(--rail-type-meta-line);
  font-weight: 700;
  transition: background-color var(--rail-stack-transition), color var(--rail-stack-transition);
}

.rail-header__back:hover,
.rail-header__back:focus-visible {
  background-color: var(--rail-surface-ui-hover);
  outline: none;
}

.rail-header__brand {
  display: block;
  max-width: 100%;
  font-family: var(--body-font);
  font-style: normal;
  font-size: var(--rail-type-strong-size);
  font-weight: var(--rail-type-strong-weight);
  line-height: var(--rail-type-strong-line);
  letter-spacing: var(--rail-type-strong-spacing);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.rail-header__breadcrumb {
  position: absolute;
  left: 0;
  bottom: calc(100% + 0.48rem);
  display: flex;
  align-items: center;
  gap: 0.4rem;
  width: max-content;
  max-width: min(100%, 27rem);
  min-width: 0;
  overflow: hidden;
  color: var(--rail-surface-muted);
  font-family: var(--body-font);
  font-size: var(--rail-type-meta-size);
  line-height: var(--rail-type-meta-line);
  letter-spacing: 0;
  white-space: nowrap;
  pointer-events: auto;
}

.rail-header__breadcrumb-item {
  min-width: 0;
  max-width: 12rem;
  padding: 0;
  overflow: hidden;
  border: 0;
  background: transparent;
  color: var(--rail-surface-muted);
  font: inherit;
  text-align: left;
  text-overflow: ellipsis;
  white-space: nowrap;
  cursor: pointer;
  transition: color var(--rail-stack-transition), opacity var(--rail-stack-transition);
}

.rail-header__breadcrumb-item:hover,
.rail-header__breadcrumb-item:focus-visible {
  color: var(--rail-surface-text);
  outline: none;
}

.rail-header__breadcrumb-item--current {
  color: var(--rail-surface-text);
}

.rail-header__breadcrumb-separator {
  flex: 0 0 auto;
  color: var(--rail-surface-muted);
  opacity: 0.56;
}

.rail-header__brand::before {
  content: "";
}

.rail-header__menu {
  position: relative;
  width: 2.5rem;
  height: 2.5rem;
  display: flex;
  align-items: center;
  justify-content: center;
  flex: 0 0 2.5rem;
  border: 1px solid var(--rail-surface-menu-frame, var(--rail-surface-divider));
  background: transparent;
  color: var(--rail-surface-text);
  font-size: 0;
  transition: background-color var(--rail-stack-transition), color var(--rail-stack-transition);
}

.rail-header__menu::after {
  content: "";
  position: relative;
  width: 0.46rem;
  height: 0.46rem;
  border-right: 1.5px solid currentColor;
  border-bottom: 1.5px solid currentColor;
  transform: translateY(-0.12rem) rotate(45deg);
  transition: transform var(--transition-smooth);
}

.rail-header__menu:hover,
.rail-header__menu:focus-visible {
  background-color: var(--rail-surface-ui-hover);
  outline: none;
}

.rail-header__menu.is-open::after {
  transform: translateY(0.08rem) rotate(-135deg);
}

.rail-header__meta {
  display: none;
}

.rail-menu {
  position: absolute;
  top: calc(100% + 0.35rem);
  left: 0;
  z-index: 12;
  width: 100%;
  max-height: min(68vh, 34rem);
  overflow-y: auto;
  background-color: var(--rail-surface-color);
  border: 0;
  box-shadow: 0 1rem 2rem rgba(25, 21, 20, 0.1);
  border-radius: 0;
  padding: 0.9rem 0.95rem 0.95rem;
}

.rail-menu__section + .rail-menu__section {
  border-top: 1px solid var(--rail-surface-divider);
  margin-top: 0.85rem;
  padding-top: 0.8rem;
}

.rail-menu__label {
  margin: 0;
  padding: 0 0 0.25rem;
  font-family: var(--body-font);
  font-size: var(--type-size-xs);
  font-weight: var(--rail-type-label-weight);
  line-height: var(--rail-type-label-line);
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--rail-surface-soft);
}

.rail-menu__list {
  display: grid;
  gap: 0.52rem;
}

.rail-menu__item {
  width: 100%;
  display: grid;
  grid-template-columns: minmax(0, max-content) minmax(1.5rem, 1fr) auto;
  align-items: end;
  gap: 0.55rem;
  padding: 0.04rem 0;
  text-align: left;
  font-family: var(--body-font);
  font-size: 0;
  color: var(--rail-surface-muted);
  transition: color var(--rail-stack-transition);
}

.rail-menu__item-copy {
  min-width: 0;
  font-family: var(--body-font);
  font-size: var(--type-size-2xl);
  font-weight: 700;
  line-height: 0.96;
  letter-spacing: -0.03em;
  transition: transform var(--transition-smooth);
}

.rail-menu__item-rule {
  min-width: 1.5rem;
  align-self: end;
  margin-bottom: 0.42rem;
  border-bottom: 1px dashed var(--rail-surface-divider);
  opacity: 0.82;
  transform: scaleX(0.92);
  transform-origin: left center;
  transition:
    border-color var(--rail-stack-transition),
    opacity var(--rail-stack-transition),
    transform var(--rail-stack-transition);
}

.rail-menu__item-index {
  font-family: var(--display-font);
  font-size: var(--type-size-md);
  font-weight: 700;
  line-height: 1;
  letter-spacing: var(--type-tracking-none);
  color: var(--rail-surface-soft);
  transform: translateY(-0.08rem);
  transition:
    color var(--rail-stack-transition),
    transform var(--rail-stack-transition);
}

.rail-menu__item:hover,
.rail-menu__item:focus-visible,
.rail-menu__item.is-current {
  color: var(--rail-surface-text);
}

.rail-menu__item:hover .rail-menu__item-copy,
.rail-menu__item:focus-visible .rail-menu__item-copy,
.rail-menu__item.is-current .rail-menu__item-copy {
  transform: translateX(0.08rem);
}

.rail-menu__item:hover .rail-menu__item-rule,
.rail-menu__item:focus-visible .rail-menu__item-rule {
  border-color: var(--rail-surface-muted);
  opacity: 1;
  transform: scaleX(1);
}

.rail-menu__item:hover .rail-menu__item-index,
.rail-menu__item:focus-visible .rail-menu__item-index {
  color: var(--rail-surface-muted);
  transform: translateY(-0.12rem);
}

.rail-menu__item.is-current .rail-menu__item-rule {
  border-color: var(--rail-current-accent);
  opacity: 1;
  transform: scaleX(1);
}

.rail-menu__item.is-current .rail-menu__item-index {
  color: var(--rail-current-accent);
}

.rail-menu__item:focus-visible {
  outline: 1px solid var(--rail-surface-divider);
  outline-offset: 0.3rem;
}

.rail-header__eyebrow,
.rail-header__status,
.rail-pill,
.rail-social a span {
  letter-spacing: 0.16em;
  text-transform: uppercase;
}

.rail-scroll {
  flex: 1;
  min-height: 0;
  position: relative;
  overflow-y: auto;
  scrollbar-width: thin;
  scrollbar-color: rgba(23, 19, 19, 0.2) transparent;
}

.rail-content {
  padding: 10.625rem var(--rail-shell-padding) var(--rail-content-padding-bottom);
}

.rail-article {
  width: min(100%, var(--rail-content-width));
  max-width: 100%;
}

.content-panel[data-stack-state="detail"] .content-panel__inner.content-panel__inner--entering-forward,
.content-panel[data-stack-state="detail"] .content-panel__inner.content-panel__inner--entering-backward {
  will-change: transform;
}

.content-panel[data-stack-state="detail"] .content-panel__inner.content-panel__inner--entering-forward {
  animation: rail-panel-enter-forward 320ms cubic-bezier(0.16, 1, 0.3, 1) both;
}

.content-panel[data-stack-state="detail"] .content-panel__inner.content-panel__inner--entering-backward {
  animation: rail-panel-enter-backward 320ms cubic-bezier(0.16, 1, 0.3, 1) both;
}

@keyframes rail-panel-enter-forward {
  from {
    transform: translate3d(1.2rem, 0.16rem, 0) rotate(var(--rail-current-rotate, 0deg));
  }

  to {
    transform: translate3d(0, 0.16rem, 0) rotate(var(--rail-current-rotate, 0deg));
  }
}

@keyframes rail-panel-enter-backward {
  from {
    transform: translate3d(-1.2rem, 0.16rem, 0) rotate(var(--rail-current-rotate, 0deg));
  }

  to {
    transform: translate3d(0, 0.16rem, 0) rotate(var(--rail-current-rotate, 0deg));
  }
}

.rail-article--home {
  display: block;
}

.rail-content--home {
  --rail-content-padding-bottom: 0;
  min-height: 100%;
  display: flex;
  flex-direction: column;
}

.rail-content--home .rail-article--home {
  flex: 1 0 auto;
  min-height: 100%;
  display: flex;
  flex-direction: column;
}

.rail-article--home .rail-panel-section--travel-note,
.rail-article--home .rail-panel-section--press-note,
.rail-article--home .rail-panel-section--contact-note,
.rail-article--home .rail-panel-section--partners {
  margin-inline: calc(var(--rail-shell-padding) * -1);
  padding-inline: var(--rail-shell-padding);
}

.rail-article--home .rail-panel-section--travel-note + .rail-panel-section--press-note,
.rail-article--home .rail-panel-section--press-note + .rail-panel-section--contact-note,
.rail-article--home .rail-panel-section--contact-note + .rail-panel-section--partners {
  margin-top: 0;
}

.rail-content--home .rail-panel-section--partners {
  flex: 1 0 auto;
}

.rail-panel-section--home-about .rail-image-frame--about {
  margin-bottom: 3rem;
}

.rail-article--detail {
  display: block;
}

.rail-hero {
  display: grid;
  gap: 0.8rem;
}

.rail-panel-section + .rail-panel-section {
  margin-top: 3.125rem;
}

.rail-panel-section--travel-note {
  padding: 1.375rem 1.5rem 1.4rem;
  gap: 0;
  background: #0f0c0d;
  border: 1px solid rgba(15, 12, 13, 0.88);
  box-shadow: none;
}

.rail-panel-section--travel-note .rail-section-label {
  margin-bottom: 1rem;
  color: rgba(245, 240, 235, 0.56);
}

.rail-panel-section--travel-note .rail-summary {
  max-width: 22rem;
  color: rgba(245, 240, 235, 0.96);
}

.rail-panel-section--travel-note .rail-cta {
  margin-top: 1rem;
  color: rgba(15, 12, 13, 0.96);
  border-color: rgba(245, 240, 235, 0.18);
  background: rgba(255, 252, 248, 0.96);
  box-shadow: 0 0.7rem 1.6rem rgba(9, 7, 8, 0.24);
}

.rail-panel-section--travel-note .rail-cta:hover,
.rail-panel-section--travel-note .rail-cta:focus-visible {
  background: rgba(255, 255, 255, 1);
  box-shadow: 0 0.9rem 1.9rem rgba(9, 7, 8, 0.28);
}

.rail-panel-section--press-note {
  padding: 1.375rem 1.5rem 1.4rem;
  gap: 0;
  background:
    radial-gradient(circle at top right, rgba(98, 69, 91, 0.08), transparent 0 10rem),
    linear-gradient(180deg, rgba(195, 110, 98, 0.16) 0%, rgba(195, 110, 98, 0.115) 100%);
  border: 1px solid rgba(170, 91, 80, 0.16);
}

.rail-panel-section--press-note .rail-section-label {
  margin-bottom: 1rem;
  color: rgba(114, 59, 51, 0.72);
}

.rail-panel-section--press-note .rail-summary {
  max-width: 25rem;
  color: rgba(23, 19, 19, 0.94);
}

.rail-panel-section--press-note .rail-panel-copy {
  max-width: 23rem;
  margin-top: 1rem;
  color: rgba(23, 19, 19, 0.8);
}

.rail-panel-section--press-note .rail-cta {
  margin-top: 1rem;
  color: var(--atlas-paper);
  border-color: rgba(23, 19, 19, 0.28);
  background: var(--atlas-ink);
  box-shadow: 0 0.65rem 1.4rem rgba(23, 19, 19, 0.16);
}

.rail-panel-section--press-note .rail-cta:hover,
.rail-panel-section--press-note .rail-cta:focus-visible {
  background: #0f0c0d;
  box-shadow: 0 0.85rem 1.7rem rgba(23, 19, 19, 0.22);
}

.rail-panel-section--contact-note {
  padding: 1.375rem 1.5rem 1.4rem;
  gap: 0;
  background:
    radial-gradient(circle at 18% 16%, rgba(255, 255, 255, 0.08), transparent 0 9rem),
    linear-gradient(180deg, rgba(195, 110, 98, 0.96) 0%, rgba(181, 97, 84, 0.98) 100%);
  border: 1px solid rgba(114, 59, 51, 0.34);
  box-shadow: none;
}

.rail-panel-section--contact-note .rail-section-label,
.rail-panel-section--contact-note .rail-summary,
.rail-panel-section--contact-note .rail-panel-copy,
.rail-panel-section--contact-note .rail-contact a,
.rail-panel-section--contact-note .rail-social a,
.rail-panel-section--contact-note .rail-social__entry {
  color: rgba(23, 19, 19, 0.94);
}

.rail-panel-section--contact-note .rail-section-label {
  margin-bottom: 1rem;
  color: rgba(23, 19, 19, 0.68);
}

.rail-panel-section--contact-note .rail-contact a,
.rail-panel-section--contact-note .rail-social a strong,
.rail-panel-section--contact-note .rail-social__entry strong {
  text-decoration-color: rgba(23, 19, 19, 0.78);
}

.rail-panel-section--contact-note .rail-social a span,
.rail-panel-section--contact-note .rail-social__entry span {
  color: rgba(23, 19, 19, 0.62);
}

.rail-panel-section--contact-note .rail-social {
  padding: 0.95rem 0 0;
  background: transparent;
  border-top: 1px solid rgba(114, 59, 51, 0.28);
}

.rail-panel-section--contact-note .rail-social a,
.rail-panel-section--contact-note .rail-social__entry {
  padding: 0.18rem 0;
}

.rail-article--about-page .rail-panel-section--contact-note {
  padding: 1.5rem;
  background: #0f0c0d;
  border-color: rgba(245, 240, 235, 0.12);
  box-shadow: 0 18px 40px rgba(9, 7, 8, 0.22);
}

.rail-article--about-page .rail-panel-section--contact-note .rail-about-section-title,
.rail-article--about-page .rail-panel-section--contact-note .rail-panel-copy,
.rail-article--about-page .rail-panel-section--contact-note .rail-contact a,
.rail-article--about-page .rail-panel-section--contact-note .rail-social a,
.rail-article--about-page .rail-panel-section--contact-note .rail-social__entry {
  color: rgba(245, 240, 235, 0.96);
}

.rail-article--about-page .rail-panel-section--contact-note .rail-about-section-title {
  margin-bottom: 1rem;
}

.rail-article--about-page .rail-panel-section--contact-note .rail-contact a,
.rail-article--about-page .rail-panel-section--contact-note .rail-social a strong,
.rail-article--about-page .rail-panel-section--contact-note .rail-social__entry strong {
  text-decoration-color: rgba(245, 240, 235, 0.72);
}

.rail-article--about-page .rail-panel-section--contact-note .rail-social {
  margin-top: 1rem;
  padding-top: 0;
  border-top: 0;
}

.rail-article--about-page .rail-panel-section--contact-note .rail-contact--about {
  margin: 0 0 0.85rem;
}

.rail-article--about-page .rail-panel-section--contact-note .rail-contact__row {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 1rem;
}

.rail-article--about-page .rail-panel-section--contact-note .rail-contact__label {
  font-family: var(--body-font);
  font-size: var(--rail-type-body-size);
  line-height: var(--rail-type-body-line);
  font-weight: var(--rail-type-strong-weight);
  color: rgba(245, 240, 235, 0.96);
}

.rail-article--about-page .rail-panel-section--contact-note .rail-contact__link {
  text-align: right;
  text-decoration-line: underline;
  text-decoration-thickness: 1px;
  text-underline-offset: 0.14em;
}

.rail-article--about-page .rail-panel-section--contact-note .rail-social a span,
.rail-article--about-page .rail-panel-section--contact-note .rail-social__entry span {
  color: rgba(245, 240, 235, 0.76);
}

.rail-article--about-page .rail-panel-section--contact-note .rail-cta {
  margin-top: 1.25rem;
  padding: 0.72rem 1rem;
  border: 1px solid rgba(245, 240, 235, 0.18);
  background: rgba(245, 240, 235, 0.96);
  color: rgba(15, 12, 13, 0.96);
  text-decoration: none;
}

.rail-article--about-page .rail-panel-section--contact-note .rail-cta:hover,
.rail-article--about-page .rail-panel-section--contact-note .rail-cta:focus-visible {
  opacity: 1;
  background: rgba(245, 240, 235, 0.86);
}

.rail-article--about-page .rail-panel-section--intro {
  padding-bottom: 0;
}

.rail-panel-section--about-team {
  margin-top: 0.9rem;
}

.rail-panel-section--about-team .rail-profile-list {
  margin-top: 0;
}

.rail-panel-section--partners {
  padding: 1.375rem var(--rail-shell-padding) 1.6rem;
  background: rgba(255, 255, 255, 0.96);
  border-top: 1px solid rgba(23, 19, 19, 0.08);
  display: grid;
  align-content: start;
  gap: 1rem;
}

.rail-panel-section--partners .rail-section-label {
  margin-bottom: 0;
  color: rgba(23, 19, 19, 0.54);
}

.rail-panel-section--partners .rail-summary {
  color: rgba(23, 19, 19, 0.96);
}

.rail-partners {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 1.35rem 1.15rem;
  padding-top: 0.25rem;
}

.rail-partners__logo {
  display: inline-block;
  flex: 0 0 auto;
  width: auto;
  height: 2.55rem;
  max-width: 8.75rem;
  object-fit: contain;
  filter: grayscale(1);
  mix-blend-mode: multiply;
  opacity: 0.86;
}

.rail-partners__link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transition: opacity var(--transition-smooth), transform var(--transition-smooth);
}

.rail-partners__link:hover,
.rail-partners__link:focus-visible {
  opacity: 0.78;
  transform: translateY(-0.08rem);
  outline: none;
}

.rail-partners__logo--portrait {
  height: 3.7rem;
  max-width: 4.9rem;
}

.rail-partners__logo--wide {
  height: 2.15rem;
  max-width: 11rem;
}

.rail-partners__logo--inverted {
  filter: grayscale(1) invert(1);
}

.rail-section-label {
  margin: 0 0 0.9375rem;
  font-family: var(--body-font);
  font-size: var(--rail-type-label-size);
  line-height: 1rem;
  letter-spacing: var(--rail-type-label-spacing);
  text-transform: uppercase;
  font-weight: var(--rail-type-label-weight);
  color: rgba(23, 19, 19, 0.72);
}

.rail-about-section-title {
  margin: 0;
  font-family: var(--body-font);
  font-size: var(--rail-type-subhead-size);
  line-height: var(--rail-type-subhead-line);
  letter-spacing: var(--rail-type-subhead-spacing);
  font-weight: var(--rail-type-subhead-weight);
  color: var(--atlas-ink);
  text-wrap: balance;
}

.rail-about-subsection__title {
  margin: 0;
  font-family: var(--body-font);
  font-size: var(--rail-type-strong-size);
  line-height: var(--rail-type-strong-line);
  letter-spacing: var(--rail-type-strong-spacing);
  font-weight: var(--rail-type-strong-weight);
  color: var(--atlas-ink);
  text-wrap: balance;
}

.rail-about-section-title + .rail-panel-copy,
.rail-about-section-title + .rail-summary--statement {
  margin-top: var(--rail-title-copy-gap);
}

.rail-book-publisher-link {
  color: inherit;
  text-decoration: none;
  border-bottom: 1px solid rgba(23, 19, 19, 0.24);
  transition:
    opacity var(--transition-smooth),
    border-color var(--transition-smooth);
}

.rail-book-publisher-link:hover,
.rail-book-publisher-link:focus-visible {
  opacity: 0.66;
  border-color: rgba(23, 19, 19, 0.52);
  outline: none;
}

.rail-summary {
  margin: 0;
  font-family: var(--body-font);
  font-size: var(--rail-type-display-size);
  line-height: var(--rail-type-display-line);
  letter-spacing: var(--rail-type-display-spacing);
  font-weight: var(--rail-type-display-weight);
  color: rgba(23, 19, 19, 0.96);
  text-wrap: balance;
}

.rail-summary--statement {
  font-size: var(--rail-type-strong-size);
  line-height: var(--rail-type-strong-line);
  letter-spacing: var(--rail-type-strong-spacing);
  font-weight: var(--rail-type-strong-weight);
  text-wrap: pretty;
}

.rail-panel-copy {
  margin: 0;
  font-family: var(--body-font);
  font-size: var(--rail-type-body-size);
  line-height: var(--rail-type-body-line);
  letter-spacing: var(--rail-type-body-spacing);
  font-weight: var(--rail-type-body-weight);
  color: rgba(23, 19, 19, 0.84);
  text-wrap: pretty;
}

.rail-panel-copy a {
  text-decoration: underline;
  text-decoration-thickness: 1px;
  text-underline-offset: 2px;
}

.rail-inline-node-link {
  padding: 0;
  border: 0;
  background: transparent;
  font: inherit;
  color: inherit;
  text-decoration: underline;
  text-decoration-thickness: 1px;
  text-underline-offset: 2px;
  cursor: pointer;
}

.rail-inline-node-link:hover,
.rail-inline-node-link:focus-visible {
  opacity: 0.68;
  outline: none;
}

.rail-panel-copy--lead {
  font-size: var(--rail-type-strong-size);
  line-height: var(--rail-type-strong-line);
  letter-spacing: var(--rail-type-strong-spacing);
  font-weight: 500;
  color: rgba(23, 19, 19, 0.76);
}

.rail-panel-section--exhibition-intro {
  display: grid;
  gap: 0.9rem;
}

.rail-panel-section--exhibition-intro .rail-summary {
  text-wrap: pretty;
}

.rail-summary + .rail-panel-copy {
  margin-top: var(--rail-title-copy-gap);
}

.rail-panel-copy + .rail-panel-copy {
  margin-top: 0.75rem;
}

.rail-panel-section--intro .rail-meta-stack,
.rail-panel-section--intro .rail-cta,
.rail-panel-section--archive .rail-archive,
.rail-panel-section .rail-image-placeholder,
.rail-panel-section .rail-cta,
.rail-panel-section .rail-contact,
.rail-panel-section .rail-social,
.rail-panel-section .rail-collection-grid,
.rail-panel-section .rail-about-subsections,
.rail-panel-section .rail-about-city-list,
.rail-panel-section .rail-profile-list,
.rail-panel-section .rail-essayist-list,
.rail-panel-section .rail-artist-list,
.rail-panel-section .rail-artist-card-grid,
.rail-panel-section .rail-person-contribution-grid,
.rail-panel-section .rail-pill-grid {
  margin-top: 0.9375rem;
}

.rail-panel-copy + .rail-bullet-list {
  margin-top: 1.5rem;
}

.rail-bullet-list + .rail-cta {
  margin-top: 1.5rem;
}

.rail-cta + .rail-about-subsections {
  margin-top: 2rem;
}

.rail-kicker {
  margin: 0;
  font-family: var(--body-font);
  font-size: var(--rail-type-label-size);
  line-height: var(--rail-type-label-line);
  font-weight: var(--rail-type-label-weight);
  letter-spacing: var(--rail-type-label-spacing);
  text-transform: uppercase;
  color: rgba(23, 19, 19, 0.55);
}

.rail-image-placeholder {
  position: relative;
  width: 100%;
  margin: 0;
  aspect-ratio: 16 / 10;
  box-sizing: border-box;
  padding: 0.875rem;
  border: 1px solid rgba(23, 19, 19, 0.12);
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.42), rgba(255, 255, 255, 0.18)),
    linear-gradient(135deg, rgba(98, 69, 91, 0.1), rgba(98, 69, 91, 0.04));
  overflow: hidden;
}

.rail-image-placeholder::before,
.rail-image-placeholder::after {
  content: "";
  position: absolute;
  inset: 0.875rem;
  pointer-events: none;
}

.rail-image-placeholder::before {
  background:
    linear-gradient(to right, rgba(23, 19, 19, 0.08) 1px, transparent 1px),
    linear-gradient(to bottom, rgba(23, 19, 19, 0.08) 1px, transparent 1px);
  background-size: 1.5rem 1.5rem;
  opacity: 0.35;
}

.rail-image-placeholder::after {
  background:
    linear-gradient(135deg, transparent calc(50% - 0.5px), rgba(23, 19, 19, 0.12) calc(50% - 0.5px), rgba(23, 19, 19, 0.12) calc(50% + 0.5px), transparent calc(50% + 0.5px)),
    linear-gradient(45deg, transparent calc(50% - 0.5px), rgba(23, 19, 19, 0.08) calc(50% - 0.5px), rgba(23, 19, 19, 0.08) calc(50% + 0.5px), transparent calc(50% + 0.5px));
  opacity: 0.6;
}

.rail-image-placeholder__label {
  position: absolute;
  top: 1.45rem;
  left: 1.5rem;
  z-index: 1;
  font-family: var(--body-font);
  font-size: var(--rail-type-label-size);
  line-height: var(--rail-type-label-line);
  font-weight: var(--rail-type-label-weight);
  letter-spacing: var(--rail-type-label-spacing);
  text-transform: uppercase;
  color: rgba(23, 19, 19, 0.58);
}

.rail-image-frame {
  position: relative;
  display: grid;
  place-items: center;
  width: 100%;
  margin: 0;
  aspect-ratio: auto;
  box-sizing: border-box;
  overflow: visible;
  padding: 0;
  background: transparent;
}

.rail-image-frame__image {
  display: block;
  width: 100%;
  height: auto;
  max-width: 100%;
  max-height: none;
  object-fit: initial;
}

.rail-image-lightbox-trigger {
  display: block;
  width: 100%;
  padding: 0;
  border: 0;
  background: transparent;
  color: inherit;
  cursor: zoom-in;
}

.rail-image-lightbox-trigger:focus-visible {
  outline: 2px solid rgba(255, 252, 248, 0.92);
  outline-offset: 4px;
}

.rail-image-lightbox-trigger .rail-image-frame__image {
  transition:
    filter var(--transition-smooth),
    transform var(--transition-smooth);
}

.rail-image-lightbox-trigger:hover .rail-image-frame__image,
.rail-image-lightbox-trigger:focus-visible .rail-image-frame__image {
  filter: brightness(1.04);
  transform: translateY(-1px);
}

.rail-image-frame__tag {
  position: absolute;
  top: 0.72rem;
  right: 0.72rem;
  z-index: 1;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: fit-content;
  max-width: calc(100% - 1.44rem);
  min-height: 1.35rem;
  padding: 0.28rem 0.44rem 0.24rem;
  border: 1px solid rgba(222, 231, 245, 0.58);
  background: rgba(23, 19, 19, 0.72);
  color: rgba(255, 252, 248, 0.96);
  font-size: clamp(0.54rem, 0.62vw, 0.64rem);
  line-height: 1;
  letter-spacing: var(--rail-type-label-spacing);
  text-transform: uppercase;
  text-decoration: none;
  white-space: nowrap;
  box-shadow: 0 0.8rem 1.8rem rgba(23, 19, 19, 0.18);
  transition:
    background var(--transition-smooth),
    border-color var(--transition-smooth),
    color var(--transition-smooth),
    transform var(--transition-smooth);
}

.rail-image-frame__tag:hover,
.rail-image-frame__tag:focus-visible {
  border-color: rgba(255, 252, 248, 0.78);
  background: rgba(255, 252, 248, 0.94);
  color: var(--atlas-ink);
  outline: none;
  transform: translateY(-1px);
}

.rail-image-frame--about {
  aspect-ratio: auto;
}

.rail-image-frame--about .rail-image-frame__image {
  width: 100%;
  height: auto;
  max-height: none;
}

.rail-image-frame--subsection {
  aspect-ratio: auto;
  overflow: visible;
}

.rail-image-frame--book-card,
.rail-image-frame--book-feature {
  aspect-ratio: auto;
  padding: 0;
  border: 0;
  background: transparent;
  box-shadow: none;
}

.rail-image-frame--book-card {
  max-width: none;
  margin-inline: 0;
}

.rail-image-frame--book-feature {
  max-width: none;
  margin-inline: 0;
}

.rail-article--book .rail-image-frame--book-feature + .rail-summary {
  margin-top: 1.5rem;
}

.rail-image-frame__image--book-card,
.rail-image-frame__image--book-feature {
  width: 100%;
  height: auto;
  max-height: none;
  object-fit: initial;
}

.rail-image-frame__image--subsection-cover {
  width: 100%;
  height: auto;
  max-height: none;
  object-fit: initial;
  object-position: center;
}

.image-lightbox {
  position: fixed;
  inset: 0;
  z-index: 90;
  display: grid;
  place-items: center;
  padding: clamp(1rem, 3vw, 2.5rem);
}

.image-lightbox[hidden] {
  display: none;
}

.image-lightbox__backdrop {
  position: absolute;
  inset: 0;
  background: rgba(23, 19, 19, 0.74);
  backdrop-filter: blur(5px);
}

.image-lightbox__dialog {
  position: relative;
  z-index: 1;
  display: grid;
  gap: 0.72rem;
  width: min(92vw, 72rem);
  max-height: 88vh;
}

.image-lightbox__image {
  display: block;
  width: auto;
  max-width: 100%;
  max-height: 82vh;
  margin: 0 auto;
  object-fit: contain;
  background: rgba(23, 19, 19, 0.48);
  box-shadow: 0 2rem 5rem rgba(0, 0, 0, 0.34);
}

.image-lightbox__close {
  justify-self: end;
  min-height: 2.4rem;
  padding: 0.58rem 0.78rem 0.52rem;
  border: 1px solid rgba(255, 252, 248, 0.42);
  background: rgba(255, 252, 248, 0.92);
  font-family: var(--body-font);
  font-size: var(--rail-type-label-size);
  line-height: 1;
  letter-spacing: var(--rail-type-label-spacing);
  text-transform: uppercase;
  font-weight: var(--rail-type-label-weight);
  color: var(--atlas-ink);
  cursor: pointer;
  box-shadow: 0 1rem 2.5rem rgba(0, 0, 0, 0.2);
}

.image-lightbox__close:hover,
.image-lightbox__close:focus-visible {
  background: var(--atlas-ink);
  color: rgba(255, 252, 248, 0.96);
  outline: none;
}

.rail-image-placeholder + .rail-summary,
.rail-image-placeholder + .rail-section-label,
.rail-image-placeholder + .rail-title,
.rail-image-placeholder + .rail-panel-copy,
.rail-image-frame + .rail-summary,
.rail-image-frame + .rail-section-label,
.rail-image-frame + .rail-title,
.rail-image-frame + .rail-panel-copy,
.rail-image-frame + .rail-about-subsection__title,
.rail-image-placeholder + .rail-about-subsection__title {
  margin-top: 1rem;
}

.rail-image-placeholder--subsection {
  aspect-ratio: 16 / 7.5;
}

.rail-image-placeholder--subsection .rail-image-placeholder__label,
.rail-image-placeholder--subsection::before,
.rail-image-placeholder--subsection::after {
  transform: none;
}

.rail-image-placeholder--person-portrait {
  aspect-ratio: 4 / 5;
  min-height: 21rem;
}

.rail-image-placeholder--person-contribution {
  aspect-ratio: 16 / 10;
  min-height: 11.5rem;
  border-color: rgba(23, 19, 19, 0.18);
  background:
    linear-gradient(180deg, rgba(255, 251, 248, 0.82), rgba(255, 245, 239, 0.94)),
    linear-gradient(135deg, rgba(148, 90, 76, 0.16), rgba(98, 69, 91, 0.08));
}

.rail-image-placeholder--person-contribution::before {
  opacity: 0.5;
}

.rail-image-placeholder--person-contribution::after {
  opacity: 0.72;
}

.rail-image-placeholder--person-contribution .rail-image-placeholder__label {
  color: rgba(23, 19, 19, 0.84);
  background: rgba(255, 248, 243, 0.88);
  padding: 0.3rem 0.55rem;
  box-shadow: 0 0 0 1px rgba(23, 19, 19, 0.08);
}

.rail-intro {
  display: block;
}

.rail-title {
  margin: 0;
  max-width: none;
  font-family: var(--body-font);
  font-style: normal;
  font-size: var(--rail-type-display-size);
  line-height: var(--rail-type-display-line);
  letter-spacing: var(--rail-type-display-spacing);
  font-weight: var(--rail-type-display-weight);
  text-wrap: balance;
}

.rail-intro--home {
  display: grid;
  gap: 0.72rem;
}

.rail-title--node {
  max-width: 14ch;
}

.rail-lead,
.rail-body,
.rail-link-row__excerpt,
.rail-social a {
  font-family: var(--body-font);
  font-size: var(--rail-type-body-size);
  line-height: var(--rail-type-body-line);
  letter-spacing: var(--rail-type-body-spacing);
  color: rgba(23, 19, 19, 0.85);
  text-wrap: pretty;
}

.rail-link-row__title,
.rail-bullet-item__title,
.rail-about-subsection__title,
.rail-archive__title,
.rail-collection-card__title {
  text-wrap: balance;
}

.rail-bullet-item__copy,
.rail-about-subsection__copy,
.rail-about-subsection__meta,
.rail-archive__subtitle,
.rail-archive__meta,
.rail-meta-stack__value,
.rail-roster__names,
.rail-collection-card__subtitle {
  text-wrap: pretty;
}

.rail-practical-card__venue,
.rail-practical-card__date {
  text-wrap: balance;
}

.rail-practical-card__schedule dd {
  text-wrap: pretty;
}

.rail-lead {
  margin: 0;
  font-weight: var(--rail-type-body-weight);
}

.rail-body--intro {
  font-size: var(--rail-type-body-size);
  line-height: var(--rail-type-body-line);
}

.rail-body {
  margin: 0;
  font-size: var(--rail-type-body-size);
  line-height: var(--rail-type-body-line);
  font-weight: var(--rail-type-body-weight);
}

.rail-body + .rail-body {
  margin-top: 0.85rem;
}

.rail-divider {
  width: 100%;
  height: 1px;
  margin: 0;
  border: 0;
  background: var(--atlas-paper-line);
}

.rail-fact-grid {
  display: grid;
  gap: 0.9375rem;
}

.rail-fact {
  display: grid;
  grid-template-columns: minmax(0, 8.2rem) minmax(0, 1fr);
  gap: 1rem;
}

.rail-fact dt {
  font-family: var(--body-font);
  font-size: var(--rail-type-label-size);
  font-weight: var(--rail-type-label-weight);
  line-height: var(--rail-type-label-line);
  letter-spacing: var(--rail-type-label-spacing);
  text-transform: uppercase;
  color: rgba(23, 19, 19, 0.5);
}

.rail-fact dd {
  margin: 0;
  font-size: var(--rail-type-body-size);
  line-height: var(--rail-type-body-line);
  letter-spacing: var(--rail-type-body-spacing);
  font-weight: var(--rail-type-body-weight);
  color: rgba(23, 19, 19, 0.88);
}

.rail-section {
  display: grid;
  gap: 0.85rem;
  padding-top: 1rem;
  border-top: 1px solid var(--atlas-paper-line);
}

.rail-article--home .rail-section:first-of-type {
  padding-top: 0;
  border-top: 0;
}

.rail-section__head {
  display: flex;
  justify-content: space-between;
  gap: 1rem;
  font-family: var(--body-font);
  font-size: var(--rail-type-label-size);
  line-height: var(--rail-type-label-line);
  font-weight: var(--rail-type-label-weight);
  letter-spacing: var(--rail-type-label-spacing);
  text-transform: uppercase;
  color: rgba(23, 19, 19, 0.54);
}

.rail-entry-list {
  display: grid;
  gap: 0;
}

.rail-link-row {
  width: 100%;
  display: grid;
  gap: 0.2rem;
  padding: 0.7rem 0;
  color: inherit;
  text-align: left;
  text-decoration: none;
  border-bottom: 1px solid var(--atlas-paper-line);
  transition: background var(--transition-smooth);
}

.rail-link-row:hover,
.rail-link-row:focus-visible {
  background: rgba(23, 19, 19, 0.025);
  outline: none;
}

.rail-link-row__meta {
  display: flex;
  justify-content: space-between;
  gap: 1rem;
  font-family: var(--body-font);
  font-size: var(--rail-type-micro-size);
  line-height: var(--rail-type-micro-line);
  font-weight: var(--rail-type-micro-weight);
  letter-spacing: var(--rail-type-micro-spacing);
  text-transform: uppercase;
  color: rgba(23, 19, 19, 0.48);
}

.rail-link-row__title {
  margin: 0;
  font-size: var(--rail-type-strong-size);
  line-height: var(--rail-type-strong-line);
  font-weight: var(--rail-type-strong-weight);
  letter-spacing: var(--rail-type-strong-spacing);
  color: var(--atlas-ink);
}

.rail-link-row__excerpt {
  margin: 0;
  font-size: var(--rail-type-body-size);
  line-height: var(--rail-type-body-line);
  letter-spacing: var(--rail-type-body-spacing);
  font-weight: var(--rail-type-body-weight);
  color: rgba(23, 19, 19, 0.72);
}

.rail-media-list {
  display: grid;
  gap: clamp(0.9rem, 1.4vw, 1.15rem);
}

.rail-media-row {
  display: grid;
  color: inherit;
  border: 1px solid rgba(23, 19, 19, 0.12);
  border-radius: 0;
  background: #fff;
  box-shadow: 0 18px 32px rgba(23, 19, 19, 0.08);
}

.rail-media-row__body {
  display: grid;
  gap: 0.58rem;
  padding: 1.05rem 1rem 1.1rem;
  color: inherit;
  text-decoration: none;
}

.rail-media-row--interactive {
  transition:
    transform var(--transition-smooth),
    border-color var(--transition-smooth),
    background var(--transition-smooth),
    box-shadow var(--transition-smooth),
    color var(--transition-smooth);
}

.rail-media-row--interactive:hover,
.rail-media-row:has(.rail-media-row__body:focus-visible) {
  transform: translateY(-2px);
  border-color: rgba(23, 19, 19, 0.18);
  background: #fff;
  box-shadow: 0 24px 40px rgba(23, 19, 19, 0.12);
  outline: none;
}

.rail-media-row__body:focus-visible {
  outline: none;
}

.rail-media-row__head {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  gap: 0.85rem;
  align-items: start;
}

.rail-media-row__visual {
  border: 1px solid rgba(23, 19, 19, 0.08);
  background: rgba(245, 240, 235, 0.72);
}

.rail-media-row__image {
  display: block;
  width: 100%;
  height: auto;
  object-fit: contain;
  object-position: center;
}

.rail-media-row__index {
  font-family: var(--display-font);
  font-size: var(--type-size-base);
  line-height: 1;
  font-style: normal;
  font-variant-numeric: tabular-nums;
  color: rgba(98, 69, 91, 0.72);
}

.rail-media-row__meta,
.rail-media-row__action {
  font-family: var(--body-font);
  font-size: var(--rail-type-label-size);
  line-height: var(--rail-type-label-line);
  letter-spacing: var(--rail-type-label-spacing);
  text-transform: uppercase;
  font-weight: var(--rail-type-label-weight);
}

.rail-media-row__meta {
  color: rgba(23, 19, 19, 0.5);
}

.rail-media-row__action {
  color: rgba(23, 19, 19, 0.62);
  text-align: right;
}

.rail-media-row__title {
  margin: 0;
  font-family: var(--body-font);
  font-size: var(--rail-type-strong-size);
  line-height: var(--rail-type-strong-line);
  letter-spacing: var(--rail-type-strong-spacing);
  font-weight: var(--rail-type-strong-weight);
  color: rgba(23, 19, 19, 0.94);
  text-wrap: balance;
}

.rail-media-row__excerpt {
  margin: 0;
  font-family: var(--body-font);
  font-size: var(--rail-type-body-size);
  line-height: var(--rail-type-body-line);
  letter-spacing: var(--rail-type-body-spacing);
  font-weight: var(--rail-type-body-weight);
  color: rgba(23, 19, 19, 0.68);
  text-wrap: pretty;
}

.rail-media-row--interactive:hover .rail-media-row__title,
.rail-media-row:has(.rail-media-row__body:focus-visible) .rail-media-row__title,
.rail-media-row--interactive:hover .rail-media-row__action,
.rail-media-row:has(.rail-media-row__body:focus-visible) .rail-media-row__action {
  color: var(--atlas-terracotta-deep);
}

@media (max-width: 680px) {
  .rail-media-row__body {
    padding: 0.95rem 0.9rem 1rem;
  }

  .rail-media-row__head {
    grid-template-columns: auto minmax(0, 1fr);
    gap: 0.35rem 0.72rem;
  }

  .rail-media-row__action {
    grid-column: 2;
    justify-self: start;
    text-align: left;
  }
}

.rail-video-grid {
  display: grid;
  gap: 1rem;
}

.rail-video-card {
  display: grid;
  gap: 0.55rem;
  padding: 1rem;
  border: 1px solid rgba(23, 19, 19, 0.12);
  background: rgba(255, 252, 248, 0.72);
}

.rail-video-card__meta {
  display: flex;
  justify-content: space-between;
  gap: 1rem;
  font-family: var(--body-font);
  font-size: var(--rail-type-label-size);
  line-height: var(--rail-type-label-line);
  letter-spacing: var(--rail-type-label-spacing);
  text-transform: uppercase;
  font-weight: var(--rail-type-label-weight);
  color: rgba(23, 19, 19, 0.48);
}

.rail-video-card__title {
  margin: 0;
  font-family: var(--body-font);
  font-size: var(--rail-type-strong-size);
  line-height: var(--rail-type-strong-line);
  letter-spacing: var(--rail-type-strong-spacing);
  font-weight: var(--rail-type-strong-weight);
  color: rgba(23, 19, 19, 0.92);
  text-wrap: balance;
}

.rail-video-card__copy {
  margin: 0;
  font-family: var(--body-font);
  font-size: var(--rail-type-body-size);
  line-height: var(--rail-type-body-line);
  letter-spacing: var(--rail-type-body-spacing);
  font-weight: var(--rail-type-body-weight);
  color: rgba(23, 19, 19, 0.7);
  text-wrap: pretty;
}

.rail-hyperlink-list {
  display: grid;
  gap: 0;
  border-top: 1px solid rgba(23, 19, 19, 0.1);
}

.rail-hyperlink-row {
  display: grid;
  gap: 0.35rem;
  padding: 0.95rem 0;
  color: inherit;
  text-decoration: none;
  border-bottom: 1px solid rgba(23, 19, 19, 0.08);
  transition:
    opacity var(--transition-smooth),
    color var(--transition-smooth);
}

.rail-hyperlink-row:hover,
.rail-hyperlink-row:focus-visible {
  opacity: 0.76;
  outline: none;
}

.rail-hyperlink-row__head {
  display: flex;
  justify-content: space-between;
  gap: 1rem;
  align-items: baseline;
}

.rail-hyperlink-row__label,
.rail-hyperlink-row__action {
  font-family: var(--body-font);
  font-size: var(--rail-type-label-size);
  line-height: var(--rail-type-label-line);
  letter-spacing: var(--rail-type-label-spacing);
  text-transform: uppercase;
  font-weight: var(--rail-type-label-weight);
}

.rail-hyperlink-row__label {
  color: rgba(23, 19, 19, 0.72);
}

.rail-hyperlink-row__action {
  color: rgba(23, 19, 19, 0.42);
}

.rail-hyperlink-row__copy {
  margin: 0;
  font-family: var(--body-font);
  font-size: var(--rail-type-body-size);
  line-height: var(--rail-type-body-line);
  letter-spacing: var(--rail-type-body-spacing);
  font-weight: var(--rail-type-body-weight);
  color: rgba(23, 19, 19, 0.84);
  text-wrap: pretty;
}

.rail-hyperlink-row:hover .rail-hyperlink-row__label,
.rail-hyperlink-row:focus-visible .rail-hyperlink-row__label,
.rail-hyperlink-row:hover .rail-hyperlink-row__action,
.rail-hyperlink-row:focus-visible .rail-hyperlink-row__action {
  color: var(--atlas-terracotta-deep);
}

.rail-press-kit {
  display: grid;
  gap: 1rem;
  padding: 1.2rem;
  border: 1px solid rgba(23, 19, 19, 0.12);
  background:
    linear-gradient(rgba(252, 248, 243, 0.98), rgba(241, 235, 227, 0.94)),
    url("./assets/paper-texture.png");
  background-size: cover;
}

.rail-press-kit__intro {
  display: grid;
  gap: 0.45rem;
}

.rail-asset-tag-list {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
}

.rail-asset-tag {
  display: inline-flex;
  align-items: center;
  min-height: 2rem;
  padding: 0.38rem 0.7rem;
  border: 1px solid rgba(23, 19, 19, 0.1);
  background: rgba(255, 255, 255, 0.76);
  font-family: var(--body-font);
  font-size: var(--rail-type-label-size);
  line-height: var(--rail-type-label-line);
  letter-spacing: var(--rail-type-label-spacing);
  text-transform: uppercase;
  font-weight: var(--rail-type-label-weight);
  color: rgba(23, 19, 19, 0.72);
}

.rail-press-kit__includes,
.rail-press-kit__note {
  margin: 0;
  font-family: var(--body-font);
  font-size: var(--rail-type-body-size);
  line-height: var(--rail-type-body-line);
  letter-spacing: var(--rail-type-body-spacing);
  font-weight: var(--rail-type-body-weight);
  text-wrap: pretty;
}

.rail-press-kit__includes {
  color: rgba(23, 19, 19, 0.84);
}

.rail-press-kit__footer {
  display: grid;
  gap: 0.35rem;
  padding-top: 0.85rem;
  border-top: 1px solid rgba(23, 19, 19, 0.08);
}

.rail-press-kit__note {
  color: rgba(23, 19, 19, 0.58);
}

.rail-media-press-kit {
  display: grid;
  gap: 1.25rem;
  padding: 1.35rem;
  background: #090909;
  box-shadow: 0 1.1rem 2.6rem rgba(9, 7, 8, 0.28);
}

.rail-media-press-kit__body {
  display: grid;
  gap: 0.95rem;
}

.rail-media-press-kit__title,
.rail-media-press-kit__copy,
.rail-media-press-kit__asset {
  margin: 0;
  color: rgba(255, 252, 248, 0.96);
}

.rail-media-press-kit__title {
  font-family: var(--body-font);
  font-size: var(--type-size-2xl);
  line-height: 1.06;
  letter-spacing: var(--type-tracking-none);
  font-weight: 700;
  text-wrap: balance;
}

.rail-media-press-kit__copy {
  max-width: 36rem;
  font-family: var(--body-font);
  font-size: var(--rail-type-body-size);
  line-height: var(--rail-type-body-line);
  letter-spacing: var(--rail-type-body-spacing);
  font-weight: 500;
  text-wrap: pretty;
}

.rail-media-press-kit__assets {
  display: flex;
  flex-wrap: wrap;
  gap: 0.6rem 1rem;
  padding-top: 0.95rem;
  border-top: 1px solid rgba(255, 252, 248, 0.14);
}

.rail-media-press-kit__asset {
  font-family: var(--body-font);
  font-size: var(--rail-type-strong-size);
  line-height: var(--rail-type-strong-line);
  letter-spacing: var(--rail-type-strong-spacing);
  font-weight: var(--rail-type-strong-weight);
}

.rail-media-inquiries {
  display: grid;
  gap: 1rem;
  padding: 1.2rem;
  border: 1px solid rgba(98, 69, 91, 0.16);
  background:
    linear-gradient(rgba(245, 239, 233, 0.96), rgba(233, 226, 217, 0.94)),
    url("./assets/paper-texture.png");
  background-size: cover;
}

.rail-media-inquiries__head {
  display: grid;
  gap: 0.45rem;
}

.rail-media-inquiries__details {
  display: grid;
  gap: 0;
  border-top: 1px solid rgba(23, 19, 19, 0.1);
}

.rail-media-inquiries__row {
  display: grid;
  grid-template-columns: minmax(0, 7rem) minmax(0, 1fr);
  gap: 1rem;
  align-items: start;
  padding: 0.85rem 0;
  border-bottom: 1px solid rgba(23, 19, 19, 0.08);
}

.rail-media-inquiries__label {
  font-family: var(--body-font);
  font-size: var(--rail-type-label-size);
  line-height: var(--rail-type-label-line);
  letter-spacing: var(--rail-type-label-spacing);
  text-transform: uppercase;
  font-weight: var(--rail-type-label-weight);
  color: rgba(23, 19, 19, 0.5);
}

.rail-media-inquiries__value {
  margin: 0;
  min-width: 0;
  font-family: var(--body-font);
  font-size: var(--rail-type-body-size);
  line-height: var(--rail-type-body-line);
  letter-spacing: var(--rail-type-body-spacing);
  font-weight: 500;
  color: rgba(23, 19, 19, 0.86);
  overflow-wrap: anywhere;
  text-wrap: pretty;
}

.rail-media-inquiries__value--link {
  text-decoration: underline;
  text-decoration-thickness: 1px;
  text-underline-offset: 0.16em;
  transition: opacity var(--transition-smooth);
}

.rail-media-inquiries__value--link:hover,
.rail-media-inquiries__value--link:focus-visible {
  opacity: 0.66;
  outline: none;
}

.rail-media-inquiries__footer {
  padding-top: 0.15rem;
}

.rail-pill-grid,
.rail-related-grid {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
}

.rail-pill {
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
  padding: 0.42rem 0.6rem;
  background: rgba(255, 255, 255, 0.7);
  border: 1px solid rgba(23, 19, 19, 0.08);
  font-family: var(--body-font);
  font-size: var(--rail-type-micro-size);
  line-height: var(--rail-type-micro-line);
  font-weight: var(--rail-type-micro-weight);
  letter-spacing: var(--rail-type-micro-spacing);
  color: rgba(23, 19, 19, 0.74);
  transition: background var(--transition-smooth);
}

.rail-pill::before {
  content: "";
  width: 0.55rem;
  height: 0.55rem;
  background: var(--atlas-terracotta);
}

.rail-pill[data-tone="olive"]::before {
  background: var(--atlas-olive);
}

.rail-pill:hover,
.rail-pill:focus-visible {
  background: rgba(23, 19, 19, 0.04);
  outline: none;
}

.rail-bullet-list {
  margin: 0;
  padding: 0;
  list-style: none;
  display: grid;
  gap: 1.35rem;
}

.rail-bullet-list__entry {
  margin: 0;
}

.rail-bullet-item {
  display: grid;
  grid-template-columns: 2.05rem minmax(0, 1fr);
  gap: 0.95rem;
  align-items: start;
  justify-items: start;
  width: 100%;
  padding: 0;
  border: 0;
  background: transparent;
  box-shadow: none;
  text-align: left;
}

.rail-bullet-item__index {
  font-family: var(--display-font);
  font-size: var(--type-size-base);
  line-height: 1;
  font-style: normal;
  font-variant-numeric: tabular-nums;
  color: rgba(98, 69, 91, 0.72);
  transform: translateY(0.08rem);
}

.rail-bullet-item__body {
  display: grid;
  gap: var(--rail-card-title-copy-gap);
  min-width: 0;
}

.rail-bullet-item__title {
  display: block;
  font-family: var(--body-font);
  font-size: var(--rail-type-strong-size);
  line-height: var(--rail-type-strong-line);
  letter-spacing: var(--rail-type-strong-spacing);
  font-weight: var(--rail-type-strong-weight);
  color: rgba(23, 19, 19, 0.92);
}

.rail-bullet-item__copy {
  display: block;
  font-size: var(--rail-type-body-size);
  line-height: var(--rail-type-body-line);
  letter-spacing: var(--rail-type-body-spacing);
  font-weight: var(--rail-type-body-weight);
  color: rgba(23, 19, 19, 0.52);
}

.rail-bullet-item--single .rail-bullet-item__body {
  gap: 0;
}

.rail-bullet-item--single .rail-bullet-item__title {
  font-size: var(--rail-type-body-size);
  line-height: var(--rail-type-body-line);
  letter-spacing: var(--rail-type-body-spacing);
  font-weight: var(--rail-type-body-weight);
  color: rgba(23, 19, 19, 0.84);
}

.rail-bullet-item--interactive {
  position: relative;
  cursor: pointer;
  transition:
    opacity var(--transition-smooth),
    color var(--transition-smooth);
}

.rail-bullet-item--interactive:hover,
.rail-bullet-item--interactive:focus-visible {
  opacity: 0.72;
  outline: none;
}

.rail-bullet-item--interactive:hover .rail-bullet-item__title,
.rail-bullet-item--interactive:focus-visible .rail-bullet-item__title {
  color: var(--atlas-terracotta-deep);
}

.rail-partnership-benefits {
  display: grid;
  gap: 0;
  margin: 1.45rem 0 0;
  padding: 0;
  list-style: none;
  border-top: 1px solid rgba(23, 19, 19, 0.14);
}

.rail-partnership-benefits__item {
  position: relative;
  display: grid;
  grid-template-columns: 2.7rem minmax(0, 1fr);
  gap: 0.9rem;
  align-items: start;
  padding: 1rem 0 1.08rem;
  border-bottom: 1px solid rgba(23, 19, 19, 0.1);
}

.rail-partnership-benefits__item--featured {
  padding-top: 1rem;
  padding-bottom: 1.08rem;
  background: transparent;
  box-shadow: none;
  filter: none;
  backdrop-filter: none;
}

.rail-partnership-benefits__item--featured::before {
  content: none;
}

.rail-partnership-benefits__item--featured .rail-partnership-benefits__index,
.rail-partnership-benefits__item--featured .rail-partnership-benefits__title,
.rail-partnership-benefits__item--featured .rail-partnership-benefits__copy {
  text-shadow: none;
}

.rail-partnership-benefits__index,
.rail-partnership-benefits__body {
  position: relative;
  z-index: 1;
}

.rail-partnership-benefits__index {
  margin: 0;
  font-family: var(--display-font);
  font-size: var(--type-size-xl);
  line-height: 1.05;
  letter-spacing: 0.05em;
  font-variant-numeric: tabular-nums;
  color: rgba(98, 69, 91, 0.76);
  transform: translateY(0.18rem);
}

.rail-partnership-benefits__item--featured .rail-partnership-benefits__index {
  font-size: var(--type-size-xl);
  line-height: 1.05;
  letter-spacing: 0.05em;
  color: rgba(98, 69, 91, 0.76);
  transform: translateY(0.18rem);
}

.rail-partnership-benefits__body {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: 0.35rem;
  align-items: start;
}

.rail-partnership-benefits__item--featured .rail-partnership-benefits__body {
  grid-template-columns: minmax(0, 1fr);
  gap: 0.35rem;
  max-width: none;
}

.rail-partnership-benefits__title,
.rail-partnership-benefits__copy {
  margin: 0;
}

.rail-partnership-benefits__title {
  font-family: var(--body-font);
  font-size: var(--type-size-base);
  line-height: 1.06;
  letter-spacing: var(--type-tracking-none);
  font-weight: 700;
  color: rgba(23, 19, 19, 0.94);
  text-wrap: balance;
}

.rail-partnership-benefits__item:not(.rail-partnership-benefits__item--featured) .rail-partnership-benefits__title {
  max-width: none;
}

.rail-partnership-benefits__item--featured .rail-partnership-benefits__title {
  font-size: var(--type-size-base);
  line-height: 1.06;
  letter-spacing: var(--type-tracking-none);
  max-width: none;
}

.rail-partnership-benefits__copy {
  max-width: 38ch;
  font-family: var(--body-font);
  font-size: var(--type-size-base);
  line-height: 1.34;
  letter-spacing: var(--type-tracking-none);
  font-weight: 500;
  color: rgba(23, 19, 19, 0.64);
  text-wrap: pretty;
}

.content-panel[data-surface="terracotta"] .content-panel__inner .rail-partnership-benefits {
  border-top-color: rgba(245, 240, 235, 0.2);
}

.content-panel[data-surface="terracotta"] .content-panel__inner .rail-partnership-benefits__item {
  border-bottom-color: rgba(245, 240, 235, 0.16);
}

.content-panel[data-surface="terracotta"] .content-panel__inner .rail-partnership-benefits__index {
  color: rgba(245, 240, 235, 0.64);
}

.content-panel[data-surface="terracotta"] .content-panel__inner .rail-partnership-benefits__item--featured .rail-partnership-benefits__index {
  color: rgba(245, 240, 235, 0.64);
}

.content-panel[data-surface="terracotta"] .content-panel__inner .rail-partnership-benefits__title {
  color: rgba(245, 240, 235, 0.97);
}

.content-panel[data-surface="terracotta"] .content-panel__inner .rail-partnership-benefits__copy {
  color: rgba(245, 240, 235, 0.82);
}

.rail-cta {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.2rem;
  width: fit-content;
  min-height: 2.75rem;
  padding: 0.72rem 1rem;
  border: 1px solid rgba(23, 19, 19, 0.28);
  background: var(--atlas-ink);
  box-shadow: 0 0.55rem 1.25rem rgba(23, 19, 19, 0.16);
  color: var(--atlas-paper);
  text-decoration: none;
  font-family: var(--body-font);
  font-size: var(--rail-type-strong-size);
  line-height: var(--rail-type-strong-line);
  font-weight: var(--rail-type-strong-weight);
  letter-spacing: var(--rail-type-strong-spacing);
  transition:
    background var(--transition-smooth),
    color var(--transition-smooth),
    border-color var(--transition-smooth),
    box-shadow var(--transition-smooth),
    transform var(--transition-smooth);
}

.rail-cta::after {
  content: "";
  flex: 0 0 auto;
  margin-left: 0.35rem;
  width: 0.62rem;
  height: 0.62rem;
  border-top: 1.5px solid currentColor;
  border-right: 1.5px solid currentColor;
  transform: translateY(0.08rem) rotate(45deg);
}

.rail-cta:hover,
.rail-cta:focus-visible {
  background: #0f0c0d;
  box-shadow: 0 0.85rem 1.55rem rgba(9, 7, 8, 0.22);
  transform: translateY(-1px);
  outline: none;
}

.rail-cta--button {
  /* Alias retained for compatibility with older markup. */
}

.rail-cta--button:hover,
.rail-cta--button:focus-visible {
  opacity: 1;
}

.rail-cta--button-inverse {
  color: var(--atlas-ink);
  border-color: rgba(245, 240, 235, 0.16);
  background: rgba(255, 252, 248, 0.96);
  box-shadow: 0 0.7rem 1.6rem rgba(9, 7, 8, 0.24);
}

.rail-cta--button-inverse:hover,
.rail-cta--button-inverse:focus-visible {
  background: rgba(255, 255, 255, 1);
  box-shadow: 0 0.9rem 1.9rem rgba(9, 7, 8, 0.28);
}

.rail-cta--light-outline {
  color: rgba(255, 252, 248, 0.96);
  border-color: rgba(255, 252, 248, 0.22);
  background: transparent;
  box-shadow: none;
}

.rail-cta--light-outline:hover,
.rail-cta--light-outline:focus-visible {
  background: rgba(255, 252, 248, 0.96);
  color: #090909;
  box-shadow: none;
}

.rail-meta-stack {
  display: grid;
  gap: 0.32rem;
}

.rail-meta-stack--hero {
  gap: 0;
  border-top: 1px solid rgba(23, 19, 19, 0.12);
  border-bottom: 1px solid rgba(23, 19, 19, 0.12);
}

.rail-meta-stack__row {
  display: grid;
  grid-template-columns: minmax(0, 9.5rem) minmax(0, 1fr);
  gap: 1rem;
  align-items: start;
  padding: 0.875rem 0;
}

.rail-meta-stack__row + .rail-meta-stack__row {
  border-top: 1px solid rgba(23, 19, 19, 0.08);
}

.rail-meta-stack__label {
  margin: 0;
  font-family: var(--body-font);
  font-weight: var(--rail-type-label-weight);
  font-size: var(--rail-type-label-size);
  line-height: var(--rail-type-label-line);
  letter-spacing: var(--rail-type-label-spacing);
  text-transform: uppercase;
  color: rgba(23, 19, 19, 0.48);
}

.rail-meta-stack__value {
  margin: 0;
  font-family: var(--body-font);
  font-size: var(--rail-type-body-size);
  line-height: var(--rail-type-body-line);
  letter-spacing: var(--rail-type-body-spacing);
  font-weight: var(--rail-type-body-weight);
  color: rgba(23, 19, 19, 0.82);
}

.rail-meta-stack__value-link {
  text-decoration: underline;
  text-decoration-thickness: 1px;
  text-underline-offset: 0.16em;
  transition: opacity var(--transition-smooth);
}

.rail-meta-stack__value-link:hover,
.rail-meta-stack__value-link:focus-visible {
  opacity: 0.66;
  outline: none;
}

.rail-meta-stack__item {
  margin: 0;
  font-family: var(--body-font);
  font-size: var(--rail-type-body-size);
  line-height: var(--rail-type-body-line);
  letter-spacing: var(--rail-type-body-spacing);
  font-weight: var(--rail-type-body-weight);
  color: rgba(23, 19, 19, 0.68);
}

.rail-practical-card {
  display: grid;
  gap: 0;
  border: 1px solid rgba(23, 19, 19, 0.14);
  background: rgba(235, 226, 216, 0.72);
}

.rail-practical-card__banner {
  display: grid;
  gap: 0.5rem;
  padding: 1rem 1rem 1.05rem;
  background: rgba(23, 19, 19, 0.92);
  color: var(--atlas-paper);
}

.rail-practical-card__eyebrow {
  margin: 0;
  font-family: var(--body-font);
  font-size: var(--rail-type-label-size);
  line-height: var(--rail-type-label-line);
  letter-spacing: var(--rail-type-label-spacing);
  text-transform: uppercase;
  font-weight: var(--rail-type-label-weight);
  color: rgba(245, 240, 235, 0.58);
}

.rail-practical-card__venue {
  margin: 0;
  font-family: var(--body-font);
  font-size: var(--rail-type-strong-size);
  line-height: var(--rail-type-strong-line);
  letter-spacing: var(--rail-type-strong-spacing);
  font-weight: var(--rail-type-strong-weight);
  color: var(--atlas-paper);
}

.rail-practical-card__venue-link {
  text-decoration: none;
  border-bottom: 1px solid rgba(245, 240, 235, 0.38);
  transition:
    opacity var(--transition-smooth),
    border-color var(--transition-smooth);
}

.rail-practical-card__venue-link:hover,
.rail-practical-card__venue-link:focus-visible {
  opacity: 0.88;
  border-color: rgba(245, 240, 235, 0.72);
  outline: none;
}

.rail-practical-card__body {
  display: grid;
  gap: 0;
  padding: 1rem;
}

.rail-practical-card__date {
  margin: 0;
  font-family: var(--body-font);
  font-size: var(--rail-type-display-size);
  line-height: var(--rail-type-display-line);
  letter-spacing: var(--rail-type-display-spacing);
  font-weight: var(--rail-type-display-weight);
  color: rgba(23, 19, 19, 0.98);
}

.rail-practical-card__schedule {
  margin: 1rem 0 0;
  display: grid;
  gap: 0;
  border-top: 1px solid rgba(23, 19, 19, 0.1);
}

.rail-practical-card__schedule-row {
  display: grid;
  grid-template-columns: minmax(0, 9rem) minmax(0, 1fr);
  gap: 1rem;
  align-items: start;
  padding: 0.875rem 0;
}

.rail-practical-card__schedule-row + .rail-practical-card__schedule-row {
  border-top: 1px solid rgba(23, 19, 19, 0.08);
}

.rail-practical-card__schedule dt {
  margin: 0;
  font-family: var(--body-font);
  font-size: var(--rail-type-label-size);
  line-height: var(--rail-type-label-line);
  letter-spacing: var(--rail-type-label-spacing);
  text-transform: uppercase;
  font-weight: var(--rail-type-label-weight);
  color: rgba(23, 19, 19, 0.5);
}

.rail-practical-card__schedule dd {
  margin: 0;
  font-family: var(--body-font);
  font-size: var(--rail-type-body-size);
  line-height: var(--rail-type-body-line);
  letter-spacing: var(--rail-type-body-spacing);
  font-weight: var(--rail-type-body-weight);
  color: rgba(23, 19, 19, 0.84);
}

.rail-detail-sheet {
  display: grid;
  gap: 0;
  border-top: 1px solid rgba(23, 19, 19, 0.12);
}

.rail-detail-sheet__standalone {
  margin: 0;
  padding: 1rem 0 0.1rem;
  font-family: var(--body-font);
  font-size: var(--type-size-lg);
  line-height: 1.55;
  letter-spacing: var(--type-tracking-none);
  font-weight: 500;
  color: rgba(23, 19, 19, 0.86);
}

.rail-detail-sheet__name-link {
  font-weight: inherit;
}

.rail-detail-sheet__row {
  display: grid;
  grid-template-columns: minmax(0, 11rem) minmax(0, 1fr);
  gap: 1.1rem;
  align-items: start;
  padding: 1rem 0;
  border-bottom: 1px solid rgba(23, 19, 19, 0.08);
}

.rail-detail-sheet__label {
  margin: 0;
  font-family: var(--body-font);
  font-weight: var(--rail-type-label-weight);
  font-size: var(--rail-type-label-size);
  line-height: var(--rail-type-label-line);
  letter-spacing: var(--rail-type-label-spacing);
  text-transform: uppercase;
  color: rgba(23, 19, 19, 0.48);
}

.rail-detail-sheet__value {
  display: grid;
  gap: 0.42rem;
}

.rail-detail-sheet__value-line {
  margin: 0;
  font-family: var(--body-font);
  font-size: var(--type-size-base);
  line-height: 1.5;
  letter-spacing: var(--type-tracking-none);
  font-weight: 500;
  color: rgba(23, 19, 19, 0.84);
}

.rail-detail-sheet__value-key {
  font-weight: 600;
  color: rgba(23, 19, 19, 0.92);
}

.rail-detail-sheet__value-link {
  text-decoration: underline;
  text-decoration-thickness: 1px;
  text-underline-offset: 0.16em;
  transition: opacity var(--transition-smooth);
}

.rail-detail-sheet__value-link:hover,
.rail-detail-sheet__value-link:focus-visible {
  opacity: 0.66;
  outline: none;
}

.rail-gallery {
  display: grid;
  gap: 1.5rem;
}

.rail-gallery--carousel {
  display: grid;
  grid-auto-flow: column;
  grid-auto-columns: minmax(16rem, 22rem);
  gap: 1rem;
  overflow-x: auto;
  overflow-y: hidden;
  padding-bottom: 0.45rem;
  scroll-snap-type: x proximity;
  scrollbar-width: thin;
}

.rail-gallery__figure {
  margin: 0;
  display: grid;
  gap: 0.7rem;
}

.rail-gallery--carousel .rail-gallery__figure {
  min-width: 0;
  align-content: start;
  scroll-snap-align: start;
}

.rail-gallery__media {
  overflow: visible;
  padding: 0;
  border: 0;
  background: transparent;
}

.rail-gallery--carousel .rail-gallery__media {
  background: rgba(255, 252, 248, 0.46);
}

.rail-gallery__image {
  display: block;
  width: 100%;
  height: auto;
  max-height: none;
  object-fit: initial;
}

.rail-gallery--carousel .rail-gallery__image {
  aspect-ratio: 4 / 5;
  object-fit: cover;
}

.rail-gallery__placeholder {
  display: grid;
  place-items: center;
  width: 100%;
  aspect-ratio: 1 / 1;
  padding: 1.5rem;
  background:
    linear-gradient(rgba(252, 248, 243, 0.98), rgba(241, 235, 227, 0.94)),
    url("./assets/paper-texture.png");
  background-size: cover;
  color: rgba(23, 19, 19, 0.44);
}

.rail-gallery__placeholder-label {
  font-family: var(--body-font);
  font-size: var(--type-size-md);
  line-height: 1.45;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  text-align: center;
}

.rail-gallery__caption {
  display: flex;
  gap: 0.45rem;
  align-items: baseline;
  margin: 0;
  font-family: var(--body-font);
  font-size: var(--type-size-base);
  line-height: 1.45;
  letter-spacing: var(--type-tracking-none);
  font-weight: 500;
  color: rgba(23, 19, 19, 0.76);
}

.rail-gallery__caption-mark {
  flex: none;
  color: rgba(23, 19, 19, 0.52);
}

.rail-panel-section--travel-extended {
  position: relative;
  display: grid;
  gap: clamp(1.2rem, 2vw, 1.7rem);
  padding: clamp(1.15rem, 1.8vw, 1.45rem);
  border: 0;
  background:
    linear-gradient(180deg, rgba(245, 239, 233, 0.98), rgba(233, 226, 217, 0.95)),
    url("./assets/paper-texture.png");
  background-size: cover;
  overflow: hidden;
}

.rail-panel-section--travel-extended::after {
  content: "";
  position: absolute;
  top: -7rem;
  right: -7rem;
  width: 14rem;
  height: 14rem;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(98, 69, 91, 0.14) 0%, rgba(98, 69, 91, 0.04) 42%, transparent 72%);
  pointer-events: none;
}

.rail-panel-section--about-partnerships {
  background:
    linear-gradient(180deg, rgba(255, 252, 248, 0.98), rgba(248, 244, 238, 0.96)),
    url("./assets/paper-texture.png");
  border-color: rgba(23, 19, 19, 0.14);
}

.rail-panel-section--about-partnerships::before {
  display: none;
}

.rail-panel-section--about-partnerships::after {
  display: none;
}

.rail-travel-hero {
  position: relative;
  z-index: 1;
  display: grid;
  gap: 0.9rem;
  align-items: start;
}

.rail-travel-hero__copy {
  display: grid;
  gap: 1rem;
}

.rail-panel-section--travel-extended .rail-summary + .rail-panel-copy {
  margin-top: 0;
}

.rail-travel-route {
  position: relative;
  z-index: 1;
  display: grid;
  gap: 0.72rem;
  padding: 0.95rem 1rem 1rem;
  border: 1px solid rgba(98, 69, 91, 0.14);
  background: linear-gradient(180deg, rgba(98, 69, 91, 0.04), rgba(255, 255, 255, 0.22));
}

.rail-travel-route__label,
.rail-travel-block-label {
  margin: 0;
  padding-top: 0.78rem;
  border-top: 1px solid rgba(23, 19, 19, 0.12);
  font-family: var(--body-font);
  font-size: var(--rail-type-label-size);
  line-height: var(--rail-type-label-line);
  letter-spacing: var(--rail-type-label-spacing);
  text-transform: uppercase;
  font-weight: var(--rail-type-label-weight);
  color: rgba(23, 19, 19, 0.54);
}

.rail-travel-route__label {
  padding-top: 0;
  border-top: 0;
}

.rail-travel-route__track {
  position: relative;
  display: grid;
  gap: 0.8rem;
  padding-left: 1rem;
}

.rail-travel-route__track::before {
  content: "";
  position: absolute;
  left: 0.22rem;
  top: 0.34rem;
  bottom: 0.38rem;
  width: 1px;
  background: rgba(98, 69, 91, 0.26);
}

.rail-travel-stop {
  position: relative;
  display: grid;
  gap: 0.18rem;
}

.rail-travel-stop::before {
  content: "";
  position: absolute;
  top: 0.34rem;
  left: -1rem;
  width: 0.46rem;
  height: 0.46rem;
  border-radius: 50%;
  background: var(--atlas-terracotta-deep);
  box-shadow: 0 0 0 0.18rem rgba(195, 110, 98, 0.16);
}

.rail-travel-stop__year {
  margin: 0;
  font-family: var(--display-font);
  font-size: var(--type-size-base);
  line-height: 1;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--atlas-plum-deep);
}

.rail-travel-stop__cities {
  margin: 0;
  font-family: var(--body-font);
  font-size: var(--rail-type-strong-size);
  line-height: var(--rail-type-strong-line);
  letter-spacing: var(--rail-type-strong-spacing);
  font-weight: var(--rail-type-strong-weight);
  color: var(--atlas-ink);
  text-wrap: balance;
}

.rail-travel-stop__note {
  margin: 0;
  font-family: var(--body-font);
  font-size: var(--rail-type-meta-size);
  line-height: var(--rail-type-meta-line);
  letter-spacing: var(--rail-type-meta-spacing);
  font-weight: 500;
  color: rgba(23, 19, 19, 0.54);
}

.rail-travel-brochure {
  position: relative;
  z-index: 1;
  display: grid;
  gap: 0.95rem;
  padding: 0.95rem;
  border: 1px solid rgba(98, 69, 91, 0.14);
  background: linear-gradient(180deg, rgba(255, 252, 248, 0.48), rgba(255, 252, 248, 0.18));
}

.rail-travel-brochure__preview {
  display: block;
  margin: 0;
  overflow: hidden;
  border: 1px solid rgba(23, 19, 19, 0.16);
  background: rgba(255, 252, 248, 0.82);
  box-shadow: 0 0.8rem 1.8rem rgba(23, 19, 19, 0.12);
}

.rail-travel-brochure__image {
  display: block;
  width: 100%;
  height: auto;
}

.rail-travel-brochure__body {
  display: grid;
  gap: 0.45rem;
}

.rail-travel-brochure__label {
  margin: 0;
  font-family: var(--body-font);
  font-size: var(--rail-type-label-size);
  line-height: var(--rail-type-label-line);
  letter-spacing: var(--rail-type-label-spacing);
  text-transform: uppercase;
  font-weight: var(--rail-type-label-weight);
  color: rgba(23, 19, 19, 0.52);
}

.rail-travel-brochure__title {
  margin: 0;
  font-family: var(--body-font);
  font-size: var(--rail-type-strong-size);
  line-height: var(--rail-type-strong-line);
  letter-spacing: var(--rail-type-strong-spacing);
  font-weight: var(--rail-type-strong-weight);
  color: var(--atlas-ink);
}

.rail-travel-brochure__copy {
  margin: 0;
  font-family: var(--body-font);
  font-size: var(--rail-type-meta-size);
  line-height: var(--rail-type-meta-line);
  letter-spacing: var(--rail-type-meta-spacing);
  font-weight: 500;
  color: rgba(23, 19, 19, 0.62);
}

.rail-travel-story,
.rail-travel-value {
  position: relative;
  z-index: 1;
  display: grid;
  gap: 0.85rem;
}

.rail-travel-benefits {
  display: grid;
  gap: 0;
  margin: 0;
  padding: 0;
  list-style: none;
  counter-reset: none;
}

.rail-travel-benefits__item {
  display: grid;
  grid-template-columns: 2.1rem minmax(0, 1fr);
  gap: 0.3rem 0.8rem;
  margin: 0;
  padding: 0.9rem 0;
  border-top: 1px solid rgba(23, 19, 19, 0.08);
}

.rail-travel-benefits__index {
  margin: 0;
  font-family: var(--display-font);
  font-size: var(--type-size-base);
  line-height: 1;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--atlas-terracotta-deep);
}

.rail-travel-benefits__text {
  margin: 0;
  font-family: var(--body-font);
  font-size: var(--rail-type-body-size);
  line-height: var(--rail-type-body-line);
  letter-spacing: var(--rail-type-body-spacing);
  font-weight: var(--rail-type-body-weight);
  color: rgba(23, 19, 19, 0.84);
  text-wrap: pretty;
}

.rail-travel-footer {
  position: relative;
  z-index: 1;
  display: grid;
  gap: 0.9rem;
  align-items: start;
  padding-top: 0.3rem;
  border-top: 1px solid rgba(23, 19, 19, 0.08);
}

.rail-travel-contact {
  display: grid;
  gap: 0.28rem;
  padding: 0.95rem 1rem;
  border: 1px solid rgba(98, 69, 91, 0.12);
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.26), rgba(255, 255, 255, 0.08));
}

.rail-travel-contact__label {
  margin: 0;
  font-family: var(--body-font);
  font-weight: var(--rail-type-label-weight);
  font-size: var(--rail-type-label-size);
  line-height: var(--rail-type-label-line);
  letter-spacing: var(--rail-type-label-spacing);
  text-transform: uppercase;
  color: rgba(23, 19, 19, 0.48);
}

.rail-travel-contact__link {
  width: fit-content;
  text-decoration: underline;
  text-decoration-thickness: 1px;
  text-underline-offset: 0.16em;
  font-family: var(--body-font);
  font-size: var(--type-size-base);
  line-height: 1.5;
  letter-spacing: var(--type-tracking-none);
  font-weight: 500;
  color: rgba(23, 19, 19, 0.86);
  transition: opacity var(--transition-smooth);
}

.rail-panel-section--travel-extended .rail-cta {
  margin-top: 0;
  justify-content: space-between;
  width: 100%;
  padding: 0.92rem 1.05rem 0.94rem;
  border: 1px solid rgba(23, 19, 19, 0.92);
  background: var(--atlas-ink);
  color: var(--atlas-paper);
  box-shadow: 0 1.2rem 2.8rem rgba(23, 19, 19, 0.26);
}

.rail-panel-section--travel-extended .rail-cta::after {
  margin-left: 0.8rem;
}

.rail-panel-section--travel-extended .rail-cta:hover,
.rail-panel-section--travel-extended .rail-cta:focus-visible {
  opacity: 1;
  background: #0f0c0d;
  border-color: #0f0c0d;
  color: var(--atlas-paper);
}

.rail-travel-contact__link:hover,
.rail-travel-contact__link:focus-visible {
  opacity: 0.66;
  outline: none;
}

.rail-artist-list {
  display: grid;
  gap: 0;
  border-top: 1px solid rgba(23, 19, 19, 0.12);
}

.rail-artist-row {
  display: grid;
  grid-template-columns: 2.5rem minmax(0, 1fr) auto;
  gap: 1rem;
  align-items: start;
  width: 100%;
  padding: 0.95rem 0;
  border: 0;
  border-bottom: 1px solid rgba(23, 19, 19, 0.08);
  background: transparent;
  text-align: left;
}

.rail-artist-row--interactive {
  cursor: pointer;
  transition:
    opacity var(--transition-smooth),
    color var(--transition-smooth);
}

.rail-artist-row--interactive:hover,
.rail-artist-row--interactive:focus-visible {
  opacity: 0.78;
  outline: none;
}

.rail-artist-row__index,
.rail-artist-row__link-label {
  margin: 0;
  font-family: var(--body-font);
  font-size: var(--rail-type-label-size);
  line-height: var(--rail-type-label-line);
  letter-spacing: var(--rail-type-label-spacing);
  text-transform: uppercase;
  font-weight: var(--rail-type-label-weight);
  color: rgba(23, 19, 19, 0.48);
}

.rail-artist-row__body {
  display: grid;
  gap: 0.24rem;
  min-width: 0;
}

.rail-artist-row__name,
.rail-artist-row__work {
  margin: 0;
}

.rail-artist-row__name {
  font-family: var(--body-font);
  font-size: var(--type-size-lg);
  line-height: 1.3;
  letter-spacing: var(--type-tracking-none);
  font-weight: 600;
  color: rgba(23, 19, 19, 0.92);
}

.rail-artist-row__work {
  font-family: var(--body-font);
  font-size: var(--type-size-base);
  line-height: 1.5;
  letter-spacing: var(--type-tracking-none);
  font-weight: 500;
  color: rgba(23, 19, 19, 0.74);
}

.rail-artist-row--interactive:hover .rail-artist-row__name,
.rail-artist-row--interactive:focus-visible .rail-artist-row__name,
.rail-artist-row--interactive:hover .rail-artist-row__link-label,
.rail-artist-row--interactive:focus-visible .rail-artist-row__link-label {
  color: var(--atlas-terracotta-deep);
}

.content-panel[data-surface="terracotta"] .content-panel__inner .rail-panel-section--artist-list .rail-artist-row--interactive:hover .rail-artist-row__name,
.content-panel[data-surface="terracotta"] .content-panel__inner .rail-panel-section--artist-list .rail-artist-row--interactive:focus-visible .rail-artist-row__name,
.content-panel[data-surface="terracotta"] .content-panel__inner .rail-panel-section--artist-list .rail-artist-row--interactive:hover .rail-artist-row__link-label,
.content-panel[data-surface="terracotta"] .content-panel__inner .rail-panel-section--artist-list .rail-artist-row--interactive:focus-visible .rail-artist-row__link-label {
  color: var(--rail-surface-text);
}

.content-panel[data-surface="terracotta"] .content-panel__inner .rail-hyperlink-row:hover .rail-hyperlink-row__label,
.content-panel[data-surface="terracotta"] .content-panel__inner .rail-hyperlink-row:focus-visible .rail-hyperlink-row__label,
.content-panel[data-surface="terracotta"] .content-panel__inner .rail-hyperlink-row:hover .rail-hyperlink-row__action,
.content-panel[data-surface="terracotta"] .content-panel__inner .rail-hyperlink-row:focus-visible .rail-hyperlink-row__action,
.content-panel[data-surface="terracotta"] .content-panel__inner .rail-bullet-item--interactive:hover .rail-bullet-item__title,
.content-panel[data-surface="terracotta"] .content-panel__inner .rail-bullet-item--interactive:focus-visible .rail-bullet-item__title,
.content-panel[data-surface="terracotta"] .content-panel__inner .rail-contributor-directory__name-button:hover,
.content-panel[data-surface="terracotta"] .content-panel__inner .rail-contributor-directory__name-button:focus-visible {
  color: var(--rail-surface-text);
}

.rail-archive__header,
.rail-archive__row {
  display: flex;
  align-items: flex-start;
  gap: 0.9375rem;
}

.rail-archive__header {
  margin-top: 3.125rem;
}

.rail-archive--compact .rail-archive__header {
  margin-top: 0;
}

.rail-archive__list {
  margin-top: 0.9375rem;
  display: flex;
  flex-direction: column;
  gap: 0.9375rem;
}

.rail-archive__label {
  font-family: var(--body-font);
  font-size: var(--rail-type-label-size);
  line-height: var(--rail-type-label-line);
  letter-spacing: var(--rail-type-label-spacing);
  text-transform: uppercase;
  font-weight: var(--rail-type-label-weight);
  color: rgba(23, 19, 19, 0.52);
}

.rail-archive__label:nth-child(1),
.rail-archive__primary {
  flex: 0 0 50%;
}

.rail-archive__label:nth-child(2),
.rail-archive__label:nth-child(3),
.rail-archive__meta {
  flex: 0 0 calc(25% - 0.9375rem);
}

.rail-archive__row {
  width: 100%;
  text-align: left;
  transition: opacity var(--transition-smooth);
}

.rail-archive__row:hover,
.rail-archive__row:focus-visible {
  opacity: 0.66;
  outline: none;
}

.rail-archive__primary {
  display: flex;
  flex-direction: column;
}

.rail-archive__title {
  font-family: var(--body-font);
  font-size: var(--rail-type-strong-size);
  line-height: var(--rail-type-strong-line);
  letter-spacing: var(--rail-type-strong-spacing);
  color: var(--atlas-ink);
  font-weight: var(--rail-type-strong-weight);
}

.rail-archive__subtitle {
  margin-top: 0.22rem;
  font-family: var(--body-font);
  font-size: var(--rail-type-meta-size);
  line-height: var(--rail-type-meta-line);
  letter-spacing: var(--rail-type-meta-spacing);
  font-weight: var(--rail-type-meta-weight);
  color: rgba(23, 19, 19, 0.5);
}

.rail-archive__meta {
  font-family: var(--body-font);
  font-size: var(--rail-type-meta-size);
  line-height: var(--rail-type-meta-line);
  letter-spacing: var(--rail-type-meta-spacing);
  font-weight: var(--rail-type-meta-weight);
  color: rgba(23, 19, 19, 0.62);
  text-align: left;
}

.rail-about-subsections {
  display: grid;
  gap: 1rem;
}

.rail-panel-section--about-mission {
  padding: 1rem;
  border: 1px solid rgba(23, 19, 19, 0.12);
  background: rgba(255, 252, 248, 0.68);
}

.rail-panel-section--about-mission .rail-summary--statement {
  color: rgba(23, 19, 19, 0.92);
}

.content-panel[data-surface="terracotta"] .content-panel__inner .rail-panel-section--about-mission,
.content-panel[data-surface="olive"] .content-panel__inner .rail-panel-section--about-mission,
.content-panel[data-surface="plum"] .content-panel__inner .rail-panel-section--about-mission,
.content-panel[data-surface="red"] .content-panel__inner .rail-panel-section--about-mission {
  border-color: rgba(23, 19, 19, 0.12);
  background: rgba(255, 249, 245, 0.92);
  box-shadow: 0 16px 34px rgba(23, 19, 19, 0.08);
}

.content-panel[data-surface="terracotta"] .content-panel__inner .rail-panel-section--about-mission .rail-about-section-title,
.content-panel[data-surface="olive"] .content-panel__inner .rail-panel-section--about-mission .rail-about-section-title,
.content-panel[data-surface="plum"] .content-panel__inner .rail-panel-section--about-mission .rail-about-section-title,
.content-panel[data-surface="red"] .content-panel__inner .rail-panel-section--about-mission .rail-about-section-title {
  color: rgba(23, 19, 19, 0.84);
}

.content-panel[data-surface="terracotta"] .content-panel__inner .rail-panel-section--about-mission .rail-summary--statement,
.content-panel[data-surface="olive"] .content-panel__inner .rail-panel-section--about-mission .rail-summary--statement,
.content-panel[data-surface="plum"] .content-panel__inner .rail-panel-section--about-mission .rail-summary--statement,
.content-panel[data-surface="red"] .content-panel__inner .rail-panel-section--about-mission .rail-summary--statement {
  color: rgba(23, 19, 19, 0.94);
}

.rail-about-city-list {
  display: grid;
  gap: 1rem;
}

/* Shared card tokens — keep profile / essayist / artist / about-city cards visually consistent */
.rail-profile-card,
.rail-essayist-card,
.rail-artist-card,
.rail-about-city-card {
  --card-pad: 1rem;
  --card-border: 1px solid rgba(23, 19, 19, 0.12);
  --card-bg: rgba(255, 252, 247, 0.92);
  --card-shadow: 0 12px 24px rgba(23, 19, 19, 0.05);
  --card-bg-hover: rgba(255, 255, 252, 0.98);
  --card-border-hover: 1px solid rgba(23, 19, 19, 0.2);
  --card-shadow-hover: 0 18px 30px rgba(23, 19, 19, 0.09);
}

.rail-about-city-card {
  display: grid;
  gap: 0.72rem;
  width: 100%;
  padding: var(--card-pad);
  border: var(--card-border);
  border-radius: 0;
  background: var(--card-bg);
  text-align: left;
  color: inherit;
  text-decoration: none;
  box-shadow: var(--card-shadow);
  transition:
    transform var(--transition-smooth),
    background var(--transition-smooth),
    border-color var(--transition-smooth),
    box-shadow var(--transition-smooth);
}

.rail-about-city-card--interactive {
  cursor: pointer;
}

.rail-about-city-card--interactive:hover,
.rail-about-city-card--interactive:focus-visible {
  transform: translateY(-0.12rem);
  background: var(--card-bg-hover);
  border: var(--card-border-hover);
  box-shadow: var(--card-shadow-hover);
  outline: none;
}

.rail-about-city-card__media {
  position: relative;
  width: 100%;
  aspect-ratio: 16 / 8.6;
  overflow: hidden;
  border: 1px solid rgba(23, 19, 19, 0.14);
  background-color: rgba(23, 19, 19, 0.08);
  background-position: var(--media-position, center);
  background-repeat: no-repeat;
  background-size: cover;
}

.rail-about-city-card__index {
  margin: 0;
  font-family: var(--body-font);
  font-size: var(--rail-type-label-size);
  line-height: var(--rail-type-label-line);
  letter-spacing: var(--rail-type-label-spacing);
  text-transform: uppercase;
  font-weight: var(--rail-type-label-weight);
  color: rgba(23, 19, 19, 0.56);
}

.rail-about-city-card__title {
  margin: 0;
  font-family: var(--body-font);
  font-size: var(--rail-type-strong-size);
  line-height: var(--rail-type-strong-line);
  letter-spacing: var(--rail-type-strong-spacing);
  font-weight: var(--rail-type-strong-weight);
  color: var(--atlas-ink);
  text-wrap: balance;
}

.rail-profile-card__title {
  margin: 0;
  font-family: var(--body-font);
  font-size: var(--rail-type-strong-size);
  line-height: var(--rail-type-strong-line);
  letter-spacing: var(--rail-type-strong-spacing);
  font-weight: var(--rail-type-strong-weight);
  color: var(--atlas-ink);
  text-wrap: balance;
}

.rail-about-city-card__copy,
.rail-profile-card__bio {
  margin: 0;
  font-family: var(--body-font);
  font-size: var(--rail-type-body-size);
  line-height: var(--rail-type-body-line);
  letter-spacing: var(--rail-type-body-spacing);
  font-weight: var(--rail-type-body-weight);
  color: rgba(23, 19, 19, 0.82);
  text-wrap: pretty;
}

.rail-profile-list {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: 0.9rem;
}

.rail-profile-card {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  align-items: start;
  gap: 0.85rem;
  width: 100%;
  padding: var(--card-pad);
  border: var(--card-border);
  border-radius: 0;
  background: var(--card-bg);
  text-align: left;
  box-shadow: var(--card-shadow);
  transition:
    transform var(--transition-smooth),
    background var(--transition-smooth),
    border-color var(--transition-smooth),
    box-shadow var(--transition-smooth);
}

.rail-profile-card--no-media {
  grid-template-columns: minmax(0, 1fr);
}

.rail-profile-card--interactive {
  cursor: pointer;
}

.rail-profile-card--interactive:hover,
.rail-profile-card--interactive:focus-visible {
  transform: translateY(-0.12rem);
  background: var(--card-bg-hover);
  border: var(--card-border-hover);
  box-shadow: var(--card-shadow-hover);
  outline: none;
}

.rail-profile-card__media {
  position: relative;
  overflow: hidden;
  width: 100%;
  aspect-ratio: 1;
  min-height: 0;
  background:
    linear-gradient(rgba(77, 55, 71, 0.08), rgba(77, 55, 71, 0.08)),
    url("./assets/team/radial.png") center 42% / 145% auto no-repeat,
    var(--atlas-plum);
  align-self: auto;
}

.rail-profile-card__media::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 0;
  background: radial-gradient(circle at 50% 36%, rgba(245, 240, 235, 0.2), transparent 44%);
  pointer-events: none;
}

.rail-profile-card__image {
  position: relative;
  z-index: 1;
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  background: transparent;
  filter: grayscale(1);
}

.rail-profile-card__placeholder {
  display: grid;
  place-items: center;
  width: 100%;
  height: 100%;
  background:
    linear-gradient(135deg, rgba(111, 83, 105, 0.96), rgba(84, 61, 80, 0.98)),
    url("./assets/paper-texture.png");
  background-size: cover;
}

.rail-profile-card__placeholder-text {
  font-family: var(--body-font);
  font-size: var(--type-size-xl);
  line-height: 1;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  font-weight: 700;
  color: rgba(255, 245, 239, 0.9);
}

.rail-profile-card__body {
  display: grid;
  align-content: start;
  gap: 0.6rem;
  min-width: 0;
}

.rail-profile-card__head {
  display: grid;
  gap: 0.3rem;
}

.rail-profile-card__title-block {
  display: grid;
  gap: 0.22rem;
  min-width: 0;
}

.rail-profile-card__role {
  margin: 0;
  font-family: var(--body-font);
  font-size: var(--rail-type-body-size);
  line-height: var(--rail-type-body-line);
  letter-spacing: var(--rail-type-body-spacing);
  font-weight: var(--rail-type-strong-weight);
  color: rgba(23, 19, 19, 0.68);
  text-wrap: pretty;
}

.rail-profile-card__affiliation {
  margin: 0;
  font-family: var(--body-font);
  font-size: var(--rail-type-label-size);
  line-height: var(--rail-type-label-line);
  letter-spacing: var(--rail-type-label-spacing);
  text-transform: uppercase;
  font-weight: var(--rail-type-label-weight);
  color: rgba(23, 19, 19, 0.5);
  text-wrap: pretty;
}

.rail-profile-card__bio {
  color: rgba(23, 19, 19, 0.82);
  font-size: var(--rail-type-body-size);
  line-height: var(--rail-type-body-line);
  font-weight: var(--rail-type-body-weight);
}

.rail-essayist-list {
  display: grid;
  gap: 0.9rem;
}

.rail-essayist-card {
  display: grid;
  grid-template-columns: 8.75rem minmax(0, 1fr);
  align-items: stretch;
  gap: 1rem;
  width: 100%;
  padding: var(--card-pad);
  border: var(--card-border);
  border-radius: 0;
  background: var(--card-bg);
  text-align: left;
  box-shadow: var(--card-shadow);
  transition:
    transform var(--transition-smooth),
    background var(--transition-smooth),
    border-color var(--transition-smooth),
    box-shadow var(--transition-smooth);
}

.rail-essayist-card--no-media {
  grid-template-columns: minmax(0, 1fr);
}

.rail-essayist-card--interactive {
  cursor: pointer;
}

.rail-essayist-card--interactive:hover,
.rail-essayist-card--interactive:focus-visible {
  transform: translateY(-0.12rem);
  background: var(--card-bg-hover);
  border: var(--card-border-hover);
  box-shadow: var(--card-shadow-hover);
  outline: none;
}

.rail-essayist-card__head {
  display: grid;
  gap: 0.26rem;
}

.rail-essayist-card__name,
.rail-artist-card__name {
  margin: 0;
  font-family: var(--body-font);
  font-size: var(--rail-type-strong-size);
  line-height: var(--rail-type-strong-line);
  letter-spacing: var(--rail-type-strong-spacing);
  font-weight: var(--rail-type-strong-weight);
  color: var(--atlas-ink);
  text-wrap: balance;
}

.rail-essayist-card__affiliation,
.rail-essayist-card__titles-label {
  margin: 0;
  font-family: var(--body-font);
  font-size: var(--rail-type-label-size);
  line-height: var(--rail-type-label-line);
  letter-spacing: var(--rail-type-label-spacing);
  text-transform: uppercase;
  font-weight: var(--rail-type-label-weight);
}

.rail-essayist-card__affiliation {
  color: rgba(23, 19, 19, 0.56);
  text-wrap: pretty;
}

.rail-essayist-card__bio,
.rail-artist-card__bio {
  margin: 0;
  font-family: var(--body-font);
  font-size: var(--rail-type-body-size);
  line-height: var(--rail-type-body-line);
  letter-spacing: var(--rail-type-body-spacing);
  font-weight: var(--rail-type-body-weight);
  color: rgba(23, 19, 19, 0.82);
  text-wrap: pretty;
}

.rail-essayist-card__titles {
  display: grid;
  gap: 0.4rem;
  padding-top: 0.8rem;
  border-top: 1px solid rgba(23, 19, 19, 0.08);
}

.rail-essayist-card__titles-label {
  color: rgba(23, 19, 19, 0.48);
}

.rail-essayist-card__titles-list {
  display: grid;
  gap: 0.8rem;
  margin: 0;
  padding: 0;
  list-style: none;
}

.rail-essayist-card__title-item {
  display: grid;
  gap: 0.22rem;
  margin: 0;
  font-family: var(--body-font);
  font-size: var(--rail-type-meta-size);
  line-height: 1.42;
  letter-spacing: var(--rail-type-meta-spacing);
  font-weight: 500;
  color: rgba(23, 19, 19, 0.74);
  text-wrap: pretty;
}

.rail-essayist-card__title-theme,
.rail-essayist-card__title-name,
.rail-essayist-card__title-summary {
  display: block;
}

.rail-essayist-card__title-theme {
  color: rgba(23, 19, 19, 0.46);
  font-size: var(--rail-type-label-size);
  line-height: var(--rail-type-label-line);
  letter-spacing: var(--rail-type-label-spacing);
  text-transform: uppercase;
  font-weight: var(--rail-type-label-weight);
}

.rail-essayist-card__title-name {
  color: rgba(23, 19, 19, 0.82);
  font-weight: 650;
}

.rail-essayist-card__title-summary {
  color: rgba(23, 19, 19, 0.66);
  font-weight: 400;
}

.rail-artist-card-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.75rem;
}

.rail-article--about-page .rail-artist-card-grid {
  grid-template-columns: minmax(0, 1fr);
}

.rail-artist-card {
  display: grid;
  grid-template-columns: 8.75rem minmax(0, 1fr);
  align-items: stretch;
  gap: 1rem;
  width: 100%;
  padding: var(--card-pad);
  border: var(--card-border);
  border-radius: 0;
  background: var(--card-bg);
  text-align: left;
  box-shadow: var(--card-shadow);
  transition:
    transform var(--transition-smooth),
    background var(--transition-smooth),
    border-color var(--transition-smooth),
    box-shadow var(--transition-smooth);
}

.rail-artist-card--no-media {
  grid-template-columns: minmax(0, 1fr);
}

.rail-artist-card--interactive {
  cursor: pointer;
}

.rail-artist-card--interactive:hover,
.rail-artist-card--interactive:focus-visible {
  transform: translateY(-0.12rem);
  background: var(--card-bg-hover);
  border: var(--card-border-hover);
  box-shadow: var(--card-shadow-hover);
  outline: none;
}

.rail-artist-list + .rail-cta {
  margin-top: 1rem;
}

.rail-person-hero {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: 1rem;
  align-items: start;
}

.rail-person-hero--no-media {
  grid-template-columns: minmax(0, 1fr);
}

.rail-person-hero__media {
  position: relative;
  display: grid;
  place-items: end center;
  overflow: hidden;
  min-width: 0;
  aspect-ratio: 1;
  background:
    linear-gradient(rgba(77, 55, 71, 0.08), rgba(77, 55, 71, 0.08)),
    url("./assets/team/radial.png") center 42% / 145% auto no-repeat,
    var(--atlas-plum);
  border: 1px solid rgba(23, 19, 19, 0.12);
}

.rail-person-hero__media::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 0;
  background: radial-gradient(circle at 50% 36%, rgba(245, 240, 235, 0.2), transparent 44%);
  pointer-events: none;
}

.rail-person-hero__image {
  position: relative;
  z-index: 1;
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center 48%;
  filter: grayscale(1);
}

.rail-person-hero__image[alt="Tracy Haggai"] {
  position: absolute;
  inset: 0;
  object-fit: contain;
  object-position: center bottom;
}

.rail-person-hero__content {
  display: grid;
  align-content: start;
}

.content-panel[data-surface="red"] .rail-article--person .rail-person-hero__media {
  background:
    linear-gradient(rgba(148, 40, 50, 0.12), rgba(148, 40, 50, 0.12)),
    url("./assets/team/radial.png") center 42% / 145% auto no-repeat,
    var(--atlas-red-deep);
  border-color: rgba(255, 255, 255, 0.18);
}

.content-panel[data-surface="red"] .rail-article--person .rail-section-label,
.content-panel[data-surface="red"] .rail-article--person .rail-person-hero__affiliation,
.content-panel[data-surface="red"] .rail-article--person .rail-panel-copy {
  color: rgba(245, 240, 235, 0.78);
}

.content-panel[data-surface="red"] .rail-article--person .rail-summary {
  color: var(--atlas-paper);
}

.rail-person-alpha-nav {
  display: inline-grid;
  grid-template-columns: 1.65rem minmax(3.8rem, auto) 1.65rem;
  align-items: center;
  justify-self: start;
  gap: 0.26rem;
  margin: 0 0 0.55rem;
}

.rail-person-alpha-nav__button {
  display: inline-grid;
  width: 1.65rem;
  height: 1.65rem;
  place-items: center;
  padding: 0;
  border: 1px solid rgba(23, 19, 19, 0.12);
  border-radius: 999px;
  background: rgba(255, 252, 248, 0.36);
  color: rgba(23, 19, 19, 0.54);
  font-family: var(--body-font);
  font-size: var(--type-size-sm);
  line-height: 1;
  font-weight: 600;
  cursor: pointer;
  transition:
    transform var(--transition-smooth),
    background var(--transition-smooth),
    border-color var(--transition-smooth),
    color var(--transition-smooth);
}

.rail-person-alpha-nav__button:hover,
.rail-person-alpha-nav__button:focus-visible {
  transform: translateY(-0.04rem);
  border-color: rgba(23, 19, 19, 0.22);
  background: rgba(255, 252, 248, 0.78);
  color: rgba(23, 19, 19, 0.86);
  outline: none;
}

.rail-person-alpha-nav__button:disabled {
  cursor: default;
  opacity: 0.42;
  transform: none;
}

.rail-person-alpha-nav__count {
  display: inline-grid;
  min-height: 1.65rem;
  place-items: center;
  padding: 0 0.48rem;
  border: 1px solid rgba(23, 19, 19, 0.08);
  background: rgba(255, 252, 248, 0.32);
  font-family: var(--mono-font);
  font-size: var(--type-size-2xs);
  line-height: var(--rail-type-label-line);
  letter-spacing: var(--type-tracking-none);
  font-weight: 600;
  color: rgba(23, 19, 19, 0.48);
  white-space: nowrap;
}

.rail-person-hero__affiliation,
.rail-person-contribution-card__eyebrow,
.rail-person-contribution-card__meta {
  margin: 0;
  font-family: var(--body-font);
}

.rail-person-hero__affiliation {
  margin-top: 0.45rem;
  font-size: var(--rail-type-body-size);
  line-height: var(--rail-type-body-line);
  letter-spacing: var(--rail-type-body-spacing);
  font-weight: 500;
  color: rgba(23, 19, 19, 0.58);
  text-wrap: pretty;
}

.rail-person-hero__contact {
  justify-self: start;
  margin-top: 1rem;
  padding: 0.62rem 0.82rem;
  border: 1px solid rgba(23, 19, 19, 0.18);
  background: rgba(23, 19, 19, 0.9);
  color: var(--atlas-paper);
  font-family: var(--body-font);
  font-size: var(--rail-type-label-size);
  line-height: var(--rail-type-label-line);
  letter-spacing: var(--rail-type-label-spacing);
  text-transform: uppercase;
  font-weight: var(--rail-type-label-weight);
  text-decoration: none;
  transition:
    transform var(--transition-smooth),
    background var(--transition-smooth),
    border-color var(--transition-smooth);
}

.rail-person-hero__contact:hover,
.rail-person-hero__contact:focus-visible {
  transform: translateY(-0.08rem);
  background: var(--atlas-terracotta);
  border-color: rgba(23, 19, 19, 0.26);
  outline: none;
}

.rail-person-hero__contacts {
  display: flex;
  flex-wrap: wrap;
  gap: 0.45rem;
  margin-top: 1rem;
}

.rail-person-hero__contacts .rail-person-hero__contact {
  margin-top: 0;
}

.rail-person-hero__contact--icon {
  display: inline-grid;
  width: 2.85rem;
  height: 2.85rem;
  place-items: center;
  padding: 0;
}

.rail-person-hero__contact--icon .rail-person-social-icon {
  width: 1.15rem;
  height: 1.15rem;
}

.rail-person-contact-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(8.5rem, max-content));
  gap: 0.5rem;
}

.rail-person-contact-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 0;
  min-height: 2.45rem;
  padding: 0.68rem 0.85rem;
  border: 1px solid rgba(23, 19, 19, 0.12);
  background: rgba(255, 252, 248, 0.74);
  color: inherit;
  text-decoration: none;
  transition:
    transform var(--transition-smooth),
    background var(--transition-smooth),
    border-color var(--transition-smooth);
}

.rail-person-contact-link:hover,
.rail-person-contact-link:focus-visible {
  transform: translateY(-0.08rem);
  background: rgba(255, 252, 248, 0.94);
  border-color: rgba(23, 19, 19, 0.26);
  outline: none;
}

.rail-person-contact-link__label,
.rail-person-contact-link__value {
  min-width: 0;
  overflow-wrap: anywhere;
  font-family: var(--body-font);
}

.rail-person-contact-link__label {
  font-size: var(--rail-type-label-size);
  line-height: var(--rail-type-label-line);
  letter-spacing: var(--rail-type-label-spacing);
  text-transform: uppercase;
  font-weight: var(--rail-type-label-weight);
  color: rgba(23, 19, 19, 0.78);
}

.rail-person-contact-link__label--icon {
  display: inline-grid;
  width: 1.5rem;
  height: 1.5rem;
  place-items: center;
  color: rgba(23, 19, 19, 0.68);
}

.rail-person-social-icon {
  display: block;
  width: 1rem;
  height: 1rem;
  fill: none;
  stroke: currentColor;
  stroke-width: 1.8;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.rail-sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

.rail-person-contact-link__value {
  font-size: var(--rail-type-meta-size);
  line-height: 1.35;
  letter-spacing: var(--rail-type-meta-spacing);
  font-weight: 600;
  color: rgba(23, 19, 19, 0.82);
}

.rail-person-contribution-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(16rem, 1fr));
  gap: 0.9rem;
}

.rail-person-contribution-card {
  display: grid;
  gap: 0;
  border: 1px solid rgba(23, 19, 19, 0.1);
  background: rgba(255, 252, 248, 0.82);
}

.rail-person-contribution-card__media-button {
  display: block;
  width: 100%;
  padding: 0;
  border: 0;
  background: transparent;
  color: inherit;
  cursor: pointer;
  text-align: inherit;
}

.rail-person-contribution-card__media-button:focus-visible {
  outline: 2px solid rgba(23, 19, 19, 0.7);
  outline-offset: -2px;
}

.rail-person-contribution-card .rail-image-frame--contribution {
  aspect-ratio: auto;
  overflow: visible;
  border: 0;
  background: rgba(255, 252, 248, 0.62);
  box-shadow: none;
}

.rail-person-contribution-card .rail-image-frame--contribution-wide {
  aspect-ratio: auto;
}

.rail-person-contribution-card .rail-image-frame__image--contribution {
  width: 100%;
  height: auto;
  max-height: none;
  object-fit: initial;
  object-position: center;
}

.rail-playable-media-list {
  display: grid;
  gap: 1rem;
}

.rail-playable-media-list--compact {
  gap: 0.75rem;
}

.rail-playable-media {
  display: grid;
  gap: 0.48rem;
  min-width: 0;
}

.rail-playable-media__frame {
  position: relative;
  overflow: hidden;
  width: 100%;
  aspect-ratio: 16 / 9;
  background: #171313;
  border: 1px solid rgba(23, 19, 19, 0.14);
}

.rail-playable-media__frame--audio {
  display: grid;
  min-height: 4rem;
  aspect-ratio: auto;
  place-items: center;
  padding: 0.8rem;
  background: rgba(23, 19, 19, 0.08);
}

.rail-playable-media__iframe,
.rail-playable-media__video {
  display: block;
  width: 100%;
  height: 100%;
  border: 0;
}

.rail-playable-media__audio {
  display: block;
  width: 100%;
}

.rail-playable-media__caption {
  display: grid;
  gap: 0.12rem;
}

.rail-playable-media__title,
.rail-playable-media__meta {
  margin: 0;
  min-width: 0;
  overflow-wrap: anywhere;
  font-family: var(--body-font);
  letter-spacing: var(--rail-type-body-spacing);
}

.rail-playable-media__title {
  font-size: var(--rail-type-body-size);
  line-height: 1.42;
  font-weight: 600;
  color: rgba(23, 19, 19, 0.9);
}

.rail-playable-media__meta {
  font-family: var(--mono-font);
  font-size: var(--type-size-sm);
  line-height: 1.45;
  color: rgba(23, 19, 19, 0.58);
}

.rail-person-contribution-card .rail-playable-media-list--compact {
  border-bottom: 1px solid rgba(23, 19, 19, 0.1);
}

.rail-person-contribution-card .rail-playable-media--compact {
  gap: 0;
}

.rail-person-contribution-card .rail-playable-media--compact .rail-playable-media__frame {
  border: 0;
}

.rail-person-contribution-card .rail-playable-media--compact .rail-playable-media__caption {
  padding: 0.75rem 0.9rem 0.2rem;
}

.rail-person-contribution-card__body {
  display: grid;
  gap: 0.48rem;
  padding: 0.9rem;
}

.rail-person-contribution-card__eyebrow,
.rail-person-contribution-card__meta {
  font-size: var(--rail-type-label-size);
  line-height: var(--rail-type-label-line);
  letter-spacing: var(--rail-type-label-spacing);
  text-transform: uppercase;
  font-weight: var(--rail-type-label-weight);
}

.rail-person-contribution-card__eyebrow {
  color: rgba(23, 19, 19, 0.5);
}

.rail-person-contribution-card__theme {
  display: flex;
  flex-wrap: wrap;
}

.rail-person-contribution-card__title {
  margin: 0;
  font-family: var(--body-font);
  font-size: var(--type-size-lg);
  line-height: 1.3;
  letter-spacing: var(--type-tracking-none);
  font-weight: 600;
  color: rgba(23, 19, 19, 0.92);
  text-wrap: balance;
}

.rail-person-contribution-card__title-link {
  display: inline;
  margin: 0;
  padding: 0;
  border: 0;
  background: transparent;
  color: inherit;
  font: inherit;
  letter-spacing: inherit;
  text-align: left;
  cursor: pointer;
}

.rail-person-contribution-card__title-link:hover,
.rail-person-contribution-card__title-link:focus-visible {
  text-decoration: underline;
  text-decoration-thickness: 0.08em;
  text-underline-offset: 0.14em;
  outline: none;
}

.rail-person-contribution-card__meta {
  color: rgba(23, 19, 19, 0.46);
}

.rail-person-contribution-card__summary {
  margin: 0;
  font-family: var(--body-font);
  font-size: var(--rail-type-body-size);
  line-height: var(--rail-type-body-line);
  letter-spacing: var(--rail-type-body-spacing);
  color: rgba(23, 19, 19, 0.72);
  text-wrap: pretty;
}

.content-panel[data-surface="terracotta"] .content-panel__inner .rail-person-contribution-card,
.content-panel[data-surface="olive"] .content-panel__inner .rail-person-contribution-card,
.content-panel[data-surface="plum"] .content-panel__inner .rail-person-contribution-card,
.content-panel[data-surface="red"] .content-panel__inner .rail-person-contribution-card {
  border-color: rgba(23, 19, 19, 0.18);
  background: rgba(255, 249, 245, 0.96);
  box-shadow: 0 18px 40px rgba(23, 19, 19, 0.08);
}

.content-panel[data-surface="terracotta"] .content-panel__inner .rail-person-contribution-card__eyebrow,
.content-panel[data-surface="olive"] .content-panel__inner .rail-person-contribution-card__eyebrow,
.content-panel[data-surface="plum"] .content-panel__inner .rail-person-contribution-card__eyebrow,
.content-panel[data-surface="red"] .content-panel__inner .rail-person-contribution-card__eyebrow {
  color: rgba(23, 19, 19, 0.64);
}

.content-panel[data-surface="terracotta"] .content-panel__inner .rail-person-contribution-card__title,
.content-panel[data-surface="olive"] .content-panel__inner .rail-person-contribution-card__title,
.content-panel[data-surface="plum"] .content-panel__inner .rail-person-contribution-card__title,
.content-panel[data-surface="red"] .content-panel__inner .rail-person-contribution-card__title {
  color: rgba(23, 19, 19, 0.96);
}

.content-panel[data-surface="terracotta"] .content-panel__inner .rail-person-contribution-card__meta,
.content-panel[data-surface="olive"] .content-panel__inner .rail-person-contribution-card__meta,
.content-panel[data-surface="plum"] .content-panel__inner .rail-person-contribution-card__meta,
.content-panel[data-surface="red"] .content-panel__inner .rail-person-contribution-card__meta {
  color: rgba(23, 19, 19, 0.68);
}

.content-panel[data-surface="terracotta"] .content-panel__inner .rail-person-contribution-card .rail-pill,
.content-panel[data-surface="olive"] .content-panel__inner .rail-person-contribution-card .rail-pill,
.content-panel[data-surface="plum"] .content-panel__inner .rail-person-contribution-card .rail-pill,
.content-panel[data-surface="red"] .content-panel__inner .rail-person-contribution-card .rail-pill {
  color: rgba(23, 19, 19, 0.78);
  background: rgba(255, 255, 255, 0.86);
  border-color: rgba(23, 19, 19, 0.1);
}

.content-panel[data-surface="terracotta"] .content-panel__inner .rail-person-contribution-card .rail-person-inline-link,
.content-panel[data-surface="olive"] .content-panel__inner .rail-person-contribution-card .rail-person-inline-link,
.content-panel[data-surface="plum"] .content-panel__inner .rail-person-contribution-card .rail-person-inline-link,
.content-panel[data-surface="red"] .content-panel__inner .rail-person-contribution-card .rail-person-inline-link {
  color: var(--atlas-terracotta-deep);
}

.content-panel[data-surface="terracotta"] .content-panel__inner .rail-image-placeholder--person-contribution .rail-image-placeholder__label,
.content-panel[data-surface="olive"] .content-panel__inner .rail-image-placeholder--person-contribution .rail-image-placeholder__label,
.content-panel[data-surface="plum"] .content-panel__inner .rail-image-placeholder--person-contribution .rail-image-placeholder__label,
.content-panel[data-surface="red"] .content-panel__inner .rail-image-placeholder--person-contribution .rail-image-placeholder__label {
  color: rgba(23, 19, 19, 0.84);
}

.rail-person-inline-link {
  width: fit-content;
  padding: 0;
  border: 0;
  background: transparent;
  font-family: var(--body-font);
  font-size: var(--type-size-base);
  line-height: 1.45;
  letter-spacing: var(--type-tracking-none);
  font-weight: 500;
  color: var(--atlas-terracotta-deep);
  text-decoration: underline;
  text-decoration-thickness: 1px;
  text-underline-offset: 0.14em;
  cursor: pointer;
  transition: opacity var(--transition-smooth);
}

.rail-person-inline-link:hover,
.rail-person-inline-link:focus-visible {
  opacity: 0.72;
  outline: none;
}

.rail-work-artist-links {
  display: grid;
  gap: 0.45rem;
  margin-top: 1.45rem;
}

.rail-work-artist-links + .rail-panel-copy {
  margin-top: 1.15rem;
}

.rail-work-artist-links__label {
  font-family: var(--mono-font);
  font-size: var(--rail-type-label-size);
  line-height: var(--rail-type-label-line);
  letter-spacing: var(--rail-type-label-spacing);
  text-transform: uppercase;
  font-weight: var(--rail-type-label-weight);
  color: rgba(23, 19, 19, 0.52);
}

.rail-work-artist-links__list {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem 0.75rem;
}

.rail-work-artist-links__button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 2.5rem;
  padding: 0.68rem 0.95rem;
  border: 1px solid rgba(15, 12, 13, 0.92);
  background: #0f0c0d;
  color: var(--atlas-paper);
  font-size: var(--rail-type-strong-size);
  line-height: var(--rail-type-strong-line);
  letter-spacing: var(--rail-type-strong-spacing);
  font-weight: var(--rail-type-strong-weight);
  text-decoration: none;
  box-shadow: 0 0.55rem 1.15rem rgba(9, 7, 8, 0.18);
  transition:
    background var(--transition-smooth),
    color var(--transition-smooth),
    border-color var(--transition-smooth),
    box-shadow var(--transition-smooth),
    transform var(--transition-smooth);
}

.rail-work-artist-links__button:hover,
.rail-work-artist-links__button:focus-visible {
  opacity: 1;
  background: #1b1517;
  border-color: rgba(15, 12, 13, 1);
  box-shadow: 0 0.8rem 1.45rem rgba(9, 7, 8, 0.24);
  transform: translateY(-1px);
}

.rail-about-subsection--inline {
  margin-top: 1.5rem;
  padding: 1.375rem 1.5rem 1.4rem;
  border-top: 0;
  background: #0f0c0d;
  border: 1px solid rgba(15, 12, 13, 0.88);
}

.rail-article--about-page .rail-about-subsection--inline .rail-about-subsection__title {
  color: rgba(245, 240, 235, 0.96);
}

.rail-article--about-page .rail-about-subsection--inline .rail-about-subsection__copy {
  color: rgba(245, 240, 235, 0.82);
}

.rail-article--about-page .rail-about-subsection--inline .rail-cta {
  color: var(--atlas-ink);
  text-decoration: none;
  border-color: rgba(245, 240, 235, 0.16);
  background: rgba(255, 252, 248, 0.96);
  box-shadow: 0 0.7rem 1.6rem rgba(9, 7, 8, 0.24);
}

.rail-article--about-page .rail-about-subsection--inline .rail-cta--button {
  color: var(--atlas-ink);
  text-decoration: none;
}

.rail-article--about-page .rail-about-subsection--inline .rail-cta:hover,
.rail-article--about-page .rail-about-subsection--inline .rail-cta:focus-visible {
  background: rgba(255, 255, 255, 1);
  box-shadow: 0 0.9rem 1.9rem rgba(9, 7, 8, 0.28);
}

.rail-article--about-page .rail-about-subsection--inline .rail-cta--button:hover,
.rail-article--about-page .rail-about-subsection--inline .rail-cta--button:focus-visible {
  opacity: 1;
}

.rail-contributor-directories {
  display: grid;
  gap: 1.75rem;
  margin-top: 0.9375rem;
}

.rail-contributor-directory {
  display: grid;
  gap: 0.85rem;
  padding-top: 1rem;
  border-top: 1px solid rgba(23, 19, 19, 0.08);
}

.rail-contributor-directory__head {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: 1rem;
}

.rail-contributor-directory__title {
  margin: 0;
  font-family: var(--body-font);
  font-size: var(--rail-type-strong-size);
  line-height: var(--rail-type-strong-line);
  letter-spacing: var(--rail-type-strong-spacing);
  font-weight: var(--rail-type-strong-weight);
  color: var(--atlas-ink);
  text-wrap: balance;
}

.rail-contributor-directory__count {
  margin: 0;
  font-family: var(--body-font);
  font-size: var(--rail-type-meta-size);
  line-height: var(--rail-type-meta-line);
  letter-spacing: var(--rail-type-meta-spacing);
  font-weight: var(--rail-type-meta-weight);
  color: rgba(23, 19, 19, 0.52);
  white-space: nowrap;
}

.rail-contributor-directory__list {
  margin: 0;
  padding: 0;
  list-style: none;
  column-count: 2;
  column-gap: 1.5rem;
}

.rail-contributor-directory__item {
  break-inside: avoid;
  margin: 0 0 0.48rem;
  font-family: var(--body-font);
  font-size: var(--rail-type-body-size);
  line-height: var(--rail-type-body-line);
  letter-spacing: var(--rail-type-body-spacing);
  font-weight: var(--rail-type-body-weight);
  color: rgba(23, 19, 19, 0.82);
  text-wrap: pretty;
}

.rail-contributor-directory__name-button {
  display: inline;
  padding: 0;
  border: 0;
  background: transparent;
  font: inherit;
  color: inherit;
  text-align: left;
  cursor: pointer;
  transition: opacity var(--transition-smooth), color var(--transition-smooth);
}

.rail-contributor-directory__name-button:hover,
.rail-contributor-directory__name-button:focus-visible {
  opacity: 0.78;
  color: var(--atlas-terracotta-deep);
  outline: none;
}

.content-panel[data-surface="olive"] .content-panel__inner .rail-contributor-directory__name-button:hover,
.content-panel[data-surface="olive"] .content-panel__inner .rail-contributor-directory__name-button:focus-visible {
  opacity: 1;
  color: var(--rail-surface-text);
}

.rail-contributor-directory .rail-cta {
  margin-top: 0.15rem;
}

.rail-book-contents {
  display: grid;
  gap: 1.25rem;
}

.rail-book-contents__groups {
  display: grid;
  gap: 1rem;
}

.rail-book-contents__group {
  display: grid;
  gap: 1.15rem;
  padding-top: 1rem;
  border-top: 1px solid rgba(23, 19, 19, 0.08);
}

.rail-book-contents__group:first-child {
  padding-top: 0;
  border-top: 0;
}

.rail-book-contents__group-title {
  margin: 0;
  font-family: var(--body-font);
  font-size: var(--rail-type-label-size);
  line-height: var(--rail-type-label-line);
  letter-spacing: 0.12em;
  font-weight: var(--rail-type-label-weight);
  text-transform: uppercase;
  color: rgba(23, 19, 19, 0.56);
}

.rail-book-contents__entries {
  display: grid;
  gap: 0.7rem;
}

.rail-book-contents__entry {
  display: grid;
  gap: 0.18rem;
}

.rail-book-contents__entry-title,
.rail-book-contents__entry-authors {
  margin: 0;
  font-family: var(--body-font);
}

.rail-book-contents__entry-title {
  font-size: var(--rail-type-body-size);
  line-height: 1.28;
  letter-spacing: var(--rail-type-body-spacing);
  font-weight: 600;
  color: rgba(23, 19, 19, 0.9);
  text-wrap: pretty;
}

.rail-book-contents__entry-authors {
  font-size: var(--rail-type-meta-size);
  line-height: 1.45;
  letter-spacing: var(--rail-type-meta-spacing);
  font-weight: var(--rail-type-meta-weight);
  color: rgba(23, 19, 19, 0.58);
  text-wrap: pretty;
}

.rail-book-contents__artists {
  display: grid;
  gap: 0.48rem;
  padding: 0.82rem 0.9rem;
  border: 1px solid rgba(23, 19, 19, 0.08);
  background: rgba(255, 252, 248, 0.58);
}

.rail-book-contents__artists-label {
  margin: 0 0 0.15rem;
  font-family: var(--body-font);
  font-size: var(--rail-type-label-size);
  line-height: var(--rail-type-label-line);
  letter-spacing: var(--rail-type-label-spacing);
  font-weight: var(--rail-type-label-weight);
  text-transform: uppercase;
  color: rgba(23, 19, 19, 0.52);
}

.rail-book-contents__artist {
  display: grid;
  gap: 0.08rem;
}

.rail-book-contents__artist-name,
.rail-book-contents__artist-work {
  margin: 0;
  font-family: var(--body-font);
  text-align: left;
}

.rail-book-contents__artist-name {
  padding-left: 0;
  width: fit-content;
  font-size: var(--rail-type-body-size);
  line-height: 1.28;
  letter-spacing: var(--rail-type-body-spacing);
  font-weight: 600;
  color: rgba(23, 19, 19, 0.9);
}

button.rail-book-contents__artist-name {
  padding: 0;
  border: 0;
  background: transparent;
  cursor: pointer;
}

button.rail-book-contents__artist-name:hover,
button.rail-book-contents__artist-name:focus-visible {
  color: var(--atlas-terracotta-deep);
  outline: none;
}

.rail-book-contents__artist-work {
  font-size: var(--rail-type-meta-size);
  line-height: 1.45;
  letter-spacing: var(--rail-type-meta-spacing);
  font-weight: var(--rail-type-meta-weight);
  color: rgba(23, 19, 19, 0.58);
  text-wrap: pretty;
}

.rail-theme-gallery-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: 1.75rem;
}

.rail-theme-gallery-card {
  display: grid;
  gap: 0.55rem;
  width: 100%;
  justify-self: start;
}

.rail-theme-gallery-card--interactive {
  width: 100%;
  padding: 0;
  text-align: left;
  border: 0;
  background: transparent;
  cursor: pointer;
  transition: transform var(--transition-smooth), opacity var(--transition-smooth);
}

.rail-theme-gallery-card--interactive:hover,
.rail-theme-gallery-card--interactive:focus-visible {
  opacity: 0.82;
  transform: translateY(-0.16rem);
  outline: none;
}

.rail-theme-gallery-card:nth-child(2n) .rail-theme-gallery-card__media {
  width: 100%;
  margin-left: 0;
}

.rail-theme-gallery-card__media {
  position: relative;
  width: 100%;
  inline-size: 100%;
  justify-self: start;
  margin: 0;
  padding: 0;
  background: transparent;
  border: 0;
  box-shadow: none;
}

.rail-theme-gallery-card__media::before {
  content: none;
}

.rail-theme-gallery-card__image {
  display: block;
  width: 100%;
  inline-size: 100%;
  max-width: 100%;
  height: auto;
  max-height: none;
  object-fit: initial;
}

.rail-theme-gallery-card__image {
  position: relative;
  z-index: 1;
  filter: saturate(0.92) contrast(1.02);
  background: rgba(255, 252, 248, 0.62);
}

.rail-article--detail .rail-panel-section--intro > .rail-theme-gallery-card {
  width: min(100%, 31rem);
  margin-inline: 0 auto;
}

.rail-theme-gallery-card__placeholder {
  display: block;
  width: 100%;
  aspect-ratio: 4 / 5;
  position: relative;
  z-index: 1;
}

.rail-theme-gallery-card__copy {
  display: grid;
  gap: 0.12rem;
  max-width: 24rem;
  margin-left: 0.2rem;
}

.rail-theme-gallery-card__title,
.rail-theme-gallery-card__subtitle,
.rail-theme-gallery-card__meta,
.rail-theme-gallery-card__caption,
.rail-theme-excerpt-card__copy,
.rail-theme-note {
  margin: 0;
  font-family: var(--body-font);
  font-size: var(--rail-type-body-size);
  line-height: var(--rail-type-body-line);
  letter-spacing: var(--rail-type-body-spacing);
  font-weight: var(--rail-type-body-weight);
  color: rgba(23, 19, 19, 0.82);
  text-wrap: pretty;
}

.rail-theme-gallery-card__title {
  font-size: var(--rail-type-body-size);
  line-height: 1.42;
  font-weight: 600;
  color: rgba(23, 19, 19, 0.9);
}

.rail-theme-gallery-card__subtitle,
.rail-theme-gallery-card__meta,
.rail-theme-gallery-card__caption {
  font-family: var(--mono-font);
  font-size: var(--type-size-sm);
  line-height: 1.55;
  letter-spacing: 0.01em;
  color: rgba(23, 19, 19, 0.62);
}

.rail-theme-gallery-card__subtitle {
  color: rgba(23, 19, 19, 0.76);
}

.rail-theme-gallery-card__link-label {
  display: inline-flex;
  width: fit-content;
  margin-top: 0.1rem;
  padding-bottom: 0.12rem;
  border-bottom: 1px solid currentColor;
  font-family: var(--body-font);
  font-size: var(--rail-type-label-size);
  line-height: var(--rail-type-label-line);
  letter-spacing: var(--rail-type-label-spacing);
  text-transform: uppercase;
  font-weight: var(--rail-type-label-weight);
  color: var(--atlas-terracotta-deep);
}

.rail-theme-excerpt-grid {
  display: grid;
  gap: 0.85rem;
}

.rail-theme-excerpt-card {
  display: grid;
  gap: 0.45rem;
  padding: 1rem;
  border: 1px solid rgba(23, 19, 19, 0.1);
  background:
    linear-gradient(rgba(247, 248, 249, 0.96), rgba(232, 236, 240, 0.92)),
    url("./assets/paper-texture.png");
  background-size: cover;
}

.rail-theme-excerpt-card__title,
.rail-theme-excerpt-card__source {
  margin: 0;
  font-family: var(--body-font);
  text-transform: uppercase;
}

.rail-theme-excerpt-card__title {
  font-size: var(--rail-type-label-size);
  line-height: var(--rail-type-label-line);
  letter-spacing: var(--rail-type-label-spacing);
  font-weight: var(--rail-type-label-weight);
  color: rgba(23, 19, 19, 0.5);
}

.rail-theme-excerpt-card__source {
  font-size: var(--rail-type-meta-size);
  line-height: var(--rail-type-meta-line);
  letter-spacing: var(--rail-type-meta-spacing);
  font-weight: var(--rail-type-meta-weight);
  color: rgba(23, 19, 19, 0.58);
}

.rail-theme-contributor-list {
  display: grid;
  border-top: 1px solid rgba(23, 19, 19, 0.08);
}

.rail-theme-contributor {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto auto;
  align-items: baseline;
  gap: 0.55rem;
  width: 100%;
  padding: 0.8rem 0;
  text-align: left;
  border-bottom: 1px solid rgba(23, 19, 19, 0.08);
  background: transparent;
}

.rail-theme-contributor--interactive {
  cursor: pointer;
  transition: opacity var(--transition-smooth), color var(--transition-smooth);
}

.rail-theme-contributor--interactive:hover,
.rail-theme-contributor--interactive:focus-visible {
  opacity: 0.72;
  outline: none;
}

.rail-theme-contributor__name,
.rail-theme-contributor__role,
.rail-theme-contributor__separator {
  font-family: var(--body-font);
}

.rail-theme-contributor__name {
  font-size: var(--rail-type-strong-size);
  line-height: var(--rail-type-strong-line);
  letter-spacing: var(--rail-type-strong-spacing);
  font-weight: var(--rail-type-strong-weight);
  color: var(--atlas-ink);
  text-wrap: balance;
}

.rail-theme-contributor__separator,
.rail-theme-contributor__role {
  font-size: var(--rail-type-meta-size);
  line-height: var(--rail-type-meta-line);
  letter-spacing: var(--rail-type-meta-spacing);
  font-weight: var(--rail-type-meta-weight);
  color: rgba(23, 19, 19, 0.58);
}

.rail-theme-note {
  padding: 1rem;
  border: 1px solid rgba(23, 19, 19, 0.1);
  background: rgba(255, 252, 248, 0.72);
}

.rail-index-grid {
  display: grid;
  gap: 0.8rem;
}

.rail-index-card {
  display: grid;
  gap: 0.55rem;
  width: 100%;
  min-height: 8.75rem;
  padding: 1rem;
  text-align: left;
  border: 1px solid rgba(23, 19, 19, 0.1);
  background:
    linear-gradient(180deg, rgba(255, 252, 248, 0.96), rgba(243, 237, 229, 0.9)),
    url("./assets/paper-texture.png");
  background-size: cover;
  color: var(--atlas-ink);
  transition:
    border-color var(--transition-smooth),
    box-shadow var(--transition-smooth),
    transform var(--transition-smooth);
}

.rail-index-card:hover,
.rail-index-card:focus-visible {
  border-color: rgba(23, 19, 19, 0.22);
  box-shadow: 0 0.85rem 1.7rem rgba(23, 19, 19, 0.1);
  transform: translateY(-0.1rem);
  outline: none;
}

.rail-index-card__eyebrow,
.rail-index-card__action {
  margin: 0;
  font-size: var(--rail-type-label-size);
  line-height: var(--rail-type-label-line);
  letter-spacing: var(--rail-type-label-spacing);
  font-weight: var(--rail-type-label-weight);
  text-transform: uppercase;
  color: rgba(23, 19, 19, 0.52);
}

.rail-index-card__title {
  margin: 0;
  font-size: var(--rail-type-subhead-size);
  line-height: var(--rail-type-subhead-line);
  letter-spacing: var(--rail-type-subhead-spacing);
  font-weight: var(--rail-type-subhead-weight);
  color: var(--atlas-ink);
  overflow-wrap: anywhere;
}

.rail-index-card__copy {
  margin: 0;
  font-size: var(--rail-type-meta-size);
  line-height: 1.45;
  color: rgba(23, 19, 19, 0.66);
  text-wrap: pretty;
}

.rail-index-card__action {
  align-self: end;
  color: var(--atlas-terracotta-deep);
}

.rail-credit-note {
  margin: 0.85rem 0 0;
  font-size: var(--rail-type-meta-size);
  line-height: 1.45;
  color: rgba(23, 19, 19, 0.56);
}

.rail-article--city-page .rail-panel-section--intro .rail-credit-note + .rail-summary {
  margin-top: 0.55rem;
}

.rail-inline-external-link {
  display: inline-flex;
  align-items: center;
  width: fit-content;
  min-height: 2.5rem;
  padding: 0.68rem 0.88rem;
  border: 1px solid rgba(23, 19, 19, 0.16);
  background: rgba(255, 252, 248, 0.72);
  color: var(--atlas-ink);
  font-weight: 700;
  transition: background var(--transition-smooth), border-color var(--transition-smooth);
}

.rail-inline-external-link:hover,
.rail-inline-external-link:focus-visible {
  border-color: rgba(23, 19, 19, 0.28);
  background: rgba(255, 252, 248, 0.94);
  outline: none;
}

.rail-newsletter {
  display: grid;
  gap: 0.95rem;
  padding: 1rem;
  border: 1px solid rgba(23, 19, 19, 0.12);
  background:
    linear-gradient(135deg, rgba(245, 240, 235, 0.94), rgba(232, 226, 216, 0.9)),
    url("./assets/paper-texture.png");
  background-size: cover;
}

.rail-newsletter__title {
  margin: 0;
  font-family: var(--body-font);
  font-size: var(--type-size-xl);
  line-height: 1.05;
  font-weight: 800;
  color: var(--atlas-ink);
  text-wrap: balance;
}

.rail-newsletter__title + .rail-panel-copy {
  margin-top: 0.32rem;
}

.rail-newsletter__form {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 0.55rem;
  align-items: stretch;
}

.rail-newsletter__copy .rail-panel-copy {
  margin-top: 0;
}

.rail-newsletter__field {
  display: block;
  min-height: 2.75rem;
}

.rail-newsletter__label {
  font-size: var(--rail-type-label-size);
  line-height: var(--rail-type-label-line);
  letter-spacing: var(--rail-type-label-spacing);
  font-weight: var(--rail-type-label-weight);
  text-transform: uppercase;
  color: rgba(23, 19, 19, 0.52);
}

.rail-newsletter__input {
  width: 100%;
  height: 100%;
  min-width: 0;
  min-height: 2.75rem;
  box-sizing: border-box;
  padding: 0.72rem 0.8rem;
  border: 1px solid rgba(23, 19, 19, 0.18);
  border-radius: 0;
  background: rgba(255, 252, 248, 0.78);
  color: var(--atlas-ink);
}

.rail-newsletter__input:focus {
  outline: 2px solid rgba(98, 69, 91, 0.24);
  outline-offset: 2px;
}

.rail-newsletter__submit {
  align-self: stretch;
  height: 100%;
  min-height: 2.75rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.72rem 0.95rem;
  background: var(--atlas-ink);
  color: var(--atlas-paper);
  font-weight: 700;
}

.rail-newsletter__privacy {
  margin: 0;
  font-size: var(--rail-type-meta-size);
  line-height: 1.45;
  color: rgba(23, 19, 19, 0.58);
}

.rail-panel-section--newsletter-home {
  margin-top: 2.1rem;
}

.rail-panel-section--newsletter-home .rail-section-label {
  margin-bottom: 0.55rem;
}

.rail-panel-section--newsletter-home .rail-newsletter {
  padding: 1rem;
  gap: 0.8rem;
  border-color: rgba(23, 19, 19, 0.22);
  background:
    linear-gradient(135deg, rgba(255, 252, 248, 0.98), rgba(245, 240, 235, 0.94)),
    url("./assets/paper-texture.png");
  background-size: cover;
}

.rail-panel-section--newsletter-home .rail-newsletter__title {
  font-size: clamp(1.28rem, 1.1rem + 0.42vw, 1.55rem);
}

.rail-panel-section--newsletter-home .rail-summary {
  font-size: var(--type-size-xl);
  line-height: 1.02;
}

.rail-panel-section--newsletter-home .rail-panel-copy {
  margin-top: 0.38rem;
}

.rail-download-list {
  display: grid;
  gap: 0.7rem;
}

.rail-download-row {
  display: grid;
  gap: 0.22rem;
  padding: 0.9rem 1rem;
  border: 1px solid rgba(23, 19, 19, 0.12);
  background: rgba(255, 252, 248, 0.68);
  transition: background var(--transition-smooth), border-color var(--transition-smooth);
}

.rail-download-row:hover,
.rail-download-row:focus-visible {
  border-color: rgba(23, 19, 19, 0.26);
  background: rgba(255, 252, 248, 0.92);
  outline: none;
}

.rail-download-row__label {
  font-size: var(--rail-type-strong-size);
  line-height: var(--rail-type-strong-line);
  letter-spacing: var(--rail-type-strong-spacing);
  font-weight: var(--rail-type-strong-weight);
  color: var(--atlas-ink);
}

.rail-download-row__description {
  font-size: var(--rail-type-meta-size);
  line-height: 1.45;
  color: rgba(23, 19, 19, 0.58);
}

.content-panel[data-surface="plum"] .content-panel__inner .rail-article--theme-detail .rail-section-label {
  color: var(--rail-surface-muted);
}

.content-panel[data-surface="plum"] .content-panel__inner .rail-article--theme-detail .rail-summary,
.content-panel[data-surface="plum"] .content-panel__inner .rail-article--theme-detail .rail-panel-copy,
.content-panel[data-surface="plum"] .content-panel__inner .rail-article--theme-detail .rail-theme-contributor__name {
  color: var(--rail-surface-text);
}

.content-panel[data-surface="plum"] .content-panel__inner .rail-article--theme-detail .rail-theme-gallery-card__caption,
.content-panel[data-surface="plum"] .content-panel__inner .rail-article--theme-detail .rail-credit-note,
.content-panel[data-surface="plum"] .content-panel__inner .rail-article--theme-detail .rail-theme-contributor__role,
.content-panel[data-surface="plum"] .content-panel__inner .rail-article--theme-detail .rail-theme-contributor__separator {
  color: var(--rail-surface-muted);
}

.content-panel[data-surface="plum"] .content-panel__inner .rail-article--theme-detail .rail-theme-gallery-card__title,
.content-panel[data-surface="plum"] .content-panel__inner .rail-article--theme-detail .rail-theme-gallery-card__subtitle,
.content-panel[data-surface="plum"] .content-panel__inner .rail-article--theme-detail .rail-theme-gallery-card__meta,
.content-panel[data-surface="plum"] .content-panel__inner .rail-article--theme-detail .rail-theme-note {
  color: var(--rail-surface-text);
}

.content-panel[data-surface="plum"] .content-panel__inner .rail-article--theme-detail .rail-theme-gallery-card__subtitle,
.content-panel[data-surface="plum"] .content-panel__inner .rail-article--theme-detail .rail-theme-gallery-card__meta {
  color: var(--rail-surface-muted);
}

.content-panel[data-surface="plum"] .content-panel__inner .rail-article--theme-detail .rail-theme-gallery-card__link-label {
  color: var(--rail-surface-text);
}

.content-panel[data-surface="plum"] .content-panel__inner .rail-article--theme-detail .rail-theme-contributor-list,
.content-panel[data-surface="plum"] .content-panel__inner .rail-article--theme-detail .rail-theme-contributor {
  border-color: var(--rail-surface-divider);
}

.content-panel[data-surface="plum"] .content-panel__inner .rail-article--theme-detail .rail-theme-gallery-card__placeholder .rail-gallery__placeholder-label,
.content-panel[data-surface="plum"] .content-panel__inner .rail-article--theme-detail .rail-theme-gallery-card__placeholder .rail-gallery__placeholder-index {
  color: rgba(23, 19, 19, 0.5);
}

.content-panel[data-surface="plum"] .content-panel__inner .rail-theme-atlas--related {
  padding: 0;
  overflow: visible;
  border: 0;
  background: transparent;
  box-shadow: none;
}

.content-panel[data-surface="plum"] .content-panel__inner .rail-theme-atlas--related::before {
  content: none;
}

.content-panel[data-surface="plum"] .content-panel__inner .rail-theme-atlas--related .rail-theme-atlas__header {
  gap: 0.3rem;
}

.content-panel[data-surface="plum"] .content-panel__inner .rail-theme-atlas--related .rail-theme-atlas__labels {
  align-items: center;
}

.content-panel[data-surface="plum"] .content-panel__inner .rail-theme-atlas--related .rail-theme-atlas__note {
  max-width: none;
}

.content-panel[data-surface="plum"] .content-panel__inner .rail-theme-atlas--related .rail-theme-atlas__grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: 0.7rem;
}

.content-panel[data-surface="plum"] .content-panel__inner .rail-theme-atlas--related .rail-theme-atlas__grid::before,
.content-panel[data-surface="plum"] .content-panel__inner .rail-theme-atlas--related .rail-theme-atlas__grid::after {
  content: none;
}

.content-panel[data-surface="plum"] .content-panel__inner .rail-theme-atlas--related .rail-theme-atlas-card,
.content-panel[data-surface="plum"] .content-panel__inner .rail-theme-atlas--related .rail-theme-atlas-card[data-theme-slot] {
  grid-column: auto;
  grid-row: auto;
  min-height: 0;
  margin: 0;
  gap: 0.7rem;
  padding: 0.9rem 1rem;
  overflow: visible;
  border-color: var(--rail-surface-divider);
  background: rgba(245, 240, 235, 0.075);
  box-shadow: none;
}

.content-panel[data-surface="plum"] .content-panel__inner .rail-theme-atlas--related .rail-theme-atlas-card::before,
.content-panel[data-surface="plum"] .content-panel__inner .rail-theme-atlas--related .rail-theme-atlas-card::after,
.content-panel[data-surface="plum"] .content-panel__inner .rail-theme-atlas--related .rail-theme-atlas-card__mark {
  content: none;
  display: none;
}

.content-panel[data-surface="plum"] .content-panel__inner .rail-theme-atlas--related .rail-theme-atlas-card__top,
.content-panel[data-surface="plum"] .content-panel__inner .rail-theme-atlas--related .rail-theme-atlas-card__bottom {
  gap: 0.65rem;
}

.content-panel[data-surface="plum"] .content-panel__inner .rail-theme-atlas--related .rail-theme-atlas-card__index,
.content-panel[data-surface="plum"] .content-panel__inner .rail-theme-atlas--related .rail-theme-atlas-card__mode,
.content-panel[data-surface="plum"] .content-panel__inner .rail-theme-atlas--related .rail-theme-atlas-card__action {
  color: var(--rail-surface-muted);
}

.content-panel[data-surface="plum"] .content-panel__inner .rail-theme-atlas--related .rail-theme-atlas-card__mode,
.content-panel[data-surface="plum"] .content-panel__inner .rail-theme-atlas--related .rail-theme-atlas-card__action {
  border-color: var(--rail-surface-divider);
  background: rgba(245, 240, 235, 0.07);
}

.content-panel[data-surface="plum"] .content-panel__inner .rail-theme-atlas--related .rail-theme-atlas-card__title {
  max-width: none;
  font-size: var(--type-size-xl);
  line-height: 1.04;
  letter-spacing: var(--type-tracking-none);
  color: var(--rail-surface-text);
}

.content-panel[data-surface="plum"] .content-panel__inner .rail-theme-atlas--related .rail-theme-atlas-card__copy {
  max-width: none;
  display: block;
  overflow: visible;
  font-size: var(--type-size-base);
  line-height: 1.42;
  color: var(--rail-surface-muted);
  -webkit-line-clamp: unset;
}

.content-panel[data-surface="plum"] .content-panel__inner .rail-theme-atlas--related .rail-theme-atlas-card__signal {
  max-width: none;
  color: var(--rail-surface-soft);
}

.rail-theme-atlas {
  position: relative;
  display: grid;
  gap: 1rem;
  padding: clamp(1rem, 1.5vw, 1.2rem);
  overflow: hidden;
  border: 1px solid rgba(98, 69, 91, 0.34);
  background:
    radial-gradient(circle at top left, rgba(195, 110, 98, 0.14), transparent 34%),
    radial-gradient(circle at bottom right, rgba(126, 126, 85, 0.1), transparent 30%),
    linear-gradient(180deg, rgba(77, 55, 71, 0.98), rgba(55, 38, 49, 0.97)),
    url("./assets/paper-texture.png");
  background-size: auto, auto, auto, 560px auto;
  box-shadow:
    inset 0 1px 0 rgba(245, 240, 235, 0.08),
    0 1rem 2.4rem rgba(17, 12, 15, 0.14);
  isolation: isolate;
}

.rail-theme-atlas::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(245, 240, 235, 0.075) 1px, transparent 1px),
    linear-gradient(90deg, rgba(245, 240, 235, 0.075) 1px, transparent 1px);
  background-size: 4.6rem 4.6rem;
  opacity: 0.18;
  pointer-events: none;
}

.rail-theme-atlas__header,
.rail-theme-atlas__grid {
  position: relative;
  z-index: 1;
}

.rail-theme-atlas__header {
  display: grid;
  gap: 0.45rem;
}

.rail-theme-atlas__labels {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 0.75rem;
}

.rail-theme-atlas__count,
.rail-theme-atlas__descriptor,
.rail-theme-atlas__note {
  margin: 0;
  font-family: var(--body-font);
  font-size: var(--rail-type-label-size);
  line-height: var(--rail-type-label-line);
  letter-spacing: var(--rail-type-label-spacing);
  text-transform: uppercase;
}

.rail-theme-atlas__count {
  font-weight: var(--rail-type-label-weight);
  color: rgba(245, 240, 235, 0.88);
}

.rail-theme-atlas__descriptor {
  color: rgba(245, 240, 235, 0.52);
}

.rail-theme-atlas__note {
  max-width: 22ch;
  color: rgba(245, 240, 235, 0.62);
}

.rail-theme-atlas__grid {
  position: relative;
  display: grid;
  grid-template-columns: repeat(10, minmax(0, 1fr));
  gap: 0.9rem;
  align-items: start;
}

.rail-theme-atlas__grid::before,
.rail-theme-atlas__grid::after {
  content: "";
  position: absolute;
  pointer-events: none;
}

.rail-theme-atlas__grid::before {
  top: 4.4rem;
  left: 39%;
  width: 35%;
  height: 9.75rem;
  border-top: 1px solid rgba(245, 240, 235, 0.16);
  border-right: 1px solid rgba(245, 240, 235, 0.14);
  opacity: 0.55;
}

.rail-theme-atlas__grid::after {
  left: 21%;
  right: 13%;
  bottom: 3.3rem;
  height: 3.3rem;
  border-bottom: 1px solid rgba(245, 240, 235, 0.12);
  border-left: 1px solid rgba(245, 240, 235, 0.1);
  opacity: 0.45;
}

.rail-theme-atlas-card {
  --theme-accent: var(--atlas-terracotta);
  --theme-accent-deep: var(--atlas-terracotta-deep);
  --theme-rgb: 195, 110, 98;
  position: relative;
  display: grid;
  gap: 0.9rem;
  min-height: 12.6rem;
  padding: 1rem;
  overflow: hidden;
  text-align: left;
  border: 1px solid rgba(var(--theme-rgb), 0.22);
  background:
    linear-gradient(180deg, rgba(255, 252, 248, 0.97), rgba(243, 237, 229, 0.94)),
    url("./assets/paper-texture.png");
  background-size: cover;
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.42),
    0 1rem 2.2rem rgba(14, 10, 10, 0.13);
  isolation: isolate;
  transition:
    transform var(--transition-smooth),
    box-shadow var(--transition-smooth),
    border-color var(--transition-smooth);
}

.rail-theme-atlas-card::before {
  content: "";
  position: absolute;
  inset: 0 0 auto;
  height: 0.22rem;
  background: linear-gradient(90deg, var(--theme-accent-deep), rgba(var(--theme-rgb), 0.18));
  z-index: 0;
}

.rail-theme-atlas-card::after {
  content: "";
  position: absolute;
  right: -2.2rem;
  bottom: -2.7rem;
  width: 9.25rem;
  aspect-ratio: 1;
  border-radius: 999px;
  background: radial-gradient(circle, rgba(var(--theme-rgb), 0.16) 0%, rgba(var(--theme-rgb), 0.06) 38%, transparent 72%);
  z-index: 0;
  pointer-events: none;
}

.rail-theme-atlas-card--terracotta {
  --theme-accent: var(--atlas-terracotta);
  --theme-accent-deep: var(--atlas-terracotta-deep);
  --theme-rgb: 195, 110, 98;
}

.rail-theme-atlas-card--olive {
  --theme-accent: var(--atlas-olive);
  --theme-accent-deep: var(--atlas-olive-deep);
  --theme-rgb: 126, 126, 85;
}

.rail-theme-atlas-card--plum {
  --theme-accent: var(--atlas-plum);
  --theme-accent-deep: var(--atlas-plum-deep);
  --theme-rgb: 98, 69, 91;
}

.rail-theme-atlas-card:hover,
.rail-theme-atlas-card:focus-visible {
  transform: translateY(-0.35rem);
  border-color: rgba(var(--theme-rgb), 0.4);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.56),
    0 1.35rem 2.9rem rgba(14, 10, 10, 0.16);
  outline: none;
}

.rail-theme-atlas-card[data-theme-slot="lead"] {
  grid-column: 1 / span 6;
  grid-row: 1 / span 2;
  min-height: 19rem;
}

.rail-theme-atlas-card[data-theme-slot="north"] {
  grid-column: 7 / -1;
  grid-row: 1;
  min-height: 11.8rem;
}

.rail-theme-atlas-card[data-theme-slot="south"] {
  grid-column: 7 / -1;
  grid-row: 2;
  min-height: 12.2rem;
  margin-top: 0.85rem;
}

.rail-theme-atlas-card[data-theme-slot="west"] {
  grid-column: 1 / span 4;
  grid-row: 3;
  min-height: 11.75rem;
}

.rail-theme-atlas-card[data-theme-slot="east"] {
  grid-column: 3 / -1;
  grid-row: 3;
  min-height: 11.75rem;
  margin-top: 1rem;
}

.rail-theme-atlas[data-theme-count="5"] .rail-theme-atlas-card[data-theme-slot="east"] {
  grid-column: 5 / -1;
}

.rail-theme-atlas[data-theme-count="1"] .rail-theme-atlas-card[data-theme-slot="lead"] {
  grid-column: 1 / -1;
  grid-row: auto;
}

.rail-theme-atlas-card[data-theme-slot^="extra"] {
  grid-column: span 3;
}

.rail-theme-atlas-card__top,
.rail-theme-atlas-card__body,
.rail-theme-atlas-card__bottom {
  position: relative;
  z-index: 1;
}

.rail-theme-atlas-card__top,
.rail-theme-atlas-card__bottom {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 0.8rem;
}

.rail-theme-atlas-card__index,
.rail-theme-atlas-card__mode,
.rail-theme-atlas-card__action {
  font-family: var(--body-font);
  font-size: var(--rail-type-label-size);
  line-height: var(--rail-type-label-line);
  letter-spacing: var(--rail-type-label-spacing);
  text-transform: uppercase;
}

.rail-theme-atlas-card__index {
  font-weight: var(--rail-type-label-weight);
  color: rgba(23, 19, 19, 0.48);
}

.rail-theme-atlas-card__mode {
  padding: 0.24rem 0.45rem;
  border: 1px solid rgba(var(--theme-rgb), 0.2);
  background: rgba(var(--theme-rgb), 0.08);
  font-weight: 700;
  color: var(--theme-accent-deep);
}

.rail-theme-atlas-card__body {
  display: grid;
  gap: 0.55rem;
}

.rail-theme-atlas-card__title,
.rail-theme-atlas-card__copy,
.rail-theme-atlas-card__signal {
  margin: 0;
  font-family: var(--body-font);
}

.rail-theme-atlas-card__title {
  max-width: 13ch;
  font-size: var(--type-size-2xl);
  line-height: 0.96;
  letter-spacing: var(--type-tracking-none);
  font-weight: 700;
  color: var(--atlas-ink);
  text-wrap: balance;
}

.rail-theme-atlas-card[data-theme-slot="lead"] .rail-theme-atlas-card__title {
  max-width: 10ch;
  font-size: var(--type-size-4xl);
  line-height: 0.92;
}

.rail-theme-atlas-card__copy {
  max-width: 24ch;
  display: -webkit-box;
  overflow: hidden;
  font-size: var(--type-size-base);
  line-height: 1.42;
  letter-spacing: var(--type-tracking-none);
  font-weight: 500;
  color: rgba(23, 19, 19, 0.74);
  text-wrap: pretty;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 5;
}

.rail-theme-atlas-card[data-theme-slot="lead"] .rail-theme-atlas-card__copy {
  max-width: 29ch;
  font-size: var(--type-size-base);
  line-height: 1.46;
  -webkit-line-clamp: 6;
}

.rail-theme-atlas-card__bottom {
  align-items: end;
  margin-top: auto;
  padding-top: 0.72rem;
  border-top: 1px solid rgba(23, 19, 19, 0.08);
}

.rail-theme-atlas-card__signal {
  max-width: 18ch;
  font-size: var(--rail-type-meta-size);
  line-height: 1.35;
  letter-spacing: 0.01em;
  font-weight: 600;
  color: rgba(23, 19, 19, 0.56);
  text-wrap: balance;
}

.rail-theme-atlas-card__action {
  flex: none;
  padding: 0.2rem 0.42rem;
  border: 1px solid rgba(var(--theme-rgb), 0.16);
  background: rgba(var(--theme-rgb), 0.08);
  font-weight: 700;
  color: rgba(23, 19, 19, 0.44);
  transition:
    color var(--transition-smooth),
    background-color var(--transition-smooth),
    border-color var(--transition-smooth);
}

.rail-theme-atlas-card:hover .rail-theme-atlas-card__action,
.rail-theme-atlas-card:focus-visible .rail-theme-atlas-card__action {
  border-color: rgba(var(--theme-rgb), 0.28);
  background: rgba(var(--theme-rgb), 0.14);
  color: var(--theme-accent-deep);
}

.rail-theme-atlas-card__mark {
  position: absolute;
  top: 0.1rem;
  right: 0.72rem;
  z-index: 0;
  font-family: var(--display-font);
  font-size: var(--type-size-6xl);
  line-height: 0.82;
  color: rgba(var(--theme-rgb), 0.14);
  transform: translateY(-0.02em);
  pointer-events: none;
  transition: transform var(--transition-smooth), color var(--transition-smooth);
}

.rail-theme-atlas-card[data-theme-slot="lead"] .rail-theme-atlas-card__mark {
  font-size: var(--type-size-7xl);
}

.rail-theme-atlas-card:hover .rail-theme-atlas-card__mark,
.rail-theme-atlas-card:focus-visible .rail-theme-atlas-card__mark {
  transform: translateY(-0.08em);
  color: rgba(var(--theme-rgb), 0.18);
}

.rail-theme-field {
  position: relative;
  display: grid;
  gap: 1rem;
  padding: clamp(1rem, 1.5vw, 1.15rem);
  overflow: hidden;
  border: 1px solid rgba(98, 69, 91, 0.28);
  background:
    radial-gradient(circle at top left, rgba(195, 110, 98, 0.14), transparent 32%),
    radial-gradient(circle at 82% 76%, rgba(126, 126, 85, 0.11), transparent 28%),
    linear-gradient(180deg, rgba(77, 55, 71, 0.985), rgba(55, 38, 49, 0.972)),
    url("./assets/paper-texture.png");
  background-size: auto, auto, auto, 520px auto;
  box-shadow:
    inset 0 1px 0 rgba(245, 240, 235, 0.08),
    0 1rem 2.25rem rgba(17, 12, 15, 0.14);
  isolation: isolate;
}

.rail-theme-field::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(245, 240, 235, 0.06) 1px, transparent 1px),
    linear-gradient(90deg, rgba(245, 240, 235, 0.06) 1px, transparent 1px);
  background-size: 4.2rem 4.2rem;
  opacity: 0.17;
  pointer-events: none;
}

.rail-theme-field__header,
.rail-theme-field__board {
  position: relative;
  z-index: 1;
}

.rail-theme-field__header {
  display: grid;
  gap: 0.35rem;
}

.rail-theme-field__labels {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 0.75rem;
}

.rail-theme-field__count,
.rail-theme-field__descriptor,
.rail-theme-field__note {
  margin: 0;
  font-family: var(--body-font);
  font-size: var(--rail-type-label-size);
  line-height: var(--rail-type-label-line);
  letter-spacing: var(--rail-type-label-spacing);
  text-transform: uppercase;
}

.rail-theme-field__count {
  font-weight: var(--rail-type-label-weight);
  color: rgba(245, 240, 235, 0.9);
}

.rail-theme-field__descriptor {
  color: rgba(245, 240, 235, 0.5);
}

.rail-theme-field__note {
  color: rgba(245, 240, 235, 0.64);
}

.rail-theme-field__board {
  position: relative;
  min-height: 46rem;
}

.rail-theme-field__board::before,
.rail-theme-field__board::after {
  content: "";
  position: absolute;
  pointer-events: none;
}

.rail-theme-field__board::before {
  inset: 3.4rem 18% 4.2rem 18%;
  border: 1px solid rgba(245, 240, 235, 0.09);
  opacity: 0.5;
}

.rail-theme-field__board::after {
  inset: 18% 32% 16% 32%;
  border: 1px dashed rgba(245, 240, 235, 0.11);
  opacity: 0.45;
}

.rail-theme-field__link {
  position: absolute;
  border-color: rgba(245, 240, 235, 0.16);
  border-style: solid;
  pointer-events: none;
  opacity: 0.7;
}

.rail-theme-field__link--north {
  top: 6.2rem;
  left: 51%;
  width: 25%;
  height: 5.8rem;
  border-width: 1px 1px 0 0;
}

.rail-theme-field__link--east {
  top: 18.1rem;
  left: 58%;
  width: 16%;
  height: 8rem;
  border-width: 1px 1px 0 0;
}

.rail-theme-field__link--southwest {
  left: 28%;
  top: 22.4rem;
  width: 11%;
  height: 8rem;
  border-width: 0 0 1px 1px;
}

.rail-theme-field__link--south {
  left: 37%;
  top: 29.6rem;
  width: 33%;
  height: 5rem;
  border-width: 1px 0 0 1px;
}

.rail-theme-field-card {
  --theme-accent: var(--atlas-terracotta);
  --theme-accent-deep: var(--atlas-terracotta-deep);
  --theme-rgb: 195, 110, 98;
  position: absolute;
  display: grid;
  gap: 0.78rem;
  width: min(100%, 28rem);
  min-height: 9.5rem;
  padding: 0.95rem 1rem;
  overflow: hidden;
  text-align: left;
  border: 1px solid rgba(var(--theme-rgb), 0.22);
  background:
    linear-gradient(180deg, rgba(255, 252, 248, 0.98), rgba(243, 237, 229, 0.95)),
    url("./assets/paper-texture.png");
  background-size: cover;
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.45),
    0 0.85rem 1.9rem rgba(14, 10, 10, 0.12);
  isolation: isolate;
  transform: rotate(var(--theme-card-rotate, 0deg));
  transition:
    transform var(--transition-smooth),
    box-shadow var(--transition-smooth),
    border-color var(--transition-smooth);
}

.rail-theme-field-card::before {
  content: "";
  position: absolute;
  inset: 0 0 auto;
  height: 0.22rem;
  background: linear-gradient(90deg, var(--theme-accent-deep), rgba(var(--theme-rgb), 0.16));
  z-index: 0;
}

.rail-theme-field-card::after {
  content: "";
  position: absolute;
  inset: auto -2rem -2.4rem auto;
  width: 8rem;
  aspect-ratio: 1;
  border-radius: 999px;
  background: radial-gradient(circle, rgba(var(--theme-rgb), 0.16) 0%, rgba(var(--theme-rgb), 0.06) 36%, transparent 72%);
  pointer-events: none;
  z-index: 0;
}

.rail-theme-field-card--terracotta {
  --theme-accent: var(--atlas-terracotta);
  --theme-accent-deep: var(--atlas-terracotta-deep);
  --theme-rgb: 195, 110, 98;
}

.rail-theme-field-card--olive {
  --theme-accent: var(--atlas-olive);
  --theme-accent-deep: var(--atlas-olive-deep);
  --theme-rgb: 126, 126, 85;
}

.rail-theme-field-card--plum {
  --theme-accent: var(--atlas-plum);
  --theme-accent-deep: var(--atlas-plum-deep);
  --theme-rgb: 98, 69, 91;
}

.rail-theme-field-card:hover,
.rail-theme-field-card:focus-visible {
  transform: translateY(-0.24rem) rotate(var(--theme-card-rotate, 0deg));
  border-color: rgba(var(--theme-rgb), 0.38);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.55),
    0 1rem 2.25rem rgba(14, 10, 10, 0.15);
  outline: none;
}

.rail-theme-field-card[data-field-slot="anchor"] {
  top: 0;
  left: 0;
  width: min(65%, 17.25rem);
  min-height: 14.5rem;
  --theme-card-rotate: -0.95deg;
}

.rail-theme-field-card[data-field-slot="north"] {
  top: 1.4rem;
  right: 0;
  width: min(41%, 11rem);
  min-height: 10rem;
  --theme-card-rotate: 0.85deg;
}

.rail-theme-field-card[data-field-slot="east"] {
  top: 15.1rem;
  right: 0.85rem;
  width: min(37%, 10.25rem);
  min-height: 10.4rem;
  --theme-card-rotate: -0.65deg;
}

.rail-theme-field-card[data-field-slot="southwest"] {
  top: 31.4rem;
  left: 0.75rem;
  width: min(38%, 10.35rem);
  min-height: 9.8rem;
  --theme-card-rotate: 0.72deg;
}

.rail-theme-field-card[data-field-slot="south"] {
  top: 33.2rem;
  right: 0;
  width: min(53%, 14rem);
  min-height: 10.6rem;
  --theme-card-rotate: -0.74deg;
}

.rail-theme-field-card[data-field-slot^="extra"] {
  top: auto;
  left: auto;
  right: auto;
}

.rail-theme-field-card__top,
.rail-theme-field-card__body,
.rail-theme-field-card__bottom {
  position: relative;
  z-index: 1;
}

.rail-theme-field-card__top,
.rail-theme-field-card__bottom {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 0.8rem;
}

.rail-theme-field-card__index,
.rail-theme-field-card__mode,
.rail-theme-field-card__action {
  font-family: var(--body-font);
  font-size: var(--rail-type-label-size);
  line-height: var(--rail-type-label-line);
  letter-spacing: var(--rail-type-label-spacing);
  text-transform: uppercase;
}

.rail-theme-field-card__index {
  font-weight: var(--rail-type-label-weight);
  color: rgba(23, 19, 19, 0.48);
}

.rail-theme-field-card__mode {
  padding: 0.22rem 0.45rem;
  border: 1px solid rgba(var(--theme-rgb), 0.2);
  background: rgba(var(--theme-rgb), 0.08);
  font-weight: 700;
  color: var(--theme-accent-deep);
}

.rail-theme-field-card__body {
  display: grid;
  gap: 0.5rem;
}

.rail-theme-field-card__title,
.rail-theme-field-card__copy,
.rail-theme-field-card__signal {
  margin: 0;
  font-family: var(--body-font);
}

.rail-theme-field-card__title {
  max-width: 12ch;
  font-size: var(--type-size-3xl);
  line-height: 0.92;
  letter-spacing: var(--type-tracking-none);
  font-weight: 700;
  color: var(--atlas-ink);
  text-wrap: balance;
}

.rail-theme-field-card[data-field-slot="anchor"] .rail-theme-field-card__title {
  max-width: 11ch;
  font-size: var(--type-size-5xl);
}

.rail-theme-field-card[data-field-slot="north"] .rail-theme-field-card__title,
.rail-theme-field-card[data-field-slot="east"] .rail-theme-field-card__title,
.rail-theme-field-card[data-field-slot="southwest"] .rail-theme-field-card__title {
  font-size: var(--type-size-xl);
  max-width: 9ch;
}

.rail-theme-field-card__copy {
  max-width: 31ch;
  display: -webkit-box;
  overflow: hidden;
  font-size: var(--type-size-base);
  line-height: 1.45;
  letter-spacing: var(--type-tracking-none);
  font-weight: 500;
  color: rgba(23, 19, 19, 0.74);
  text-wrap: pretty;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 4;
}

.rail-theme-field-card[data-field-slot="anchor"] .rail-theme-field-card__copy {
  max-width: 36ch;
  font-size: var(--type-size-base);
  -webkit-line-clamp: 5;
}

.rail-theme-field-card[data-field-slot="north"] .rail-theme-field-card__copy,
.rail-theme-field-card[data-field-slot="east"] .rail-theme-field-card__copy,
.rail-theme-field-card[data-field-slot="southwest"] .rail-theme-field-card__copy {
  font-size: var(--type-size-md);
  line-height: 1.38;
  -webkit-line-clamp: 4;
}

.rail-theme-field-card__bottom {
  align-items: end;
  margin-top: auto;
  padding-top: 0.72rem;
  border-top: 1px solid rgba(23, 19, 19, 0.08);
}

.rail-theme-field-card__signal {
  max-width: 16ch;
  font-size: var(--rail-type-meta-size);
  line-height: 1.35;
  letter-spacing: 0.01em;
  font-weight: 600;
  color: rgba(23, 19, 19, 0.56);
  text-wrap: balance;
}

.rail-theme-field-card__action {
  flex: none;
  padding: 0.2rem 0.42rem;
  border: 1px solid rgba(var(--theme-rgb), 0.16);
  background: rgba(var(--theme-rgb), 0.08);
  font-weight: 700;
  color: rgba(23, 19, 19, 0.42);
  transition:
    color var(--transition-smooth),
    background-color var(--transition-smooth),
    border-color var(--transition-smooth);
}

.rail-theme-field-card:hover .rail-theme-field-card__action,
.rail-theme-field-card:focus-visible .rail-theme-field-card__action {
  border-color: rgba(var(--theme-rgb), 0.28);
  background: rgba(var(--theme-rgb), 0.14);
  color: var(--theme-accent-deep);
}

.rail-theme-field-card__mark {
  position: absolute;
  top: 0.08rem;
  right: 0.7rem;
  z-index: 0;
  font-family: var(--display-font);
  font-size: var(--type-size-6xl);
  line-height: 0.82;
  color: rgba(var(--theme-rgb), 0.12);
  transform: translateY(-0.02em);
  pointer-events: none;
}

.rail-theme-field {
  gap: 0.9rem;
  padding: clamp(1.1rem, 1.8vw, 1.3rem);
  border-color: rgba(245, 240, 235, 0.12);
  background:
    linear-gradient(180deg, rgba(68, 47, 62, 0.985), rgba(52, 36, 48, 0.985)),
    url("./assets/paper-texture.png");
  background-size: auto, 520px auto;
  box-shadow:
    inset 0 1px 0 rgba(245, 240, 235, 0.06),
    0 1rem 2.2rem rgba(17, 12, 15, 0.12);
}

.rail-theme-field::before {
  background-image:
    linear-gradient(90deg, rgba(245, 240, 235, 0.045) 1px, transparent 1px),
    linear-gradient(rgba(245, 240, 235, 0.035) 1px, transparent 1px);
  background-size: 5.25rem 100%, 100% 5.75rem;
  opacity: 0.24;
}

.rail-theme-field__note {
  max-width: 20rem;
}

.rail-theme-route {
  position: relative;
  display: grid;
  gap: 0.95rem;
  padding: 0.45rem 0 0.15rem;
}

.rail-theme-route::before {
  content: "";
  position: absolute;
  left: 50%;
  top: 0.3rem;
  bottom: 0.3rem;
  width: 1px;
  background: linear-gradient(
    180deg,
    rgba(245, 240, 235, 0.14),
    rgba(245, 240, 235, 0.34) 18%,
    rgba(245, 240, 235, 0.16) 82%,
    rgba(245, 240, 235, 0.08)
  );
  transform: translateX(-50%);
  pointer-events: none;
}

.rail-theme-route-stop {
  position: relative;
  display: flex;
  min-height: 10.75rem;
}

.rail-theme-route-stop[data-route-slot="feature"] {
  justify-content: center;
  min-height: 15rem;
  padding-top: 1rem;
}

.rail-theme-route-stop[data-route-slot="left"] {
  justify-content: flex-start;
  padding-right: calc(50% + 1rem);
}

.rail-theme-route-stop[data-route-slot="right"] {
  justify-content: flex-end;
  padding-left: calc(50% + 1rem);
}

.rail-theme-route-stop__dot {
  position: absolute;
  left: 50%;
  top: 1.7rem;
  z-index: 2;
  width: 0.72rem;
  aspect-ratio: 1;
  border: 1px solid rgba(245, 240, 235, 0.36);
  border-radius: 999px;
  background: rgba(245, 240, 235, 0.94);
  box-shadow: 0 0 0 0.42rem rgba(68, 47, 62, 0.36);
  transform: translateX(-50%);
  pointer-events: none;
}

.rail-theme-route-stop[data-route-slot="feature"] .rail-theme-route-stop__dot {
  top: 0.32rem;
}

.rail-theme-route-card {
  --theme-accent: var(--atlas-terracotta);
  --theme-accent-deep: var(--atlas-terracotta-deep);
  --theme-rgb: 195, 110, 98;
  position: relative;
  display: grid;
  gap: 0.85rem;
  width: 100%;
  max-width: 17rem;
  min-height: 100%;
  padding: 1rem 1rem 1.05rem;
  overflow: hidden;
  text-align: left;
  border: 1px solid rgba(var(--theme-rgb), 0.2);
  background:
    linear-gradient(180deg, rgba(255, 252, 247, 0.97), rgba(244, 238, 230, 0.94)),
    url("./assets/paper-texture.png");
  background-size: cover;
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.46),
    0 0.85rem 1.75rem rgba(14, 10, 10, 0.12);
  transition:
    transform var(--transition-smooth),
    border-color var(--transition-smooth),
    box-shadow var(--transition-smooth);
  isolation: isolate;
}

.rail-theme-route-stop[data-route-slot="feature"] .rail-theme-route-card {
  width: calc(100% - 2.4rem);
  max-width: none;
  min-height: 14rem;
}

.rail-theme-route-card::before {
  content: "";
  position: absolute;
  inset: 0 0 auto;
  height: 0.28rem;
  background: linear-gradient(90deg, var(--theme-accent-deep), rgba(var(--theme-rgb), 0.16));
  z-index: 0;
}

.rail-theme-route-stop[data-route-slot="feature"] .rail-theme-route-card::after {
  content: "";
  position: absolute;
  top: -1rem;
  left: 50%;
  width: 1px;
  height: 1rem;
  background: rgba(245, 240, 235, 0.28);
  transform: translateX(-50%);
}

.rail-theme-route-stop[data-route-slot="left"] .rail-theme-route-card::after,
.rail-theme-route-stop[data-route-slot="right"] .rail-theme-route-card::after {
  content: "";
  position: absolute;
  top: 1.72rem;
  width: 1.32rem;
  height: 1px;
  background: rgba(245, 240, 235, 0.28);
}

.rail-theme-route-stop[data-route-slot="left"] .rail-theme-route-card::after {
  right: -1.32rem;
}

.rail-theme-route-stop[data-route-slot="right"] .rail-theme-route-card::after {
  left: -1.32rem;
}

.rail-theme-route-card--terracotta {
  --theme-accent: var(--atlas-terracotta);
  --theme-accent-deep: var(--atlas-terracotta-deep);
  --theme-rgb: 195, 110, 98;
}

.rail-theme-route-card--olive {
  --theme-accent: var(--atlas-olive);
  --theme-accent-deep: var(--atlas-olive-deep);
  --theme-rgb: 126, 126, 85;
}

.rail-theme-route-card--plum {
  --theme-accent: var(--atlas-plum);
  --theme-accent-deep: var(--atlas-plum-deep);
  --theme-rgb: 98, 69, 91;
}

.rail-theme-route-card:hover,
.rail-theme-route-card:focus-visible {
  transform: translateY(-0.22rem);
  border-color: rgba(var(--theme-rgb), 0.36);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.52),
    0 1rem 2rem rgba(14, 10, 10, 0.14);
  outline: none;
}

.rail-theme-route-card__top,
.rail-theme-route-card__body,
.rail-theme-route-card__bottom {
  position: relative;
  z-index: 1;
}

.rail-theme-route-card__top {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 0.8rem;
}

.rail-theme-route-card__index,
.rail-theme-route-card__mode,
.rail-theme-route-card__action {
  font-family: var(--body-font);
  font-size: var(--rail-type-label-size);
  line-height: var(--rail-type-label-line);
  letter-spacing: var(--rail-type-label-spacing);
  text-transform: uppercase;
}

.rail-theme-route-card__index {
  font-weight: var(--rail-type-label-weight);
  color: rgba(23, 19, 19, 0.48);
}

.rail-theme-route-card__mode {
  padding: 0.22rem 0.45rem;
  border: 1px solid rgba(var(--theme-rgb), 0.2);
  background: rgba(var(--theme-rgb), 0.08);
  font-weight: 700;
  color: var(--theme-accent-deep);
}

.rail-theme-route-card__body {
  display: grid;
  gap: 0.55rem;
}

.rail-theme-route-stop[data-route-slot="feature"] .rail-theme-route-card__body {
  grid-template-columns: minmax(0, 1.05fr) minmax(0, 0.95fr);
  align-items: start;
  gap: 1rem;
}

.rail-theme-route-card__title,
.rail-theme-route-card__copy,
.rail-theme-route-card__signal {
  margin: 0;
  font-family: var(--body-font);
}

.rail-theme-route-card__title {
  max-width: 10ch;
  font-size: var(--type-size-2xl);
  line-height: 0.94;
  letter-spacing: var(--type-tracking-none);
  font-weight: 700;
  color: var(--atlas-ink);
  text-wrap: balance;
}

.rail-theme-route-stop[data-route-slot="feature"] .rail-theme-route-card__title {
  max-width: 8.5ch;
  font-size: var(--type-size-4xl);
}

.rail-theme-route-card__copy {
  max-width: 28ch;
  display: -webkit-box;
  overflow: hidden;
  font-size: var(--type-size-base);
  line-height: 1.42;
  letter-spacing: var(--type-tracking-none);
  font-weight: 500;
  color: rgba(23, 19, 19, 0.72);
  text-wrap: pretty;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 4;
}

.rail-theme-route-stop[data-route-slot="feature"] .rail-theme-route-card__copy {
  max-width: 26ch;
  padding-top: 0.16rem;
  font-size: var(--type-size-base);
  -webkit-line-clamp: 6;
}

.rail-theme-route-card__bottom {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 0.8rem;
  align-items: end;
  margin-top: auto;
  padding-top: 0.72rem;
  border-top: 1px solid rgba(23, 19, 19, 0.08);
}

.rail-theme-route-card__signal {
  max-width: 17ch;
  font-size: var(--rail-type-meta-size);
  line-height: 1.35;
  letter-spacing: 0.01em;
  font-weight: 600;
  color: rgba(23, 19, 19, 0.56);
  text-wrap: balance;
}

.rail-theme-route-card__action {
  flex: none;
  padding: 0.2rem 0.42rem;
  border: 1px solid rgba(var(--theme-rgb), 0.16);
  background: rgba(var(--theme-rgb), 0.08);
  font-weight: 700;
  color: rgba(23, 19, 19, 0.42);
  transition:
    color var(--transition-smooth),
    background-color var(--transition-smooth),
    border-color var(--transition-smooth);
}

.rail-theme-route-card:hover .rail-theme-route-card__action,
.rail-theme-route-card:focus-visible .rail-theme-route-card__action {
  border-color: rgba(var(--theme-rgb), 0.28);
  background: rgba(var(--theme-rgb), 0.14);
  color: var(--theme-accent-deep);
}

.rail-theme-route-card__mark {
  position: absolute;
  top: 0.24rem;
  right: 0.86rem;
  z-index: 0;
  font-family: var(--display-font);
  font-size: var(--type-size-7xl);
  line-height: 0.8;
  color: rgba(var(--theme-rgb), 0.12);
  pointer-events: none;
}

.rail-theme-route-stop[data-route-slot="feature"] .rail-theme-route-card__mark {
  top: 0.18rem;
  right: 1rem;
  font-size: var(--type-size-7xl);
}

@media (max-width: 980px) {
  .rail-theme-field {
    padding: 1rem;
  }

  .rail-theme-route {
    gap: 0.85rem;
  }

  .rail-theme-route-stop[data-route-slot="left"] {
    padding-right: calc(50% + 0.75rem);
  }

  .rail-theme-route-stop[data-route-slot="right"] {
    padding-left: calc(50% + 0.75rem);
  }

  .rail-theme-route-stop[data-route-slot="feature"] .rail-theme-route-card {
    width: calc(100% - 1.5rem);
  }

  .rail-theme-route-stop[data-route-slot="feature"] .rail-theme-route-card__body {
    gap: 0.85rem;
  }
}

@media (max-width: 680px) {
  .rail-theme-route {
    gap: 0.78rem;
    padding-left: 1.18rem;
  }

  .rail-theme-route::before {
    left: 0.32rem;
  }

  .rail-theme-route-stop,
  .rail-theme-route-stop[data-route-slot="feature"],
  .rail-theme-route-stop[data-route-slot="left"],
  .rail-theme-route-stop[data-route-slot="right"] {
    justify-content: flex-start;
    min-height: auto;
    padding: 0 0 0 1rem;
  }

  .rail-theme-route-stop__dot,
  .rail-theme-route-stop[data-route-slot="feature"] .rail-theme-route-stop__dot {
    left: 0.32rem;
    top: 1.28rem;
    box-shadow: 0 0 0 0.34rem rgba(68, 47, 62, 0.32);
  }

  .rail-theme-route-card,
  .rail-theme-route-stop[data-route-slot="feature"] .rail-theme-route-card {
    width: 100%;
    max-width: none;
    min-height: auto;
  }

  .rail-theme-route-stop[data-route-slot="feature"] .rail-theme-route-card::after,
  .rail-theme-route-stop[data-route-slot="left"] .rail-theme-route-card::after,
  .rail-theme-route-stop[data-route-slot="right"] .rail-theme-route-card::after {
    top: 1.62rem;
    left: -1rem;
    right: auto;
    width: 1rem;
    height: 1px;
    transform: none;
  }

  .rail-theme-route-stop[data-route-slot="feature"] .rail-theme-route-card__body {
    grid-template-columns: 1fr;
  }

  .rail-theme-route-card__title {
    max-width: 11ch;
  }

  .rail-theme-route-stop[data-route-slot="feature"] .rail-theme-route-card__title {
    max-width: 9ch;
    font-size: var(--type-size-4xl);
  }

  .rail-theme-route-card__mark {
    font-size: var(--type-size-6xl);
  }

  .rail-theme-route-stop[data-route-slot="feature"] .rail-theme-route-card__mark {
    font-size: var(--type-size-7xl);
  }
}

.rail-theme-index {
  --theme-index-text: rgba(23, 19, 19, 0.94);
  --theme-index-muted: rgba(23, 19, 19, 0.5);
  --theme-index-soft: rgba(23, 19, 19, 0.7);
  --theme-index-divider: rgba(23, 19, 19, 0.1);
  --theme-index-hover: rgba(23, 19, 19, 0.03);
  display: grid;
  gap: 0.8rem;
}

.rail-theme-index__header {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 1rem;
}

.rail-theme-index__labels {
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  gap: 0.7rem 1rem;
}

.rail-theme-index__count,
.rail-theme-index__descriptor {
  margin: 0;
  font-family: var(--body-font);
  font-size: var(--rail-type-label-size);
  line-height: var(--rail-type-label-line);
  letter-spacing: var(--rail-type-label-spacing);
  text-transform: uppercase;
}

.rail-theme-index__count {
  font-weight: var(--rail-type-label-weight);
  color: var(--theme-index-text);
}

.rail-theme-index__descriptor {
  color: var(--theme-index-muted);
}

.rail-theme-link-list {
  display: grid;
  border-top: 1px solid var(--theme-index-divider);
}

.rail-theme-link-row {
  display: grid;
  gap: 0.48rem;
  width: 100%;
  padding: 1rem 0;
  text-align: left;
  border-bottom: 1px solid var(--theme-index-divider);
  background: transparent;
  color: var(--theme-index-text);
  transition:
    background-color var(--transition-smooth),
    transform var(--transition-smooth);
}

.rail-theme-link-row:hover,
.rail-theme-link-row:focus-visible {
  background: var(--theme-index-hover);
  transform: translateX(0.18rem);
  outline: none;
}

.rail-theme-link-row__head {
  display: flex;
  justify-content: space-between;
  gap: 1rem;
  align-items: baseline;
}

.rail-theme-link-row__meta,
.rail-theme-link-row__mode {
  font-family: var(--body-font);
  font-size: var(--rail-type-label-size);
  line-height: var(--rail-type-label-line);
  letter-spacing: var(--rail-type-label-spacing);
  text-transform: uppercase;
  font-weight: var(--rail-type-label-weight);
  color: var(--theme-index-muted);
}

.rail-theme-link-row__mode {
  text-align: right;
}

.rail-theme-link-row__title {
  margin: 0;
  max-width: 100%;
  overflow: visible;
  font-family: var(--body-font);
  font-size: var(--type-size-xl);
  line-height: 1.08;
  letter-spacing: var(--type-tracking-none);
  font-weight: 700;
  color: var(--theme-index-text);
  text-overflow: clip;
  text-wrap: balance;
  white-space: normal;
}

.rail-theme-link-row__excerpt {
  display: block;
  margin: 0;
  max-width: 40rem;
  overflow: visible;
  font-family: var(--body-font);
  font-size: var(--rail-type-body-size);
  line-height: var(--rail-type-body-line);
  letter-spacing: var(--rail-type-body-spacing);
  font-weight: var(--rail-type-body-weight);
  color: var(--theme-index-soft);
  text-wrap: pretty;
}

.rail-theme-link-row__signal {
  margin: 0.05rem 0 0;
  font-family: var(--body-font);
  font-size: var(--rail-type-meta-size);
  line-height: var(--rail-type-meta-line);
  letter-spacing: var(--rail-type-meta-spacing);
  font-weight: 600;
  color: var(--theme-index-muted);
  text-wrap: balance;
}

:where(
  .content-panel[data-surface="terracotta"] .content-panel__inner,
  .content-panel[data-surface="olive"] .content-panel__inner,
  .content-panel[data-surface="plum"] .content-panel__inner,
  .content-panel[data-surface="red"] .content-panel__inner
) .rail-theme-index {
  --theme-index-text: var(--rail-surface-text);
  --theme-index-muted: var(--rail-surface-muted);
  --theme-index-soft: var(--rail-surface-soft);
  --theme-index-divider: var(--rail-surface-divider);
  --theme-index-hover: var(--rail-surface-ui-hover);
}

@media (max-width: 680px) {
  .rail-theme-index__header,
  .rail-theme-link-row__head {
    flex-direction: column;
    align-items: flex-start;
    gap: 0.22rem;
  }

  .rail-theme-link-row__mode {
    text-align: left;
  }

  .rail-theme-link-row__title,
  .rail-theme-link-row__excerpt {
    max-width: none;
  }
}

.rail-about-subsection {
  display: grid;
  gap: 0;
  padding-top: 1rem;
  border-top: 1px solid rgba(23, 19, 19, 0.08);
}

.rail-about-subsection__copy {
  margin: 0;
  font-family: var(--body-font);
  font-size: var(--rail-type-body-size);
  line-height: var(--rail-type-body-line);
  letter-spacing: var(--rail-type-body-spacing);
  font-weight: var(--rail-type-body-weight);
  color: rgba(23, 19, 19, 0.84);
}

.rail-about-subsection__title + .rail-about-subsection__copy {
  margin-top: var(--rail-card-title-copy-gap);
}

.rail-about-subsection__meta {
  margin: 0;
  font-family: var(--body-font);
  font-size: var(--rail-type-meta-size);
  line-height: var(--rail-type-meta-line);
  letter-spacing: var(--rail-type-meta-spacing);
  font-weight: var(--rail-type-meta-weight);
  color: rgba(23, 19, 19, 0.58);
}

.rail-about-subsection__copy + .rail-about-subsection__meta,
.rail-about-subsection__copy + .rail-cta,
.rail-about-subsection__meta + .rail-cta {
  margin-top: 0.55rem;
}

.rail-roster {
  display: grid;
  gap: 0.28rem;
}

.rail-roster__label {
  margin: 0;
  font-family: var(--body-font);
  font-size: var(--rail-type-label-size);
  font-weight: var(--rail-type-label-weight);
  line-height: var(--rail-type-label-line);
  letter-spacing: var(--rail-type-label-spacing);
  text-transform: uppercase;
  color: rgba(23, 19, 19, 0.5);
}

.rail-roster__names {
  margin: 0;
  font-family: var(--body-font);
  font-size: var(--rail-type-body-size);
  line-height: var(--rail-type-body-line);
  letter-spacing: var(--rail-type-body-spacing);
  font-weight: var(--rail-type-body-weight);
  color: rgba(23, 19, 19, 0.82);
}

.rail-newsletter {
  display: grid;
  gap: 0.7rem;
}

.rail-newsletter__form {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: stretch;
  border: 1px solid var(--atlas-ink);
  margin-top: 0.1rem;
}

.rail-newsletter__field {
  min-height: 2.55rem;
}

.rail-newsletter__form input {
  width: 100%;
  height: 100%;
  min-height: 2.55rem;
  box-sizing: border-box;
  padding: 0 0.85rem;
  border: 0;
  background: transparent;
  color: var(--atlas-ink);
  font-size: var(--type-size-md);
}

.rail-newsletter__form input::placeholder {
  color: rgba(23, 19, 19, 0.42);
}

.rail-newsletter__form button {
  align-self: stretch;
  height: 100%;
  min-height: 2.55rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0 0.85rem;
  background: var(--atlas-ink);
  color: var(--atlas-paper);
  font-family: var(--mono-font);
  font-size: var(--type-size-md);
}

.rail-newsletter__form button:hover,
.rail-newsletter__form button:focus-visible {
  background: var(--atlas-terracotta-deep);
  outline: none;
}

.rail-newsletter__form button:disabled {
  cursor: wait;
  opacity: 0.62;
}

.rail-newsletter__honeypot {
  position: absolute;
  left: -5000px;
}

.rail-newsletter__status {
  grid-column: 1 / -1;
  margin: -0.1rem 0 0;
  font-family: var(--body-font);
  font-size: var(--rail-type-meta-size);
  line-height: var(--rail-type-meta-line);
  color: rgba(23, 19, 19, 0.64);
}

.rail-newsletter__status[data-tone="success"] {
  color: var(--atlas-terracotta-deep);
}

.rail-newsletter__status[data-tone="error"] {
  color: #9f2e2e;
}

.rail-newsletter__privacy {
  margin: 0;
  font-family: var(--body-font);
  font-size: var(--rail-type-meta-size);
  line-height: var(--rail-type-meta-line);
  letter-spacing: var(--rail-type-meta-spacing);
  font-weight: var(--rail-type-meta-weight);
  color: rgba(23, 19, 19, 0.54);
}

.rail-contact-form {
  display: grid;
  gap: 0.95rem;
}

.rail-contact-form__grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.85rem;
}

.rail-contact-form__field {
  display: grid;
  gap: 0.42rem;
}

.rail-contact-form__field--full {
  grid-column: 1 / -1;
}

.rail-contact-form__label {
  margin: 0;
  font-family: var(--body-font);
  font-size: var(--rail-type-label-size);
  line-height: var(--rail-type-label-line);
  letter-spacing: var(--rail-type-label-spacing);
  text-transform: uppercase;
  font-weight: var(--rail-type-label-weight);
  color: rgba(23, 19, 19, 0.56);
}

.rail-contact-form__input,
.rail-contact-form__select,
.rail-contact-form__textarea {
  width: 100%;
  border: 1px solid rgba(23, 19, 19, 0.14);
  background:
    linear-gradient(180deg, rgba(255, 252, 247, 0.98), rgba(244, 238, 231, 0.94)),
    url("./assets/paper-texture.png");
  background-size: cover;
  color: var(--atlas-ink);
  font-family: var(--body-font);
  font-size: var(--type-size-base);
  line-height: 1.45;
  letter-spacing: var(--type-tracking-none);
  transition:
    border-color var(--transition-smooth),
    box-shadow var(--transition-smooth),
    background-color var(--transition-smooth);
}

.rail-contact-form__input,
.rail-contact-form__select {
  min-height: 3rem;
  padding: 0 0.9rem;
}

.rail-contact-form__select {
  appearance: auto;
  border-radius: 0;
}

.rail-contact-form__textarea {
  min-height: 9.5rem;
  padding: 0.82rem 0.9rem;
  resize: vertical;
}

.rail-contact-form__input::placeholder,
.rail-contact-form__textarea::placeholder {
  color: rgba(23, 19, 19, 0.42);
}

.rail-contact-form__input:hover,
.rail-contact-form__select:hover,
.rail-contact-form__textarea:hover {
  border-color: rgba(23, 19, 19, 0.24);
}

.rail-contact-form__input:focus-visible,
.rail-contact-form__select:focus-visible,
.rail-contact-form__textarea:focus-visible {
  outline: none;
  border-color: rgba(114, 59, 51, 0.48);
  box-shadow: 0 0 0 3px rgba(195, 110, 98, 0.12);
}

.rail-contact-form__submit {
  justify-self: flex-start;
  min-height: 2.9rem;
  padding: 0 1rem;
  border: 1px solid transparent;
  background: var(--atlas-ink);
  color: var(--atlas-paper);
  font-family: var(--mono-font);
  font-size: var(--type-size-md);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  transition:
    background-color var(--transition-smooth),
    transform var(--transition-smooth),
    box-shadow var(--transition-smooth);
}

.rail-contact-form__submit:hover,
.rail-contact-form__submit:focus-visible {
  background: var(--atlas-terracotta-deep);
  box-shadow: 0 0.85rem 1.7rem rgba(23, 19, 19, 0.18);
  transform: translateY(-1px);
  outline: none;
}

.rail-contact-form__confirmation {
  margin: 0;
  font-family: var(--body-font);
  font-size: var(--rail-type-meta-size);
  line-height: var(--rail-type-meta-line);
  letter-spacing: var(--rail-type-meta-spacing);
  font-weight: 600;
  color: rgba(114, 59, 51, 0.84);
}

.rail-contact-form__confirmation[data-tone="error"] {
  color: rgba(170, 38, 31, 0.92);
}

.rail-article--contact-page .rail-contact {
  margin-top: 0.1rem;
}

.rail-article--contact-page .rail-panel-section--contact-note {
  background: #0f0c0d;
  border-color: rgba(245, 240, 235, 0.12);
  box-shadow: 0 18px 40px rgba(9, 7, 8, 0.22);
}

.rail-article--contact-page .rail-panel-section--contact-note .rail-section-label,
.rail-article--contact-page .rail-panel-section--contact-note .rail-summary,
.rail-article--contact-page .rail-panel-section--contact-note .rail-panel-copy,
.rail-article--contact-page .rail-panel-section--contact-note .rail-contact a,
.rail-article--contact-page .rail-panel-section--contact-note .rail-social a,
.rail-article--contact-page .rail-panel-section--contact-note .rail-social__entry {
  color: rgba(245, 240, 235, 0.96);
}

.rail-article--contact-page .rail-panel-section--contact-note .rail-section-label {
  color: rgba(245, 240, 235, 0.72);
}

.rail-article--contact-page .rail-panel-section--contact-note .rail-contact a,
.rail-article--contact-page .rail-panel-section--contact-note .rail-social a strong,
.rail-article--contact-page .rail-panel-section--contact-note .rail-social__entry strong {
  text-decoration-color: rgba(245, 240, 235, 0.72);
}

.rail-article--contact-page .rail-social {
  background: transparent;
}

.rail-article--contact-page .rail-panel-section--contact-note .rail-social {
  border-top-color: rgba(245, 240, 235, 0.14);
}

.rail-article--contact-page .rail-panel-section--contact-note .rail-social a span,
.rail-article--contact-page .rail-panel-section--contact-note .rail-social__entry span {
  color: rgba(245, 240, 235, 0.76);
}

.rail-contact {
  display: grid;
  gap: 0.45rem;
}

.rail-contact a {
  text-decoration: underline;
  text-decoration-thickness: 1px;
  text-underline-offset: 2px;
  font-family: var(--body-font);
  font-weight: var(--rail-type-strong-weight);
  font-size: var(--rail-type-strong-size);
  line-height: var(--rail-type-strong-line);
  letter-spacing: var(--rail-type-strong-spacing);
}

.rail-social {
  display: grid;
  gap: 0.45rem;
}

.rail-social a {
  display: flex;
  justify-content: space-between;
  gap: 1rem;
  padding: 0.1rem 0;
  font-size: var(--rail-type-body-size);
  line-height: var(--rail-type-body-line);
  letter-spacing: var(--rail-type-body-spacing);
  font-weight: var(--rail-type-body-weight);
}

.rail-social__entry {
  display: flex;
  justify-content: space-between;
  gap: 1rem;
  padding: 0.1rem 0;
  font-family: var(--body-font);
  font-weight: var(--rail-type-body-weight);
  font-size: var(--rail-type-body-size);
  line-height: var(--rail-type-body-line);
  letter-spacing: var(--rail-type-body-spacing);
  color: rgba(23, 19, 19, 0.82);
}

.rail-social__entry span {
  font-family: var(--body-font);
  font-weight: var(--rail-type-micro-weight);
  font-size: var(--rail-type-micro-size);
  line-height: var(--rail-type-micro-line);
  letter-spacing: var(--rail-type-micro-spacing);
  text-transform: uppercase;
  color: rgba(23, 19, 19, 0.56);
}

.rail-social a span {
  font-family: var(--body-font);
  font-weight: var(--rail-type-micro-weight);
  font-size: var(--rail-type-micro-size);
  line-height: var(--rail-type-micro-line);
  letter-spacing: var(--rail-type-micro-spacing);
  color: rgba(23, 19, 19, 0.56);
}

@media (max-width: 680px) {
  .rail-contact-form__grid {
    grid-template-columns: minmax(0, 1fr);
  }

  .rail-contact-form__field--full {
    grid-column: auto;
  }
}

.rail-collection-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.9375rem;
}

.rail-collection-card {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  gap: 0.55rem;
  min-height: 8.75rem;
  padding: 0.625rem;
  background: rgba(255, 253, 249, 0.92);
  border-radius: 0;
  text-align: left;
  box-shadow: 0 0.35rem 1.1rem rgba(25, 21, 20, 0.05);
  transition: background var(--transition-smooth), transform var(--transition-smooth);
}

.rail-collection-card:hover,
.rail-collection-card:focus-visible {
  background: rgba(255, 255, 255, 0.98);
  transform: translateY(-1px);
  outline: none;
}

.rail-collection-card__title {
  font-family: var(--body-font);
  font-size: var(--rail-type-strong-size);
  line-height: var(--rail-type-strong-line);
  letter-spacing: var(--rail-type-strong-spacing);
  font-weight: var(--rail-type-strong-weight);
  color: var(--atlas-ink);
}

.rail-collection-card__subtitle,
.rail-collection-card__type {
  font-family: var(--body-font);
  font-size: var(--rail-type-meta-size);
  line-height: var(--rail-type-meta-line);
  letter-spacing: var(--rail-type-meta-spacing);
}

.rail-collection-card__subtitle {
  font-weight: 500;
  color: rgba(23, 19, 19, 0.58);
}

.rail-collection-card__type {
  font-weight: 400;
  color: rgba(23, 19, 19, 0.78);
}

.flash-message {
  position: fixed;
  right: 1.25rem;
  bottom: 1.25rem;
  z-index: 15;
  padding: 0.82rem 0.9rem;
  background: rgba(23, 19, 19, 0.92);
  color: var(--atlas-paper);
  box-shadow: 0 1rem 2rem rgba(0, 0, 0, 0.22);
}

.newsletter-modal[hidden] {
  display: none;
}

.newsletter-modal {
  position: fixed;
  inset: 0;
  z-index: 40;
  display: grid;
  place-items: center;
  padding: clamp(1rem, 3vw, 2.5rem);
}

.newsletter-modal__backdrop {
  position: absolute;
  inset: 0;
  border: 0;
  background: rgba(44, 28, 43, 0.66);
  backdrop-filter: blur(4px);
}

.newsletter-modal__dialog {
  position: relative;
  width: min(34rem, 100%);
  padding: clamp(1.25rem, 4vw, 2rem);
  border: 1px solid rgba(23, 19, 19, 0.18);
  background:
    linear-gradient(135deg, rgba(255, 252, 248, 0.95), rgba(235, 226, 217, 0.92)),
    url("./assets/paper-texture.png");
  background-size: cover;
  box-shadow: 0 1.2rem 4rem rgba(0, 0, 0, 0.34);
}

.newsletter-modal__close {
  position: absolute;
  top: 0.7rem;
  right: 0.7rem;
  width: 2.2rem;
  height: 2.2rem;
  display: grid;
  place-items: center;
  border: 1px solid rgba(23, 19, 19, 0.18);
  background: rgba(255, 252, 248, 0.72);
  color: var(--atlas-ink);
  font-size: var(--type-size-lg);
  line-height: 1;
}

.newsletter-modal__close:hover,
.newsletter-modal__close:focus-visible {
  background: var(--atlas-ink);
  color: var(--atlas-paper);
  outline: none;
}

.newsletter-modal__eyebrow {
  margin: 0 0 0.8rem;
  font-family: var(--mono-font);
  font-size: var(--rail-type-label-size);
  line-height: var(--rail-type-label-line);
  letter-spacing: var(--rail-type-label-spacing);
  font-weight: var(--rail-type-label-weight);
  text-transform: uppercase;
  color: rgba(23, 19, 19, 0.58);
}

.newsletter-modal__title {
  max-width: 10ch;
  margin: 0;
  font-size: var(--type-size-3xl);
  line-height: 0.96;
  font-weight: 800;
  color: var(--atlas-ink);
  text-wrap: balance;
}

.newsletter-modal__summary {
  max-width: 28rem;
  margin: 1rem 0 1.25rem;
  font-size: var(--type-size-lg);
  line-height: 1.22;
  color: rgba(23, 19, 19, 0.76);
}

/* Compact desktop maps mode for short viewports. */
@media (min-width: 1181px) and (max-height: 760px) {
  .maps-stage__shell {
    gap: 0.7rem;
    padding: 0.75rem;
    overflow-y: auto;
  }

  .maps-stage__header {
    gap: 0.65rem 1rem;
    padding-bottom: 0.6rem;
  }

  .maps-stage__copy {
    gap: 0.28rem;
  }

  .maps-stage__summary {
    max-width: 48rem;
    line-height: 1.35;
  }

  .maps-stage__tabs {
    gap: 0.38rem;
  }

  .maps-stage__tab,
  .maps-stage__open,
  .mobility-lab__retry {
    min-height: 2.05rem;
    padding-inline: 0.72rem;
  }

  .mobility-lab {
    gap: 0.68rem;
  }

  .mobility-lab__mast {
    gap: 0.7rem;
  }

  .mobility-lab__intro {
    gap: 0.28rem;
  }

  .mobility-lab__summary {
    line-height: 1.32;
  }

  .mobility-lab__stats {
    gap: 0.45rem;
  }

  .mobility-lab__stat {
    min-width: 4.6rem;
    padding: 0.55rem 0.68rem;
  }

  .mobility-lab__stat-label {
    margin-top: 0.24rem;
  }

  .mobility-lab__controls,
  .mobility-lab__workspace {
    gap: 0.62rem;
  }

  .mobility-lab__control {
    gap: 0.28rem;
  }

  .mobility-lab__control select {
    min-height: 2.55rem;
    padding-inline: 0.75rem;
  }

  .mobility-chart {
    gap: 0.55rem;
    padding: 0.75rem;
  }

  .mobility-chart__insight {
    gap: 0.28rem;
    padding: 0.62rem 0.72rem;
  }

  .mobility-chart__insight p:last-child {
    font-size: clamp(1.32rem, 1.58vw, 1.62rem);
    line-height: 1.05;
  }

  .mobility-chart__title {
    font-size: var(--type-size-lg);
  }

  .mobility-chart__rows {
    gap: 0.55rem;
  }

  .mobility-chart__row {
    grid-template-columns: minmax(9.5rem, 12.75rem) minmax(0, 1fr);
  }

  .mobility-chart__label-group {
    gap: 0.08rem;
  }

  .mobility-chart__category {
    font-size: var(--type-size-sm);
  }

  .mobility-chart__count {
    font-size: var(--type-size-xs);
  }

  .mobility-chart__track {
    min-height: 1.72rem;
  }

  .mobility-notes {
    gap: 0.6rem;
  }

  .mobility-notes__card {
    gap: 0.34rem;
    padding: 0.72rem;
  }

  .mobility-notes__headline {
    font-size: var(--type-size-sm);
    line-height: 1.15;
  }

  .mobility-notes__body {
    font-size: var(--type-size-sm);
    line-height: 1.35;
  }
}

.newsletter-modal__form {
  margin-top: 0;
  background: rgba(255, 252, 248, 0.42);
}

.newsletter-modal__privacy {
  margin: 0.75rem 0 0;
  font-family: var(--body-font);
  font-size: var(--rail-type-meta-size);
  line-height: var(--rail-type-meta-line);
  color: rgba(23, 19, 19, 0.54);
}

@media (max-width: 1180px) {
  :root {
    --rail-shell-padding: 2.65rem;
    --rail-media-frame-padding: 0.85rem;
    --rail-content-padding-bottom: 5rem;
  }

  .maps-stage__header,
  .mobility-lab__mast,
  .mobility-lab__workspace {
    grid-template-columns: 1fr;
  }

  .maps-stage__topbar {
    justify-items: start;
  }

  .maps-stage__tabs {
    justify-content: flex-start;
  }

  .mobility-chart__row {
    grid-template-columns: minmax(9rem, 12rem) minmax(0, 1fr);
  }

  .rail-header {
    left: var(--rail-shell-padding);
    top: 2.25rem;
    width: min(100%, calc(100% - (var(--rail-shell-padding) * 2)));
  }

  .rail-content {
    padding: 8.75rem var(--rail-shell-padding) var(--rail-content-padding-bottom);
  }

  .rail-article {
    width: 100%;
  }
}

@media (max-width: 980px) {
  :root {
    --rail-track-width: 100%;
    --rail-floating-inset: 0;
    --rail-shell-padding: 2rem;
    --rail-content-padding-bottom: 2rem;
    --stage-overlay-right-gap: 0px;
    --rail-surface-texture-image: var(--atlas-paper-texture);
    --rail-surface-texture-size: 420px auto;
    --rail-surface-texture-position: center top;
    --rail-surface-texture-repeat: repeat-y;
  }

  body {
    background: var(--atlas-paper-deep);
    overflow-x: hidden;
    overflow-y: auto;
  }

  .site-shell {
    display: block;
    height: auto;
    min-height: 100vh;
  }

  .visual-stage {
    display: none;
  }

  .content-panel {
    position: relative;
    top: auto;
    right: auto;
    bottom: auto;
    left: auto;
    width: 100%;
    min-height: 100vh;
    transform: none !important;
  }

  .content-panel__stack {
    display: none;
  }

  .content-panel__inner {
    position: relative;
    inset: 0;
    min-height: 100vh;
    opacity: 1 !important;
    pointer-events: auto !important;
    border-color: transparent;
    box-shadow: none;
    transform: none !important;
  }

  .content-panel[data-surface] {
    --rail-surface-texture-opacity: 0.08;
  }

  .content-panel.content-panel--maps-mode {
    --rail-surface-color: #231a1d;
    --rail-surface-hover-color: #2b1f27;
    --rail-surface-border: rgba(245, 240, 235, 0.14);
    --rail-surface-shadow: none;
    --rail-surface-text: var(--atlas-paper);
    --rail-surface-muted: rgba(245, 240, 235, 0.64);
    --rail-surface-soft: rgba(245, 240, 235, 0.5);
    --rail-surface-divider: rgba(245, 240, 235, 0.14);
    background-color: #231a1d;
  }

  .content-panel.content-panel--maps-mode .content-panel__inner {
    background-color: #231a1d;
    color: var(--atlas-paper);
  }

  .content-panel.content-panel--maps-mode .content-panel__inner::before {
    opacity: 0;
  }

  .content-panel.content-panel--maps-mode :where(.rail-summary, .rail-title, .rail-header__brand) {
    color: rgba(245, 240, 235, 0.96);
  }

  .content-panel[data-surface="terracotta"],
  .content-panel[data-surface="olive"],
  .content-panel[data-surface="plum"],
  .content-panel[data-surface="red"] {
    --rail-surface-texture-image: none;
    --rail-surface-texture-opacity: 0;
  }

  .content-panel[data-stack-state="detail"] .content-panel__inner {
    inset: 0;
    box-shadow: none;
    transform: none !important;
  }

  .content-panel[data-stack-state="detail"] .content-panel__inner.content-panel__inner--entering-forward,
  .content-panel[data-stack-state="detail"] .content-panel__inner.content-panel__inner--entering-backward {
    animation: none;
    will-change: auto;
  }

  .content-panel__collapse {
    display: none !important;
  }

  .rail-header {
    position: sticky;
    top: 0;
    left: auto;
    width: auto;
    min-height: 3rem;
    z-index: 40;
    margin: max(0.85rem, env(safe-area-inset-top)) var(--rail-shell-padding) 0;
    padding: 0;
    border-radius: 0;
    box-shadow: none;
    background: transparent;
    border-bottom: 1px solid var(--rail-surface-border);
  }

  .rail-header::before,
  .rail-header::after {
    inset: 0;
  }

  .rail-header__home,
  .rail-header__menu,
  .rail-header__back {
    height: 3rem;
  }

  .rail-header__menu {
    width: 3rem;
    flex-basis: 3rem;
  }

  .rail-header__home {
    padding-inline: 1.05rem;
  }

  .rail-header__brand {
    font-size: var(--type-size-base);
    letter-spacing: var(--type-tracking-none);
  }

  .rail-header__brand::before {
    content: "Menu > ";
    color: var(--rail-surface-muted);
  }

  .rail-header__breadcrumb {
    display: none;
  }

  .rail-title {
    max-width: 12ch;
  }

  .rail-archive__header,
  .rail-archive__row,
  .rail-collection-grid,
  .rail-theme-atlas__grid,
  .rail-about-subsections,
  .rail-about-city-list,
  .rail-profile-list,
  .rail-essayist-list {
    gap: 0.65rem;
  }

  .rail-theme-atlas {
    gap: 0.85rem;
    padding: 0.95rem;
  }

  .rail-theme-field {
    gap: 0.85rem;
    padding: 0.95rem;
  }

  .rail-theme-field__board {
    min-height: 42rem;
  }

  .rail-theme-field-card[data-field-slot="anchor"] {
    width: min(60%, 17.5rem);
  }

  .rail-theme-field-card[data-field-slot="north"] {
    width: min(36%, 10.5rem);
    right: 0;
  }

  .rail-theme-field-card[data-field-slot="east"] {
    width: min(35%, 10rem);
    right: 0.3rem;
  }

  .rail-theme-field-card[data-field-slot="southwest"] {
    width: min(37%, 10rem);
    left: 0.2rem;
  }

  .rail-theme-field-card[data-field-slot="south"] {
    width: min(50%, 13.4rem);
  }

  .rail-theme-atlas__grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .rail-theme-atlas__grid::before,
  .rail-theme-atlas__grid::after {
    display: none;
  }

  .rail-theme-atlas-card[data-theme-slot="lead"] {
    grid-column: 1 / -1;
    grid-row: auto;
    min-height: 16rem;
  }

  .rail-theme-atlas-card[data-theme-slot="north"],
  .rail-theme-atlas-card[data-theme-slot="south"],
  .rail-theme-atlas-card[data-theme-slot="west"],
  .rail-theme-atlas-card[data-theme-slot="east"],
  .rail-theme-atlas-card[data-theme-slot^="extra"] {
    grid-column: auto;
    grid-row: auto;
    min-height: 12rem;
    margin-top: 0;
  }

  .rail-profile-list {
    grid-template-columns: minmax(0, 1fr);
  }

  .rail-profile-card {
    grid-template-columns: minmax(0, 1fr);
    gap: 0.85rem;
    padding: 0.85rem;
  }

  .rail-essayist-card {
    grid-template-columns: 7.5rem minmax(0, 1fr);
    gap: 0.85rem;
    padding: 0.85rem;
  }

  .rail-partnership-benefits__body {
    grid-template-columns: minmax(0, 1fr);
    gap: 0.42rem;
  }

  .rail-partnership-benefits__item--featured .rail-partnership-benefits__body {
    max-width: 100%;
  }

  .rail-partnership-benefits__copy {
    max-width: 31ch;
  }

  .rail-panel-section--travel-extended .rail-cta {
    width: 100%;
  }

  .rail-artist-card-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .rail-artist-card {
    grid-template-columns: 7.5rem minmax(0, 1fr);
    gap: 0.85rem;
    padding: 0.85rem;
  }

  .rail-meta-stack__row {
    grid-template-columns: minmax(9.5rem, max-content) minmax(0, 1fr);
  }

  .rail-archive__label:nth-child(2),
  .rail-archive__label:nth-child(3),
  .rail-archive__meta {
    flex-basis: calc(25% - 0.65rem);
  }

  .rail-content {
    padding: 1.5rem var(--rail-shell-padding) var(--rail-content-padding-bottom);
  }

  .rail-menu {
    left: 0;
    right: auto;
    width: 100%;
    z-index: 44;
    background-color: var(--rail-surface-color);
  }

  .rail-linear-nav {
    margin-inline: var(--rail-shell-padding);
  }

  .rail-inline-workspace__body .maps-embed-frame {
    height: clamp(22rem, 62vh, 34rem);
  }

  .visual-stage__coords {
    right: 1.25rem;
  }

  .visual-stage__anchor {
    left: 50%;
  }

  .help-panel {
    right: 1.25rem;
  }

  .stage-controls {
    gap: 0.32rem;
    padding: 0.4rem;
  }

  .stage-controls__button {
    width: 2.4rem;
    height: 2.4rem;
  }

  .stage-controls__readout {
    min-width: 3.4rem;
    font-size: var(--type-size-xs);
  }

  .maps-stage {
    right: 1rem;
    bottom: 1rem;
  }

  .maps-stage__shell {
    padding: 0.9rem;
  }

  .mobility-lab__controls {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

}

@media (max-width: 680px) {
  :root {
    --rail-shell-padding: 1.15rem;
    --rail-content-padding-bottom: calc(1.6rem + env(safe-area-inset-bottom));
    --rail-media-frame-padding: 0.6rem;
    --rail-surface-texture-size: 320px auto;
  }

  .rail-panel-section + .rail-panel-section {
    margin-top: 2.2rem;
  }

  .rail-summary {
    max-width: 100%;
  }

  .rail-header__back {
    min-width: 3.25rem;
    padding-inline: 0.65rem;
  }

  .rail-header__brand {
    max-width: 100%;
  }

  .rail-header__breadcrumb {
    display: none;
  }

  .rail-newsletter__form {
    grid-template-columns: minmax(0, 1fr);
  }

  .rail-newsletter__submit {
    width: 100%;
  }

  .rail-media-inquiries__row {
    grid-template-columns: minmax(0, 1fr);
    gap: 0.3rem;
  }

  .rail-panel-section--travel-extended {
    padding: 1rem;
  }

  .rail-travel-route,
  .rail-travel-contact {
    padding-inline: 0.9rem;
  }

  .rail-travel-benefits__item {
    grid-template-columns: 1.8rem minmax(0, 1fr);
    gap: 0.25rem 0.65rem;
  }

  .rail-partnership-benefits__item {
    grid-template-columns: 2.2rem minmax(0, 1fr);
    gap: 0.72rem;
    padding-block: 0.9rem;
  }

  .rail-partnership-benefits__item--featured {
    padding-top: 0.9rem;
    padding-bottom: 0.9rem;
  }

  .rail-partnership-benefits__item--featured::before {
    inset: 0 -0.2rem 0 -0.32rem;
  }

  .rail-partnership-benefits__index {
    font-size: var(--type-size-base);
    transform: translateY(0.14rem);
  }

  .rail-partnership-benefits__item--featured .rail-partnership-benefits__index {
    font-size: var(--type-size-base);
  }

  .rail-partnership-benefits__title {
    font-size: var(--type-size-base);
  }

  .rail-partnership-benefits__item--featured .rail-partnership-benefits__title {
    font-size: var(--type-size-base);
    max-width: none;
  }

  .rail-partnership-benefits__copy {
    max-width: 100%;
    font-size: var(--type-size-md);
  }

  .rail-profile-list {
    grid-template-columns: minmax(0, 1fr);
  }

  .rail-profile-card {
    grid-template-columns: minmax(0, 1fr);
    gap: 0.75rem;
    padding: 0.75rem;
  }

  .rail-essayist-card {
    grid-template-columns: 6.25rem minmax(0, 1fr);
    gap: 0.75rem;
    padding: 0.75rem;
  }

  .rail-profile-card__media {
    min-height: 0;
  }

  .rail-artist-card-grid {
    grid-template-columns: minmax(0, 1fr);
  }

  .rail-artist-card {
    grid-template-columns: 6.25rem minmax(0, 1fr);
    gap: 0.75rem;
    padding: 0.75rem;
  }

  .rail-person-hero,
  .rail-person-contribution-grid {
    grid-template-columns: minmax(0, 1fr);
  }

  .rail-profile-card__title {
    font-size: var(--type-size-lg);
  }

  .rail-archive__header {
    display: none;
  }

  .rail-meta-stack__row {
    grid-template-columns: 1fr;
    gap: 0.35rem;
  }

  .rail-archive__row {
    display: grid;
    gap: 0.2rem;
  }

  .rail-archive__primary,
  .rail-archive__meta {
    flex: none;
    text-align: left;
  }

  .rail-collection-grid {
    grid-template-columns: 1fr;
  }

  .rail-theme-field__labels {
    flex-direction: column;
    align-items: flex-start;
    gap: 0.22rem;
  }

  .rail-theme-atlas__header {
    gap: 0.35rem;
  }

  .rail-theme-atlas__labels {
    flex-direction: column;
    align-items: flex-start;
    gap: 0.22rem;
  }

  .rail-theme-atlas__note {
    max-width: none;
  }

  .rail-theme-field__board {
    min-height: auto;
  }

  .rail-theme-field__board::before,
  .rail-theme-field__board::after,
  .rail-theme-field__link {
    display: none;
  }

  .rail-theme-field-card[data-field-slot] {
    position: relative;
    top: auto;
    left: auto;
    right: auto;
    width: 100%;
    min-height: auto;
    transform: none;
  }

  .rail-theme-field-card:hover,
  .rail-theme-field-card:focus-visible {
    transform: translateY(-0.18rem);
  }

  .rail-theme-field-card__title {
    max-width: 12ch;
  }

  .rail-theme-field-card[data-field-slot="anchor"] .rail-theme-field-card__title {
    font-size: var(--type-size-4xl);
  }

  .rail-theme-atlas__grid {
    grid-template-columns: 1fr;
  }

  .rail-theme-atlas-card[data-theme-slot] {
    grid-column: 1 / -1;
    grid-row: auto;
    min-height: auto;
    margin-top: 0;
  }

  .rail-theme-atlas-card__mark {
    font-size: var(--type-size-6xl);
  }

  .rail-theme-atlas-card[data-theme-slot="lead"] .rail-theme-atlas-card__title {
    font-size: var(--type-size-3xl);
  }

  .rail-contributor-directory__list {
    column-count: 1;
  }

  .rail-theme-gallery-grid {
    grid-template-columns: 1fr;
  }

  .rail-theme-gallery-card:nth-child(2n) .rail-theme-gallery-card__media,
  .rail-theme-gallery-card__media {
    width: 100%;
  }

  .rail-theme-contributor {
    grid-template-columns: 1fr;
    gap: 0.18rem;
  }

  .rail-theme-contributor__separator {
    display: none;
  }

  .rail-partners {
    gap: 1rem 0.9rem;
  }

  .rail-partners__logo {
    height: 2.15rem;
    max-width: 7.2rem;
  }

  .rail-partners__logo--portrait {
    height: 3.15rem;
    max-width: 4.15rem;
  }

  .rail-partners__logo--wide {
    height: 1.8rem;
    max-width: 8.9rem;
  }

  .rail-detail-sheet__row {
    grid-template-columns: 1fr;
    gap: 0.45rem;
  }

  .rail-artist-row {
    grid-template-columns: 1fr;
    gap: 0.38rem;
  }
 
  .visual-stage__hud {
    top: calc(0.9rem + env(safe-area-inset-top));
    left: 1rem;
    gap: 0.4rem;
  }

  .visual-stage__hud,
  .visual-stage__coords {
    font-size: var(--type-size-2xs);
  }

  .visual-stage__coords {
    display: none;
  }

  .visual-stage__anchor {
    width: 1600px;
    height: 1320px;
  }

  .visual-stage__reticle-orbit--primary {
    top: 8%;
    left: 4%;
    width: 92%;
    height: 82%;
  }

  .visual-stage__reticle-orbit--secondary {
    top: 29%;
    left: 28%;
    width: 46%;
    height: 41%;
  }

  .visual-stage__reticle-marker {
    width: 0.4rem;
    height: 0.4rem;
  }

  .visual-stage__reticle-marker--northwest {
    top: 17.6%;
    left: 20.4%;
  }

  .visual-stage__reticle-marker--east {
    top: 56.1%;
    left: 95.3%;
  }

  .visual-stage__reticle-marker--southwest {
    top: 84.5%;
    left: 27%;
  }

  .visual-stage__reticle-marker--southeast {
    top: 82.6%;
    left: 76.4%;
  }

  .rail-header {
    min-height: 3rem;
  }

  .rail-content {
    padding: 1.2rem var(--rail-shell-padding) var(--rail-content-padding-bottom);
  }

  .rail-header__home {
    max-width: calc(100% - 3rem);
    height: 3rem;
    padding-inline: 0.9rem;
  }

  .rail-header__menu {
    width: 3rem;
    height: 3rem;
    flex-basis: 3rem;
  }

  .rail-menu {
    right: auto;
    width: 100%;
    max-height: 58vh;
    max-height: min(60svh, 32rem);
    max-height: min(60dvh, 32rem);
    padding: 0.95rem 0.8rem 1.05rem;
  }

  .rail-menu__section + .rail-menu__section {
    border-top: 0;
    margin-top: 0.85rem;
    padding-top: 0;
  }

  .rail-menu__label {
    display: none;
  }

  .rail-menu__list {
    gap: 0.68rem;
  }

  .rail-menu__item {
    min-height: 2.75rem;
    align-items: center;
    gap: 0.6rem;
    padding: 0.18rem 0;
  }

  .rail-menu__item-copy {
    font-size: var(--type-size-3xl);
    line-height: 0.92;
  }

  .rail-menu__item-rule {
    align-self: center;
    margin-bottom: 0;
  }

  .rail-menu__item-index {
    font-size: var(--type-size-base);
    align-self: center;
    transform: none;
  }

  .rail-fact {
    grid-template-columns: 1fr;
    gap: 0.28rem;
  }

  .rail-linear-nav {
    gap: 0.7rem;
    padding: 0.9rem;
  }

  .rail-linear-nav__meta {
    flex-direction: column;
    align-items: flex-start;
  }

  .rail-linear-nav__actions {
    grid-template-columns: 1fr;
  }

  .rail-linear-nav__link {
    min-height: 4.2rem;
  }

  .rail-panel-section--maps-inline {
    margin-inline: calc(var(--rail-shell-padding) * -1);
  }

  .rail-inline-workspace {
    height: auto;
    min-height: 0;
    padding: 0 var(--rail-shell-padding) 1rem;
    border-inline: 0;
    grid-template-rows: minmax(0, 1fr);
  }

  .rail-panel-section--maps-inline .rail-inline-workspace__header {
    display: none;
  }

  .rail-inline-workspace__body {
    min-height: 0;
  }

  .rail-inline-workspace__body .maps-embed-frame {
    width: calc(100% + (var(--rail-shell-padding) * 2));
    height: var(--maps-inline-frame-height, clamp(58rem, 132svh, 74rem));
    min-height: 0;
    margin-inline: calc(var(--rail-shell-padding) * -1);
  }

  .rail-practical-card__schedule-row {
    grid-template-columns: 1fr;
    gap: 0.28rem;
  }

  .floating-panel {
    max-width: 14.5rem;
    max-width: min(18rem, calc(100vw - 2rem));
  }

  .help-panel {
    left: 1rem;
    right: 1rem;
    bottom: calc(5.35rem + env(safe-area-inset-bottom));
  }

  .stage-controls {
    left: 50%;
    bottom: calc(0.85rem + env(safe-area-inset-bottom));
    gap: 0.35rem;
    padding: 0.42rem;
    border-radius: 999px;
    background: rgba(23, 19, 19, 0.82);
    box-shadow: 0 0.85rem 1.8rem rgba(9, 7, 8, 0.28);
    transform: translateX(-50%);
  }

  .stage-controls__button {
    width: 2.75rem;
    height: 2.75rem;
    font-size: var(--type-size-base);
  }

  .stage-controls__readout {
    min-width: 3.6rem;
    font-size: var(--type-size-xs);
  }

  .rail-meta-stack__value-link,
  .rail-practical-card__venue-link {
    display: inline-flex;
    align-items: center;
    min-height: 2.75rem;
    padding-block: 0.3rem;
  }

  .rail-social a,
  .rail-social__entry {
    align-items: center;
    min-height: 2.75rem;
    padding: 0.35rem 0;
  }

  .rail-contributor-directory__head {
    flex-direction: column;
    align-items: flex-start;
    gap: 0.28rem;
  }

  .rail-contributor-directory__item {
    margin: 0;
    border-bottom: 1px solid rgba(23, 19, 19, 0.08);
  }

  .rail-contributor-directory__item:last-child {
    border-bottom: 0;
  }

  .rail-contributor-directory__name-button {
    display: flex;
    align-items: center;
    width: 100%;
    min-height: 2.75rem;
    padding: 0.42rem 0;
  }

  .maps-stage {
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
  }

  .maps-stage__shell {
    gap: 0.85rem;
    padding: 0.8rem;
  }

  .maps-stage__tabs,
  .mobility-lab__stats {
    width: 100%;
  }

  .maps-stage__tab,
  .maps-stage__open {
    flex: 1 1 auto;
  }

  .maps-embed-overlay {
    position: static;
    width: 100%;
    margin-top: 0.75rem;
    pointer-events: auto;
  }

  .mobility-lab__controls,
  .mobility-chart__row {
    grid-template-columns: 1fr;
  }

  .mobility-chart__track {
    min-height: 1.9rem;
  }

  .mobility-chart__header {
    align-items: start;
    flex-direction: column;
  }
}

@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    animation: none !important;
    transition-duration: 0ms !important;
    scroll-behavior: auto !important;
  }
}
