body {
    font-family: var(--font-display);
    background-color: var(--color-background-primary);
    color: var(--color-text-primary);
    overflow-x: clip;
    transition: background-color 900ms ease, color 900ms ease;
}

html {
    overflow-x: clip;
    background-color: var(--color-background-primary);
    transition: background-color 900ms ease;
}

body::after {
    content: "";
    position: fixed;
    inset: 0;
    background: rgba(8, 4, 10, 0);
    pointer-events: none;
    opacity: 0;
    transition: opacity 900ms ease, background-color 900ms ease;
    z-index: 999;
}

[data-theme="dark"] body::after {
    background: rgba(8, 4, 10, 0.28);
    opacity: 1;
}

/* ================================
   Page Layout
   ================================ */

main {
  width: 100%;
  display: flex;
  flex-direction: column;
  transition: background-color 900ms ease;
}

html.is-end-blackout,
body.is-end-blackout,
body.is-end-blackout main {
  background-color: var(--neutral-700);
}

/* Every story section */

.section {
  width: 100%;
  min-height: 100vh;
  padding: var(--space-3xl) var(--space-md);

  display: flex;
  align-items: center;
  justify-content: center;
}

.section__content {
  width: min(720px, 90%);
  margin-inline: auto;
}

.section__content > * + * {
  margin-top: var(--space-md);
}

.section--events,
.section--variables,
.section--conditionals,
.section--storage,
.section--toggle {
  background: var(--color-danger);
  color: var(--neutral-0);
}

.section--conditionals {
  position: relative;
  flex-direction: column;
  gap: var(--space-lg);
  justify-content: center;
  align-items: center;
}

.section--conditionals .section__content {
  position: relative;
  z-index: 2;
  width: min(520px, 70%);
  margin: 0;
}

.section--storage {
  min-height: 255vh;
  padding-block: 0;
  align-items: stretch;
}

.section--storage .section__content {
  position: sticky;
  top: 0;
  min-height: 100vh;
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding-block: var(--space-3xl);
}

.section--toggle {
  min-height: 220vh;
  padding-block: 0;
  align-items: stretch;
  transition: background 360ms ease;
}

.section--toggle .section__content {
  position: sticky;
  top: 0;
  min-height: 100vh;
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding-block: var(--space-3xl);
}

.lamb-appears {
  position: relative;
  min-height: 136vh;
  background: var(--red-300);
  color: var(--neutral-100);
  overflow: hidden;
}

.lamb-appears::before {
  content: none;
}

.lamb-appears .section__content {
  position: relative;
  z-index: 1;
  min-height: 100vh;
  text-align: center;
  display: grid;
  justify-items: center;
  align-content: start;
  grid-template-rows: auto auto auto minmax(0, 1fr);
  padding: 5vh var(--space-lg) 0;
}

.lamb-appears .lamb-text-block {
  display: contents;
}

.lamb-appears h2 {
  color: var(--neutral-0);
  width: min(30rem, 88vw);
  margin: 0;
  font-size: clamp(2rem, 4vw, 3.5rem);
  line-height: 0.95;
  letter-spacing: 0.02em;
}

.lamb-appears p {
  color: var(--neutral-200);
  width: min(32rem, 82vw);
  margin: 0;
  text-wrap: balance;
}

.lamb-appears .chapter-highlight {
  margin-top: var(--space-lg);
  font-size: clamp(1rem, 1.6vw, 1.25rem);
}

.lamb-appears p:not(.chapter-highlight) {
  margin-top: var(--space-sm);
  color: color-mix(in srgb, var(--neutral-0) 76%, transparent);
  font-size: clamp(0.95rem, 1.4vw, 1.1rem);
}

.memory-word {
  display: inline-block;
  color: inherit;
}

.lamb-outline-svg {
  display: block;
  width: min(980px, 86vw);
  height: auto;
  margin: clamp(2rem, 5vh, 4rem) auto 0;
  color: var(--color-silhouette-primary);
  fill: none;
  filter:
    drop-shadow(0 0 0 color-mix(in srgb, var(--red-200) 0%, transparent))
    drop-shadow(0 18px 24px color-mix(in srgb, var(--neutral-700) 10%, transparent));
}

