.lumen-archive-page .tarot-stage {
  place-items: stretch;
}

.lumen-archive {
  width: min(100%, 1180px);
  margin: 0 auto;
  display: grid;
  gap: clamp(22px, 4vw, 42px);
  color: var(--navbar-text);
}

/* Lumen hero: fully open page section, with no panel frame or section shadow. */
.lumen-archive__hero {
  position: relative;
  overflow: visible;
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(230px, 0.42fr);
  gap: clamp(20px, 5vw, 58px);
  align-items: center;
  border: 0;
  border-radius: 0;
  padding: clamp(28px, 6vw, 64px);
  background: none;
  box-shadow: none;
}

.lumen-archive__hero::after {
  content: none;
}

.lumen-archive__copy {
  position: relative;
  z-index: 1;
  display: grid;
  gap: 16px;
  max-width: 780px;
}

.lumen-archive__copy h1 {
  margin: 0;
  color: var(--navbar-text);
  font-family: var(--heading-font);
  font-size: clamp(3.1rem, 9vw, 7.2rem);
  font-weight: 600;
  letter-spacing: 0;
  line-height: 0.86;
  text-shadow:
    0 0 22px color-mix(in srgb, var(--navbar-glow) 72%, transparent),
    0 2px 18px rgba(0, 0, 0, 0.24);
}

.lumen-archive__copy p {
  margin: 0;
  max-width: 64ch;
  color: var(--navbar-muted);
  font-size: clamp(1rem, 1.5vw, 1.14rem);
  line-height: 1.75;
}

.lumen-archive__copy .lumen-archive__subheading {
  color: var(--navbar-hover-text);
  font-family: var(--heading-font);
  font-size: clamp(1.55rem, 3.4vw, 2.5rem);
  line-height: 1.08;
}

.lumen-sigil {
  position: relative;
  z-index: 1;
  display: grid;
  width: min(100%, 300px);
  aspect-ratio: 1;
  place-items: center;
  justify-self: center;
  border: 0;
  border-radius: 50%;
  background:
    radial-gradient(circle, color-mix(in srgb, var(--navbar-hover-text) 18%, transparent), transparent 62%);
  box-shadow:
    0 0 38px color-mix(in srgb, var(--navbar-glow) 58%, transparent);
}

.lumen-sigil svg {
  width: 78%;
  height: 78%;
  overflow: visible;
  fill: none;
  stroke: currentColor;
  color: var(--navbar-hover-text);
  filter: drop-shadow(0 0 14px color-mix(in srgb, var(--navbar-glow) 82%, transparent));
}

.lumen-sigil__halo,
.lumen-sigil__ring {
  opacity: 0.68;
  stroke-width: 1.6;
}

.lumen-sigil__ray {
  opacity: 0.7;
  stroke-linecap: round;
  stroke-width: 2.4;
}

.lumen-sigil__petal {
  opacity: 0.5;
  stroke-width: 1.8;
}

.lumen-sigil__core {
  fill: currentColor;
  opacity: 0.82;
  stroke-width: 0;
}

.lumen-hero {
  --lumen-hero-accent: #f2d894;
  --lumen-hero-accent-strong: #fff0bd;
  --lumen-hero-text: #fffaf0;
  --lumen-hero-muted: rgba(255, 244, 224, 0.78);
  --lumen-hero-glow: rgba(236, 199, 126, 0.32);
  position: relative;
  overflow: hidden;
  min-width: 0;
  min-height: clamp(430px, 43vw, 560px);
  border: 1px solid color-mix(in srgb, var(--lumen-hero-accent) 28%, transparent);
  border-radius: 24px;
  background:
    linear-gradient(90deg, rgba(8, 6, 12, 0.9) 0%, rgba(8, 6, 12, 0.76) 31%, rgba(8, 6, 12, 0.34) 62%, rgba(8, 6, 12, 0.22) 100%),
    radial-gradient(circle at 24% 28%, color-mix(in srgb, var(--lumen-hero-glow) 72%, transparent), transparent 38%),
    url("../assets/images/concepts-ideas/lumen-moon-title-section.webp") center right / cover no-repeat;
  box-shadow:
    0 26px 78px rgba(0, 0, 0, 0.32),
    0 0 42px color-mix(in srgb, var(--lumen-hero-glow) 82%, transparent),
    inset 0 1px 0 rgba(255, 255, 255, 0.1);
  color: var(--lumen-hero-text);
}

.lumen-hero::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(180deg, rgba(0, 0, 0, 0.12), transparent 34%, rgba(0, 0, 0, 0.48)),
    radial-gradient(circle at 78% 46%, transparent 0 26%, rgba(0, 0, 0, 0.24) 58%, rgba(0, 0, 0, 0.42) 100%);
  pointer-events: none;
}

.lumen-hero__inner {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-rows: auto auto auto auto;
  align-content: center;
  gap: clamp(12px, 2vw, 20px);
  min-height: inherit;
  padding: clamp(22px, 3.6vw, 42px) clamp(24px, 4.4vw, 54px);
}

.lumen-hero__eyebrow-row {
  justify-self: center;
  display: grid;
  grid-template-columns: 58px auto 58px;
  align-items: center;
  gap: 10px;
  width: fit-content;
  max-width: 100%;
  color: var(--lumen-hero-accent-strong);
}

.lumen-hero__eyebrow-row span {
  height: 1px;
  background: linear-gradient(90deg, transparent, color-mix(in srgb, var(--lumen-hero-accent) 72%, transparent));
  box-shadow: 0 0 10px var(--lumen-hero-glow);
}

.lumen-hero__eyebrow-row span:last-child {
  transform: scaleX(-1);
}

.lumen-hero__eyebrow-row p,
.lumen-hero__small-title,
.lumen-hero-feature strong {
  margin: 0;
  font-family: var(--body-font);
  font-weight: 900;
  letter-spacing: 0.22em;
  text-transform: uppercase;
}

.lumen-hero__eyebrow-row p {
  font-size: clamp(0.72rem, 0.95vw, 0.86rem);
  line-height: 1.2;
  white-space: nowrap;
}

.lumen-hero__content {
  display: grid;
  align-items: center;
  width: min(100%, 660px);
  min-width: 0;
}

.lumen-hero__text {
  display: grid;
  gap: clamp(8px, 1.2vw, 12px);
  min-width: 0;
}

.lumen-hero__small-title {
  color: var(--lumen-hero-accent);
  font-size: clamp(0.7rem, 0.95vw, 0.84rem);
  line-height: 1;
  text-shadow: 0 0 12px var(--lumen-hero-glow);
}

.lumen-hero h1 {
  margin: 0;
  color: var(--lumen-hero-text);
  font-family: var(--heading-font);
  font-size: clamp(3.25rem, 5.5vw, 5.65rem);
  font-weight: 600;
  letter-spacing: 0;
  line-height: 0.86;
  white-space: nowrap;
  text-shadow:
    0 2px 18px rgba(0, 0, 0, 0.46),
    0 0 28px color-mix(in srgb, var(--lumen-hero-glow) 90%, transparent);
}

.lumen-hero__divider {
  width: min(100%, 270px);
  height: 1px;
  background: linear-gradient(90deg, var(--lumen-hero-accent), color-mix(in srgb, var(--lumen-hero-accent) 36%, transparent), transparent);
  box-shadow: 0 0 14px var(--lumen-hero-glow);
}

.lumen-hero__divider--small {
  width: min(100%, 150px);
  opacity: 0.78;
}

.lumen-hero h2 {
  margin: 0;
  max-width: 29ch;
  color: color-mix(in srgb, var(--lumen-hero-text) 88%, var(--lumen-hero-accent));
  font-family: var(--heading-font);
  font-size: clamp(1.45rem, 2.55vw, 2.25rem);
  font-weight: 600;
  line-height: 1.03;
  text-shadow: 0 0 18px rgba(0, 0, 0, 0.36);
}

.lumen-hero__text > p:not(.lumen-hero__small-title) {
  margin: 0;
  max-width: 48ch;
  color: var(--lumen-hero-muted);
  font-size: clamp(0.92rem, 1.12vw, 1.02rem);
  line-height: 1.58;
}

.lumen-hero__accent {
  color: var(--lumen-hero-gold, var(--lumen-hero-accent-strong));
  text-shadow: 0 0 14px color-mix(in srgb, var(--lumen-hero-gold, var(--lumen-hero-accent)) 42%, transparent);
}

.lumen-hero__features {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: clamp(8px, 1.4vw, 14px);
  width: min(100%, 720px);
}

.lumen-hero-feature {
  display: grid;
  justify-items: center;
  gap: 5px;
  min-width: 0;
  padding: 2px 8px;
  color: var(--lumen-hero-muted);
  text-align: center;
}

.lumen-hero-feature__icon {
  display: grid;
  width: clamp(42px, 4vw, 58px);
  aspect-ratio: 1;
  place-items: center;
  border: 1px solid color-mix(in srgb, var(--lumen-hero-accent) 46%, transparent);
  border-radius: 50%;
  color: var(--lumen-hero-accent-strong);
  background:
    radial-gradient(circle, color-mix(in srgb, var(--lumen-hero-accent) 18%, transparent), transparent 66%),
    rgba(0, 0, 0, 0.18);
  box-shadow:
    0 0 18px color-mix(in srgb, var(--lumen-hero-glow) 80%, transparent),
    inset 0 1px 0 rgba(255, 255, 255, 0.12);
}

.lumen-hero-feature__icon svg {
  display: block;
  width: 62%;
  height: 62%;
  overflow: visible;
  fill: none;
  stroke: currentColor;
  stroke-linecap: round;
  stroke-linejoin: round;
  stroke-width: 2.2;
  filter: drop-shadow(0 0 8px var(--lumen-hero-glow));
}

.lumen-hero-feature strong {
  color: var(--lumen-hero-accent-strong);
  font-size: 0.62rem;
  line-height: 1.2;
}

.lumen-hero-feature small {
  color: var(--lumen-hero-muted);
  font-family: var(--font-body-serif);
  font-size: 0.8rem;
  font-style: italic;
  line-height: 1.25;
}

.lumen-hero__quote {
  display: grid;
  grid-template-columns: minmax(36px, 1fr) minmax(0, auto) minmax(36px, 1fr);
  align-items: center;
  gap: clamp(10px, 2vw, 18px);
  width: min(100%, 720px);
  margin: 0;
  color: color-mix(in srgb, var(--lumen-hero-text) 82%, var(--lumen-hero-accent));
  font-family: var(--font-body-serif);
  font-size: clamp(0.94rem, 1.25vw, 1.08rem);
  font-style: italic;
  line-height: 1.45;
  text-align: center;
  text-shadow: 0 0 16px rgba(0, 0, 0, 0.34);
}

.lumen-hero__quote::before,
.lumen-hero__quote::after {
  content: "";
  height: 1px;
  background: linear-gradient(90deg, transparent, color-mix(in srgb, var(--lumen-hero-accent) 58%, transparent));
  box-shadow: 0 0 10px var(--lumen-hero-glow);
}

.lumen-hero__quote::after {
  transform: scaleX(-1);
}

.lumen-hero__quote-text {
  display: inline;
}

body.sun-mode .lumen-hero {
  --lumen-hero-accent: #e7b75d;
  --lumen-hero-accent-strong: #fff1c3;
  --lumen-hero-gold: #f1c766;
  --lumen-hero-text: #fff9ec;
  --lumen-hero-muted: rgba(255, 243, 219, 0.82);
  --lumen-hero-glow: rgba(231, 183, 93, 0.34);
  background:
    linear-gradient(90deg, rgba(29, 19, 8, 0.88) 0%, rgba(29, 19, 8, 0.72) 32%, rgba(29, 19, 8, 0.28) 63%, rgba(29, 19, 8, 0.18) 100%),
    radial-gradient(circle at 24% 28%, color-mix(in srgb, var(--lumen-hero-glow) 78%, transparent), transparent 38%),
    url("../assets/images/concepts-ideas/lumen-sun-title-section.webp") center right / cover no-repeat;
}

body.moon-mode .lumen-hero {
  --lumen-hero-accent: #d8c3ff;
  --lumen-hero-accent-strong: #fff0d0;
  --lumen-hero-gold: #f1c766;
  --lumen-hero-text: #f7f0ff;
  --lumen-hero-muted: rgba(232, 222, 255, 0.78);
  --lumen-hero-glow: rgba(167, 132, 230, 0.36);
  background:
    linear-gradient(90deg, rgba(7, 6, 19, 0.92) 0%, rgba(7, 6, 19, 0.78) 32%, rgba(7, 6, 19, 0.34) 63%, rgba(7, 6, 19, 0.2) 100%),
    radial-gradient(circle at 24% 28%, color-mix(in srgb, var(--lumen-hero-glow) 78%, transparent), transparent 38%),
    url("../assets/images/concepts-ideas/lumen-moon-title-section.webp") center right / cover no-repeat;
}