.lamb-outline-svg path {
  fill: currentColor;
}

@media (max-width: 900px) {
  .lamb-appears {
    min-height: 128vh;
  }

  .lamb-appears .section__content {
    padding-top: 7vh;
  }

  .lamb-outline-svg {
    width: min(760px, 118vw);
    margin-top: clamp(1.5rem, 4vh, 2.5rem);
  }
}

.conditionals-stack {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-md);
  width: min(900px, 90%);
  margin: 0 auto;
  flex-wrap: wrap;
}

h2 {
  font-family: var(--font-display);
  font-size: var(--font-size-heading);
}

p,
li {
  font-family: var(--font-body);
  font-size: var(--font-size-body);
  line-height: 1.5;
}

.code {
  font-family: monospace;
  background: var(--overlay-ink-15);
  padding: var(--space-sm);
  border-radius: var(--radius-sm);
}

.ritual-ring-svg {
  display: block;
  width: min(100%, 720px);
  height: auto;
  margin: var(--space-md) auto;
  fill: var(--neutral-100);
}

/* ================================
   Hero Section
   ================================ */
.hero {
    position: relative;
    width: 100%;
    min-height: 100vh;
    background-color: var(--color-danger);
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
    padding: 0;
}

/* SVG Background Container */
.hero-svg-container {
    position: absolute;
    top: 0;
    left: 0;
    width: 150%;
    height: 100%;
    z-index: 1;
    opacity: 0.6;
}

.hero-svg-image {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    color: var(--color-background-secondary);
}

/* Inline SVG Background */
.hero-svg,
.hero2-svg {
    position: absolute;
    top: -10%;
    left: 50%;
    width: calc(100% + 24vw);
    max-width: none;
    height: 130%;
    transform: translateX(-50%);
    fill: var(--neutral-600);
    pointer-events: none;
    display: block;
}

.hero-svg {
    z-index: 2;
    animation: hero-svg-breathe 5.2s ease-in-out infinite;
    will-change: transform;
}

.hero2-svg {
    z-index: 1;
    opacity: 0;
    fill: var(--color-hero-secondary);
    transform: translateX(calc(-50% + var(--drift-x, 0vw))) scaleX(-1);
    animation: hero-svg-horizontal-drift 7.6s linear infinite;
    will-change: transform, opacity;
}

@keyframes hero-svg-breathe {
    0% {
        transform: translateX(-50%) scale(1);
    }
    50% {
        transform: translateX(-50%) scale(1.04);
    }
    100% {
        transform: translateX(-50%) scale(1);
    }
}

.hero-svg path,
.hero2-svg path {
    transform-box: fill-box;
    transform-origin: center bottom;
    animation-name: hero-flame-flicker;
    animation-duration: var(--flame-duration, 3.2s);
    animation-delay: var(--flame-delay, 0s);
    animation-timing-function: ease-in-out;
    animation-iteration-count: infinite;
    animation-direction: alternate;
    will-change: transform;
}

@keyframes hero-svg-horizontal-drift {
    0% {
        --drift-x: -10vw;
        opacity: 0;
    }
    12% {
        opacity: 0.45;
    }
    88% {
        opacity: 0.45;
    }
    100% {
        --drift-x: 10vw;
        opacity: 0;
    }
}

@keyframes hero-flame-flicker {
    0% {
        transform: translateY(0) scaleX(1) scaleY(1);
    }
    25% {
        transform: translateY(calc(var(--flame-rise, 10px) * -0.55))
                   scaleX(calc(1 + (var(--flame-spread, 0.01) * 1.35)))
                   scaleY(calc(1 - (var(--flame-squeeze, 0.02) * 1.2)));
    }
    50% {
        transform: translateY(calc(var(--flame-rise, 10px) * -1))
                   scaleX(calc(1 - var(--flame-spread, 0.01)))
                   scaleY(calc(1 + var(--flame-lift, 0.03)));
    }
    100% {
        transform: translateY(calc(var(--flame-rise, 10px) * -0.4))
                   scaleX(calc(1 + (var(--flame-spread, 0.01) * 1.25)))
                   scaleY(calc(1 - (var(--flame-squeeze, 0.02) * 1.1)));
    }
}