body.blood-moon-mode .lumen-hero {
  --lumen-hero-accent: #ff5266;
  --lumen-hero-accent-strong: #ffe2d8;
  --lumen-hero-gold: #f0c56a;
  --lumen-hero-text: #fff4ec;
  --lumen-hero-muted: rgba(255, 226, 217, 0.78);
  --lumen-hero-glow: rgba(255, 40, 64, 0.32);
  background:
    linear-gradient(90deg, rgba(18, 2, 6, 0.94) 0%, rgba(18, 2, 6, 0.82) 38%, rgba(18, 2, 6, 0.56) 100%),
    radial-gradient(circle at 78% 36%, rgba(255, 82, 102, 0.16), transparent 42%),
    rgba(10, 0, 3, 0.86);
}

/* Dawn Atrium intro: open background section; only artwork and controls keep borders. */
.lumen-atrium {
  display: grid;
  grid-template-columns: minmax(280px, 0.82fr) minmax(0, 1.18fr);
  grid-template-areas:
    "title title"
    "image content"
    "form form";
  column-gap: clamp(18px, 3vw, 34px);
  row-gap: clamp(18px, 3.6vw, 36px);
  align-items: center;
  min-width: 0;
  border: 0;
  border-radius: 0;
  padding: clamp(10px, 2.5vw, 22px) clamp(4px, 1.5vw, 14px);
  background: none;
  box-shadow: none;
}

/* Artwork/card borders stay intact so the card itself still feels intentional. */
.lumen-atrium__image {
  position: relative;
  grid-area: image;
  display: grid;
  align-self: center;
  width: min(100%, 430px);
  aspect-ratio: 1086 / 1448;
  margin: 0;
  overflow: visible;
  place-items: center;
  justify-self: center;
  border: 1px solid color-mix(in srgb, var(--navbar-hover-text) 30%, transparent);
  border-radius: 24px;
  padding: clamp(8px, 1.6vw, 14px);
  background:
    radial-gradient(circle at 50% 32%, color-mix(in srgb, var(--navbar-hover-text) 24%, transparent), transparent 56%),
    linear-gradient(135deg, rgba(255, 255, 255, 0.13), transparent 54%),
    rgba(255, 255, 255, 0.05);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.16),
    0 18px 48px rgba(0, 0, 0, 0.2);
}

.lumen-atrium__image img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: contain;
  object-position: center;
  border-radius: 18px;
  filter: brightness(1.06) contrast(1.03) saturate(1.04);
}

.lumen-atrium__image figcaption {
  display: none;
}

.lumen-atrium__image.is-missing figcaption {
  display: grid;
  place-items: center;
}

.lumen-atrium__image.is-missing figcaption span {
  display: grid;
  width: clamp(110px, 18vw, 180px);
  aspect-ratio: 1;
  place-items: center;
  border: 1px solid color-mix(in srgb, var(--navbar-hover-text) 34%, transparent);
  border-radius: 50%;
  color: var(--navbar-hover-text);
  background:
    radial-gradient(circle, color-mix(in srgb, var(--navbar-hover-text) 22%, transparent), transparent 60%),
    rgba(255, 255, 255, 0.055);
  box-shadow: 0 0 34px color-mix(in srgb, var(--navbar-glow) 58%, transparent);
  font-family: var(--heading-font);
  font-size: clamp(3.5rem, 9vw, 6.5rem);
}

.lumen-atrium__title {
  grid-area: title;
  display: grid;
  align-content: center;
  justify-items: center;
  gap: clamp(10px, 1.8vw, 16px);
  width: min(100%, 760px);
  margin: 0 auto;
  min-width: 0;
  text-align: center;
}

.lumen-atrium__content {
  grid-area: content;
  display: grid;
  align-content: start;
  min-width: 0;
  padding: clamp(4px, 1vw, 10px);
}

.lumen-atrium__title h2 {
  margin: 0;
  color: var(--navbar-text);
  font-family: var(--heading-font);
  font-size: clamp(3rem, 6vw, 5.6rem);
  line-height: 0.92;
  text-align: center;
  text-shadow: 0 0 20px color-mix(in srgb, var(--navbar-glow) 58%, transparent);
}

.lumen-atrium__title > p {
  margin: 0;
  color: var(--navbar-muted);
  font-size: clamp(1rem, 1.5vw, 1.14rem);
  line-height: 1.72;
}

.lumen-atrium .lumen-featured-counter {
  justify-self: center;
  color: color-mix(in srgb, var(--navbar-hover-text) 88%, var(--navbar-text));
  max-width: 100%;
  font-size: clamp(0.62rem, 0.9vw, 0.74rem);
  letter-spacing: 0.22em;
  line-height: 1.45;
  text-align: center;
}

.lumen-atrium .lumen-featured-counter::before,
.lumen-atrium .lumen-featured-counter::after {
  content: "✦";
  display: inline-block;
  margin-inline: 0.85rem;
  color: var(--navbar-hover-text);
  font-size: 0.78em;
  text-shadow: 0 0 10px color-mix(in srgb, var(--navbar-glow) 68%, transparent);
}

.lumen-atrium__letter {
  position: relative;
  display: grid;
  gap: clamp(10px, 1.35vw, 15px);
  max-width: 68ch;
  border: 1px solid color-mix(in srgb, var(--navbar-hover-text) 24%, transparent);
  border-radius: 24px;
  padding: clamp(18px, 2.6vw, 30px);
  background:
    radial-gradient(circle at 86% 10%, color-mix(in srgb, var(--navbar-glow) 11%, transparent), transparent 42%),
    color-mix(in srgb, var(--navbar-bg) 70%, rgba(0, 0, 0, 0.24));
  box-shadow:
    0 14px 36px rgba(0, 0, 0, 0.14),
    inset 0 1px 0 rgba(255, 255, 255, 0.08);
}

.lumen-atrium__letter::before {
  content: "";
  width: 72px;
  height: 1px;
  border-radius: 999px;
  background: linear-gradient(90deg, transparent, var(--navbar-hover-text), transparent);
  box-shadow: 0 0 14px color-mix(in srgb, var(--navbar-glow) 70%, transparent);
}

.lumen-atrium__letter p:first-child {
  display: flex;
  align-items: center;
  gap: 0.65rem;
  color: color-mix(in srgb, var(--navbar-hover-text) 82%, white);
  font-family: var(--heading-font);
  font-size: clamp(1.32rem, 2.45vw, 1.78rem);
  font-weight: 600;
  line-height: 1.18;
}

.lumen-atrium__letter p:first-child::before {
  content: "✦";
  color: var(--navbar-hover-text);
  font-size: 0.9em;
  line-height: 1;
  text-shadow: 0 0 12px color-mix(in srgb, var(--navbar-glow) 70%, transparent);
}

.lumen-atrium__letter p {
  margin: 0;
  color: color-mix(in srgb, var(--navbar-muted) 86%, var(--navbar-text));
  font-family: var(--font-body-serif);
  font-size: clamp(1.02rem, 1.55vw, 1.16rem);
  font-weight: 400;
  line-height: 1.86;
}

.lumen-atrium__divider {
  display: block;
  width: min(100%, 130px);
  height: 1px;
  margin: clamp(2px, 0.45vw, 5px) 0;
  border-radius: 999px;
  background: linear-gradient(
    90deg,
    color-mix(in srgb, var(--navbar-hover-text) 58%, transparent),
    color-mix(in srgb, var(--navbar-hover-text) 18%, transparent),
    transparent
  );
}

.lumen-name-entry {
  grid-area: form;
  display: grid;
  width: min(100%, 880px);
  margin: clamp(14px, 2.8vw, 28px) auto 0;
}

.lumen-name-form {
  --lumen-name-text: #fff6dc;
  --lumen-name-muted: #eadbb8;
  --lumen-name-accent: #f0c76f;
  --lumen-name-accent-strong: #fff0b7;
  --lumen-name-frame: rgba(241, 197, 107, 0.54);
  --lumen-name-glow: rgba(255, 198, 92, 0.36);
  --lumen-name-panel: rgba(18, 28, 22, 0.58);
  position: relative;
  isolation: isolate;
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  justify-items: center;
  gap: clamp(12px, 2vw, 18px);
  width: 100%;
  max-width: 820px;
  margin: 0 auto;
  border: 1px solid var(--lumen-name-frame);
  border-radius: clamp(26px, 3vw, 34px);
  padding: clamp(1.45rem, 4vw, 3rem);
  background:
    radial-gradient(circle at 50% 0%, color-mix(in srgb, var(--lumen-name-glow) 40%, transparent), transparent 38%),
    linear-gradient(135deg, rgba(255, 255, 255, 0.06), transparent 42%),
    var(--lumen-name-panel);
  box-shadow:
    0 0 36px color-mix(in srgb, var(--lumen-name-glow) 36%, transparent),
    0 20px 48px rgba(0, 0, 0, 0.18),
    inset 0 0 28px rgba(255, 255, 255, 0.035);
  backdrop-filter: blur(10px);
  color: var(--lumen-name-text);
  text-align: center;
}

.lumen-name-entry__ornament {
  color: var(--lumen-name-accent-strong);
  font-size: clamp(1rem, 1.8vw, 1.35rem);
  line-height: 1;
  text-shadow:
    0 0 12px color-mix(in srgb, var(--lumen-name-glow) 80%, transparent),
    0 0 24px color-mix(in srgb, var(--lumen-name-glow) 38%, transparent);
  animation: lumenNameOrnamentPulse 4.8s ease-in-out infinite;
}

.lumen-name-form__fields {
  display: grid;
  justify-items: center;
  gap: clamp(0.55rem, 1.6vw, 0.9rem);
  width: min(100%, 680px);
  min-width: 0;
}

.lumen-name-form__fields[hidden],
.lumen-name-form__change[hidden] {
  display: none;
}

.lumen-name-form label {
  color: var(--lumen-name-accent-strong);
  font-family: var(--logo-font);
  font-size: clamp(0.72rem, 1.05vw, 0.88rem);
  letter-spacing: 0.2em;
  line-height: 1.4;
  text-transform: uppercase;
  text-shadow: 0 0 12px color-mix(in srgb, var(--lumen-name-glow) 58%, transparent);
}

.lumen-name-form label::after {
  content: "";
  display: block;
  width: min(100%, 180px);
  height: 1px;
  margin: 0.72rem auto 0;
  background: linear-gradient(90deg, transparent, var(--lumen-name-frame), transparent);
  box-shadow: 0 0 10px color-mix(in srgb, var(--lumen-name-glow) 44%, transparent);
}

.lumen-name-form__hint {
  max-width: 54ch;
  margin: 0;
  color: color-mix(in srgb, var(--lumen-name-muted) 78%, var(--lumen-name-text));
  font-family: var(--font-body-serif);
  font-size: clamp(0.96rem, 1.2vw, 1.06rem);
  line-height: 1.6;
}

.lumen-name-form__row {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.9rem;
  width: min(100%, 680px);
  min-width: 0;
  margin: clamp(0.65rem, 2vw, 1.2rem) auto 0;
}

.lumen-name-form input {
  appearance: none;
  flex: 1 1 320px;
  width: 100%;
  min-width: 0;
  min-height: 52px;
  border: 1px solid color-mix(in srgb, var(--lumen-name-frame) 82%, transparent);
  border-radius: 16px;
  padding: 0 1rem;
  color: var(--lumen-name-text);
  background:
    radial-gradient(circle at 50% 50%, color-mix(in srgb, var(--lumen-name-glow) 18%, transparent), transparent 64%),
    rgba(0, 0, 0, 0.24);
  box-shadow:
    inset 0 0 18px rgba(0, 0, 0, 0.18),
    0 0 18px color-mix(in srgb, var(--lumen-name-glow) 18%, transparent);
  font-family: var(--font-body-serif);
  font-size: clamp(1rem, 1.35vw, 1.12rem);
  font-style: italic;
  line-height: 1;
  transition:
    border-color 180ms ease,
    box-shadow 180ms ease,
    background 180ms ease;
}

.lumen-name-form input::placeholder {
  color: color-mix(in srgb, var(--lumen-name-muted) 58%, transparent);
}

.lumen-name-form input:focus {
  border-color: color-mix(in srgb, var(--lumen-name-accent-strong) 84%, white);
  outline: none;
  box-shadow:
    inset 0 0 24px color-mix(in srgb, var(--lumen-name-glow) 20%, transparent),
    0 0 0 4px color-mix(in srgb, var(--lumen-name-glow) 22%, transparent),
    0 0 30px color-mix(in srgb, var(--lumen-name-glow) 56%, transparent);
}

.lumen-name-form button {
  flex: 0 0 auto;
  min-height: 52px;
  border: 1px solid color-mix(in srgb, var(--lumen-name-accent-strong) 72%, var(--lumen-name-frame));
  border-radius: 16px;
  padding: 0 1.5rem;
  color: #493314;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.42), transparent 42%),
    linear-gradient(135deg, #fff2bf, #efc76b 56%, #c98935);
  box-shadow:
    0 0 18px color-mix(in srgb, var(--lumen-name-glow) 68%, transparent),
    inset 0 1px 0 rgba(255, 255, 255, 0.5),
    inset 0 -1px 0 rgba(89, 53, 16, 0.24);
  cursor: pointer;
  font-family: var(--heading-font);
  font-size: clamp(0.95rem, 1.2vw, 1.05rem);
  font-weight: 800;
  letter-spacing: 0;
  text-shadow: 0 1px 0 rgba(255, 249, 224, 0.42);
  transition:
    box-shadow 180ms ease,
    transform 180ms ease,
    filter 180ms ease;
}

.lumen-name-form button:hover,
.lumen-name-form button:focus-visible {
  outline: none;
  transform: translateY(-2px);
  filter: brightness(1.05) saturate(1.05);
  box-shadow:
    0 0 28px color-mix(in srgb, var(--lumen-name-glow) 92%, transparent),
    0 0 46px color-mix(in srgb, var(--lumen-name-glow) 42%, transparent),
    inset 0 1px 0 rgba(255, 255, 255, 0.58);
}

.lumen-name-form button:focus-visible {
  outline: 2px solid color-mix(in srgb, var(--lumen-name-accent-strong) 86%, white);
  outline-offset: 4px;
}

.lumen-name-form__message {
  display: grid;
  gap: 4px;
  min-height: 1.5em;
  margin: 0;
  padding-top: 0.3rem;
  color: color-mix(in srgb, var(--lumen-name-text) 90%, var(--lumen-name-accent));
  font-family: var(--font-body-serif);
  font-size: clamp(1rem, 1.45vw, 1.18rem);
  line-height: 1.55;
  text-align: center;
}

.lumen-name-form__message:empty {
  display: none;
}

.lumen-name-form:has(.lumen-name-form__fields[hidden]) {
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  gap: 1rem;
}

.lumen-name-form:has(.lumen-name-form__fields[hidden]) .lumen-name-form__message {
  padding-top: 0;
}

.lumen-name-form__message span:first-child {
  color: var(--lumen-name-accent-strong);
  font-weight: 800;
}

.lumen-name-form__change {
  justify-self: end;
  min-height: 44px;
  border: 1px solid color-mix(in srgb, var(--lumen-name-accent-strong) 42%, transparent);
  border-radius: 14px;
  border-color: color-mix(in srgb, var(--lumen-name-accent-strong) 42%, transparent);
  padding: 0 18px;
  color: var(--lumen-name-text);
  background:
    linear-gradient(135deg, rgba(255, 255, 255, 0.1), transparent 48%),
    color-mix(in srgb, var(--lumen-name-accent) 14%, rgba(0, 0, 0, 0.2));
  box-shadow: 0 0 16px color-mix(in srgb, var(--lumen-name-glow) 34%, transparent);
  font-size: 0.9rem;
}

body.sun-mode .lumen-atrium__letter {
  border-color: rgba(236, 186, 91, 0.28);
  background:
    radial-gradient(circle at 90% 8%, rgba(232, 179, 78, 0.1), transparent 42%),
    rgba(24, 18, 10, 0.66);
  box-shadow:
    0 14px 38px rgba(0, 0, 0, 0.16),
    inset 0 1px 0 rgba(255, 238, 194, 0.09);
}

body.moon-mode .lumen-atrium__letter {
  border-color: rgba(196, 173, 255, 0.2);
  background:
    radial-gradient(circle at 90% 8%, rgba(162, 126, 224, 0.12), transparent 42%),
    rgba(8, 7, 18, 0.7);
  box-shadow:
    0 14px 38px rgba(0, 0, 0, 0.2),
    inset 0 1px 0 rgba(232, 222, 255, 0.08);
}

body.sun-mode .lumen-name-form {
  --lumen-name-text: #fff8df;
  --lumen-name-muted: #e9d6a5;
  --lumen-name-accent: #edbd5f;
  --lumen-name-accent-strong: #ffe6a0;
  --lumen-name-frame: rgba(237, 189, 95, 0.55);
  --lumen-name-glow: rgba(255, 191, 76, 0.38);
  --lumen-name-panel: rgba(18, 31, 25, 0.6);
}

body.moon-mode .lumen-name-form,
body.blood-moon-mode .lumen-name-form {
  --lumen-name-text: #f7f0ff;
  --lumen-name-muted: #e5e0f2;
  --lumen-name-accent: #ece8ff;
  --lumen-name-accent-strong: #fffdf6;
  --lumen-name-frame: rgba(236, 234, 255, 0.42);
  --lumen-name-glow: rgba(245, 246, 255, 0.38);
  --lumen-name-panel: rgba(11, 9, 24, 0.68);
}

@keyframes lumenNameOrnamentPulse {
  0%,
  100% {
    opacity: 0.72;
    transform: scale(1);
  }

  50% {
    opacity: 1;
    transform: scale(1.08);
  }
}

@media (prefers-reduced-motion: reduce) {
  .lumen-name-entry__card,
  .lumen-name-entry__form input,
  .lumen-name-entry__form button,
  .lumen-name-entry__ornament {
    animation: none;
    transition: none;
  }
}

.lumen-sanctuary {
  /* Sun mode is the default Lumen palette: amber light, warm glass, soft teal depth. */
  --lumen-selector-text: #fff6dc;
  --lumen-selector-muted: #eadbb8;
  --lumen-selector-accent: #efc875;
  --lumen-selector-accent-strong: #ffe0a0;
  --lumen-selector-line: rgba(238, 190, 106, 0.28);
  --lumen-selector-line-soft: rgba(238, 190, 106, 0.16);
  --lumen-selector-separator: rgba(255, 219, 141, 0.72);
  --lumen-selector-separator-glow: rgba(255, 197, 86, 0.58);
  --lumen-selector-glow: rgba(255, 202, 104, 0.52);
  --lumen-selector-glow-soft: rgba(255, 239, 186, 0.28);
  --lumen-selector-node-bg: rgba(48, 39, 28, 0.48);
  --lumen-selector-node-bg-alt: rgba(56, 43, 28, 0.52);
  --lumen-selector-field-a: rgba(255, 199, 104, 0.18);
  --lumen-selector-field-b: rgba(25, 105, 109, 0.24);
  --lumen-selector-field-c: rgba(195, 134, 57, 0.14);
  --lumen-selector-panel: rgba(46, 34, 24, 0.62);
  --lumen-selector-cta-bg: linear-gradient(135deg, #fff8de, #edc77e 58%, #d59642);
  --lumen-selector-cta-text: #4f3517;
  --lumen-showcase-scroll-thumb: rgba(255, 214, 130, 0.86);
  --lumen-showcase-scroll-thumb-strong: #ffe7a8;
  --lumen-showcase-scroll-track: rgba(255, 226, 160, 0.12);
  display: grid;
  gap: clamp(18px, 3vw, 30px);
  min-width: 0;
}

/* Moon mode swaps the Lumen selector into violet/indigo accents without changing behavior. */
body.moon-mode .lumen-sanctuary {
  --lumen-selector-text: #f3edff;
  --lumen-selector-muted: #d9cff5;
  --lumen-selector-accent: #c9b6ff;
  --lumen-selector-accent-strong: #e4d9ff;
  --lumen-selector-line: rgba(178, 142, 255, 0.32);
  --lumen-selector-line-soft: rgba(151, 120, 225, 0.18);
  --lumen-selector-separator: rgba(209, 188, 255, 0.76);
  --lumen-selector-separator-glow: rgba(159, 104, 255, 0.58);
  --lumen-selector-glow: rgba(170, 113, 255, 0.56);
  --lumen-selector-glow-soft: rgba(220, 204, 255, 0.3);
  --lumen-selector-node-bg: rgba(33, 26, 58, 0.58);
  --lumen-selector-node-bg-alt: rgba(41, 32, 72, 0.62);
  --lumen-selector-field-a: rgba(170, 113, 255, 0.18);
  --lumen-selector-field-b: rgba(49, 78, 123, 0.2);
  --lumen-selector-field-c: rgba(99, 68, 156, 0.16);
  --lumen-selector-panel: rgba(25, 20, 46, 0.7);
  --lumen-selector-cta-bg: linear-gradient(135deg, #f3edff, #c8b4ff 58%, #8c6edf);
  --lumen-selector-cta-text: #241747;
  --lumen-showcase-scroll-thumb: rgba(202, 183, 255, 0.84);
  --lumen-showcase-scroll-thumb-strong: #eadfff;
  --lumen-showcase-scroll-track: rgba(186, 160, 255, 0.13);
}

body.blood-moon-mode .lumen-sanctuary {
  --lumen-showcase-scroll-thumb: rgba(255, 68, 91, 0.78);
  --lumen-showcase-scroll-thumb-strong: #ffc7bd;
  --lumen-showcase-scroll-track: rgba(255, 76, 96, 0.12);
}

.lumen-sanctuary__heading {
  display: grid;
  gap: 10px;
  justify-items: center;
  padding-block: clamp(4px, 1.5vw, 14px);
  text-align: center;
}

.lumen-sanctuary__heading::before,
.lumen-sanctuary__heading::after {
  content: "";
  display: block;
  width: min(64vw, 620px);
  height: 1px;
  border-radius: 999px;
  background: linear-gradient(90deg, transparent, var(--lumen-selector-separator), transparent);
  box-shadow:
    0 0 10px color-mix(in srgb, var(--lumen-selector-separator-glow) 72%, transparent),
    0 0 24px color-mix(in srgb, var(--lumen-selector-separator-glow) 38%, transparent);
}

.lumen-sanctuary__heading::before {
  margin-bottom: clamp(2px, 0.7vw, 8px);
}

.lumen-sanctuary__heading::after {
  content: none;
}

.lumen-sanctuary__heading h2 {
  margin: 0;
  color: color-mix(in srgb, var(--lumen-selector-text) 88%, var(--navbar-text));
  font-family: var(--heading-font);
  font-size: clamp(2.55rem, 5.8vw, 5rem);
  line-height: 0.95;
  text-shadow:
    0 0 22px color-mix(in srgb, var(--lumen-selector-glow) 70%, transparent),
    0 2px 16px rgba(0, 0, 0, 0.24);
}

.lumen-sanctuary__heading p {
  margin: 0;
  max-width: 62ch;
  color: color-mix(in srgb, var(--lumen-selector-muted) 76%, var(--navbar-muted));
  line-height: 1.7;
}

.lumen-sanctuary__subheading {
  color: var(--lumen-selector-accent);
  font-family: var(--heading-font);
  font-size: clamp(1.35rem, 2.8vw, 2.1rem);
  line-height: 1.08;
  text-shadow: 0 0 16px color-mix(in srgb, var(--lumen-selector-glow) 56%, transparent);
}

/* Lightwork selector keeps the original button behavior while presenting five vertical paths. */
.lumen-sanctuary__rail {
  position: relative;
  display: grid;
  place-items: center;
  max-width: 100%;
  min-width: 0;
  overflow: visible;
  border: 0;
  border-radius: 0;
  padding: clamp(38px, 5vw, 66px) 0 clamp(16px, 3vw, 30px);
  background: transparent;
  box-shadow: none;
}

.lumen-sanctuary__rail::before,
.lumen-sanctuary__rail::after {
  content: none;
}

.lumen-sanctuary__rail::after {
  content: "";
  display: block;
  width: min(68vw, 680px);
  height: 1px;
  margin-top: clamp(18px, 3vw, 34px);
  border-radius: 999px;
  background: linear-gradient(90deg, transparent, var(--lumen-selector-separator), transparent);
  box-shadow:
    0 0 10px color-mix(in srgb, var(--lumen-selector-separator-glow) 72%, transparent),
    0 0 24px color-mix(in srgb, var(--lumen-selector-separator-glow) 38%, transparent);
}

.lumen-compass {
  display: grid;
  grid-template-columns: repeat(5, minmax(120px, 1fr));
  align-items: end;
  gap: clamp(6px, 1.2vw, 18px);
  width: min(100%, 1240px);
  min-width: 0;
}

.lumen-sanctuary-tab {
  position: relative;
  isolation: isolate;
  overflow: visible;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  align-items: center;
  gap: clamp(24px, 3.2vw, 42px);
  width: 100%;
  min-width: 0;
  min-height: clamp(330px, 35vw, 430px);
  border: 0;
  border-radius: 0;
  padding: clamp(34px, 4vw, 54px) clamp(14px, 1.8vw, 28px) clamp(24px, 3vw, 40px);
  color: color-mix(in srgb, var(--lumen-selector-muted) 76%, var(--navbar-muted));
  background: transparent;
  box-shadow: none;
  cursor: pointer;
  font-family: var(--body-font);
  text-align: center;
  transition:
    opacity 240ms ease,
    color 220ms ease,
    filter 240ms ease,
    transform 320ms cubic-bezier(0.2, 0.78, 0.28, 1);
}

.lumen-sanctuary-tab::before,
.lumen-sanctuary-tab::after {
  content: "";
  position: absolute;
  top: 10%;
  bottom: 7%;
  width: 1px;
  background: linear-gradient(
    to bottom,
    transparent,
    color-mix(in srgb, var(--lumen-selector-line) 92%, transparent) 18%,
    color-mix(in srgb, var(--lumen-selector-accent-strong) 54%, transparent) 50%,
    color-mix(in srgb, var(--lumen-selector-line) 92%, transparent) 82%,
    transparent
  );
  box-shadow: 0 0 12px color-mix(in srgb, var(--lumen-selector-glow) 22%, transparent);
  pointer-events: none;
  transition:
    background 260ms ease,
    box-shadow 260ms ease,
    top 260ms ease,
    bottom 260ms ease;
}

.lumen-sanctuary-tab::before {
  left: 0;
}

.lumen-sanctuary-tab::after {
  right: 0;
}

.lumen-sanctuary-tab--featured,
.lumen-sanctuary-tab.is-active {
  min-height: clamp(380px, 39vw, 500px);
}

.lumen-sanctuary-tab__copy::before,
.lumen-sanctuary-tab__copy::after {
  content: "";
  position: absolute;
  top: 10%;
  width: 7px;
  aspect-ratio: 1;
  background: var(--lumen-selector-accent-strong);
  clip-path: polygon(50% 0, 62% 38%, 100% 50%, 62% 62%, 50% 100%, 38% 62%, 0 50%, 38% 38%);
  box-shadow: 0 0 12px color-mix(in srgb, var(--lumen-selector-glow) 70%, transparent);
  transform: translateX(-50%);
}

.lumen-sanctuary-tab__copy::before {
  left: 0;
}

.lumen-sanctuary-tab__copy::after {
  left: 100%;
}

.lumen-sanctuary-tab::selection {
  background: transparent;
}

.lumen-sanctuary-tab:hover,
.lumen-sanctuary-tab:focus-visible,
.lumen-sanctuary-tab.is-active {
  color: var(--lumen-selector-text);
  filter: saturate(1.08);
}

.lumen-sanctuary-tab:hover,
.lumen-sanctuary-tab:focus-visible {
  transform: translateY(-12px) scale(1.035);
}

.lumen-sanctuary-tab.is-active {
  z-index: 2;
  transform: translateY(-22px) scale(1.08);
}

.lumen-sanctuary-tab.is-active::before,
.lumen-sanctuary-tab.is-active::after,
.lumen-sanctuary-tab:hover::before,
.lumen-sanctuary-tab:hover::after,
.lumen-sanctuary-tab:focus-visible::before,
.lumen-sanctuary-tab:focus-visible::after {
  top: 5%;
  bottom: 3%;
  background: linear-gradient(
    to bottom,
    transparent,
    color-mix(in srgb, var(--lumen-selector-accent-strong) 78%, transparent) 14%,
    var(--lumen-selector-accent-strong) 50%,
    color-mix(in srgb, var(--lumen-selector-accent-strong) 78%, transparent) 86%,
    transparent
  );
  box-shadow:
    0 0 16px color-mix(in srgb, var(--lumen-selector-glow) 62%, transparent),
    0 0 34px color-mix(in srgb, var(--lumen-selector-glow) 38%, transparent);
}

.lumen-sanctuary-tab.is-active::selection {
  background: transparent;
}

.lumen-sanctuary-tab:focus-visible {
  outline: 2px solid var(--navbar-hover-text);
  outline-offset: 8px;
}

.lumen-sanctuary-tab__copy {
  position: relative;
  display: grid;
  gap: clamp(12px, 1.5vw, 18px);
  align-content: start;
  justify-items: center;
  min-width: 0;
  width: 100%;
  text-align: center;
  z-index: 1;
}

.lumen-featured-counter,
.lumen-info-box h3 {
  color: var(--lumen-selector-accent);
  font-family: var(--logo-font);
  font-size: 0.72rem;
  letter-spacing: 0.18em;
  line-height: 1.2;
  text-transform: uppercase;
}

.lumen-sanctuary-tab__copy strong {
  color: color-mix(in srgb, var(--lumen-selector-text) 88%, var(--navbar-text));
  font-family: var(--heading-font);
  font-size: clamp(1.72rem, 2.6vw, 2.85rem);
  font-weight: 600;
  line-height: 0.98;
  text-shadow: 0 0 16px color-mix(in srgb, var(--lumen-selector-glow) 40%, transparent);
  transition:
    color 220ms ease,
    text-shadow 220ms ease,
    transform 260ms ease;
}

.lumen-sanctuary-tab__copy em {
  color: color-mix(in srgb, var(--lumen-selector-muted) 78%, var(--navbar-muted));
  max-width: 14ch;
  font-family: var(--font-body-serif);
  font-size: clamp(1rem, 1.3vw, 1.26rem);
  font-style: normal;
  line-height: 1.34;
  transition:
    color 220ms ease,
    text-shadow 220ms ease,
    transform 260ms ease;
}

.lumen-sanctuary-tab__icon {
  position: relative;
  z-index: 1;
  display: grid;
  width: clamp(112px, 10vw, 160px);
  aspect-ratio: 1;
  place-items: center;
  justify-self: center;
  transition:
    filter 260ms ease,
    transform 320ms cubic-bezier(0.2, 0.78, 0.28, 1);
}

.lumen-sanctuary-tab__icon::before {
  content: "";
  position: absolute;
  inset: -24%;
  z-index: -1;
  border-radius: 50%;
  background: radial-gradient(circle, color-mix(in srgb, var(--lumen-selector-glow) 32%, transparent), transparent 68%);
  opacity: 0.34;
  transform: scale(0.86);
  transition:
    opacity 260ms ease,
    transform 320ms ease;
}

.lumen-sanctuary-tab--featured .lumen-sanctuary-tab__icon,
.lumen-sanctuary-tab.is-active .lumen-sanctuary-tab__icon {
  width: clamp(138px, 13vw, 190px);
}

.lumen-sanctuary-tab__icon img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: contain;
  opacity: 1;
  filter:
    brightness(1.72)
    contrast(1.24)
    saturate(1.25)
    drop-shadow(0 0 12px color-mix(in srgb, var(--lumen-selector-glow) 26%, transparent));
  transition:
    filter 260ms ease,
    transform 320ms cubic-bezier(0.2, 0.78, 0.28, 1);
}

.lumen-sanctuary-tab:hover .lumen-sanctuary-tab__icon,
.lumen-sanctuary-tab:focus-visible .lumen-sanctuary-tab__icon {
  transform: translateY(-4px) scale(1.06);
}

.lumen-sanctuary-tab.is-active .lumen-sanctuary-tab__icon {
  transform: translateY(-6px) scale(1.1);
}

.lumen-sanctuary-tab:hover .lumen-sanctuary-tab__icon::before,
.lumen-sanctuary-tab:focus-visible .lumen-sanctuary-tab__icon::before,
.lumen-sanctuary-tab.is-active .lumen-sanctuary-tab__icon::before {
  opacity: 0.82;
  transform: scale(1.12);
}

.lumen-sanctuary-tab:hover .lumen-sanctuary-tab__icon img,
.lumen-sanctuary-tab:focus-visible .lumen-sanctuary-tab__icon img,
.lumen-sanctuary-tab.is-active .lumen-sanctuary-tab__icon img {
  filter:
    brightness(2.15)
    contrast(1.28)
    saturate(1.28)
    drop-shadow(0 0 18px var(--lumen-selector-glow))
    drop-shadow(0 0 34px color-mix(in srgb, var(--lumen-selector-glow) 40%, transparent));
}

.lumen-sanctuary-tab:hover .lumen-sanctuary-tab__copy strong,
.lumen-sanctuary-tab:focus-visible .lumen-sanctuary-tab__copy strong,
.lumen-sanctuary-tab.is-active .lumen-sanctuary-tab__copy strong {
  color: var(--lumen-selector-text);
  text-shadow:
    0 0 18px color-mix(in srgb, var(--lumen-selector-glow) 78%, transparent),
    0 0 34px color-mix(in srgb, var(--lumen-selector-glow) 38%, transparent);
}

.lumen-sanctuary-tab:hover .lumen-sanctuary-tab__copy em,
.lumen-sanctuary-tab:focus-visible .lumen-sanctuary-tab__copy em,
.lumen-sanctuary-tab.is-active .lumen-sanctuary-tab__copy em {
  color: color-mix(in srgb, var(--lumen-selector-accent-strong) 88%, var(--lumen-selector-text));
  text-shadow: 0 0 14px color-mix(in srgb, var(--lumen-selector-glow) 48%, transparent);
}

.lumen-sanctuary-tab__divider {
  display: none;
}

.lumen-sanctuary-tab__accent {
  display: grid;
  grid-template-columns: minmax(34px, 1fr) auto minmax(34px, 1fr);
  align-items: center;
  gap: 8px;
  width: min(100%, 116px);
  color: var(--lumen-selector-accent-strong);
  filter: drop-shadow(0 0 10px color-mix(in srgb, var(--lumen-selector-glow) 46%, transparent));
}

.lumen-sanctuary-tab__accent::before {
  content: "";
  height: 1px;
  background: linear-gradient(90deg, transparent, color-mix(in srgb, var(--lumen-selector-accent-strong) 62%, transparent));
}

.lumen-sanctuary-tab__accent::after {
  content: "✦";
  order: 2;
  font-size: 0.74rem;
  line-height: 1;
}

.lumen-sanctuary-tab__accent {
  grid-template-areas: "line-left star line-right";
}

.lumen-sanctuary-tab__accent::before {
  grid-area: line-left;
}

.lumen-sanctuary-tab__accent::after {
  grid-area: star;
}

.lumen-sanctuary-tab__accent {
  background:
    linear-gradient(90deg, transparent 0 58%, color-mix(in srgb, var(--lumen-selector-accent-strong) 62%, transparent) 58% 100%);
  background-position: right center;
  background-size: 46% 1px;
  background-repeat: no-repeat;
}

.lumen-sanctuary-tab.is-active::selection {
  background: transparent;
}

.lumen-sanctuary-tab::selection,
.lumen-sanctuary-tab *::selection {
  background: color-mix(in srgb, var(--lumen-selector-accent-strong) 24%, transparent);
}

.lumen-sanctuary-tab.is-active::before,
.lumen-sanctuary-tab.is-active::after {
  width: 1px;
}

.lumen-sanctuary-tab.is-active::selection {
  color: inherit;
}

.lumen-sanctuary-tab.is-active .lumen-sanctuary-tab__copy {
  text-shadow: 0 0 14px color-mix(in srgb, var(--lumen-selector-glow) 36%, transparent);
}

.lumen-sanctuary-tab.is-active::selection {
  background: transparent;
}

.lumen-sanctuary-tab.is-active::before,
.lumen-sanctuary-tab.is-active::after {
  opacity: 1;
}

.lumen-sanctuary-tab.is-active {
  text-shadow: 0 0 18px color-mix(in srgb, var(--lumen-selector-glow) 28%, transparent);
}

.lumen-sanctuary-tab--reflection-pool.is-active .lumen-sanctuary-tab__icon::after {
  content: "";
  position: absolute;
  inset: 0;
  background:
    url("../assets/images/reflection-button-transparent.webp") center / contain no-repeat,
    url("../assets/images/reflection-button-transparent.webp") center / contain no-repeat,
    url("../assets/images/reflection-button-transparent.webp") center / contain no-repeat;
  filter:
    brightness(2.5)
    contrast(1.36)
    saturate(1.3)
    drop-shadow(0 0 18px var(--lumen-selector-glow))
    drop-shadow(0 0 34px color-mix(in srgb, var(--lumen-selector-glow) 44%, transparent));
  pointer-events: none;
}

/* Selected sanctuary portal: Design 1 room image and information panel. */
.lumen-sanctuary-viewer {
  display: block;
  min-width: 0;
  scroll-margin-top: clamp(5rem, 12vh, 7rem);
  border: 0;
  border-radius: 0;
  padding: 0;
  background: transparent;
  box-shadow: none;
}

.sanctuary-portal-preview {
  display: grid;
  gap: clamp(1.2rem, 3vw, 2rem);
  justify-items: center;
  min-width: 0;
  max-width: 100%;
  overflow-x: clip;
  border: 0;
  padding: clamp(2.25rem, 5vw, 4.25rem) 1rem;
  background: transparent;
  box-shadow: none;
  touch-action: pan-y;
}

.sanctuary-mobile-guide {
  display: none;
}

.sanctuary-portal-stage {
  display: grid;
  justify-items: center;
  width: 100%;
  min-width: 0;
  max-width: 100%;
  animation: sanctuaryPortalReveal 260ms ease both;
}

.sanctuary-portal-stage.is-active {
  opacity: 1;
  transform: translateY(-2px);
}

.sanctuary-room-showcase {
  display: grid;
  grid-template-columns: minmax(280px, 420px) minmax(420px, 1fr);
  align-items: center;
  gap: clamp(2rem, 5vw, 4.5rem);
  width: min(100% - 2rem, 1180px);
  margin: 0 auto;
  min-width: 0;
}

.sanctuary-room-showcase__visual {
  display: flex;
  justify-content: center;
  min-width: 0;
}

.sanctuary-portal-frame {
  position: relative;
  display: grid;
  width: min(100%, 420px);
  max-width: 100%;
  aspect-ratio: 2 / 3;
  margin: 0;
  overflow: hidden;
  place-items: center;
  border: 0;
  border-radius: clamp(20px, 3vw, 34px);
  padding: 0;
  background: transparent;
  box-shadow:
    0 24px 70px rgba(0, 0, 0, 0.28),
    0 0 38px color-mix(in srgb, var(--lumen-selector-glow) 34%, transparent);
}

.sanctuary-portal-image-button {
  display: grid;
  width: 100%;
  height: 100%;
  min-width: 0;
  border: 0;
  border-radius: inherit;
  overflow: hidden;
  padding: 0;
  place-items: center;
  background: transparent;
  cursor: zoom-in;
}

.sanctuary-portal-image-button:focus-visible {
  outline: 2px solid var(--lumen-selector-accent-strong);
  outline-offset: 5px;
  border-radius: inherit;
  box-shadow: 0 0 24px var(--lumen-selector-glow);
}

.sanctuary-portal-image-button:hover img,
.sanctuary-portal-image-button:focus-visible img {
  filter: brightness(1.1) contrast(1.04) saturate(1.05);
}

.sanctuary-portal-image {
  display: block;
  width: 100%;
  max-width: none;
  height: 100%;
  max-height: none;
  object-fit: cover;
  object-position: center;
  border-radius: inherit;
  filter: brightness(1.06) contrast(1.03) saturate(1.04);
  transform: none;
  transform-origin: center;
}

.sanctuary-room-showcase__info {
  display: flex;
  flex-direction: column;
  justify-content: center;
  min-width: 0;
  min-height: clamp(480px, 42vw, 560px);
  border: 1px solid color-mix(in srgb, var(--lumen-selector-accent-strong) 46%, transparent);
  border-radius: 28px;
  padding: clamp(2rem, 4vw, 3.5rem);
  color: var(--lumen-selector-text);
  background:
    radial-gradient(circle at 50% 0%, color-mix(in srgb, var(--lumen-selector-accent-strong) 10%, transparent), transparent 38%),
    linear-gradient(145deg, color-mix(in srgb, var(--lumen-selector-node-bg) 86%, rgba(0, 0, 0, 0.42)), rgba(3, 9, 9, 0.58));
  box-shadow:
    0 0 32px color-mix(in srgb, var(--lumen-selector-glow) 18%, transparent),
    inset 0 0 28px rgba(255, 255, 255, 0.028);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}

.sanctuary-room-showcase__eyebrow {
  margin: 0 0 0.75rem;
  color: var(--lumen-selector-accent-strong);
  font-family: var(--body-font);
  font-size: 0.74rem;
  font-weight: 900;
  letter-spacing: 0.2em;
  line-height: 1.2;
  text-transform: uppercase;
}

.sanctuary-room-showcase__info h2 {
  margin: 0;
  color: color-mix(in srgb, var(--lumen-selector-text) 90%, var(--navbar-text));
  font-family: var(--heading-font);
  font-size: clamp(2.55rem, 5vw, 4.75rem);
  font-weight: 600;
  line-height: 0.95;
  letter-spacing: 0;
  text-shadow: 0 0 18px color-mix(in srgb, var(--lumen-selector-glow) 34%, transparent);
}

.sanctuary-room-showcase__tagline {
  margin: 1rem 0 0;
  color: color-mix(in srgb, var(--lumen-selector-accent-strong) 76%, var(--lumen-selector-text));
  font-size: clamp(1.08rem, 1.5vw, 1.22rem);
  font-style: italic;
  line-height: 1.55;
}

.sanctuary-room-showcase__divider {
  width: min(100%, 360px);
  height: 1px;
  margin: clamp(1.2rem, 2.6vw, 1.7rem) 0;
  background: linear-gradient(90deg, var(--lumen-selector-accent-strong), color-mix(in srgb, var(--lumen-selector-accent) 38%, transparent), transparent);
  box-shadow: 0 0 14px color-mix(in srgb, var(--lumen-selector-glow) 54%, transparent);
}

.sanctuary-room-showcase__description {
  display: grid;
  gap: 0.85rem;
}

.sanctuary-room-showcase__description p {
  margin: 0;
  max-width: 62ch;
  color: color-mix(in srgb, var(--lumen-selector-muted) 82%, var(--navbar-muted));
  font-size: clamp(0.98rem, 1.16vw, 1.08rem);
  line-height: 1.7;
}

.sanctuary-room-showcase__offers {
  display: grid;
  gap: 0.8rem;
  margin: clamp(1.35rem, 2.8vw, 1.8rem) 0 clamp(1.45rem, 3vw, 2rem);
}

.sanctuary-room-showcase__offers p {
  margin: 0;
  color: var(--lumen-selector-accent-strong);
  font-family: var(--body-font);
  font-size: 0.72rem;
  font-weight: 900;
  letter-spacing: 0.16em;
  line-height: 1.2;
  text-transform: uppercase;
}

.sanctuary-offers {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: clamp(0.65rem, 1.4vw, 1rem);
  width: min(100%, 390px);
  max-width: 100%;
  margin: 0;
}

.sanctuary-offer-tile {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  aspect-ratio: auto;
  min-width: 0;
  min-height: 78px;
  border: 1px solid color-mix(in srgb, var(--lumen-selector-accent-strong) 42%, transparent);
  border-radius: 16px;
  padding: 0.85rem 0.55rem;
  background:
    radial-gradient(circle at 50% 18%, color-mix(in srgb, var(--lumen-selector-accent-strong) 13%, transparent), transparent 56%),
    color-mix(in srgb, var(--lumen-selector-node-bg) 46%, rgba(0, 0, 0, 0.34));
  box-shadow:
    inset 0 0 18px rgba(255, 255, 255, 0.025),
    0 0 18px color-mix(in srgb, var(--lumen-selector-glow) 7%, transparent);
  transition:
    transform 180ms ease,
    border-color 180ms ease,
    box-shadow 180ms ease,
    background 180ms ease;
}

.sanctuary-offer-tile:hover,
.sanctuary-offer-tile:focus-within {
  transform: translateY(-4px);
  border-color: color-mix(in srgb, var(--lumen-selector-accent-strong) 78%, var(--lumen-selector-text));
  background:
    radial-gradient(circle at 50% 18%, color-mix(in srgb, var(--lumen-selector-accent-strong) 18%, transparent), transparent 58%),
    color-mix(in srgb, var(--lumen-selector-node-bg) 52%, rgba(0, 0, 0, 0.28));
  box-shadow:
    0 0 26px color-mix(in srgb, var(--lumen-selector-glow) 24%, transparent),
    inset 0 0 20px rgba(255, 255, 255, 0.04);
}

.sanctuary-offer-icon {
  display: block;
  width: clamp(42px, 4.6vw, 60px);
  height: clamp(42px, 4.6vw, 60px);
  object-fit: contain;
  background: transparent;
  mix-blend-mode: normal;
  filter:
    drop-shadow(0 0 8px color-mix(in srgb, var(--lumen-selector-glow) 52%, transparent))
    drop-shadow(0 0 14px color-mix(in srgb, var(--lumen-selector-accent-strong) 18%, transparent));
}

.sanctuary-offer-label {
  display: block;
  max-width: 100%;
  color: color-mix(in srgb, var(--lumen-selector-text) 88%, var(--navbar-text));
  font-family: var(--body-font);
  font-size: clamp(0.66rem, 0.9vw, 0.76rem);
  font-weight: 800;
  letter-spacing: 0.025em;
  line-height: 1.2;
  text-align: center;
  text-transform: uppercase;
  white-space: nowrap;
}

.sanctuary-portal-frame figcaption {
  display: none;
}

.sanctuary-portal-frame.is-missing {
  width: min(90vw, 420px);
  aspect-ratio: 2 / 3;
  place-items: center;
  border-radius: 22px;
  background:
    radial-gradient(circle, color-mix(in srgb, var(--lumen-selector-accent-strong) 20%, transparent), transparent 62%),
    color-mix(in srgb, var(--lumen-selector-node-bg) 44%, transparent);
}

.sanctuary-portal-frame.is-missing figcaption {
  display: grid;
  place-items: center;
}

.sanctuary-portal-frame.is-missing figcaption span {
  display: grid;
  width: clamp(110px, 18vw, 180px);
  aspect-ratio: 1;
  place-items: center;
  border: 1px solid color-mix(in srgb, var(--lumen-selector-accent-strong) 34%, transparent);
  border-radius: 50%;
  color: var(--lumen-selector-accent-strong);
  background:
    radial-gradient(circle, color-mix(in srgb, var(--lumen-selector-accent-strong) 22%, transparent), transparent 60%),
    rgba(255, 255, 255, 0.055);
  box-shadow: 0 0 28px color-mix(in srgb, var(--lumen-selector-glow) 42%, transparent);
  font-family: var(--heading-font);
  font-size: clamp(3.5rem, 9vw, 6.5rem);
}

.sanctuary-portal-controls {
  display: grid;
  grid-template-columns: minmax(88px, auto) minmax(84px, auto) minmax(88px, auto);
  gap: clamp(0.7rem, 2vw, 1rem);
  align-items: center;
  justify-content: center;
  width: min(100% - 2rem, 1180px);
  max-width: 100%;
  margin-top: 2px;
}

.sanctuary-portal-control {
  min-height: 36px;
  border: 1px solid color-mix(in srgb, var(--lumen-selector-accent) 42%, transparent);
  border-radius: 999px;
  padding: 0 14px;
  color: color-mix(in srgb, var(--lumen-selector-text) 84%, var(--navbar-text));
  background:
    linear-gradient(135deg, color-mix(in srgb, var(--lumen-selector-accent-strong) 8%, transparent), transparent 52%),
    color-mix(in srgb, var(--lumen-selector-node-bg) 62%, transparent);
  box-shadow: 0 0 12px color-mix(in srgb, var(--lumen-selector-glow) 18%, transparent);
  cursor: pointer;
  font-family: var(--body-font);
  font-size: 0.82rem;
  font-weight: 800;
}

.sanctuary-portal-control:hover,
.sanctuary-portal-control:focus-visible,
.sanctuary-portal-segment:hover,
.sanctuary-portal-segment:focus-visible {
  border-color: color-mix(in srgb, var(--lumen-selector-accent-strong) 80%, white);
  outline: none;
  box-shadow: 0 0 18px color-mix(in srgb, var(--lumen-selector-glow) 48%, transparent);
}

.sanctuary-portal-progress {
  display: flex;
  gap: 7px;
  align-items: center;
  justify-content: center;
  min-width: 104px;
}

.sanctuary-portal-segment {
  width: 22px;
  height: 3px;
  border: 1px solid color-mix(in srgb, var(--lumen-selector-accent) 48%, transparent);
  border-radius: 999px;
  padding: 0;
  background: color-mix(in srgb, var(--lumen-selector-node-bg) 70%, transparent);
  box-shadow: 0 0 8px color-mix(in srgb, var(--lumen-selector-glow) 18%, transparent);
  cursor: pointer;
}

.sanctuary-portal-segment.is-active {
  width: 34px;
  background: color-mix(in srgb, var(--lumen-selector-accent-strong) 82%, white);
  box-shadow: 0 0 14px color-mix(in srgb, var(--lumen-selector-glow) 58%, transparent);
}

@keyframes sanctuaryPortalReveal {
  from {
    opacity: 0;
    transform: translateY(8px) scale(0.992);
  }

  to {
    opacity: 1;
    transform: translateY(-2px) scale(1);
  }
}

.lumen-enter-button {
  min-height: 42px;
  border: 1px solid color-mix(in srgb, var(--lumen-selector-accent) 42%, transparent);
  border-radius: 999px;
  padding: 0 16px;
  color: color-mix(in srgb, var(--lumen-selector-text) 86%, var(--navbar-text));
  background:
    linear-gradient(135deg, color-mix(in srgb, var(--lumen-selector-accent-strong) 10%, transparent), transparent 48%),
    color-mix(in srgb, var(--lumen-selector-node-bg) 82%, transparent);
  box-shadow: 0 0 14px color-mix(in srgb, var(--lumen-selector-glow) 28%, transparent);
  cursor: pointer;
  font-family: var(--body-font);
  font-weight: 800;
}

.lumen-enter-button {
  border-color: color-mix(in srgb, var(--lumen-selector-accent-strong) 82%, transparent);
  padding-inline: 20px;
  color: var(--lumen-selector-cta-text);
  background: var(--lumen-selector-cta-bg);
  box-shadow:
    0 0 24px var(--lumen-selector-glow),
    inset 0 1px 0 rgba(255, 255, 255, 0.48);
}

.lumen-enter-button::after {
  content: " ✦";
}

.lumen-enter-button:hover,
.lumen-enter-button:focus-visible {
  border-color: color-mix(in srgb, var(--lumen-selector-accent-strong) 92%, white);
  outline: none;
  box-shadow:
    0 0 28px var(--lumen-selector-glow),
    inset 0 1px 0 rgba(255, 255, 255, 0.5);
  transform: translateY(-1px);
}

.lumen-sanctuary-interior {
  display: grid;
  min-width: 0;
  border: 0;
  border-radius: 0;
  padding: clamp(28px, 5vw, 56px) clamp(6px, 2vw, 16px) clamp(20px, 4vw, 42px);
  background: transparent;
  box-shadow: none;
}

.lumen-sanctuary-interior[hidden] {
  display: none;
}

.lumen-interior-shell {
  display: grid;
  gap: clamp(28px, 4vw, 44px);
  width: min(100%, 1120px);
  margin: 0 auto;
  color: #fff2d1;
}

.lumen-interior-header {
  display: grid;
  gap: clamp(14px, 2vw, 20px);
  justify-items: start;
  min-width: 0;
}

.lumen-interior-eyebrow {
  display: flex;
  gap: 14px;
  align-items: center;
  margin: 0;
  color: color-mix(in srgb, var(--lumen-selector-accent-strong) 86%, white);
  font-family: var(--logo-font);
  font-size: clamp(0.72rem, 1.1vw, 0.84rem);
  letter-spacing: 0.32em;
  line-height: 1.2;
  text-transform: uppercase;
}

.lumen-interior-eyebrow i {
  position: relative;
  display: block;
  width: clamp(74px, 8vw, 112px);
  height: 1px;
  background: linear-gradient(90deg, color-mix(in srgb, var(--lumen-selector-accent) 80%, transparent), transparent);
}

.lumen-interior-eyebrow i::after {
  content: "✥";
  position: absolute;
  top: 50%;
  left: 68%;
  color: color-mix(in srgb, var(--lumen-selector-accent-strong) 76%, white);
  font-size: 0.74rem;
  line-height: 1;
  text-shadow: 0 0 10px var(--lumen-selector-glow);
  transform: translate(-50%, -50%);
}

.lumen-interior-header h2 {
  max-width: 100%;
  margin: 0;
  color: color-mix(in srgb, #fff7df 92%, var(--lumen-selector-accent-strong));
  font-family: var(--heading-font);
  font-size: clamp(3.1rem, 7.2vw, 6.2rem);
  font-weight: 500;
  letter-spacing: 0;
  line-height: 0.9;
  text-shadow:
    0 0 24px color-mix(in srgb, var(--lumen-selector-glow) 26%, transparent),
    0 3px 20px rgba(0, 0, 0, 0.24);
}

.lumen-interior-intro {
  display: grid;
  gap: 10px;
  max-width: 82ch;
}

.lumen-interior-intro p {
  margin: 0;
  color: color-mix(in srgb, #fff2d1 82%, var(--navbar-muted));
  font-family: var(--font-body-serif);
  font-size: clamp(1.34rem, 2.1vw, 1.82rem);
  line-height: 1.45;
}

.lumen-interior-panel-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: clamp(20px, 2.4vw, 28px);
  align-items: stretch;
  min-width: 0;
  padding-top: clamp(28px, 4vw, 42px);
}

.lumen-interior-panel {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: clamp(16px, 2vw, 22px);
  align-items: center;
  min-height: clamp(300px, 30vw, 390px);
  min-width: 0;
  border: 1px solid color-mix(in srgb, var(--lumen-selector-accent) 58%, rgba(255, 255, 255, 0.18));
  border-radius: 18px;
  padding: clamp(70px, 7vw, 88px) clamp(24px, 4vw, 54px) clamp(34px, 4vw, 48px);
  background:
    radial-gradient(circle at 50% 10%, color-mix(in srgb, var(--lumen-selector-accent-strong) 7%, transparent), transparent 48%),
    rgba(18, 24, 28, 0.24);
  box-shadow:
    inset 0 1px 0 rgba(255, 246, 218, 0.09),
    0 0 20px color-mix(in srgb, var(--lumen-selector-glow) 10%, transparent);
  text-align: center;
}

.lumen-interior-panel::before,
.lumen-interior-panel::after {
  content: "";
  position: absolute;
  top: -1px;
  width: clamp(72px, 10vw, 148px);
  height: 1px;
  background: linear-gradient(90deg, transparent, color-mix(in srgb, var(--lumen-selector-accent) 78%, transparent));
}

.lumen-interior-panel::before {
  right: calc(50% + 44px);
}

.lumen-interior-panel::after {
  left: calc(50% + 44px);
  transform: scaleX(-1);
}

.lumen-interior-panel__badge {
  position: absolute;
  top: 0;
  left: 50%;
  display: grid;
  width: clamp(78px, 8vw, 96px);
  aspect-ratio: 1;
  place-items: center;
  border: 1px solid color-mix(in srgb, var(--lumen-selector-accent) 58%, transparent);
  border-radius: 50%;
  background:
    radial-gradient(circle, color-mix(in srgb, var(--lumen-selector-accent-strong) 13%, transparent), transparent 62%),
    rgba(20, 24, 24, 0.54);
  box-shadow:
    0 0 18px color-mix(in srgb, var(--lumen-selector-glow) 22%, transparent),
    inset 0 0 22px color-mix(in srgb, var(--lumen-selector-accent) 7%, transparent);
  transform: translate(-50%, -50%);
}

.lumen-interior-panel__badge span {
  color: color-mix(in srgb, var(--lumen-selector-accent-strong) 88%, white);
  font-size: clamp(1.75rem, 2.6vw, 2.35rem);
  line-height: 1;
  text-shadow: 0 0 12px color-mix(in srgb, var(--lumen-selector-glow) 52%, transparent);
}

.lumen-scroll-glyph {
  display: block;
  width: clamp(2.2rem, 3.2vw, 2.75rem);
  aspect-ratio: 1;
  background: currentColor;
  filter: drop-shadow(0 0 10px color-mix(in srgb, var(--lumen-selector-glow) 62%, transparent));
  mask: url("../assets/icons/zodiac/scroll-icon.svg") center / contain no-repeat;
  -webkit-mask: url("../assets/icons/zodiac/scroll-icon.svg") center / contain no-repeat;
}

.lumen-interior-panel__label {
  margin: 0;
  color: color-mix(in srgb, var(--lumen-selector-accent-strong) 84%, white);
  font-family: var(--logo-font);
  font-size: clamp(0.78rem, 1.1vw, 0.9rem);
  letter-spacing: 0.32em;
  line-height: 1.2;
  text-transform: uppercase;
}

.lumen-interior-panel h3,
.lumen-interior-panel blockquote {
  max-width: 16ch;
  margin: 0;
  color: color-mix(in srgb, #fff8e7 92%, var(--lumen-selector-accent-strong));
  font-family: var(--heading-font);
  font-size: clamp(2.15rem, 4.1vw, 3.65rem);
  font-weight: 500;
  letter-spacing: 0;
  line-height: 1.02;
  text-shadow: 0 0 18px color-mix(in srgb, var(--lumen-selector-glow) 22%, transparent);
}

.lumen-interior-panel blockquote {
  max-width: 23ch;
  font-size: clamp(2rem, 3vw, 3.05rem);
  line-height: 1.18;
}

.lumen-interior-panel--scroll h3 {
  max-width: 18ch;
}

.lumen-interior-panel__copy {
  max-width: 34ch;
  margin: 0;
  color: color-mix(in srgb, #fff2d1 74%, var(--navbar-muted));
  font-family: var(--font-body-serif);
  font-size: clamp(1.2rem, 1.75vw, 1.52rem);
  line-height: 1.48;
}

.lumen-interior-panel__divider {
  position: relative;
  width: min(100%, 240px);
  height: 1px;
  margin-block: -2px;
  background: linear-gradient(90deg, transparent, color-mix(in srgb, var(--lumen-selector-accent) 64%, transparent), transparent);
}

.lumen-interior-panel__divider::after {
  content: "✦";
  position: absolute;
  top: 50%;
  left: 50%;
  color: color-mix(in srgb, var(--lumen-selector-accent-strong) 82%, white);
  font-size: 0.82rem;
  line-height: 1;
  text-shadow: 0 0 12px var(--lumen-selector-glow);
  transform: translate(-50%, -50%);
}

.lumen-interior-action {
  display: inline-flex;
  gap: 12px;
  align-items: center;
  justify-content: center;
  margin-top: auto;
  min-width: min(100%, 240px);
  min-height: 54px;
  border: 1px solid color-mix(in srgb, var(--lumen-selector-accent-strong) 62%, transparent);
  border-radius: 999px;
  padding: 0 22px;
  color: color-mix(in srgb, #ffe8af 92%, white);
  background: rgba(20, 22, 20, 0.34);
  box-shadow:
    0 0 16px color-mix(in srgb, var(--lumen-selector-glow) 18%, transparent),
    inset 0 1px 0 rgba(255, 246, 218, 0.1);
  cursor: pointer;
  font-family: "Cormorant Garamond", Georgia, serif;
  font-size: clamp(1.03rem, 1.35vw, 1.18rem);
  font-weight: 700;
  line-height: 1;
}

.lumen-interior-action span {
  font-family: var(--body-font);
  font-size: 1rem;
  line-height: 1;
}

.lumen-interior-action .lumen-scroll-glyph--button {
  width: 1.1rem;
  color: inherit;
}

.lumen-interior-action:hover,
.lumen-interior-action:focus-visible,
.lumen-return-button:hover,
.lumen-return-button:focus-visible {
  border-color: color-mix(in srgb, var(--lumen-selector-accent-strong) 88%, white);
  outline: none;
  box-shadow:
    0 0 24px color-mix(in srgb, var(--lumen-selector-glow) 36%, transparent),
    inset 0 1px 0 rgba(255, 246, 218, 0.18);
  transform: translateY(-1px);
}

.lumen-sanctuary-return-row {
  display: flex;
  justify-content: flex-start;
  min-width: 0;
}

.lumen-return-button {
  display: inline-flex;
  gap: 12px;
  align-items: center;
  border: 0;
  padding: 0;
  color: color-mix(in srgb, #ffe8af 90%, white);
  background: transparent;
  box-shadow: none;
  cursor: pointer;
  font-family: "Cormorant Garamond", Georgia, serif;
  font-size: clamp(1.06rem, 1.55vw, 1.28rem);
  font-weight: 700;
  line-height: 1;
}

.lumen-return-button span {
  display: grid;
  width: 42px;
  aspect-ratio: 1;
  place-items: center;
  border: 1px solid color-mix(in srgb, var(--lumen-selector-accent-strong) 62%, transparent);
  border-radius: 50%;
  font-family: var(--body-font);
  font-size: 1rem;
  box-shadow: 0 0 14px color-mix(in srgb, var(--lumen-selector-glow) 18%, transparent);
}

.lumen-interior-flourish {
  display: grid;
  grid-template-columns: minmax(80px, 1fr) auto minmax(80px, 1fr);
  gap: 14px;
  align-items: center;
  justify-self: center;
  width: min(100%, 360px);
  margin-top: -16px;
  color: color-mix(in srgb, var(--lumen-selector-accent-strong) 78%, white);
}

.lumen-interior-flourish::before,
.lumen-interior-flourish::after {
  content: "";
  height: 1px;
  background: linear-gradient(90deg, transparent, color-mix(in srgb, var(--lumen-selector-accent) 62%, transparent));
}

.lumen-interior-flourish::after {
  transform: scaleX(-1);
}

.lumen-interior-flourish span {
  display: grid;
  width: 28px;
  aspect-ratio: 1;
  place-items: center;
}

.lumen-interior-flourish span::before {
  content: "✧";
  font-size: 1.45rem;
  line-height: 1;
  text-shadow: 0 0 12px var(--lumen-selector-glow);
}

body.is-lumen-image-lightbox-open {
  overflow: hidden;
}

/* Reusable expanded artwork viewer for full Lumen card images. */
.lumen-image-lightbox {
  position: fixed;
  inset: 0;
  z-index: 1200;
  display: none;
  place-items: center;
  padding: clamp(14px, 3vw, 28px);
}

.lumen-image-lightbox.is-open {
  display: grid;
}

.lumen-image-lightbox__backdrop {
  position: absolute;
  inset: 0;
  border: 0;
  background:
    radial-gradient(circle at 50% 38%, color-mix(in srgb, var(--navbar-glow) 24%, transparent), transparent 42%),
    rgba(7, 6, 12, 0.82);
  cursor: zoom-out;
}

.lumen-image-lightbox__dialog {
  position: relative;
  z-index: 1;
  display: grid;
  max-width: min(94vw, 980px);
  max-height: 94vh;
  min-width: 0;
  justify-items: center;
  border: 0;
  border-radius: 0;
  padding: 0;
  background: transparent;
  box-shadow: none;
}

.lumen-image-lightbox__close {
  position: absolute;
  top: clamp(-12px, -1.4vw, -8px);
  right: clamp(-12px, -1.4vw, -8px);
  z-index: 2;
  display: grid;
  width: 44px;
  min-height: 44px;
  place-items: center;
  border: 0;
  border-radius: 0;
  padding: 0;
  color: #050505;
  background: transparent;
  box-shadow: none;
  cursor: pointer;
  font-size: 2.45rem;
  font-weight: 300;
  line-height: 1;
  text-shadow: 0 0 10px rgba(255, 255, 255, 0.42);
}

.lumen-image-lightbox__close:focus-visible,
.lumen-image-lightbox__close:hover {
  outline: none;
  box-shadow: 0 0 24px color-mix(in srgb, var(--navbar-glow) 62%, transparent);
}

.lumen-image-lightbox__image {
  display: block;
  max-width: 90vw;
  max-height: 86vh;
  width: auto;
  height: auto;
  object-fit: contain;
  border-radius: 18px;
  box-shadow: 0 0 28px color-mix(in srgb, var(--navbar-glow) 44%, transparent);
}

body.sun-mode .lumen-archive__hero,
body.sun-mode .lumen-atrium {
  border-color: rgba(199, 142, 43, 0.3);
  background:
    radial-gradient(circle at 22% 18%, rgba(255, 219, 138, 0.24), transparent 42%),
    radial-gradient(circle at 88% 18%, rgba(255, 255, 255, 0.12), transparent 30%),
    linear-gradient(135deg, rgba(255, 249, 224, 0.18), transparent 52%),
    rgba(55, 32, 12, 0.68);
}

body.sun-mode .lumen-archive__hero,
body.sun-mode .lumen-atrium {
  border: 0;
  background: none;
  box-shadow: none;
}

body.sun-mode .lumen-featured-image,
body.sun-mode .lumen-atrium__image,
body.sun-mode .lumen-info-box {
  border-color: rgba(255, 213, 116, 0.22);
}

body.sun-mode .lumen-sanctuary-tab:nth-child(2n) {
  background: transparent;
}

body.moon-mode .lumen-archive__hero,
body.moon-mode .lumen-atrium {
  border-color: rgba(180, 200, 235, 0.24);
  background:
    radial-gradient(circle at 22% 18%, rgba(197, 219, 255, 0.14), transparent 42%),
    radial-gradient(circle at 88% 18%, rgba(160, 125, 218, 0.12), transparent 30%),
    linear-gradient(135deg, rgba(255, 255, 255, 0.1), transparent 52%),
    rgba(13, 9, 32, 0.78);
}

body.moon-mode .lumen-archive__hero,
body.moon-mode .lumen-atrium {
  border: 0;
  background: none;
  box-shadow: none;
}

body.moon-mode .lumen-featured-image,
body.moon-mode .lumen-atrium__image,
body.moon-mode .lumen-info-box {
  border-color: rgba(197, 219, 255, 0.18);
}

body.moon-mode .lumen-sanctuary-tab:nth-child(2n) {
  background: transparent;
}

body.blood-moon-mode .lumen-archive {
  filter: saturate(0.88);
}

/* Reassert the selector variables after the broader page theme blocks above. */
body.sun-mode .lumen-sanctuary__rail,
body.moon-mode .lumen-sanctuary__rail {
  border: 0;
  background: transparent;
  box-shadow: none;
}

body.sun-mode .lumen-sanctuary-tab,
body.moon-mode .lumen-sanctuary-tab {
  border-color: transparent;
  background: transparent;
  box-shadow: none;
}

body.sun-mode .lumen-sanctuary-tab:hover,
body.sun-mode .lumen-sanctuary-tab:focus-visible,
body.sun-mode .lumen-sanctuary-tab.is-active,
body.moon-mode .lumen-sanctuary-tab:hover,
body.moon-mode .lumen-sanctuary-tab:focus-visible,
body.moon-mode .lumen-sanctuary-tab.is-active {
  border-color: transparent;
  box-shadow: none;
}

body.sun-mode .lumen-sanctuary-viewer,
body.moon-mode .lumen-sanctuary-viewer {
  border: 0;
  background: transparent;
  box-shadow: none;
}

@media (min-width: 768px) and (max-width: 980px) {
  .sanctuary-room-showcase {
    display: flex;
    width: min(100%, 100vw);
    max-width: 100%;
    overflow-x: auto;
    overflow-y: hidden;
    gap: 1rem;
    padding: 0 1rem 0.75rem;
    scroll-padding-inline: 1rem;
    scroll-snap-type: x mandatory;
    scrollbar-width: thin;
    scrollbar-color:
      color-mix(in srgb, var(--lumen-showcase-scroll-thumb) 88%, var(--lumen-showcase-scroll-thumb-strong))
      transparent;
    -webkit-overflow-scrolling: touch;
  }

  .sanctuary-room-showcase::-webkit-scrollbar {
    height: 6px;
  }

  .sanctuary-room-showcase::-webkit-scrollbar-track {
    border-radius: 999px;
    background:
      linear-gradient(
        90deg,
        transparent,
        var(--lumen-showcase-scroll-track) 18%,
        var(--lumen-showcase-scroll-track) 82%,
        transparent
      );
  }

  .sanctuary-room-showcase::-webkit-scrollbar-thumb {
    border-radius: 999px;
    background:
      linear-gradient(
        90deg,
        transparent,
        color-mix(in srgb, var(--lumen-showcase-scroll-thumb) 78%, transparent) 14%,
        var(--lumen-showcase-scroll-thumb-strong) 50%,
        color-mix(in srgb, var(--lumen-showcase-scroll-thumb) 78%, transparent) 86%,
        transparent
      );
    box-shadow:
      0 0 10px color-mix(in srgb, var(--lumen-showcase-scroll-thumb) 62%, transparent),
      0 0 18px color-mix(in srgb, var(--lumen-showcase-scroll-thumb-strong) 32%, transparent);
  }

  .sanctuary-room-showcase::-webkit-scrollbar-button {
    display: none;
  }

  .sanctuary-room-showcase__visual,
  .sanctuary-room-showcase__info {
    flex: 0 0 min(86vw, 520px);
    scroll-snap-align: center;
  }

  .sanctuary-room-showcase__info {
    min-height: 500px;
  }

  .sanctuary-room-showcase .sanctuary-portal-frame {
    width: min(100%, 380px);
  }
}

@media (max-width: 980px) {
  .lumen-hero {
    min-height: auto;
    background-position: 62% center;
  }

  .lumen-hero__inner {
    min-height: clamp(500px, 68vw, 620px);
    padding: clamp(22px, 4vw, 34px);
  }

  .lumen-hero__content {
    width: min(100%, 640px);
  }

  .lumen-hero__features {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    width: min(100%, 520px);
  }

  .lumen-archive__hero {
    grid-template-columns: 1fr;
  }

  .lumen-sigil {
    width: min(62vw, 240px);
  }

  .lumen-atrium {
    grid-template-columns: minmax(220px, 0.82fr) minmax(0, 1fr);
    column-gap: clamp(14px, 2.4vw, 24px);
  }

  .lumen-atrium__title h2 {
    font-size: clamp(2.9rem, 7vw, 4.75rem);
  }

  .lumen-info-grid {
    grid-template-columns: 1fr;
  }

  .lumen-sanctuary__rail {
    display: block;
    min-height: 0;
    overflow-x: auto;
    overflow-y: hidden;
    padding: 30px 18px 18px;
    scroll-padding-inline: 18px;
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
  }

  .lumen-sanctuary__rail::before,
  .lumen-sanctuary__rail::after,
  .lumen-compass__rings,
  .lumen-compass__lines,
  .lumen-compass__center {
    display: none;
  }

  .lumen-compass {
    display: flex;
    width: max-content;
    min-width: 100%;
    height: auto;
    gap: 10px;
    align-items: end;
  }

  .lumen-sanctuary-tab,
  .lumen-sanctuary-tab--reflection-pool,
  .lumen-sanctuary-tab--sanctuary-of-breath,
  .lumen-sanctuary-tab--garden-of-renewal,
  .lumen-sanctuary-tab--rooted-grove,
  .lumen-sanctuary-tab--hall-of-mirrors {
    position: relative;
    inset: auto;
    top: auto;
    right: auto;
    bottom: auto;
    left: auto;
    flex: 0 0 clamp(150px, 20vw, 190px);
    width: clamp(150px, 20vw, 190px);
    min-height: clamp(300px, 38vw, 390px);
    border: 0;
    border-radius: 0;
    padding: 30px 12px 24px;
    background: transparent;
    box-shadow: none;
    transform: none;
    scroll-snap-align: start;
  }

  .lumen-sanctuary-tab:hover,
  .lumen-sanctuary-tab:focus-visible,
  .lumen-sanctuary-tab.is-active,
  .lumen-sanctuary-tab--reflection-pool:hover,
  .lumen-sanctuary-tab--reflection-pool:focus-visible,
  .lumen-sanctuary-tab--reflection-pool.is-active {
    transform: translateY(-12px) scale(1.04);
  }

  .lumen-interior-panel-grid {
    grid-template-columns: 1fr;
    gap: clamp(44px, 8vw, 58px);
  }

  .lumen-interior-panel {
    min-height: 300px;
  }
}

@media (max-width: 640px) {
  .lumen-archive {
    gap: 16px;
  }

  .lumen-hero {
    border-radius: 20px;
    background-position: 68% center;
  }

  .lumen-hero::before {
    background:
      linear-gradient(180deg, rgba(0, 0, 0, 0.28), rgba(0, 0, 0, 0.14) 34%, rgba(0, 0, 0, 0.66)),
      linear-gradient(90deg, rgba(0, 0, 0, 0.46), rgba(0, 0, 0, 0.18));
  }

  .lumen-hero__inner {
    gap: 14px;
    min-height: 0;
    padding: 20px 18px 22px;
  }

  .lumen-hero__eyebrow-row {
    grid-template-columns: 34px auto 34px;
    gap: 8px;
    width: fit-content;
  }

  .lumen-hero__eyebrow-row p {
    font-size: 0.62rem;
    letter-spacing: 0.16em;
  }

  .lumen-hero__content {
    width: 100%;
  }

  .lumen-hero h1 {
    font-size: clamp(2.35rem, 12vw, 3.3rem);
    line-height: 0.86;
    white-space: normal;
  }

  .lumen-hero h2 {
    max-width: 14ch;
    font-size: clamp(1.32rem, 7vw, 1.75rem);
  }

  .lumen-hero__text > p:not(.lumen-hero__small-title) {
    max-width: 100%;
    font-size: 0.9rem;
    line-height: 1.52;
  }

  .lumen-hero__features {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px 8px;
    width: 100%;
  }

  .lumen-hero-feature {
    padding-inline: 4px;
  }

  .lumen-hero-feature strong {
    letter-spacing: 0.16em;
  }

  .lumen-hero__quote {
    grid-template-columns: 1fr;
    gap: 8px;
    font-size: 0.92rem;
    line-height: 1.32;
  }

  .lumen-hero__quote::before,
  .lumen-hero__quote::after {
    width: min(100%, 220px);
    justify-self: center;
  }

  .lumen-archive__hero {
    border-radius: 24px;
    padding: 24px;
  }

  .lumen-archive__hero::after {
    inset: 12px;
    border-radius: 18px;
  }

  .lumen-atrium {
    grid-template-columns: 1fr;
    grid-template-areas:
      "title"
      "image"
      "content"
      "form";
    border-radius: 24px;
    padding: 14px;
  }

  .lumen-atrium__title {
    width: min(100%, 440px);
    margin: 0 auto;
  }

  .lumen-atrium__title h2 {
    font-size: clamp(2.7rem, 13vw, 4rem);
  }

  .lumen-atrium__letter {
    border-radius: 20px;
    padding: 18px;
  }

  .lumen-name-entry {
    width: min(calc(100% - 1rem), 760px);
  }

  .lumen-name-form {
    grid-template-columns: 1fr;
    justify-items: center;
    width: 100%;
    border-radius: 24px;
    padding: clamp(1.25rem, 4vw, 2rem);
    text-align: center;
  }

  .lumen-name-form__fields,
  .lumen-name-form__message {
    width: 100%;
  }

  .lumen-name-form label {
    font-size: 0.66rem;
    letter-spacing: 0.13em;
  }

  .lumen-name-form input {
    flex: 0 1 auto;
    min-height: 48px;
    padding-inline: 13px;
    font-size: 0.95rem;
  }

  .lumen-name-form:has(.lumen-name-form__fields[hidden]) {
    grid-template-columns: 1fr;
  }

  .sanctuary-portal-preview {
    padding: clamp(1rem, 5vw, 1.6rem) 0;
  }

  .sanctuary-room-showcase {
    grid-template-columns: 1fr;
    gap: 1.2rem;
    width: min(100%, calc(100vw - 24px));
  }

  .sanctuary-room-showcase__visual,
  .sanctuary-room-showcase__info {
    width: 100%;
  }

  .sanctuary-room-showcase .sanctuary-portal-frame {
    width: min(100%, 330px);
  }

  .sanctuary-room-showcase__info {
    min-height: 0;
    border-radius: 22px;
    padding: clamp(1rem, 4.8vw, 1.35rem);
  }

  .sanctuary-room-showcase__info h2 {
    font-size: clamp(2rem, 9.8vw, 2.85rem);
  }

  .sanctuary-room-showcase__eyebrow {
    margin-bottom: 0.55rem;
    font-size: 0.66rem;
    letter-spacing: 0.16em;
  }

  .sanctuary-room-showcase__tagline {
    margin-top: 0.75rem;
    font-size: 0.96rem;
    line-height: 1.42;
  }

  .sanctuary-room-showcase__divider {
    margin: 0.9rem 0;
  }

  .sanctuary-room-showcase__description {
    gap: 0.58rem;
  }

  .sanctuary-room-showcase__description p {
    font-size: 0.86rem;
    line-height: 1.48;
  }

  .sanctuary-room-showcase__offers {
    gap: 0.55rem;
    margin: 0.95rem 0 1rem;
  }

  .sanctuary-room-showcase__offers p {
    font-size: 0.64rem;
    letter-spacing: 0.13em;
  }

  .sanctuary-offers {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.55rem;
    width: 100%;
    max-width: 360px;
  }

  .sanctuary-offer-tile {
    aspect-ratio: auto;
    min-height: 64px;
    border-radius: 12px;
    padding: 0.45rem 0.4rem;
  }

  .sanctuary-offer-icon {
    width: 26px;
    height: 26px;
  }

  .sanctuary-offer-label {
    font-size: 0.62rem;
    letter-spacing: 0.02em;
  }

  .sanctuary-portal-controls {
    width: min(100%, 330px);
    grid-template-columns: minmax(0, 1fr) auto minmax(0, 1fr);
    gap: 10px;
  }

  .sanctuary-portal-control {
    padding-inline: 10px;
  }

  .lumen-sanctuary-interior {
    padding: 28px 14px 16px;
  }

  .lumen-interior-shell {
    gap: 28px;
  }

  .lumen-interior-eyebrow {
    gap: 10px;
    letter-spacing: 0.24em;
  }

  .lumen-interior-eyebrow i {
    width: 72px;
  }

  .lumen-interior-header h2 {
    max-width: 10ch;
    font-size: clamp(2.55rem, 11vw, 3.65rem);
  }

  .lumen-interior-intro p {
    font-size: clamp(1.12rem, 5vw, 1.34rem);
  }

  .lumen-interior-panel-grid {
    gap: 48px;
    padding-top: 28px;
  }

  .lumen-interior-panel {
    min-height: 0;
    border-radius: 18px;
    padding: 58px 18px 28px;
  }

  .lumen-interior-panel::before,
  .lumen-interior-panel::after {
    width: 72px;
  }

  .lumen-interior-panel__badge {
    width: 72px;
  }

  .lumen-interior-panel__label {
    letter-spacing: 0.24em;
  }

  .lumen-interior-panel h3,
  .lumen-interior-panel blockquote {
    max-width: 16ch;
    font-size: clamp(2rem, 10vw, 2.75rem);
  }

  .lumen-interior-panel blockquote {
    max-width: 19ch;
  }

  .lumen-interior-action {
    width: min(100%, 260px);
  }

  .lumen-return-button {
    width: auto;
  }

  .lumen-interior-flourish {
    width: min(100%, 280px);
    margin-top: -8px;
  }

  .lumen-atrium__image {
    min-height: 300px;
  }

  .sanctuary-portal-image {
    max-height: 72vh;
  }

  .lumen-image-lightbox {
    padding: 10px;
  }

  .lumen-image-lightbox__dialog {
    max-width: 96vw;
    max-height: 94vh;
    border-radius: 20px;
  }

  .lumen-image-lightbox__image {
    max-width: 94vw;
    max-height: 88vh;
  }

  .lumen-atrium__image {
    width: min(100%, 330px);
    min-height: 0;
  }

  .lumen-name-form__row {
    flex-direction: column;
  }

  .lumen-name-form button {
    width: 100%;
    min-height: 48px;
    padding-inline: 14px;
    font-size: 0.9rem;
  }

  .lumen-name-form__change {
    width: min(100%, 240px);
  }

  .lumen-sanctuary__rail {
    display: grid;
    overflow: hidden;
    padding: 14px 0;
    scroll-snap-type: none;
  }

  .lumen-compass {
    display: grid;
    grid-template-columns: repeat(5, minmax(0, 1fr));
    width: 100%;
    min-width: 0;
    gap: clamp(4px, 1.2vw, 10px);
    justify-items: center;
    align-items: end;
  }

  .lumen-compass__center {
    position: relative;
    top: auto;
    left: auto;
    display: grid;
    width: 92px;
    margin: 2px 0 8px;
    transform: none;
  }

  .lumen-sanctuary-tab,
  .lumen-sanctuary-tab--reflection-pool,
  .lumen-sanctuary-tab--sanctuary-of-breath,
  .lumen-sanctuary-tab--garden-of-renewal,
  .lumen-sanctuary-tab--rooted-grove,
  .lumen-sanctuary-tab--hall-of-mirrors {
    width: 100%;
    min-height: clamp(270px, 38vw, 350px);
    aspect-ratio: auto;
    border: 0;
    border-radius: 0;
    padding: 28px 10px 22px;
    background: transparent;
    box-shadow: none;
  }

  .lumen-sanctuary-tab__copy {
    grid-template-columns: 1fr;
    column-gap: 0;
    text-align: center;
  }

  .lumen-sanctuary-tab__glyph {
    grid-row: span 2;
    align-self: center;
  }

  .lumen-sanctuary-tab__copy strong,
  .lumen-sanctuary-tab__copy em {
    justify-self: center;
    max-width: 13ch;
  }

  .lumen-enter-button {
    width: 100%;
  }
}

@media (max-width: 767px) {
  .lumen-name-form:has(.lumen-name-form__fields[hidden]) {
    grid-template-columns: 1fr;
    justify-items: center;
    gap: 12px;
    width: 100%;
    margin-inline: auto;
    border-radius: 24px;
    padding: 1.35rem 1.15rem;
  }

  .lumen-name-form:has(.lumen-name-form__fields[hidden]) .lumen-name-form__message {
    gap: 0.6rem;
    width: 100%;
    min-height: 0;
    padding-top: 0;
    font-size: clamp(0.98rem, 4.3vw, 1.08rem);
    line-height: 1.55;
    text-align: center;
  }

  .lumen-name-form:has(.lumen-name-form__fields[hidden]) .lumen-name-form__message span:first-child {
    font-weight: 700;
  }

  .lumen-name-form:has(.lumen-name-form__fields[hidden]) .lumen-name-form__change {
    justify-self: center;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: min(100%, 240px);
    min-height: 40px;
    margin-top: 0.25rem;
    border-radius: 999px;
  }

  .lumen-sanctuary__rail {
    display: block;
    width: min(100%, 100vw);
    max-width: 100%;
    overflow-x: auto;
    overflow-y: hidden;
    padding: 18px 0 26px;
    scroll-padding-inline: max(18px, calc((100vw - min(260px, 68vw)) / 2));
    scroll-snap-type: x mandatory;
    scrollbar-width: none;
    -webkit-overflow-scrolling: touch;
  }

  .lumen-sanctuary__rail::-webkit-scrollbar {
    display: none;
  }

  .lumen-sanctuary__rail::after {
    display: none;
  }

  .lumen-compass,
  .lumen-compass.lumen-compass--loop {
    display: flex;
    width: max-content;
    min-width: 0;
    gap: clamp(12px, 4vw, 18px);
    align-items: end;
    padding-inline: max(18px, calc((100vw - min(260px, 68vw)) / 2));
  }

  .lumen-sanctuary-tab,
  .lumen-sanctuary-tab--reflection-pool,
  .lumen-sanctuary-tab--sanctuary-of-breath,
  .lumen-sanctuary-tab--garden-of-renewal,
  .lumen-sanctuary-tab--rooted-grove,
  .lumen-sanctuary-tab--hall-of-mirrors {
    flex: 0 0 clamp(180px, 68vw, 260px);
    width: clamp(180px, 68vw, 260px);
    min-height: clamp(300px, 78vw, 380px);
    padding: 30px 14px 26px;
    scroll-snap-align: center;
    scroll-snap-stop: always;
  }

  .lumen-sanctuary-tab--featured,
  .lumen-sanctuary-tab.is-active {
    min-height: clamp(320px, 82vw, 400px);
  }

  .lumen-sanctuary-tab:hover,
  .lumen-sanctuary-tab:focus-visible,
  .lumen-sanctuary-tab.is-active,
  .lumen-sanctuary-tab--reflection-pool:hover,
  .lumen-sanctuary-tab--reflection-pool:focus-visible,
  .lumen-sanctuary-tab--reflection-pool.is-active {
    transform: translateY(-8px) scale(1.03);
  }

  .lumen-sanctuary-tab__icon,
  .lumen-sanctuary-tab--featured .lumen-sanctuary-tab__icon,
  .lumen-sanctuary-tab.is-active .lumen-sanctuary-tab__icon {
    width: clamp(96px, 30vw, 128px);
  }

  .lumen-sanctuary-tab__copy strong {
    font-size: clamp(1.65rem, 8vw, 2.35rem);
  }

  .lumen-sanctuary-tab__copy em {
    font-size: clamp(0.98rem, 4.4vw, 1.12rem);
  }

  .sanctuary-portal-preview {
    padding-top: clamp(1.25rem, 6vw, 2rem);
  }

  .sanctuary-mobile-guide {
    display: grid;
    gap: 4px;
    justify-items: center;
    max-width: min(100%, 330px);
    margin: 0 auto 2px;
    text-align: center;
  }

  .sanctuary-mobile-guide p,
  .sanctuary-mobile-guide span {
    margin: 0;
  }

  .sanctuary-mobile-guide p {
    color: color-mix(in srgb, var(--lumen-selector-text) 88%, var(--navbar-text));
    font-family: var(--heading-font);
    font-size: clamp(1.45rem, 8vw, 2.15rem);
    line-height: 1;
  }

  .sanctuary-mobile-guide span {
    color: color-mix(in srgb, var(--lumen-selector-muted) 82%, var(--navbar-muted));
    font-size: 0.88rem;
    font-weight: 700;
    line-height: 1.35;
  }
}

@media (min-width: 768px) {
  .lumen-name-form:has(.lumen-name-form__fields[hidden]) {
    grid-template-columns: minmax(0, 1fr) auto;
    align-items: end;
    justify-items: stretch;
    column-gap: clamp(1rem, 3vw, 2rem);
    row-gap: 0.65rem;
    text-align: left;
  }

  .lumen-name-form:has(.lumen-name-form__fields[hidden]) .lumen-name-entry__ornament {
    grid-column: 1 / -1;
    justify-self: center;
  }

  .lumen-name-form:has(.lumen-name-form__fields[hidden]) .lumen-name-form__message {
    grid-column: 1;
    justify-self: start;
    max-width: 44rem;
    text-align: left;
  }

  .lumen-name-form:has(.lumen-name-form__fields[hidden]) .lumen-name-form__change {
    grid-column: 2;
    justify-self: end;
    align-self: end;
    margin-top: 0;
  }

  .lumen-sanctuary__rail {
    display: grid;
    overflow: visible;
    padding: clamp(34px, 5vw, 66px) 0 clamp(16px, 3vw, 30px);
    scroll-snap-type: none;
  }

  .lumen-sanctuary__rail::after {
    display: block;
  }

  .lumen-compass {
    display: grid;
    grid-template-columns: repeat(5, minmax(0, 1fr));
    align-items: end;
    gap: clamp(6px, 1.2vw, 18px);
    width: min(100%, 1240px);
    min-width: 0;
    height: auto;
    justify-items: stretch;
  }

  .lumen-sanctuary-tab,
  .lumen-sanctuary-tab--reflection-pool,
  .lumen-sanctuary-tab--sanctuary-of-breath,
  .lumen-sanctuary-tab--garden-of-renewal,
  .lumen-sanctuary-tab--rooted-grove,
  .lumen-sanctuary-tab--hall-of-mirrors {
    position: relative;
    inset: auto;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    gap: clamp(22px, 3vw, 42px);
    width: 100%;
    min-height: clamp(330px, 35vw, 430px);
    border: 0;
    border-radius: 0;
    padding: clamp(34px, 4vw, 54px) clamp(10px, 1.7vw, 28px) clamp(24px, 3vw, 40px);
    background: transparent;
    box-shadow: none;
    aspect-ratio: auto;
    transform: none;
    scroll-snap-align: none;
  }

  .lumen-sanctuary-tab--featured {
    min-height: clamp(380px, 39vw, 500px);
  }

  .lumen-sanctuary-tab:hover,
  .lumen-sanctuary-tab:focus-visible,
  .lumen-sanctuary-tab.is-active,
  .lumen-sanctuary-tab--reflection-pool:hover,
  .lumen-sanctuary-tab--reflection-pool:focus-visible,
  .lumen-sanctuary-tab--reflection-pool.is-active {
    transform: translateY(-12px) scale(1.035);
  }

  .lumen-sanctuary-tab.is-active,
  .lumen-sanctuary-tab--reflection-pool.is-active {
    transform: translateY(-22px) scale(1.08);
  }
}

@media (min-width: 768px) and (max-width: 899px) {
  .lumen-compass {
    gap: 16px;
  }

  .lumen-sanctuary-tab,
  .lumen-sanctuary-tab--reflection-pool,
  .lumen-sanctuary-tab--sanctuary-of-breath,
  .lumen-sanctuary-tab--garden-of-renewal,
  .lumen-sanctuary-tab--rooted-grove,
  .lumen-sanctuary-tab--hall-of-mirrors {
    min-height: clamp(286px, 41vw, 340px);
    padding: 28px 8px 22px;
  }

  .lumen-sanctuary-tab--sanctuary-of-breath {
    grid-column: auto;
  }

  .lumen-sanctuary-tab__icon,
  .lumen-sanctuary-tab--featured .lumen-sanctuary-tab__icon {
    width: clamp(72px, 10vw, 94px);
  }

  .lumen-sanctuary-tab__copy strong {
    font-size: clamp(1.1rem, 2.5vw, 1.45rem);
  }

  .lumen-sanctuary-tab__copy em {
    font-size: 0.8rem;
  }
}