/* Content Container */
.hero-content {
    position: relative;
    z-index: 2;
    text-align: center;
    padding: var(--space-lg);
    max-width: 100%;
}

/* Title Styles */
.hero-title {
    font-family: var(--font-display);
    line-height: 1.2;
    word-wrap: break-word;
    display: flex;
    flex-direction: column;
    gap: var(--space-xs);
}

/* Primary title spans (JS Concepts, Cult of the Lamb) */
.hero-title--primary {
    font-size: var(--font-size-title);
    color: var(--neutral-100);
    font-weight: var(--font-weight-regular);
}

/* Secondary title spans (Explained, Terms) */
.hero-title--secondary {
    font-size: var(--font-size-heading);
    color: var(--color-danger);
    font-weight: var(--font-weight-regular);
    text-shadow: 2px 2px 4px var(--overlay-ink-20);
}

/* ================================
   Story Sections
   ================================ */

.section h2 {
  font-family: var(--font-display);
  font-size: var(--font-size-heading);
  margin-bottom: var(--space-md);
}

.section p {
  font-family: var(--font-body);
  font-size: var(--font-size-body);
  margin-bottom: var(--space-sm);
}

.section ul {
  margin-bottom: var(--space-lg);
  padding-left: var(--space-md);
  font-family: var(--font-body);
}

.ritual-mater {
  width: var(--size-ritual-meter);
  display: block;
  margin: var(--space-xl) auto;

  filter:
    drop-shadow(0 0 25px var(--overlay-ink-70))
    drop-shadow(0 0 10px var(--overlay-ink-60));
}

.ritual-stack {
  position: relative;
  width: 74vw;
  margin: var(--space-xl) 0;
  left: 50%;
  transform: translateX(-50%);
}

#ritual-black-matter,
.ritual-black-matter2 {
  display: block;
  width: 100%;
  height: auto;
}

#ritual-black-matter {
  position: relative;
  z-index: 1;
}

.ritual-black-matter2 {
  position: absolute;
  inset: 0;
  z-index: 0;
  fill: var(--red-500);
  pointer-events: none;
}

.ritual-black-matter2 path {
  transform-box: fill-box;
  transform-origin: center;
}

.ritual-ring-art {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 96%;
  height: 96%;
  transform: translate(-50%, -50%);
  object-fit: contain;
  z-index: 2;
  pointer-events: none;
}

.ritual-eye-animation {
  position: absolute;
  top: 50%;
  left: 50%;
  width: min(30vw, 192px);
  height: auto;
  transform: translate(-57%, -56%);
  z-index: 3;
  color: var(--color-eye-stroke);
  pointer-events: none;
}

.ritual-eye-animation .cult-crown__highlight {
  fill: var(--neutral-0);
  stroke: var(--color-eye-stroke);
}

.ritual-button {
  display: flex;
  align-items: center;
  justify-content: center;
  margin: var(--space-md) auto 0;
  padding: 18px 54px;
  border: 2px solid var(--color-accent-primary);
  width: min(440px, 78vw);
  min-height: 96px;
  background-color: var(--neutral-600);
  color: var(--color-accent-primary);
  font-family: var(--font-display);
  font-size: clamp(20px, 3vw, 34px);
  letter-spacing: 0.04em;
  text-transform: none;
  white-space: nowrap;
  border-radius: 140px;
  cursor: pointer;
  box-shadow:
    0 8px 0 var(--overlay-ink-25),
    0 12px 24px var(--overlay-ink-25),
    0 24px 48px var(--overlay-ink-20),
    0 0 28px var(--overlay-ink-30);
  transition: transform 180ms ease, box-shadow 180ms ease, outline-color 180ms ease;
}

.ritual-button:hover {
  transform: translateY(-1px);
}

.ritual-button:focus {
  outline: none;
}

.ritual-button:focus-visible {
  outline: 3px solid var(--neutral-0);
  outline-offset: 5px;
  box-shadow:
    0 0 0 6px color-mix(in srgb, var(--color-accent-primary) 38%, transparent),
    0 8px 0 var(--overlay-ink-25),
    0 12px 24px var(--overlay-ink-25),
    0 24px 48px var(--overlay-ink-20),
    0 0 28px var(--overlay-ink-30);
}


.variables-icons {
  position: relative;
  width: min(360px, 78vw);
  aspect-ratio: 1 / 1;
  margin: var(--space-lg) auto;
}

.variables-icon {
  position: absolute;
  width: var(--size-icon-lg);
  height: var(--size-icon-lg);
  background-repeat: no-repeat;
  background-size: contain;
  background-position: center;
  filter: drop-shadow(0 2px 0 var(--overlay-ink-25));
  transform: translate(-50%, -50%);
}

.variables-icon--faith {
  background-image: var(--icon-faith);
  left: 10%;
  top: 25%;
}

.variables-icon--gold {
  background-image: var(--icon-gold);
  left: 25%;
  top: 87%;
}

.variables-icon--hunger {
  background-image: var(--icon-hunger);
  left: 50%;
  top: 2%;
}

.variables-icon--health {
  background-image: var(--icon-health);
  left: 75%;
  top: 87%;
}

.variables-icon--church {
  background-image: var(--icon-church);
  left: 90%;
  top: 25%;
}

.faith-meter {
  display: flex;
  justify-content: center;
  align-items: center;
  margin-top: 0;
  width: min(var(--size-faith-meter), 40vw);
}

.faith-meter-svg {
  display: block;
  height: clamp(var(--size-faith-meter-min-height), 55vh, var(--size-faith-meter-max-height));
  width: auto;
  max-width: min(var(--size-faith-meter), 70vw);
  color: var(--neutral-600);
}

.faith-meter-svg path {
  fill: currentColor;
}

.faith-meter-fill {
  fill: var(--color-accent-primary);
  opacity: 0.9;
}

.faith-meter-outline {
  stroke: currentColor;
  fill: none;
}

.rebellion-svg {
  position: relative;
  top: -160px;
  display: block;
  width: min(220px, 45vw);
  height: auto;
  margin: 0 auto;
  color: var(--color-text-primary);
}

.rebellion-svg path {
  fill: currentColor;
}

.save-icon {
  display: block;
  width: min(260px, 60vw);
  height: auto;
  margin: var(--space-md) auto 0;
  color: var(--neutral-700);
}

.cult-crown {
  display: block;
  width: min(33vw, 360px);
  height: auto;
  margin: var(--space-md) auto 0;
  color: var(--neutral-700);
  will-change: transform;
}

.cult-crown-wrap {
  position: relative;
  will-change: transform, opacity;
}

.cult-crown-wrap::after {
  content: "";
  position: absolute;
  left: 50%;
  bottom: -22px;
  width: min(30vw, 300px);
  height: 42px;
  transform: translateX(-50%);
  border-radius: 50%;
  background: radial-gradient(circle, rgba(0, 0, 0, 0.54) 0%, rgba(0, 0, 0, 0.34) 42%, rgba(0, 0, 0, 0.12) 68%, rgba(0, 0, 0, 0) 88%);
  filter: blur(10px);
  opacity: 0.88;
  pointer-events: none;
}

.section--toggle.is-lights-off .cult-crown-wrap::after {
  background: radial-gradient(
    circle,
    color-mix(in srgb, var(--red-300) 62%, transparent) 0%,
    color-mix(in srgb, var(--red-400) 42%, transparent) 42%,
    color-mix(in srgb, var(--red-500) 18%, transparent) 68%,
    transparent 88%
  );
  filter: blur(12px);
  opacity: 0.96;
}

.night-mode-toggle {
  display: block;
  width: min(156px, 42vw);
  height: auto;
  overflow: visible;
  --toggle-track-color: var(--neutral-700);
  --toggle-knob-color: var(--neutral-700);
  --toggle-glow-strong: color-mix(in srgb, var(--neutral-100) 38%, transparent);
  --toggle-glow-soft: color-mix(in srgb, var(--neutral-200) 20%, transparent);
}

.night-mode-toggle-button {
  position: relative;
  display: block;
  appearance: none;
  -webkit-appearance: none;
  -webkit-tap-highlight-color: transparent;
  margin: var(--space-md) auto 0;
  padding: 0;
  border: 0;
  background: transparent;
  cursor: pointer;
  color: var(--neutral-700);
  border-radius: 999px;
  user-select: none;
  transition: transform 280ms ease;
  isolation: isolate;
}

.night-mode-toggle-button:focus {
  outline: none;
}

.night-mode-toggle-button:hover,
.night-mode-toggle-button:focus-visible {
  transform: scale(1.03);
}

.night-mode-toggle-button:focus-visible {
  outline: 3px solid var(--neutral-0);
  outline-offset: 6px;
  box-shadow: 0 0 0 8px color-mix(in srgb, var(--color-accent-primary) 32%, transparent);
}

.night-mode-toggle-button:active {
  background: transparent;
}

.night-mode-toggle-button::before {
  content: "";
  position: absolute;
  left: 50%;
  top: 50%;
  width: 175%;
  height: 210%;
  transform: translate(-50%, -50%);
  border-radius: 50%;
  background: radial-gradient(
    ellipse at center,
    color-mix(in srgb, var(--neutral-100) 46%, transparent) 0%,
    color-mix(in srgb, var(--neutral-200) 22%, transparent) 34%,
    color-mix(in srgb, var(--neutral-300) 10%, transparent) 52%,
    transparent 78%
  );
  filter: blur(16px);
  opacity: 0.82;
  pointer-events: none;
  z-index: -1;
}

.night-mode-toggle__track,
.night-mode-toggle__knob {
  transition: stroke 280ms ease, fill 280ms ease, filter 280ms ease;
  filter:
    drop-shadow(0 0 4px var(--toggle-glow-strong))
    drop-shadow(0 0 10px var(--toggle-glow-soft));
}

.night-mode-toggle__track {
  stroke: var(--toggle-track-color);
}

.night-mode-toggle__knob {
  fill: var(--toggle-knob-color);
  stroke: var(--toggle-knob-color);
}

.section--toggle.is-lights-off {
  background: linear-gradient(180deg, #5e0010 0%, #280006 56%, #170004 100%);
}

.section--toggle.is-lights-off .night-mode-toggle-button {
}

.section--toggle.is-lights-off .night-mode-toggle {
  --toggle-track-color: var(--neutral-100);
  --toggle-knob-color: var(--neutral-100);
  --toggle-glow-strong: color-mix(in srgb, var(--neutral-100) 28%, transparent);
  --toggle-glow-soft: color-mix(in srgb, var(--neutral-200) 14%, transparent);
}

.section--toggle.is-lights-off .night-mode-toggle-button::before {
  background: radial-gradient(
    ellipse at center,
    color-mix(in srgb, var(--neutral-100) 28%, transparent) 0%,
    color-mix(in srgb, var(--neutral-200) 16%, transparent) 34%,
    color-mix(in srgb, var(--neutral-300) 8%, transparent) 52%,
    transparent 78%
  );
}

/* Dark matter parallax transition */
.section--dark-matter-parallax {
  position: relative;
  min-height: 260vh;
  padding: 0;
  overflow: hidden;
  background:
    radial-gradient(circle at 50% 35%, var(--overlay-ink-20) 0%, transparent 48%),
    linear-gradient(180deg, var(--color-danger) 0%, #8c0013 52%, var(--color-danger) 100%);
}

.section--dark-matter-parallax::before,
.section--dark-matter-parallax::after {
  content: "";
  position: absolute;
  inset-inline: 0;
  height: 18vh;
  z-index: 5;
  pointer-events: none;
}

.section--dark-matter-parallax::before {
  top: 0;
  background: linear-gradient(180deg, var(--color-danger) 0%, transparent 100%);
}

.section--dark-matter-parallax::after {
  bottom: 0;
  height: 40vh;
  background: linear-gradient(180deg, transparent 0%, rgba(140, 0, 19, 0.28) 22%, rgba(180, 0, 25, 0.62) 58%, var(--color-danger) 100%);
}

.dark-matter-parallax {
  position: relative;
  width: 100%;
  min-height: 260vh;
}

.dark-matter-parallax__scene {
  position: sticky;
  top: 0;
  min-height: 100vh;
  height: 100vh;
  overflow: hidden;
  isolation: isolate;
}

.dark-matter-parallax__glow {
  position: absolute;
  inset: 0;
  z-index: 4;
  pointer-events: none;
  background:
    radial-gradient(circle at 50% 20%, rgba(255, 92, 92, 0.18) 0%, transparent 40%),
    linear-gradient(180deg, transparent 0%, rgba(32, 0, 0, 0.18) 45%, rgba(214, 0, 31, 0.42) 100%);
  mix-blend-mode: screen;
}

.dark-matter-2 {
  display: block;
  width: 100vw;
  max-width: none;
  height: auto;
  color: var(--neutral-700);
  fill: currentColor;
  filter: drop-shadow(0 8px 18px var(--overlay-ink-25));
  overflow: hidden;
}

.dark-matter-2 .st0 {
  display: inline;
}

.dark-matter-2 #dark-matter-shape,
.dark-matter-2 use {
  transform-box: fill-box;
  transform-origin: center;
}

.parallax-layer {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 140vw;
  max-width: none;
  min-width: 120rem;
  pointer-events: none;
  transform: translate(-50%, -50%);
  will-change: transform, opacity;
}

.parallax-layer--back {
  z-index: 1;
  opacity: 0.3;
  color: rgba(15, 0, 0, 0.96);
  transform: translate(-50%, -50%) scale(1.1);
}

.parallax-2 {
  z-index: 2;
  opacity: 0.48;
  color: rgba(8, 0, 0, 0.98);
  mix-blend-mode: multiply;
  transform: translate(-50%, -50%) scale(1.22);
}

.parallax-3 {
  z-index: 3;
  opacity: 0.72;
  color: rgba(0, 0, 0, 1);
  mix-blend-mode: multiply;
  transform: translate(-50%, -50%) scale(1.34);
}

/* Cult red sections */

.section--events,
.section--variables,
.section--conditionals,
.section--storage,
.section--toggle {
  background: var(--color-danger);
  color: var(--neutral-0);
}

/* Code blocks */

.code {
  font-family: monospace;
  margin-top: var(--space-md);
}

/* Highlight text */

.chapter-highlight {
  margin-top: var(--space-lg);
  font-size: var(--font-size-highlight);
}

/* ================================
   Responsive Design
   ================================ */

/* Tablets and smaller devices */
@media (max-width: 1024px) {
    .hero-title--primary {
        font-size: 72px;
    }

    .hero-title--secondary {
        font-size: 36px;
    }

    .section--dark-matter-parallax,
    .dark-matter-parallax {
      min-height: 200vh;
    }

    .dark-matter-parallax__scene {
      min-height: 100vh;
      height: 100vh;
    }

    .parallax-layer {
      width: max(205vw, 110rem);
      min-width: 110rem;
    }
}

/* Mobile devices */
@media (max-width: 768px) {
    .section {
        padding: var(--space-xl) var(--space-md);
    }

    .section__content {
        width: min(100%, 38rem);
    }

    .hero {
        min-height: 100vh;
    }

    .hero-content {
        padding: var(--space-md);
    }

    .hero-title--primary {
        font-size: 48px;
    }

    .hero-title--secondary {
        font-size: 28px;
    }

    .section h2 {
        font-size: clamp(2rem, 11vw, 2.9rem);
        line-height: 0.96;
        text-wrap: balance;
    }

    .section p,
    .section li {
        font-size: clamp(1rem, 2.7vw, 1.125rem);
    }

    .chapter-highlight {
        font-size: clamp(1rem, 5vw, 1.25rem);
    }

    .code {
        padding: var(--space-sm);
        overflow-wrap: anywhere;
        word-break: break-word;
    }

    .ritual-stack {
        width: min(82vw, 28rem);
        margin: var(--space-lg) 0;
    }

    .ritual-eye-animation {
        width: min(34vw, 150px);
    }

    .ritual-button {
        min-height: 84px;
        padding: 16px 28px;
        font-size: clamp(1.6rem, 6vw, 2rem);
    }

    .parallax-layer {
        width: max(245vw, 98rem);
        min-width: 98rem;
    }
}

/* Small mobile devices */
@media (max-width: 480px) {
    .section {
        padding: var(--space-xl) 14px;
    }

    .hero-title--primary {
        font-size: 36px;
    }

    .hero-title--secondary {
        font-size: 20px;
    }

    .hero-content {
        padding: var(--space-sm);
    }

    .section h2 {
        font-size: clamp(1.85rem, 15vw, 2.55rem);
    }

    .section ul {
        padding-left: 0;
    }

    .conditionals-stack {
        flex-direction: column;
        align-items: center;
        gap: var(--space-xl);
        width: min(100%, 24rem);
    }

    .section--conditionals {
        justify-content: flex-start;
        padding-top: calc(var(--space-xl) * 1.3);
    }

    .section--conditionals .section__content {
        width: 100%;
        text-align: left;
    }

    .section--conditionals .section__content h2 {
        max-width: 8ch;
    }

    .faith-meter {
        width: min(8.75rem, 38vw);
        margin: 0 auto;
    }

    .faith-meter-svg {
        height: clamp(26rem, 72vh, 36rem);
        max-width: 100%;
    }

    .rebellion-svg {
        top: -112px;
        width: min(9rem, 36vw);
    }

    .ritual-stack {
        width: min(88vw, 22rem);
    }

    .ritual-button {
        width: 100%;
        min-height: 76px;
        padding: 14px 20px;
        font-size: clamp(1.45rem, 8vw, 1.8rem);
        white-space: normal;
    }

    .parallax-layer {
        width: max(285vw, 88rem);
        min-width: 88rem;
    }
}

/* Large screens */
@media (min-width: 1920px) {
    .hero-title--primary {
        font-size: 120px;
    }

    .hero-title--secondary {
        font-size: 60px;
    }
}

/* ================================
   Accessibility
   ================================ */
@media (prefers-reduced-motion: reduce) {
    * {
        animation: none !important;
        transition: none !important;
    }

    html,
    body,
    #smooth-wrapper,
    #smooth-content {
        scroll-behavior: auto !important;
    }

    #smooth-wrapper,
    #smooth-content,
    main {
        height: auto !important;
        min-height: 0 !important;
        overflow: visible !important;
        transform: none !important;
    }

    .section,
    .section--storage,
    .section--toggle,
    .section--dark-matter-parallax,
    .dark-matter-parallax,
    .lamb-appears {
        min-height: auto !important;
    }

    .section--storage,
    .section--toggle,
    .section--dark-matter-parallax {
        padding-block: var(--space-3xl) !important;
    }

    .section--storage .section__content,
    .section--toggle .section__content,
    .dark-matter-parallax__scene,
    .lamb-appears .section__content {
        position: static !important;
        top: auto !important;
        height: auto !important;
        min-height: auto !important;
    }

    .lamb-appears .section__content {
        padding-bottom: var(--space-3xl) !important;
    }

    .conditionals-stack,
    .section--conditionals .section__content {
        width: min(720px, 90%) !important;
    }

    [data-speed],
    [data-lag] {
        transform: none !important;
    }

    .dark-matter-parallax__glow,
    .cult-crown-wrap::after {
        opacity: 1;
    }
}

@media (max-width: 768px) {

  .section {
    padding: var(--space-xl) var(--space-md);
  }

  h2 {
    font-size: 32px;
  }

}
