/* Homepage-only styles extracted from site.css */
.home-page .mobile-nav-button,
.home-page .mobile-premium-strip,
.home-page .mobile-header-spacer,
.home-page .mobile-nav-panel-head,
.home-page .mobile-nav-close,
.home-page .mobile-nav-close-fab,
.home-page .mobile-nav-overlay,
.home-page .hero-mobile-cta {
  display: none;
}

.home-page .mobile-nav-toggle {
  position: absolute;
  width: 1px;
  height: 1px;
  margin: -1px;
  padding: 0;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
  opacity: 0;
  pointer-events: none;
}

.hero {
  position: relative;
  min-height: calc(100vh - 78px);
  padding: 0;
  background: #08090d;
  overflow: hidden;
}

.hero::before,
.hero::after {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
}

.hero::before {
  background:
    linear-gradient(90deg, rgba(7, 8, 12, 0.98) 0%, rgba(7, 8, 12, 0.92) 22%, rgba(7, 8, 12, 0.62) 38%, rgba(7, 8, 12, 0.22) 58%, rgba(7, 8, 12, 0.12) 72%, rgba(7, 8, 12, 0.58) 100%),
    linear-gradient(180deg, rgba(6, 7, 10, 0.32) 0%, rgba(6, 7, 10, 0.06) 18%, rgba(6, 7, 10, 0.38) 100%);
}

.hero::after {
  background:
    radial-gradient(circle at 72% 42%, rgba(216, 155, 89, 0.2), transparent 9%),
    radial-gradient(circle at 72% 43%, rgba(216, 155, 89, 0.08), transparent 24%),
    radial-gradient(circle at 54% 74%, rgba(255, 245, 224, 0.04), transparent 18%);
  filter: blur(20px);
  mix-blend-mode: screen;
}

.hero-media {
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 60% 48%, rgba(166, 110, 60, 0.22), transparent 18%),
    radial-gradient(circle at 76% 56%, rgba(94, 58, 30, 0.26), transparent 24%),
    linear-gradient(180deg, #07090d 0%, #0c0d10 42%, #120f0d 72%, #16100d 100%);
}

.hero-media picture {
  display: block;
  width: 100%;
  height: 100%;
}

.hero-media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: 70% center;
  filter: brightness(0.46) saturate(0.78) contrast(1.05);
  transform: scale(1.03);
}

.hero-layout {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: minmax(48px, 1fr) minmax(280px, 360px) minmax(72px, 0.26fr) minmax(220px, 320px) minmax(56px, 0.9fr);
  grid-template-rows: auto auto auto 1fr auto;
  align-items: end;
  gap: 0;
  min-height: calc(100vh - 78px);
  padding: 118px 0 74px;
}

.hero-copy-cover {
  position: relative;
}

.hero-copy-cover::before {
  content: "";
  position: absolute;
  inset: -16px -18px -12px -10px;
  background:
    radial-gradient(circle at 16% 18%, rgba(255, 246, 227, 0.04), transparent 14%),
    linear-gradient(180deg, rgba(7, 8, 12, 0.16), rgba(7, 8, 12, 0.06));
  filter: blur(8px);
  pointer-events: none;
  z-index: -1;
}

.hero-intro {
  grid-column: 1 / span 3;
  grid-row: 1;
  align-self: start;
  justify-self: start;
  width: fit-content;
  transform: translateY(-74px);
  margin-left: 20px;
}

.hero-headline {
  grid-column: 1 / span 4;
  grid-row: 2;
  align-self: start;
  justify-self: start;
  width: min(1040px, calc(100% - 100px));
  margin-top: 30px;
  margin-left: 20px;
}

.hero-support {
  grid-column: 1 / span 3;
  grid-row: 3;
  align-self: start;
  max-width: 520px;
  margin-top: 22px;
  margin-left: 20px;
}

.hero-meta-line {
  margin: 0 0 -2px;
  color: rgba(242, 233, 216, 0.78);
  font-family: var(--sans);
  font-size: 10px;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  white-space: nowrap;
}

.section-tag {
  display: inline-grid;
  margin: 0 0 12px;
  color: var(--paper);
}

#heroTagWrap[hidden] {
  display: none;
}

.section-tag span {
  display: inline-block;
  padding-left: 12px;
  position: relative;
  font-size: 10px;
  letter-spacing: 0.2em;
}

.section-tag span::before {
  content: "";
  position: absolute;
  left: 0;
  top: 50%;
  width: 5px;
  height: 5px;
  border-radius: 50%;
  background: var(--gold-soft);
  transform: translateY(-50%);
}

#heroTag:empty {
  display: none;
  padding-left: 0;
}

#heroTag:empty::before {
  display: none;
}

.hero-preface {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  margin: 0 0 14px;
  color: rgba(229, 214, 186, 0.76);
  font-family: var(--sans);
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.12em;
}

.hero-preface::before,
.hero-preface::after {
  content: "";
  width: 28px;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(217, 194, 154, 0.34), transparent);
}

.hero-preface span {
  white-space: nowrap;
}

.hero-headline h1 {
  margin: 0;
  max-width: 980px;
  font-family: var(--hero-title-display);
  font-size: clamp(32px, 4vw, 54px);
  font-weight: 600;
  line-height: 0.98;
  letter-spacing: -0.025em;
  text-shadow: 0 8px 20px rgba(0, 0, 0, 0.22);
}

.hero-title-line {
  display: block;
}

.hero-title-desktop-copy {
  display: inline;
}

.hero-title-mobile-line {
  display: none;
}

.hero-title-line--lead {
  white-space: nowrap;
}

.hero-sub,
.hero-note,
.intro-copy,
.stage-summary,
.volume p,
.pathway p,
.trust-copy p,
.trust-vow p,
.wish-copy p {
  color: var(--text-soft);
  font-family: var(--sans);
  font-size: 16px;
}

.hero-sub {
  max-width: none;
  margin: 0;
  color: rgba(246, 237, 220, 0.66);
  font-size: 12px;
  line-height: 1.58;
  text-shadow: 0 6px 18px rgba(0, 0, 0, 0.18);
}

.hero-actions {
  grid-column: 1 / span 4;
  grid-row: 5;
  justify-self: start;
  align-self: end;
  display: grid;
  grid-template-columns: repeat(2, minmax(280px, 1fr));
  gap: 18px 24px;
  align-items: stretch;
  margin-top: 0;
  margin-left: 20px;
  width: min(760px, calc(100% - 100px));
  max-width: 100%;
}

.ritual-entry {
  position: relative;
  display: grid;
  grid-template-columns: 38px minmax(0, 1fr);
  align-items: start;
  gap: 12px;
  min-height: 0;
  min-width: 0;
  width: 100%;
  padding: 10px 12px 14px 0;
  background: none;
  border: 0;
  box-shadow: none;
  transition: transform 220ms ease, opacity 220ms ease;
}

.ritual-entry::before,
.ritual-entry::after {
  content: "";
  position: absolute;
}

.ritual-entry::before {
  left: 10px;
  top: 6px;
  width: 54px;
  height: 54px;
  border-radius: 50%;
  background:
    radial-gradient(circle at 50% 50%, rgba(146, 55, 39, 0.14), transparent 58%),
    radial-gradient(circle at 56% 42%, rgba(255, 223, 195, 0.06), transparent 22%);
  filter: blur(8px);
  opacity: 0.54;
}

.ritual-entry::after {
  left: 68px;
  right: 18px;
  bottom: 10px;
  height: 2px;
  background: linear-gradient(90deg, rgba(217, 194, 154, 0.58), rgba(217, 194, 154, 0.22), rgba(217, 194, 154, 0));
  box-shadow: 0 0 14px rgba(217, 194, 154, 0.18);
  opacity: 0.82;
  transition: opacity 220ms ease, transform 220ms ease, box-shadow 220ms ease;
}

.ritual-entry:hover {
  transform: translateY(-3px);
}

.ritual-entry:hover::after {
  opacity: 1;
  transform: scaleX(1.04);
  box-shadow: 0 0 18px rgba(217, 194, 154, 0.26);
}

.ritual-entry-seal {
  width: 38px;
  height: 38px;
  display: grid;
  place-items: center;
  border-radius: 50%;
  border: 1px solid rgba(141, 59, 43, 0.34);
  color: #f2dfc8;
  font-size: 13px;
  background:
    radial-gradient(circle at 36% 32%, rgba(212, 113, 91, 0.18), transparent 42%),
    radial-gradient(circle at 50% 50%, rgba(255, 224, 193, 0.04), transparent 68%),
    linear-gradient(180deg, rgba(123, 47, 34, 0.78), rgba(68, 23, 18, 0.88));
  box-shadow:
    inset 0 0 12px rgba(255, 205, 180, 0.03),
    inset 0 1px 0 rgba(255, 238, 220, 0.08),
    0 10px 16px rgba(29, 10, 8, 0.16);
}

.ritual-entry-copy {
  display: grid;
  gap: 4px;
  padding-top: 3px;
}

.ritual-entry-copy strong {
  display: block;
  font-family: var(--hero-display);
  font-size: 18px;
  font-weight: 700;
  line-height: 1.08;
  letter-spacing: -0.03em;
  text-shadow: 0 6px 14px rgba(0, 0, 0, 0.18);
}

.ritual-entry-copy small {
  display: block;
  max-width: none;
  color: rgba(232, 218, 196, 0.62);
  font-family: var(--sans);
  font-size: 11px;
  line-height: 1.58;
  white-space: nowrap;
}

.hero-note {
  max-width: none;
  margin: 14px 0 0;
  padding-top: 12px;
  border-top: 1px solid rgba(185, 154, 98, 0.14);
  color: rgba(242, 229, 205, 0.52);
  font-size: 10px;
  line-height: 1.58;
  white-space: nowrap;
}

.hero-edge-copy {
  grid-column: 5;
  grid-row: 2 / span 2;
  align-self: center;
  justify-self: end;
  display: grid;
  gap: 8px;
  padding-top: 0;
  color: rgba(223, 209, 181, 0.34);
  font-family: var(--sans);
  font-size: 9px;
  letter-spacing: 0.14em;
  writing-mode: vertical-rl;
  text-orientation: upright;
  white-space: nowrap;
}

@keyframes heroGlowBreath {
  0%, 100% {
    opacity: 0.86;
  }
  50% {
    opacity: 1;
  }
}

.section-intro {
  display: grid;
  justify-items: center;
  gap: 12px;
  text-align: center;
  margin-bottom: 34px;
}

.section-intro h2 {
  margin: 0;
  font-family: var(--hero-title-display);
  font-size: clamp(36px, 4vw, 54px);
  line-height: 1.08;
}

.intro-copy { margin: 0; max-width: 760px; }

.questions-section .section-intro {
  justify-items: start;
  text-align: left;
  margin-bottom: 0;
}

.questions-section .section-intro h2 {
  max-width: none;
  font-size: clamp(40px, 4.2vw, 64px);
  line-height: 1.08;
  white-space: nowrap;
}

.questions-section .intro-copy {
  max-width: 44rem;
  font-size: 16px;
  line-height: 1.8;
}

.question-doorways {
  position: relative;
  margin-top: 36px;
  padding: 0;
  border-bottom: 0;
}

.question-doorways::before,
.question-doorways::after {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
}

.question-doorways::before {
  background:
    radial-gradient(circle at 18% 22%, rgba(106, 132, 188, 0.12), transparent 18%),
    radial-gradient(circle at 78% 12%, rgba(217, 194, 154, 0.08), transparent 16%),
    radial-gradient(circle at 82% 66%, rgba(126, 92, 174, 0.08), transparent 20%),
    radial-gradient(circle at 28% 78%, rgba(78, 112, 154, 0.08), transparent 16%);
  filter: blur(28px);
  opacity: 0.9;
  animation: cosmosDrift 18s ease-in-out infinite alternate;
}

.question-doorways::after {
  inset: 8% 10%;
  background-image:
    radial-gradient(circle, rgba(255, 244, 226, 0.95) 0 1px, transparent 1.6px),
    radial-gradient(circle, rgba(217, 194, 154, 0.82) 0 1.2px, transparent 1.8px),
    radial-gradient(circle, rgba(186, 209, 255, 0.8) 0 1px, transparent 1.8px),
    radial-gradient(circle, rgba(255, 244, 226, 0.9) 0 1.4px, transparent 2px);
  background-size: 180px 180px, 240px 240px, 320px 320px, 420px 420px;
  background-position: 10% 14%, 74% 18%, 30% 78%, 84% 70%;
  opacity: 0.42;
  animation: starlightPulse 6s ease-in-out infinite;
}

.question-tablist-shell {
  position: relative;
  padding: 22px 0 26px;
}

.question-tablist-mark {
  display: grid;
  gap: 6px;
  justify-items: center;
  margin-bottom: 18px;
  text-align: center;
}

.question-tablist-mark span {
  color: rgba(217, 194, 154, 0.88);
  font-size: 15px;
  letter-spacing: 0.26em;
}

.question-tablist-mark em {
  color: rgba(217, 194, 154, 0.54);
  font-family: var(--sans);
  font-size: 11px;
  letter-spacing: 0.22em;
  font-style: normal;
  text-transform: uppercase;
}

.question-tablist {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 14px;
}

.question-doorway-rail {
  display: contents;
}

.question-mobile-topic-stage {
  display: none;
}

.question-tablist .doorway {
  width: auto;
  max-width: none;
  min-height: 0;
  padding: 12px 18px;
  margin: 0;
  display: inline-grid;
  grid-template-columns: auto auto;
  align-items: center;
  gap: 3px 12px;
  text-align: left;
  background: rgba(9, 13, 19, 0.42);
  border: 1px solid rgba(185, 154, 98, 0.1);
  border-radius: 999px;
  box-shadow: inset 0 1px 0 rgba(255, 244, 226, 0.03);
  backdrop-filter: blur(10px);
  overflow: visible;
  filter: none;
}

.question-tablist .doorway::before,
.question-tablist .doorway::after,
.question-tablist .doorway-seal::before {
  display: none;
}

.question-tablist .doorway:hover,
.question-tablist .doorway.is-active {
  transform: translateY(-2px);
  background: rgba(14, 20, 28, 0.74);
  border-color: rgba(217, 194, 154, 0.24);
  box-shadow:
    inset 0 1px 0 rgba(255, 244, 226, 0.06),
    0 12px 28px rgba(0, 0, 0, 0.16);
}

.question-tablist .doorway-seal {
  grid-row: 1 / span 2;
  width: 34px;
  height: 34px;
  border-radius: 50%;
}

.doorway-title {
  color: rgba(244, 236, 220, 0.96);
  font-size: 16px;
  line-height: 1.2;
  letter-spacing: 0.06em;
}

.doorway-sub {
  color: rgba(217, 194, 154, 0.58);
  font-family: var(--sans);
  font-size: 10px;
  line-height: 1.2;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}

.question-compass-frame {
  position: relative;
  min-height: 760px;
  padding: 34px;
  display: grid;
  grid-template-columns: minmax(180px, 1fr) minmax(220px, 0.9fr) minmax(180px, 1fr);
  grid-template-rows: minmax(174px, auto) minmax(250px, auto) minmax(174px, auto);
  grid-template-areas:
    ". north ."
    "west core east"
    ". south .";
  align-items: center;
  background:
    radial-gradient(circle at 67% 16%, rgba(255, 245, 220, 0.2), rgba(255, 245, 220, 0.08) 7%, transparent 14%),
    radial-gradient(circle at 66% 17%, rgba(255, 245, 220, 0.08), transparent 18%),
    radial-gradient(circle at 50% 50%, rgba(98, 127, 171, 0.1), transparent 48%),
    radial-gradient(circle at 50% 50%, rgba(217, 194, 154, 0.11), transparent 22%),
    radial-gradient(circle at 50% 50%, rgba(217, 194, 154, 0.05), transparent 42%),
    radial-gradient(circle at 50% 50%, rgba(8, 11, 16, 0.2), rgba(8, 11, 16, 0) 70%),
    linear-gradient(180deg, rgba(5, 8, 14, 0.84), rgba(8, 12, 18, 0.68));
  overflow: hidden;
}

.question-compass-frame::before,
.question-compass-frame::after {
  content: "";
  position: absolute;
  inset: 50%;
  transform: translate(-50%, -50%);
  border-radius: 50%;
  pointer-events: none;
}

.question-compass-frame::before {
  width: min(78%, 700px);
  aspect-ratio: 1;
  border: 20px solid rgba(142, 118, 74, 0.1);
  box-shadow:
    inset 0 0 0 1px rgba(255, 244, 226, 0.05),
    0 0 80px rgba(0, 0, 0, 0.16);
}

.question-compass-frame::after {
  width: min(60%, 520px);
  aspect-ratio: 1;
  border: 1px solid rgba(185, 154, 98, 0.08);
  opacity: 0.5;
}

.question-compass-frame > .orbit-outer::before,
.question-compass-frame > .orbit-outer::after,
.question-compass-frame > .orbit-inner::before,
.question-compass-frame > .orbit-inner::after {
  content: "";
  position: absolute;
  border-radius: 50%;
  pointer-events: none;
}

.orbit-outer,
.orbit-inner {
  position: absolute;
  inset: 50%;
  border-radius: 50%;
  transform: translate(-50%, -50%);
  pointer-events: none;
}

.orbit-outer {
  width: min(82%, 704px);
  aspect-ratio: 1;
  border: 1px solid rgba(185, 154, 98, 0.06);
  opacity: 0.18;
  animation: slowSpin 42s linear infinite;
}

.orbit-inner {
  width: min(36%, 310px);
  aspect-ratio: 1;
  border: 1px solid rgba(185, 154, 98, 0.1);
  opacity: 0.18;
  animation: slowSpinReverse 30s linear infinite;
}

.orbit-outer::before {
  inset: -36px;
  border: 1px dashed rgba(255, 244, 226, 0.04);
}

.orbit-outer::after {
  inset: 12%;
  background:
    radial-gradient(circle at 15% 44%, rgba(255, 244, 226, 0.5) 0 1px, transparent 2px),
    radial-gradient(circle at 82% 38%, rgba(255, 244, 226, 0.45) 0 1px, transparent 2px),
    radial-gradient(circle at 54% 92%, rgba(217, 194, 154, 0.36) 0 1px, transparent 2px);
  opacity: 0.7;
}

.orbit-inner::before {
  inset: -18px;
  border: 1px solid rgba(255, 244, 226, 0.04);
}

.orbit-inner::after {
  inset: 16%;
  background:
    radial-gradient(circle at 50% 0%, rgba(255, 245, 220, 0.12), transparent 20%),
    radial-gradient(circle at center, rgba(85, 105, 141, 0.08), transparent 68%);
  animation: haloBreath 8s ease-in-out infinite;
}

.question-compass-core {
  position: relative;
  grid-area: core;
  width: 236px;
  height: 236px;
  margin: 0 auto;
  padding: 28px 24px;
  border-radius: 50%;
  border: 1px solid rgba(217, 194, 154, 0.16);
  display: grid;
  place-items: center;
  align-content: center;
  gap: 10px;
  text-align: center;
  background:
    radial-gradient(circle at 50% 30%, rgba(255, 244, 226, 0.1), transparent 28%),
    radial-gradient(circle at center, rgba(12, 16, 23, 0.9), rgba(8, 11, 16, 0.86) 66%, rgba(8, 11, 16, 0.42));
  box-shadow:
    inset 0 0 0 22px rgba(7, 10, 15, 0.7),
    inset 0 0 0 1px rgba(255, 244, 226, 0.05),
    0 26px 64px rgba(0, 0, 0, 0.24);
  backdrop-filter: blur(12px) saturate(110%);
}

.question-compass-core::before,
.question-compass-core::after {
  content: "";
  position: absolute;
  border-radius: 50%;
  pointer-events: none;
}

.question-compass-core::before {
  inset: 20px;
  border: 1px solid rgba(217, 194, 154, 0.12);
}

.question-compass-core::after {
  inset: -16px;
  border: 1px solid rgba(217, 194, 154, 0.08);
}

.question-compass-core .compass-core-copy::before,
.question-compass-core .compass-core-copy::after {
  content: "";
  display: inline-block;
  width: 18px;
  height: 1px;
  margin: 0 10px 4px;
  background: linear-gradient(90deg, rgba(217, 194, 154, 0), rgba(217, 194, 154, 0.58), rgba(217, 194, 154, 0));
  vertical-align: middle;
}

.compass-core-seal {
  display: grid;
  place-items: center;
  width: 42px;
  height: 42px;
  border-radius: 12px;
  border: 1px solid rgba(217, 194, 154, 0.24);
  color: rgba(248, 239, 223, 0.92);
  background: linear-gradient(180deg, rgba(95, 35, 26, 0.92), rgba(58, 17, 13, 0.92));
  box-shadow: inset 0 1px 0 rgba(255, 244, 226, 0.16), 0 10px 26px rgba(0, 0, 0, 0.18);
  font-size: 18px;
  letter-spacing: 0.08em;
}

.compass-core-title {
  font-size: 22px;
  letter-spacing: 0.18em;
  color: rgba(247, 236, 216, 0.94);
}

.compass-core-copy {
  color: rgba(217, 194, 154, 0.68);
  font-family: var(--sans);
  font-size: 11px;
  letter-spacing: 0.34em;
  white-space: nowrap;
}

.compass-core-note {
  max-width: 15ch;
  margin: 0;
  color: rgba(232, 222, 204, 0.66);
  font-size: 11px;
  line-height: 1.75;
  white-space: nowrap;
}

.doorway {
  position: relative;
  min-width: 0;
  width: 100%;
  max-width: 300px;
  min-height: 0;
  margin: 0 auto;
  padding: 10px 10px 22px;
  border: 0;
  background: none;
  box-shadow: none;
  text-align: left;
  display: grid;
  align-content: start;
  gap: 10px;
  transition:
    transform 240ms cubic-bezier(0.22, 1, 0.36, 1),
    opacity 220ms ease,
    filter 220ms ease,
    background 240ms ease,
    border-color 240ms ease,
    box-shadow 240ms ease;
  overflow: hidden;
}

.doorway::before,
.doorway::after {
  content: "";
  position: absolute;
  pointer-events: none;
}

.doorway::before {
  inset: auto 12% 0;
  top: 44px;
  border: 0;
  background:
    radial-gradient(circle at 50% 0%, rgba(255, 244, 226, 0.08), transparent 34%),
    linear-gradient(180deg, rgba(217, 194, 154, 0.05), rgba(217, 194, 154, 0));
  filter: blur(10px);
  opacity: 0.42;
  transition: opacity 240ms ease, transform 240ms ease;
}

.doorway::after {
  left: 18%;
  right: 18%;
  bottom: 8px;
  height: 1px;
  background: linear-gradient(90deg, rgba(217, 194, 154, 0), rgba(217, 194, 154, 0.34), rgba(217, 194, 154, 0));
  opacity: 0.72;
  transition: opacity 240ms ease, transform 240ms ease;
}

.doorway-north {
  grid-area: north;
}

.doorway-south {
  grid-area: south;
}

.doorway-west {
  grid-area: west;
}

.doorway-east {
  grid-area: east;
}

.doorway:not(.is-active) {
  opacity: 0.64;
}

.doorway:hover {
  filter: brightness(1.1);
  opacity: 1;
  z-index: 2;
}

.doorway.is-active {
  filter: brightness(1.18);
  opacity: 1;
  background:
    linear-gradient(180deg, rgba(255, 244, 226, 0.16), rgba(255, 244, 226, 0.05)),
    linear-gradient(180deg, rgba(48, 56, 68, 0.99), rgba(27, 32, 42, 0.98));
}

.doorway:hover::before {
  opacity: 0.96;
  transform: scale(1.04);
}

.doorway:hover::after {
  opacity: 1;
  transform: scaleX(1.08);
}

.doorway.is-active.doorway-west {
  transform: translateX(4px);
}

.doorway.is-active.doorway-east {
  transform: translateX(-4px);
}

.doorway:hover.doorway-west {
  transform: translateX(8px);
}

.doorway:hover.doorway-east {
  transform: translateX(-8px);
}

.doorway-axis,
.doorway-copy,
.doorway-omen {
  position: relative;
  z-index: 1;
}

.doorway-axis {
  display: grid;
  align-items: center;
  grid-template-columns: 1fr auto 1fr;
  column-gap: 14px;
  width: 100%;
  color: rgba(217, 194, 154, 0.78);
}

.doorway-seal {
  display: grid;
  place-items: center;
  width: 30px;
  height: 30px;
  border-radius: 9px;
  background: linear-gradient(180deg, rgba(118, 44, 29, 0.92), rgba(71, 20, 15, 0.92));
  border: 1px solid rgba(217, 194, 154, 0.18);
  color: rgba(248, 239, 223, 0.92);
  font-size: 13px;
  box-shadow: inset 0 1px 0 rgba(255, 244, 226, 0.14), 0 8px 18px rgba(0, 0, 0, 0.16);
  transition: transform 240ms ease, box-shadow 240ms ease, border-color 240ms ease;
}

.doorway-direction,
.doorway-gate {
  font-family: var(--sans);
  font-size: 10px;
  letter-spacing: 0.26em;
  text-transform: uppercase;
  white-space: nowrap;
}

.doorway-direction {
  justify-self: end;
}

.doorway-gate {
  justify-self: start;
}

.doorway-copy {
  display: grid;
  gap: 8px;
  justify-items: center;
  margin: 0;
  max-width: none;
  padding-top: 10px;
  text-align: center;
}

.doorway-copy::before {
  content: "";
  position: absolute;
  left: 20%;
  right: 20%;
  top: 0;
  height: 1px;
  background: linear-gradient(90deg, rgba(217, 194, 154, 0), rgba(217, 194, 154, 0.2), rgba(217, 194, 154, 0));
}

.doorway strong {
  display: block;
  margin: 0;
  font-size: 28px;
  line-height: 1.18;
  letter-spacing: 0.04em;
  color: rgba(243, 235, 222, 0.96);
  transition: color 240ms ease, text-shadow 240ms ease, transform 240ms ease;
}

.doorway em {
  color: rgba(189, 163, 116, 0.72);
  font-family: var(--sans);
  font-size: 11px;
  line-height: 1.4;
  letter-spacing: 0.24em;
  text-transform: uppercase;
  font-style: normal;
  transition: color 240ms ease, letter-spacing 240ms ease;
}

.doorway-omen {
  margin: 0 auto;
  max-width: 22ch;
  color: rgba(217, 194, 154, 0.66);
  font-size: 12px;
  line-height: 1.8;
  letter-spacing: 0.08em;
  text-align: center;
  white-space: nowrap;
  transition: color 240ms ease, transform 240ms ease;
}

.doorway-north .doorway-axis,
.doorway-south .doorway-axis {
  grid-template-columns: max-content auto max-content;
  justify-content: center;
}

.doorway-north .doorway-direction,
.doorway-north .doorway-gate,
.doorway-south .doorway-direction,
.doorway-south .doorway-gate {
  letter-spacing: 0.1em;
}

.doorway-north {
  justify-items: center;
}

.doorway-north .doorway-axis {
  width: fit-content;
  margin-inline: auto;
  justify-self: center;
}

.doorway-north .doorway-copy {
  width: fit-content;
  margin-inline: auto;
  justify-items: center;
  justify-content: center;
  justify-self: center;
  text-align: center;
}

.doorway-north .doorway-omen {
  width: fit-content;
  margin-inline: auto;
  justify-self: center;
  text-align: center;
}

.doorway:hover .doorway-seal {
  transform: translateY(-2px) scale(1.08);
  border-color: rgba(239, 216, 176, 0.36);
  box-shadow:
    inset 0 1px 0 rgba(255, 244, 226, 0.22),
    0 14px 28px rgba(90, 34, 22, 0.34);
}

.doorway:hover strong {
  color: rgba(255, 247, 232, 0.99);
  text-shadow: 0 0 18px rgba(255, 232, 190, 0.16);
  transform: translateY(-1px);
}

.doorway.is-active .doorway-seal {
  border-color: rgba(239, 216, 176, 0.34);
  box-shadow:
    inset 0 1px 0 rgba(255, 244, 226, 0.2),
    0 12px 24px rgba(90, 34, 22, 0.28);
}

.doorway.is-active strong {
  color: rgba(255, 247, 232, 0.99);
  text-shadow: 0 0 18px rgba(255, 232, 190, 0.14);
}

.doorway.is-active em {
  color: rgba(227, 205, 166, 0.92);
}

.doorway.is-active .doorway-omen {
  color: rgba(241, 228, 203, 0.88);
}

.doorway:hover em {
  color: rgba(227, 205, 166, 0.96);
  letter-spacing: 0.21em;
}

.doorway:hover .doorway-omen {
  color: rgba(241, 228, 203, 0.9);
  transform: translateY(-1px);
}

.doorway-north,
.doorway-south {
  max-width: 340px;
}

.doorway-west,
.doorway-east {
  max-width: 280px;
}

.doorway-north::before,
.doorway-south::before {
  left: 22%;
  right: 22%;
}

.doorway-north::after,
.doorway-south::after {
  left: 26%;
  right: 26%;
}

.doorway-west::after,
.doorway-east::after {
  left: 24%;
  right: 24%;
}

.doorway-west .doorway-copy,
.doorway-east .doorway-copy,
.doorway-west .doorway-axis,
.doorway-east .doorway-omen,
.doorway-west .doorway-omen {
  justify-items: center;
  justify-content: center;
  text-align: center;
}

.doorway-west,
.doorway-east {
  align-self: center;
}

.doorway-north {
  transform-origin: center bottom;
}

.doorway-south {
  transform-origin: center top;
}

.doorway-west {
  transform-origin: right center;
}

.doorway-east {
  transform-origin: left center;
}

.doorway.is-active strong {
  text-shadow: 0 0 18px rgba(255, 235, 196, 0.08);
}

.doorway-seal {
  position: relative;
}

.doorway-seal::before {
  content: "";
  position: absolute;
  inset: -12px;
  border-radius: 50%;
  border: 1px solid rgba(217, 194, 154, 0.08);
}

.doorway-direction,
.doorway-gate {
  opacity: 0.82;
}

.scroll-surface,
.trust-field,
.wish-sanctuary {
  border-radius: 30px;
  border: 1px solid var(--line);
  background: linear-gradient(180deg, rgba(21, 26, 32, 0.98), rgba(17, 20, 24, 0.98));
  box-shadow: var(--shadow);
}

.question-stage[data-topic="wealth"] {
  box-shadow: 0 28px 64px rgba(0, 0, 0, 0.24), inset 0 1px 0 rgba(214, 176, 116, 0.04);
}
.question-stage[data-topic="relationship"] {
  box-shadow: 0 28px 64px rgba(0, 0, 0, 0.24), inset 0 1px 0 rgba(182, 144, 118, 0.04);
}
.question-stage[data-topic="child"] {
  box-shadow: 0 28px 64px rgba(0, 0, 0, 0.24), inset 0 1px 0 rgba(141, 166, 126, 0.04);
}
.question-stage[data-topic="timing"] {
  box-shadow: 0 28px 64px rgba(0, 0, 0, 0.24), inset 0 1px 0 rgba(147, 156, 192, 0.04);
}
.question-stage {
  position: relative;
  margin-top: 18px;
  padding: 30px 32px;
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(300px, 0.78fr);
  grid-template-areas: "copy visual";
  column-gap: 28px;
  row-gap: 18px;
  border: 1px solid rgba(185, 154, 98, 0.1);
  border-radius: 30px;
  background:
    radial-gradient(circle at 84% 18%, rgba(255, 244, 226, 0.055), transparent 18%),
    radial-gradient(circle at 14% 0%, rgba(185, 154, 98, 0.05), transparent 22%),
    linear-gradient(180deg, rgba(16, 21, 28, 0.96), rgba(10, 13, 18, 0.98));
  box-shadow: 0 28px 72px rgba(0, 0, 0, 0.22);
  overflow: hidden;
}

.question-stage::before {
  content: "";
  position: absolute;
  inset: 14px;
  border-radius: 24px;
  border: 1px solid rgba(217, 194, 154, 0.06);
  pointer-events: none;
}
.question-stage-main {
  display: contents;
}
.question-copy {
  grid-area: copy;
  display: grid;
  align-content: start;
  gap: 14px;
  max-width: 650px;
}
.stage-kicker { margin: 0; color: var(--gold-soft); letter-spacing: 0.12em; font-family: var(--sans); }
.question-copy h3 {
  margin: 0;
  max-width: 12ch;
  font-family: var(--hero-title-display);
  font-size: clamp(34px, 3.8vw, 58px);
  line-height: 1.22;
  letter-spacing: -0.025em;
}
.stage-summary {
  max-width: 32rem;
  color: rgba(244, 234, 216, 0.84);
  font-size: 16px;
  line-height: 1.9;
}
.question-stage-actions {
  display: grid;
  gap: 12px;
  margin-top: 6px;
  max-width: 32rem;
}
.question-visual {
  grid-area: visual;
  position: relative;
  display: grid;
  align-content: start;
  gap: 12px;
  min-height: 100%;
  padding: 4px 0 0 12px;
  border-left: 1px solid rgba(185, 154, 98, 0.08);
}

.visual-heading {
  position: relative;
  z-index: 6;
  display: grid;
  gap: 10px;
  padding: 0;
  color: var(--muted);
  font-family: var(--sans);
  margin-bottom: 0;
}
.visual-heading span {
  font-size: 12px;
  letter-spacing: 0.22em;
}
.visual-heading em {
  color: rgba(236, 225, 204, 0.92);
  font-size: 18px;
  font-style: normal;
}

.question-stage-detail {
  display: contents;
}

.question-detail-column {
  min-width: 0;
}

.question-detail-column--guide {
  padding-top: 10px;
  border-top: 1px solid rgba(185, 154, 98, 0.08);
}

.stage-list,
.volume-list {
  margin: 0;
  padding: 0;
  list-style: none;
}

.stage-list li {
  position: relative;
  padding-left: 16px;
  color: var(--text-soft);
  font-family: var(--sans);
  margin-top: 10px;
  line-height: 1.75;
}

.stage-list li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 12px;
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--gold);
}

.stage-list-title,
.visual-caption,
.visual-insight-head,
.visual-reflection {
  margin: 0;
}

.stage-list-title {
  color: rgba(236, 225, 204, 0.94);
  font-size: 24px;
  line-height: 1.35;
}

.visual-caption,
.stage-soft-note {
  color: rgba(214, 196, 160, 0.78);
  font-family: var(--sans);
  line-height: 1.9;
}

.visual-insights {
  display: grid;
  gap: 14px;
}

.visual-insight-head {
  display: grid;
  gap: 4px;
}

.visual-insight-head strong {
  font-size: 22px;
}

.visual-insight-head em {
  color: var(--muted);
  font-family: var(--sans);
  font-style: normal;
}

.visual-insight-grid { display: grid; gap: 14px; }
.insight-card {
  padding: 0 0 0 20px;
  border-radius: 0;
  background: none;
  border: 0;
  border-left: 0;
  position: relative;
}
.insight-card::before {
  content: "—";
  position: absolute;
  left: 0;
  top: 0;
  color: rgba(198, 171, 120, 0.78);
}
.insight-order { color: var(--gold-soft); font-family: var(--sans); font-size: 12px; }
.insight-card strong { display: block; margin-top: 0; font-size: 18px; }
.insight-card em, .insight-card p, .visual-caption, .visual-reflection p {
  color: var(--muted);
  font-family: var(--sans);
}
.insight-order,
.insight-card em {
  display: none;
}
.visual-reflection {
  display: grid;
  gap: 8px;
  padding-top: 8px;
}
.visual-reflection strong {
  font-size: 18px;
}

.library-layout {
  display: grid;
  grid-template-columns: 280px 1fr;
  gap: 24px;
}

.directory-list { display: grid; gap: 12px; margin-top: 22px; }
.directory-item {
  padding: 16px 18px;
  border: 1px solid var(--line);
  background: rgba(13, 16, 22, 0.58);
  text-align: left;
}
.directory-item strong { display: block; }
.directory-item em { color: var(--muted); font-family: var(--sans); font-size: 12px; }
.directory-item.is-active { border-color: var(--line-strong); }

.scroll-surface { padding: 24px; }
.scroll-mark { color: var(--gold-soft); font-family: var(--sans); letter-spacing: 0.18em; font-size: 12px; }
.scroll-current { margin-top: 14px; margin-bottom: 20px; color: var(--text-soft); font-family: var(--sans); }
.volume-list { display: grid; gap: 16px; }
.volume { padding: 20px; border-radius: 22px; background: rgba(13, 16, 22, 0.5); border: 1px solid rgba(185, 154, 98, 0.08); }
.volume-kicker { margin: 0 0 6px; color: var(--gold-soft); font-family: var(--sans); font-size: 12px; letter-spacing: 0.16em; }
.volume h3 { margin: 0 0 10px; font-size: 26px; }
.volume h3 span { display: block; color: var(--muted); font-size: 13px; font-family: var(--sans); font-weight: 400; margin-top: 6px; }

.deeper-section {
  position: relative;
  overflow: hidden;
}
.deeper-section::before,
.deeper-section::after {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
}
.deeper-section::before {
  z-index: 0;
  background:
    radial-gradient(circle at 50% 24%, rgba(180, 142, 82, 0.12), transparent 18%),
    radial-gradient(circle at 18% 42%, rgba(78, 96, 120, 0.12), transparent 24%),
    radial-gradient(circle at 84% 44%, rgba(112, 84, 52, 0.11), transparent 26%),
    linear-gradient(180deg, rgba(8, 10, 14, 0) 0%, rgba(10, 12, 16, 0.12) 38%, rgba(18, 16, 13, 0.22) 100%);
  filter: blur(26px);
}
.deeper-section::after {
  z-index: 0;
  inset: auto 0 0;
  height: 240px;
  background:
    radial-gradient(circle at 50% 0%, rgba(94, 66, 42, 0.16), transparent 46%),
    linear-gradient(180deg, rgba(14, 16, 20, 0), rgba(14, 16, 20, 0.68));
}
.pathway-list {
  position: relative;
  z-index: 1;
  margin-top: 44px;
  padding: 16px 0 42px;
}
.pathway-list::before,
.pathway-list::after {
  content: "";
  position: absolute;
  pointer-events: none;
}
.pathway-list::before {
  inset: -52px -64px -20px;
  z-index: 0;
  border-radius: 64px;
  background:
    radial-gradient(circle at 50% 16%, rgba(188, 147, 84, 0.16), transparent 20%),
    radial-gradient(circle at 14% 56%, rgba(26, 30, 38, 0.62), transparent 28%),
    radial-gradient(circle at 86% 58%, rgba(25, 29, 35, 0.56), transparent 28%),
    linear-gradient(180deg, rgba(10, 12, 16, 0.18), rgba(17, 15, 13, 0.32) 68%, rgba(12, 10, 9, 0.52) 100%);
  filter: blur(34px);
  opacity: 0.92;
}
.pathway-list::after {
  left: 5%;
  right: 5%;
  bottom: -30px;
  height: 180px;
  z-index: 0;
  border-radius: 50%;
  background:
    radial-gradient(circle at 50% 24%, rgba(24, 20, 18, 0.72), rgba(10, 10, 12, 0) 72%);
  filter: blur(30px);
}

.oracle-reference-scene {
  position: relative;
  isolation: isolate;
  min-height: 0;
  overflow: hidden;
  border-radius: 32px;
  background: transparent;
  border: 0;
  box-shadow: none;
}
.oracle-reference-scene--image {
  --oracle-bg-position: center 18%;
  min-height: 700px;
  padding: 32px;
  overflow: hidden;
  background: url("/images/deeper-pathway-bg.jpg?v=20260325k");
  background-size: cover;
  background-position: var(--oracle-bg-position);
  background-repeat: no-repeat;
  border: 0;
  box-shadow: none;
}
.oracle-reference-overlay {
  position: relative;
  inset: auto;
  z-index: 2;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  align-items: end;
  gap: 24px;
  min-height: 636px;
}
.oracle-hotspot {
  position: relative;
  display: grid;
  align-content: start;
  justify-items: start;
  text-align: left;
  height: 100%;
  padding: 26px 24px 24px;
  color: #f3ead9;
}
.oracle-hotspot--left {
  margin-top: 88px;
}
.oracle-hotspot--center {
  margin-top: 0;
}
.oracle-hotspot--right {
  margin-top: 88px;
}
.oracle-hotspot-label {
  position: static;
  margin: 0;
  margin-bottom: 12px;
  color: rgba(233, 217, 185, 0.92);
  font-family: var(--sans);
  font-size: 14px;
  letter-spacing: 0.08em;
  text-shadow: 0 2px 14px rgba(0, 0, 0, 0.4);
}
.oracle-hotspot-seal {
  display: inline-block;
  width: auto;
  height: auto;
  margin-bottom: 12px;
  color: #eef1df;
  font-size: 34px;
  line-height: 1;
  text-shadow: 0 4px 18px rgba(0, 0, 0, 0.28);
}
.oracle-hotspot-seal--center {
  margin-bottom: 14px;
}
.oracle-hotspot h3 {
  margin: 0;
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  z-index: 2;
  width: max-content;
  max-width: calc(100% - 24px);
  color: #f5ebdb;
  font-size: clamp(28px, 2vw, 40px);
  line-height: 1.12;
  text-align: center;
  text-shadow: 0 3px 24px rgba(0, 0, 0, 0.26);
}
.oracle-hotspot--left h3,
.oracle-hotspot--right h3 {
  bottom: 98px;
}
.oracle-hotspot--left h3 {
  left: 59%;
}
.oracle-hotspot--center h3 {
  left: 54%;
  bottom: 166px;
}
.oracle-hotspot-cn,
.oracle-hotspot-en {
  margin: 10px 0 0;
  max-width: 34ch;
  color: rgba(244, 234, 216, 0.9);
  font-family: var(--sans);
  font-size: 14px;
  line-height: 1.65;
  text-shadow: 0 2px 12px rgba(0, 0, 0, 0.34);
}
.oracle-hotspot-en {
  color: rgba(227, 216, 196, 0.8);
  font-size: 11px;
  line-height: 1.5;
}
.oracle-hotspot-link {
  position: absolute;
  left: 50%;
  z-index: 2;
  margin-top: 0;
  min-width: 0;
  width: max-content;
  max-width: calc(100% - 24px);
  padding: 0;
  border-radius: 0;
  border: 0;
  background: none;
  box-shadow: none;
  justify-items: center;
  text-align: center;
  gap: 10px;
  transform: translateX(-50%);
}
.oracle-hotspot--left .oracle-hotspot-link,
.oracle-hotspot--right .oracle-hotspot-link {
  bottom: 68px;
}
.oracle-hotspot--left .oracle-hotspot-link {
  left: 59%;
}
.oracle-hotspot--center .oracle-hotspot-link {
  left: 54%;
  bottom: 136px;
}
.oracle-hotspot--right .oracle-hotspot-link {
  left: 50%;
  max-width: none;
}
.oracle-reference-scene--image::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 1;
  pointer-events: none;
  background:
    linear-gradient(180deg, rgba(11, 14, 20, 0.76) 0%, rgba(11, 14, 20, 0.28) 7%, rgba(11, 14, 20, 0.06) 15%, rgba(16, 14, 12, 0) 24%, rgba(16, 14, 12, 0) 68%, rgba(16, 14, 12, 0.28) 80%, rgba(16, 14, 12, 0.7) 91%, rgba(16, 14, 12, 0.92) 100%),
    linear-gradient(90deg, rgba(10, 12, 18, 0.88) 0%, rgba(10, 12, 18, 0.38) 6%, rgba(10, 12, 18, 0.08) 13%, rgba(10, 12, 18, 0) 21%, rgba(10, 12, 18, 0) 79%, rgba(10, 12, 18, 0.1) 87%, rgba(10, 12, 18, 0.46) 94%, rgba(10, 12, 18, 0.82) 100%),
    radial-gradient(circle at 50% 12%, rgba(12, 12, 14, 0.04), rgba(12, 12, 14, 0.14) 34%, rgba(12, 12, 14, 0.28) 100%),
    linear-gradient(180deg, rgba(10, 10, 12, 0.08) 0%, rgba(10, 10, 12, 0.04) 34%, rgba(10, 10, 12, 0.16) 58%, rgba(7, 7, 9, 0.42) 76%, rgba(5, 5, 7, 0.62) 100%);
  opacity: 1;
  -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 100 100' preserveAspectRatio='none'%3E%3Cdefs%3E%3CradialGradient id='cutout' cx='50%25' cy='50%25' r='50%25'%3E%3Cstop offset='58%25' stop-color='black'/%3E%3Cstop offset='100%25' stop-color='white'/%3E%3C/radialGradient%3E%3C/defs%3E%3Crect width='100' height='100' fill='white'/%3E%3Cellipse cx='22' cy='66' rx='17' ry='22' fill='url(%23cutout)'/%3E%3Cellipse cx='52' cy='42' rx='17' ry='28' fill='url(%23cutout)'/%3E%3Cellipse cx='80' cy='66' rx='16' ry='21' fill='url(%23cutout)'/%3E%3C/svg%3E");
  mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 100 100' preserveAspectRatio='none'%3E%3Cdefs%3E%3CradialGradient id='cutout' cx='50%25' cy='50%25' r='50%25'%3E%3Cstop offset='58%25' stop-color='black'/%3E%3Cstop offset='100%25' stop-color='white'/%3E%3C/radialGradient%3E%3C/defs%3E%3Crect width='100' height='100' fill='white'/%3E%3Cellipse cx='22' cy='66' rx='17' ry='22' fill='url(%23cutout)'/%3E%3Cellipse cx='52' cy='42' rx='17' ry='28' fill='url(%23cutout)'/%3E%3Cellipse cx='80' cy='66' rx='16' ry='21' fill='url(%23cutout)'/%3E%3C/svg%3E");
  -webkit-mask-repeat: no-repeat;
  mask-repeat: no-repeat;
  -webkit-mask-size: 100% 100%;
  mask-size: 100% 100%;
}
.oracle-reference-frame, .oracle-reference-sky, .oracle-reference-geo, .oracle-reference-stars, .oracle-reference-glow, .oracle-reference-lotus, .oracle-reference-table, .oracle-reference-front { position: absolute; pointer-events: none; }
.oracle-reference-frame { inset: 0; }
.oracle-reference-sky {
  inset: 0 0 218px;
  background:
    radial-gradient(circle at 50% 20%, rgba(205, 171, 97, 0.12), transparent 18%),
    radial-gradient(circle at 20% 16%, rgba(81, 103, 140, 0.12), transparent 20%),
    radial-gradient(circle at 84% 18%, rgba(77, 96, 128, 0.1), transparent 22%),
    linear-gradient(180deg, rgba(19, 20, 24, 0.98), rgba(28, 26, 24, 0.95));
}
.oracle-reference-geo { left: 50%; top: 42px; transform: translateX(-50%); border: 1px solid rgba(203, 171, 112, 0.09); border-radius: 50%; }
.oracle-reference-geo--outer { width: 760px; height: 760px; }
.oracle-reference-geo--inner { width: 520px; height: 520px; border-color: rgba(203, 171, 112, 0.06); }
.oracle-reference-stars {
  top: 0;
  width: 34%;
  height: 320px;
  opacity: 0.18;
  background-image:
    radial-gradient(circle, rgba(255, 244, 226, 0.92) 0 1px, transparent 1.8px),
    radial-gradient(circle, rgba(255, 244, 226, 0.76) 0 1.2px, transparent 2px);
  background-size: 120px 120px, 170px 170px;
}
.oracle-reference-stars--left { left: 0; background-position: 18px 26px, 68px 88px; }
.oracle-reference-stars--right { right: 0; background-position: 88px 44px, 22px 104px; }
.oracle-reference-glow { border-radius: 50%; filter: blur(28px); }
.oracle-reference-glow--left { left: 132px; top: 436px; width: 260px; height: 260px; background: radial-gradient(circle at center, rgba(96, 128, 112, 0.22), transparent 72%); }
.oracle-reference-glow--center { left: 50%; top: 144px; width: 440px; height: 440px; transform: translateX(-50%); background: radial-gradient(circle at center, rgba(215, 177, 101, 0.34), transparent 62%); }
.oracle-reference-glow--right { right: 132px; top: 430px; width: 260px; height: 260px; background: radial-gradient(circle at center, rgba(194, 144, 82, 0.24), transparent 72%); }
.oracle-reference-lotus { right: 24px; bottom: 224px; width: 136px; height: 136px; }
.oracle-reference-lotus::before, .oracle-reference-lotus::after { content: ""; position: absolute; inset: 16px; background: linear-gradient(180deg, rgba(255, 235, 188, 0.94), rgba(242, 175, 98, 0.24)); clip-path: polygon(50% 0, 100% 100%, 0 100%); }
.oracle-reference-lotus::before { transform: rotate(-28deg); }
.oracle-reference-lotus::after { transform: rotate(28deg); }
.oracle-reference-table { left: 0; right: 0; bottom: 78px; height: 206px; background: linear-gradient(180deg, rgba(255, 228, 190, 0.06), rgba(0, 0, 0, 0.02) 20%, rgba(0, 0, 0, 0.16)), linear-gradient(180deg, rgba(110, 78, 50, 0.62), rgba(54, 35, 22, 0.98)); border-top: 1px solid rgba(221, 188, 126, 0.18); }
.oracle-reference-front { left: 0; right: 0; bottom: 0; height: 92px; background: linear-gradient(180deg, rgba(34, 18, 8, 0.1), rgba(0, 0, 0, 0.24)), linear-gradient(180deg, rgba(76, 51, 31, 0.96), rgba(38, 24, 16, 0.98)); }
.oracle-reference-grid { position: relative; z-index: 2; display: grid; grid-template-columns: 0.92fr 1.2fr 0.92fr; align-items: end; gap: 18px; min-height: 840px; padding: 86px 48px 40px; }
.oracle-reference-column { display: grid; justify-items: center; text-align: center; align-self: end; }
.oracle-reference-column--left, .oracle-reference-column--right { padding-bottom: 52px; }
.oracle-reference-label, .oracle-reference-caption { color: rgba(232, 216, 184, 0.88); font-family: var(--sans); font-size: 14px; letter-spacing: 0.08em; margin-bottom: 16px; }
.oracle-reference-title { display: grid; justify-items: center; gap: 10px; margin-bottom: 10px; }
.oracle-reference-title-mark, .oracle-reference-seal { width: 66px; height: 66px; display: grid; place-items: center; border-radius: 50%; color: #edf1de; font-size: 34px; border: 1px solid rgba(212, 230, 189, 0.28); background: radial-gradient(circle at 40% 30%, rgba(235, 249, 223, 0.28), transparent 42%), linear-gradient(180deg, rgba(147, 169, 126, 0.96), rgba(92, 116, 81, 0.98)); box-shadow: 0 14px 26px rgba(0, 0, 0, 0.18); }
.oracle-reference-title-mark--wish, .oracle-reference-seal--jade, .oracle-reference-seal--compass { position: relative; z-index: 2; }
.oracle-reference-title h2, .oracle-reference-column h3 { margin: 0; color: #f5ebdb; font-size: 34px; line-height: 1.08; text-shadow: 0 3px 24px rgba(0, 0, 0, 0.16); }
.oracle-reference-column h3 { margin-top: 10px; }
.oracle-reference-object { position: relative; display: grid; justify-items: center; align-items: end; }
.oracle-reference-object--jade, .oracle-reference-object--compass { width: 320px; height: 290px; }
.oracle-reference-object--mirror { width: 520px; height: 500px; }
.object-halo { position: absolute; left: 50%; top: 30px; width: 240px; height: 240px; transform: translateX(-50%); border-radius: 50%; background: radial-gradient(circle at center, rgba(214, 177, 102, 0.24), transparent 64%); filter: blur(18px); }
.object-halo--large { top: -18px; width: 420px; height: 420px; background: radial-gradient(circle at center, rgba(214, 177, 102, 0.34), rgba(214, 177, 102, 0.08) 42%, transparent 68%); filter: blur(26px); }
.object-stand { position: absolute; left: 50%; bottom: 0; transform: translateX(-50%); }
.oracle-reference-object--jade::before { content: ""; position: absolute; left: 50%; top: 34px; width: 220px; height: 220px; transform: translateX(-50%); border-radius: 50%; background: radial-gradient(circle at 34% 26%, rgba(232, 240, 220, 0.3), transparent 16%), radial-gradient(circle at 54% 58%, rgba(214, 225, 202, 0.16), transparent 18%), radial-gradient(circle at center, rgba(111, 129, 116, 0.58), rgba(63, 74, 66, 0.98) 78%); box-shadow: inset 0 0 0 16px rgba(146, 168, 148, 0.28), inset 0 0 0 28px rgba(52, 64, 58, 0.92), 0 24px 40px rgba(0, 0, 0, 0.26); }
.oracle-reference-object--jade::after { content: ""; position: absolute; left: 50%; top: 104px; width: 62px; height: 62px; transform: translateX(-50%); border-radius: 50%; background: #161513; box-shadow: 0 0 0 10px rgba(75, 84, 74, 0.5), 0 0 0 20px rgba(25, 29, 26, 0.96); }
.oracle-reference-object--compass::before { content: ""; position: absolute; left: 50%; top: 34px; width: 224px; height: 224px; transform: translateX(-50%); border-radius: 50%; background: radial-gradient(circle at 34% 26%, rgba(243, 228, 192, 0.24), transparent 16%), radial-gradient(circle at 58% 62%, rgba(201, 162, 103, 0.14), transparent 20%), radial-gradient(circle at center, rgba(161, 123, 73, 0.34), rgba(94, 68, 38, 0.92) 78%); box-shadow: inset 0 0 0 12px rgba(222, 196, 140, 0.24), inset 0 0 0 26px rgba(116, 87, 50, 0.96), 0 24px 42px rgba(0, 0, 0, 0.26); }
.oracle-reference-object--compass::after { content: ""; position: absolute; left: 50%; top: 118px; width: 26px; height: 26px; transform: translateX(-50%); border-radius: 50%; background: radial-gradient(circle at center, rgba(255,255,255,0.65), rgba(123, 104, 86, 0.9)); box-shadow: 0 0 0 2px rgba(234, 224, 202, 0.3); }
.oracle-reference-object--mirror::before { content: ""; position: absolute; left: 50%; top: 24px; width: 300px; height: 300px; transform: translateX(-50%); border-radius: 50%; background: radial-gradient(circle at 34% 30%, rgba(229, 237, 220, 0.12), transparent 14%), radial-gradient(circle at 58% 58%, rgba(90, 196, 160, 0.18), transparent 16%), radial-gradient(circle at center, rgba(84, 116, 108, 0.46), rgba(44, 45, 42, 0.94) 76%); box-shadow: inset 0 0 0 18px rgba(86, 116, 103, 0.72), inset 0 0 0 34px rgba(28, 31, 30, 0.94), 0 30px 48px rgba(0, 0, 0, 0.28); }
.oracle-reference-object--mirror::after { content: ""; position: absolute; left: 50%; top: 154px; width: 24px; height: 24px; transform: translateX(-50%); border-radius: 50%; background: radial-gradient(circle at center, rgba(255,255,255,0.46), rgba(63, 60, 54, 0.92)); }
.oracle-reference-object--jade .object-stand { width: 230px; height: 84px; }
.oracle-reference-object--compass .object-stand { width: 238px; height: 82px; }
.oracle-reference-object--mirror .object-stand { width: 360px; height: 170px; }
.oracle-reference-object--jade .object-stand::before,
.oracle-reference-object--compass .object-stand::before,
.oracle-reference-object--mirror .object-stand::before { content: ""; position: absolute; left: 50%; transform: translateX(-50%); }
.oracle-reference-object--jade .object-stand::before { bottom: 18px; width: 168px; height: 24px; background: linear-gradient(180deg, rgba(131, 164, 139, 0.96), rgba(89, 115, 95, 0.98)); box-shadow: 0 8px 16px rgba(0,0,0,0.16); }
.oracle-reference-object--jade .object-stand::after { content: ""; position: absolute; left: 50%; bottom: 0; width: 230px; height: 28px; transform: translateX(-50%); background: linear-gradient(180deg, rgba(105, 134, 110, 0.96), rgba(75, 95, 80, 0.98)); border-radius: 10px; }
.oracle-reference-object--compass .object-stand::before { bottom: 12px; width: 148px; height: 48px; border-radius: 50%; background: linear-gradient(180deg, rgba(131, 108, 77, 0.96), rgba(84, 61, 39, 0.98)); }
.oracle-reference-object--compass .object-stand::after { content: ""; position: absolute; left: 50%; bottom: 0; width: 188px; height: 18px; transform: translateX(-50%); border-radius: 999px; background: linear-gradient(180deg, rgba(96, 74, 49, 0.96), rgba(62, 43, 25, 0.98)); }
.oracle-reference-object--mirror .object-stand::before { bottom: 48px; width: 240px; height: 86px; background: linear-gradient(180deg, rgba(76, 95, 86, 0.96), rgba(55, 68, 62, 0.98)); clip-path: polygon(16% 0, 84% 0, 73% 100%, 27% 100%); }
.oracle-reference-object--mirror .object-stand::after { content: ""; position: absolute; left: 50%; bottom: 0; width: 360px; height: 70px; transform: translateX(-50%); border-radius: 10px; background: linear-gradient(180deg, rgba(103, 74, 48, 0.98), rgba(73, 47, 28, 0.98)); box-shadow: inset 0 10px 16px rgba(255, 229, 192, 0.08), 0 12px 20px rgba(0, 0, 0, 0.18); }
.oracle-reference-cn, .oracle-reference-en { margin: 10px 0 0; max-width: 30ch; color: rgba(244, 234, 216, 0.88); font-family: var(--sans); font-size: 15px; line-height: 1.7; }
.oracle-reference-en { color: rgba(227, 216, 196, 0.74); font-size: 12px; line-height: 1.55; }
.pathway-link {
  margin-top: 18px;
  min-width: 0;
  width: fit-content;
  padding: 0;
  border-radius: 0;
  background: none;
  border: 0;
  box-shadow: none;
  justify-items: start;
  text-align: left;
  gap: 6px;
}

.pathway-link span,
.oracle-hotspot-link span {
  color: rgba(244, 234, 216, 0.96);
  font-size: 16px;
  line-height: 1.3;
  text-shadow: 0 2px 12px rgba(0, 0, 0, 0.32);
}

.pathway-link small,
.oracle-hotspot-link small {
  color: rgba(217, 194, 154, 0.72);
  font-size: 11px;
  letter-spacing: 0.08em;
  text-shadow: 0 2px 10px rgba(0, 0, 0, 0.28);
}
.oracle-hotspot-link small {
  display: block;
  white-space: nowrap;
}

.pathway-link:hover,
.pathway-link:focus-visible,
.oracle-hotspot-link:hover,
.oracle-hotspot-link:focus-visible {
  transform: translateY(-1px);
}
.oracle-hotspot-link:hover,
.oracle-hotspot-link:focus-visible {
  transform: translateX(-50%) translateY(-1px);
}

.pathway-link:hover span,
.pathway-link:focus-visible span,
.oracle-hotspot-link:hover span,
.oracle-hotspot-link:focus-visible span {
  color: rgba(255, 244, 226, 1);
}

.pathway-link::after,
.oracle-hotspot-link::after {
  content: "";
  width: 100%;
  height: 1px;
  margin-top: 0;
  background: linear-gradient(90deg, rgba(217, 194, 154, 0.56), rgba(217, 194, 154, 0.14), transparent);
}
.oracle-reference-action { margin-top: 16px; }

#deeperTitle {
  text-align: center;
  line-height: 1.18;
}

.deeper-title-line {
  display: block;
}

.deeper-title-mobile-line {
  display: none;
}

.trust-section {
  position: relative;
  overflow: hidden;
}

.trust-section::before,
.trust-section::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  pointer-events: none;
  z-index: 0;
}

.trust-section::before {
  inset: 0;
  background:
    radial-gradient(circle at 50% 42%, rgba(185, 154, 98, 0.08), transparent 32%),
    radial-gradient(circle at 18% 54%, rgba(72, 84, 102, 0.08), transparent 24%),
    radial-gradient(circle at 82% 52%, rgba(104, 78, 50, 0.08), transparent 26%),
    linear-gradient(180deg, rgba(8, 10, 14, 0.62) 0%, rgba(8, 10, 14, 0.18) 16%, rgba(12, 11, 10, 0.06) 34%, rgba(14, 12, 10, 0.12) 72%, rgba(16, 13, 10, 0.38) 100%);
  filter: blur(22px);
  opacity: 0.92;
}

.trust-section::after {
  left: 6%;
  right: 6%;
  bottom: -44px;
  height: 220px;
  border-radius: 50%;
  background:
    radial-gradient(circle at 50% 18%, rgba(88, 64, 40, 0.22), rgba(12, 11, 10, 0) 66%);
  filter: blur(26px);
  opacity: 0.82;
}

.trust-field {
  position: relative;
  display: block;
  padding: 30px 0 10px;
  overflow: hidden;
  border: 0;
  border-radius: 0;
  box-shadow: none;
  background: none;
}

.trust-main {
  position: relative;
  z-index: 2;
  display: grid;
  gap: 26px;
  align-items: start;
}
.trust-copy {
  display: grid;
  justify-items: start;
  gap: 18px;
  max-width: none;
  text-align: left;
}
.trust-copy .intro-en {
  letter-spacing: 0.16em;
  white-space: nowrap;
}
.trust-copy h2 {
  margin: 0;
  max-width: none;
  font-family: var(--hero-title-display);
  font-size: clamp(38px, 4vw, 58px);
  line-height: 1.08;
  letter-spacing: -0.03em;
  white-space: nowrap;
}
.trust-copy p {
  max-width: 68ch;
  margin: 0;
  font-size: 16px;
  line-height: 1.92;
}

.trust-words {
  display: flex;
  flex-wrap: wrap;
  gap: 12px 40px;
  margin-top: -2px;
}
.trust-words span {
  padding: 0 0 8px;
  background: none;
  border-radius: 0;
  border: 0;
  border-bottom: 1px solid rgba(185, 154, 98, 0.18);
  color: var(--gold-soft);
  font-family: var(--sans);
  font-size: 14px;
  letter-spacing: 0.14em;
}

.trust-vows {
  position: relative;
  z-index: 2;
  display: grid;
  gap: 0;
  margin-top: 22px;
}
.trust-vow {
  position: relative;
  display: grid;
  grid-template-columns: 74px minmax(220px, 280px) minmax(0, 1fr);
  gap: 18px;
  align-items: start;
  padding: 22px 0 24px;
  background: none;
  border: 0;
  border-radius: 0;
  border-top: 1px solid rgba(185, 154, 98, 0.12);
  box-shadow: none;
}
.trust-vow-head {
  display: contents;
}
.trust-vow-index {
  grid-column: 1;
  color: rgba(217, 194, 154, 0.54);
  font-family: var(--sans);
  font-size: 12px;
  letter-spacing: 0.26em;
  padding-top: 4px;
}
.trust-vow strong {
  grid-column: 2;
  font-size: 23px;
  line-height: 1.3;
  font-weight: 600;
}
.trust-vow p {
  grid-column: 3;
  margin: 0;
  max-width: 76ch;
  color: rgba(244, 234, 216, 0.8);
}
.trust-vow:first-child {
  border-top: 1px solid rgba(185, 154, 98, 0.18);
}

.trust-aura,
.trust-orbit,
.trust-core,
.trust-seal {
  display: none;
}

.wish-section {
  position: relative;
  overflow: hidden;
  padding-bottom: 46px;
}

.wish-section::before {
  display: none;
}

.wish-scene {
  position: relative;
  z-index: 1;
  display: grid;
  gap: 28px;
  width: min(980px, 100%);
  margin: 0 auto;
}

.wish-scene::before,
.wish-scene::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(185, 154, 98, 0.34), transparent);
}

.wish-scene::before {
  top: 74px;
}

.wish-scene::after {
  bottom: 18px;
  opacity: 0.72;
}

.wish-copy {
  display: grid;
  gap: 0;
  justify-items: center;
  text-align: center;
  padding-top: 6px;
}

.wish-kicker {
  display: inline-flex;
  align-items: center;
  gap: 14px;
  margin: 0 0 18px;
}

.wish-kicker span {
  padding: 8px 14px;
  border-radius: 999px;
  color: rgba(252, 239, 215, 0.94);
  font-family: var(--sans);
  font-size: 12px;
  letter-spacing: 0.22em;
  background: rgba(112, 53, 38, 0.28);
  border: 1px solid rgba(185, 154, 98, 0.18);
}

.wish-kicker em {
  color: rgba(217, 194, 154, 0.66);
  font-family: var(--sans);
  font-size: 11px;
  font-style: normal;
  letter-spacing: 0.2em;
  text-transform: uppercase;
}

.wish-copy h2 {
  margin: 0;
  max-width: 12.5ch;
  font-size: clamp(34px, 3.9vw, 56px);
  line-height: 1.12;
}

.wish-copy > p:last-of-type {
  margin-top: 14px;
  max-width: 40rem;
  text-align: center;
  font-size: 14px;
}

.wish-axis {
  display: grid;
  grid-template-columns: minmax(0, 0.88fr) minmax(260px, 0.72fr);
  align-items: center;
  gap: 18px;
  min-height: 340px;
}

.wish-axis-copy {
  display: grid;
  gap: 18px;
  align-content: center;
}

.wish-axis-lead {
  margin: 0;
  max-width: 28rem;
  color: rgba(248, 238, 221, 0.92);
  font-size: clamp(20px, 2vw, 28px);
  line-height: 1.5;
}

.wish-streams {
  display: flex;
  flex-wrap: wrap;
  gap: 10px 14px;
  max-width: 30rem;
}

.wish-streams span {
  position: relative;
  padding-left: 16px;
  color: rgba(244, 236, 220, 0.92);
  font-family: var(--sans);
  font-size: 12px;
  letter-spacing: 0.12em;
}

.wish-streams span::before {
  content: "";
  position: absolute;
  left: 0;
  top: 50%;
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: rgba(217, 194, 154, 0.86);
  transform: translateY(-50%);
}

.wish-process {
  margin: 0;
  color: rgba(217, 194, 154, 0.76);
  font-family: var(--sans);
  font-size: 11px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
}

.wish-altar {
  min-height: 320px;
  background:
    radial-gradient(circle at center, rgba(217, 194, 154, 0.1), transparent 24%),
    radial-gradient(circle at 50% 44%, rgba(233, 210, 171, 0.08), transparent 16%);
  position: relative;
  overflow: hidden;
}

.wish-altar-mist,
.wish-altar-orbit,
.wish-altar-core,
.wish-altar-pillars,
.wish-constellation {
  position: absolute;
}

.wish-altar-mist {
  inset: 10%;
  border-radius: 50%;
  background:
    radial-gradient(circle at center, rgba(217, 194, 154, 0.18), transparent 42%),
    radial-gradient(circle at center, rgba(137, 93, 48, 0.12), transparent 58%);
  filter: blur(18px);
  animation: haloBreath 8s ease-in-out infinite;
}

.wish-altar-orbit {
  left: 50%;
  top: 50%;
  border-radius: 50%;
  transform: translate(-50%, -50%);
}

.wish-altar-orbit--outer {
  width: 260px;
  height: 260px;
  border: 1px solid rgba(185, 154, 98, 0.18);
  animation: slowSpin 38s linear infinite;
}

.wish-altar-orbit--inner {
  width: 180px;
  height: 180px;
  border: 1px dashed rgba(217, 194, 154, 0.22);
  animation: slowSpinReverse 24s linear infinite;
}

.wish-altar-core {
  left: 50%;
  top: 50%;
  width: 128px;
  height: 128px;
  transform: translate(-50%, -50%);
  border-radius: 50%;
  border: 1px solid rgba(217, 194, 154, 0.14);
  background:
    radial-gradient(circle at 50% 42%, rgba(245, 227, 189, 0.16), rgba(245, 227, 189, 0.04) 28%, transparent 56%),
    linear-gradient(180deg, rgba(18, 22, 29, 0.54), rgba(10, 12, 18, 0.2));
  box-shadow: inset 0 0 56px rgba(204, 144, 75, 0.08), 0 0 80px rgba(0, 0, 0, 0.24);
}

.wish-core-flame {
  position: absolute;
  left: 50%;
  top: 28px;
  width: 38px;
  height: 60px;
  transform: translateX(-50%);
  border-radius: 50% 50% 36% 36%;
  background: linear-gradient(180deg, rgba(255, 239, 205, 0.96), rgba(221, 167, 89, 0.84) 56%, rgba(104, 59, 28, 0.08) 100%);
  clip-path: polygon(50% 0, 82% 28%, 100% 72%, 50% 100%, 0 72%, 18% 28%);
  filter: drop-shadow(0 0 18px rgba(234, 187, 93, 0.28));
  animation: altarFlame 4.2s ease-in-out infinite;
}

.wish-core-seal {
  position: absolute;
  left: 50%;
  bottom: 18px;
  transform: translateX(-50%);
  color: rgba(251, 240, 215, 0.92);
  font-size: 24px;
  letter-spacing: 0.18em;
}

.wish-altar-pillars {
  inset: auto 24px 18px 24px;
  display: flex;
  justify-content: space-between;
  color: rgba(217, 194, 154, 0.68);
  font-family: var(--sans);
  font-size: 10px;
  letter-spacing: 0.22em;
}

.wish-star {
  position: absolute;
  width: 4px;
  height: 4px;
  border-radius: 50%;
  background: rgba(255, 241, 216, 0.96);
  box-shadow: 0 0 0 8px rgba(255, 241, 216, 0.04);
  animation: starlightPulse 5.5s ease-in-out infinite;
}

.wish-constellation {
  inset: 0;
  pointer-events: none;
}

.wish-star--1 { left: 96px; top: 140px; }
.wish-star--2 { right: 110px; top: 124px; animation-delay: 1.1s; }
.wish-star--3 { left: 130px; bottom: 148px; animation-delay: 2.2s; }
.wish-star--4 { right: 142px; bottom: 164px; animation-delay: 0.8s; }
.wish-star--5 { right: 80px; top: 208px; animation-delay: 1.8s; }

.wish-trigger {
  position: relative;
  min-width: 0;
  width: fit-content;
  min-height: 0;
  padding: 16px 42px 14px;
  border-radius: 999px;
  border: 1px solid rgba(185, 154, 98, 0.24);
  text-align: left;
  overflow: hidden;
  isolation: isolate;
  background: rgba(10, 13, 19, 0.22);
  box-shadow: inset 0 1px 0 rgba(255, 244, 226, 0.04);
  transition: transform 180ms ease, border-color 180ms ease, background 180ms ease;
}

.wish-trigger:hover {
  transform: translateY(-2px);
  border-color: rgba(217, 194, 154, 0.42);
  background: rgba(18, 22, 29, 0.38);
}

.wish-trigger::before,
.wish-trigger::after {
  content: "";
  position: absolute;
  top: 50%;
  width: 34px;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(217, 194, 154, 0.72));
  transform: translateY(-50%);
}

.wish-trigger::before {
  left: 10px;
}

.wish-trigger::after {
  right: 10px;
  transform: translateY(-50%) scaleX(-1);
}

.wish-trigger-meta,
.wish-trigger-main,
.wish-trigger small {
  display: block;
}

.wish-trigger-meta {
  color: rgba(217, 194, 154, 0.78);
  font-family: var(--sans);
  font-size: 11px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
}

.wish-trigger-main {
  margin-top: 8px;
  color: rgba(248, 238, 221, 0.96);
  font-size: clamp(20px, 2vw, 28px);
  line-height: 1.12;
}

.wish-trigger small {
  margin-top: 6px;
  color: rgba(236, 226, 207, 0.76);
  font-family: var(--sans);
  font-size: 11px;
  line-height: 1.7;
}

.wish-trigger--lantern {
  background:
    radial-gradient(circle at 50% 50%, rgba(240, 188, 92, 0.12), transparent 46%),
    rgba(10, 13, 19, 0.18);
}

.wish-trigger--lantern::after {
  background: linear-gradient(90deg, transparent, rgba(240, 188, 92, 0.92), rgba(255, 237, 199, 0.78));
}

.wish-trigger.is-featured {
  border-color: rgba(236, 198, 120, 0.3);
  box-shadow: inset 0 1px 0 rgba(255, 244, 226, 0.08), 0 0 28px rgba(240, 188, 92, 0.08);
}

.wish-table-sanctum {
  position: relative;
  z-index: 1;
  width: min(1120px, 100%);
  margin: 0 auto;
  display: grid;
  justify-items: center;
  text-align: center;
}

.wish-table-mark {
  position: relative;
  z-index: 2;
  display: grid;
  justify-items: center;
  gap: 8px;
  margin-top: 24px;
  min-height: 84px;
}

.wish-table-mark .intro-en {
  margin: 0;
  padding: 0 16px;
  color: rgba(217, 194, 154, 0.82);
  letter-spacing: 0.12em;
  background: linear-gradient(90deg, rgba(20, 16, 12, 0), rgba(20, 16, 12, 0.86) 18%, rgba(20, 16, 12, 0.86) 82%, rgba(20, 16, 12, 0));
}

.wish-table-sanctum::before,
.wish-table-sanctum::after {
  content: "";
  display: none;
  position: absolute;
  left: 4%;
  right: 4%;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(185, 154, 98, 0.34), transparent);
}

.wish-table-sanctum::before {
  top: 54px;
}

.wish-table-sanctum::after {
  bottom: 26px;
}

.wish-table-stage {
  position: relative;
  width: min(100%, 1020px);
  display: grid;
  justify-items: center;
  gap: 0;
  margin-top: 42px;
  margin-bottom: 0;
  padding-bottom: 64px;
  overflow: visible;
  --wish-radiance-origin-x: 50%;
  --wish-radiance-origin-y: 50%;
}

.wish-table-celestial {
  position: absolute;
  inset: -116px -12% -24px;
  z-index: 0;
  pointer-events: none;
  overflow: hidden;
  --wish-stage-flight-scale: 1;
  --wish-impact-x: 50%;
  --wish-impact-y: 76%;
}

.wish-table-celestial::before,
.wish-table-celestial::after {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
}

.wish-table-celestial::before {
  background-image:
    radial-gradient(circle at 8% 18%, rgba(255, 248, 233, 0.92) 0 1.2px, transparent 2.1px),
    radial-gradient(circle at 17% 31%, rgba(255, 229, 179, 0.56) 0 1px, transparent 1.9px),
    radial-gradient(circle at 27% 11%, rgba(255, 248, 233, 0.82) 0 1.1px, transparent 2px),
    radial-gradient(circle at 36% 26%, rgba(255, 229, 179, 0.58) 0 1px, transparent 1.8px),
    radial-gradient(circle at 48% 7%, rgba(255, 247, 232, 0.88) 0 1.2px, transparent 2px),
    radial-gradient(circle at 58% 22%, rgba(255, 229, 179, 0.54) 0 1px, transparent 1.8px),
    radial-gradient(circle at 67% 13%, rgba(255, 247, 232, 0.84) 0 1.15px, transparent 2px),
    radial-gradient(circle at 76% 29%, rgba(255, 229, 179, 0.56) 0 1px, transparent 1.8px),
    radial-gradient(circle at 88% 15%, rgba(255, 247, 232, 0.8) 0 1.1px, transparent 1.95px),
    radial-gradient(circle at 92% 34%, rgba(255, 229, 179, 0.48) 0 1px, transparent 1.8px),
    radial-gradient(circle at 11% 62%, rgba(255, 244, 221, 0.72) 0 1.1px, transparent 2px),
    radial-gradient(circle at 22% 74%, rgba(255, 223, 166, 0.44) 0 1px, transparent 1.8px),
    radial-gradient(circle at 41% 57%, rgba(255, 244, 221, 0.66) 0 1.1px, transparent 2px),
    radial-gradient(circle at 63% 66%, rgba(255, 223, 166, 0.44) 0 1px, transparent 1.8px),
    radial-gradient(circle at 84% 60%, rgba(255, 244, 221, 0.7) 0 1.1px, transparent 2px),
    radial-gradient(circle at 95% 78%, rgba(255, 223, 166, 0.4) 0 1px, transparent 1.8px);
  opacity: 0.74;
  filter: blur(0.15px);
  animation: cosmosDrift 22s ease-in-out infinite alternate;
}

.wish-table-celestial::after {
  background-image:
    radial-gradient(circle at 16% 22%, rgba(255, 225, 168, 0.16) 0 28px, transparent 88px),
    radial-gradient(circle at 82% 18%, rgba(255, 220, 160, 0.14) 0 32px, transparent 96px),
    radial-gradient(circle at 24% 70%, rgba(255, 210, 128, 0.1) 0 34px, transparent 110px),
    radial-gradient(circle at 78% 68%, rgba(255, 210, 128, 0.1) 0 34px, transparent 112px),
    radial-gradient(circle at 50% 48%, rgba(255, 223, 166, 0.08) 0 42px, transparent 126px);
  opacity: 0.4;
  filter: blur(18px);
  animation: haloBreath 10s ease-in-out infinite;
}

.wish-table-radiance {
  display: none;
}

.wish-table-radiance-wave {
  position: absolute;
  left: var(--wish-radiance-origin-x);
  top: var(--wish-radiance-origin-y);
  width: 1460px;
  height: 1460px;
  border-radius: 50%;
  transform: translate(-50%, -50%) scale(0.12);
  background:
    radial-gradient(circle at center,
      rgba(255, 246, 224, 0.38) 0,
      rgba(255, 230, 176, 0.3) 16%,
      rgba(255, 217, 144, 0.22) 32%,
      rgba(201, 138, 52, 0.12) 48%,
      rgba(201, 138, 52, 0.05) 64%,
      transparent 82%);
  filter: blur(42px);
  opacity: 0;
  will-change: transform, opacity;
  animation: wishRadianceWave 11.2s ease-out infinite;
}

.wish-table-radiance-wave--2 {
  animation-delay: 3.7s;
}

.wish-table-radiance-wave--3 {
  animation-delay: 7.4s;
}

.wish-table-title {
  position: relative;
  z-index: 1;
  margin: 0;
  display: grid;
  justify-items: center;
  gap: 0.06em;
  max-width: none;
  color: rgba(248, 238, 221, 0.98);
  font-family: var(--hero-title-display);
  font-size: clamp(30px, 3.25vw, 50px);
  line-height: 1.12;
  letter-spacing: -0.02em;
}

.wish-table-title span {
  display: block;
  white-space: nowrap;
}

.wish-table-title .wish-title-mobile-line {
  display: none;
}

@media (min-width: 761px) {
  html[lang="de"] body.home-page #wishTitle {
    width: min(100%, 29ch);
    max-width: min(100%, 29ch);
    margin-inline: auto;
  }

  html[lang="de"] body.home-page #wishTitle span {
    white-space: normal;
    text-wrap: balance;
    overflow-wrap: break-word;
  }
}

.wish-kicker {
  position: relative;
  z-index: 2;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 16px;
  margin: 0;
  padding: 0 20px;
  transform: translateY(10px);
  background: linear-gradient(90deg, rgba(20, 16, 12, 0), rgba(20, 16, 12, 0.92) 14%, rgba(20, 16, 12, 0.92) 86%, rgba(20, 16, 12, 0));
}

.wish-kicker span {
  padding: 10px 20px;
  border-radius: 999px;
  color: rgba(252, 239, 215, 0.96);
  font-family: var(--sans);
  font-size: 12px;
  letter-spacing: 0.18em;
  background: linear-gradient(180deg, rgba(120, 62, 43, 0.5), rgba(80, 35, 25, 0.34));
  border: 1px solid rgba(185, 154, 98, 0.22);
  box-shadow: inset 0 1px 0 rgba(255, 244, 226, 0.08);
}

.wish-kicker em {
  color: rgba(217, 194, 154, 0.76);
  font-family: var(--sans);
  font-size: 12px;
  font-style: normal;
  letter-spacing: 0.24em;
  text-transform: uppercase;
}

.wish-table-intro {
  position: relative;
  z-index: 1;
  max-width: 52rem;
  margin: 20px auto 0;
  color: var(--text-soft);
  font-family: var(--sans);
  font-size: 15px;
  line-height: 1.95;
}

.wish-table-scene {
  position: relative;
  z-index: 1;
  width: min(100%, 960px);
  height: 408px;
  margin-top: 82px;
  margin-bottom: 0;
  --wish-scene-center-y: 220px;
  --wish-orbit-shift-y: 140px;
  --wish-pulse-origin-y: 55.5%;
  overflow: visible;
}

.wish-table-scene::before,
.wish-table-scene::after {
  content: "";
  display: block;
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  pointer-events: none;
}

.wish-table-scene::before {
  top: 12px;
  width: 860px;
  height: 600px;
  border-radius: 50%;
  background:
    radial-gradient(ellipse at center, rgba(255, 248, 224, 0.34) 0, rgba(255, 224, 158, 0.3) 18%, rgba(229, 159, 60, 0.22) 36%, rgba(118, 72, 29, 0.09) 58%, transparent 80%),
    radial-gradient(ellipse at center, rgba(255, 252, 242, 0.18) 0, transparent 58%);
  filter: blur(40px);
  opacity: 1;
  animation: wishLightBreath 7s ease-in-out infinite;
}

.wish-table-scene::after {
  top: auto;
  bottom: 28px;
  width: 620px;
  height: 260px;
  border-radius: 50%;
  background:
    radial-gradient(circle at center, rgba(255, 235, 182, 0.34) 0, rgba(255, 208, 112, 0.22) 24%, rgba(180, 114, 40, 0.12) 44%, rgba(180, 114, 40, 0.03) 60%, transparent 76%),
    radial-gradient(circle at center, rgba(255, 248, 229, 0.12) 0, transparent 54%);
  filter: blur(36px);
  opacity: 0.84;
  animation: wishLightBreath 6s ease-in-out infinite reverse;
}

.wish-table-aura,
.wish-table-pulse,
.wish-table-dust,
.wish-table-mist,
.wish-table-object,
.wish-table-altar,
.wish-table-shadow {
  position: absolute;
}

.wish-table-dust,
.wish-table-mist {
  inset: 0;
  pointer-events: none;
}

.wish-table-aura {
  z-index: 1;
  left: 50%;
  bottom: 34px;
  width: 760px;
  height: 320px;
  transform: translateX(-50%);
  border-radius: 50%;
  background:
    radial-gradient(circle at center, rgba(255, 241, 198, 0.42), transparent 20%),
    radial-gradient(circle at center, rgba(244, 199, 118, 0.3), transparent 40%),
    radial-gradient(circle at center, rgba(108, 76, 42, 0.16), transparent 72%);
  filter: blur(48px);
  opacity: 1;
  animation: haloBreath 6.8s ease-in-out infinite;
  overflow: visible;
}

.wish-table-pulse {
  z-index: 2;
  inset: -18% -8% -12%;
  pointer-events: none;
  overflow: visible;
  mix-blend-mode: normal;
  display: block;
  opacity: 1;
}

.wish-table-pulse-ring {
  position: absolute;
  left: 50%;
  top: var(--wish-pulse-origin-y);
  width: 1120px;
  height: 1120px;
  border-radius: 50%;
  transform: translate(-50%, -50%) scale(0.1);
  background:
    radial-gradient(circle at center,
      rgba(255, 248, 232, 0) 0 26%,
      rgba(255, 243, 215, 0.04) 34%,
      rgba(255, 229, 177, 0.1) 44%,
      rgba(239, 184, 83, 0.16) 54%,
      rgba(189, 124, 41, 0.06) 68%,
      rgba(189, 124, 41, 0.012) 80%,
      transparent 90%);
  box-shadow:
    0 0 180px rgba(244, 196, 104, 0.28),
    inset 0 0 72px rgba(255, 240, 207, 0.08);
  filter: blur(30px);
  opacity: 0;
  will-change: transform, opacity, filter;
  animation: wishPulseExpand 11.2s ease-out infinite;
}

.wish-table-pulse-ring--2 {
  animation-delay: 2.8s;
}

.wish-table-pulse-ring--3 {
  animation-delay: 5.6s;
}

.wish-table-pulse-ring--4 {
  animation-delay: 8.4s;
}

.wish-table-dust {
  z-index: 3;
}

.wish-table-mist {
  z-index: 2;
}

.wish-table-dust-dot,
.wish-table-mist-band {
  position: absolute;
}

.wish-table-comet {
  position: absolute;
  left: calc(var(--wish-impact-x) - var(--comet-length));
  top: calc(var(--wish-impact-y) - 1px);
  width: var(--comet-length);
  height: var(--comet-size, 2px);
  border-radius: 999px;
  transform-origin: 100% 50%;
  background: linear-gradient(90deg, rgba(255, 221, 158, 0), rgba(255, 221, 158, 0.08) 28%, rgba(255, 231, 188, 0.34) 54%, rgba(255, 244, 221, 0.86) 82%, rgba(255, 252, 247, 1) 100%);
  filter: blur(0.2px) drop-shadow(0 0 8px rgba(255, 225, 168, 0.18));
  opacity: 0;
  animation: wishCometRush var(--comet-duration, 5.8s) ease-in-out infinite;
  animation-delay: var(--comet-delay, 0s);
}

.wish-table-comet::after {
  content: "";
  position: absolute;
  right: -2px;
  top: 50%;
  width: var(--comet-head, 8px);
  height: var(--comet-head, 8px);
  border-radius: 50%;
  transform: translate(50%, -50%);
  background: radial-gradient(circle at center, rgba(255, 251, 246, 1), rgba(255, 224, 163, 0.7) 60%, transparent 84%);
  box-shadow: 0 0 16px rgba(255, 226, 171, 0.32);
}

.wish-table-comet--1 {
  --comet-length: 168px;
  --comet-from-x: -520px;
  --comet-from-y: -320px;
  --comet-angle: 32deg;
  --comet-delay: -0.8s;
}

.wish-table-comet--2 {
  --comet-length: 144px;
  --comet-from-x: -140px;
  --comet-from-y: -430px;
  --comet-angle: 72deg;
  --comet-delay: -3.4s;
}

.wish-table-comet--3 {
  --comet-length: 178px;
  --comet-from-x: 160px;
  --comet-from-y: -420px;
  --comet-angle: 111deg;
  --comet-delay: -1.9s;
}

.wish-table-comet--4 {
  --comet-length: 138px;
  --comet-from-x: -560px;
  --comet-from-y: -40px;
  --comet-angle: 4deg;
  --comet-delay: -4.8s;
}

.wish-table-comet--5 {
  --comet-length: 150px;
  --comet-from-x: 560px;
  --comet-from-y: -30px;
  --comet-angle: 176deg;
  --comet-delay: -2.6s;
}

.wish-table-comet--6 {
  --comet-length: 132px;
  --comet-from-x: -360px;
  --comet-from-y: 240px;
  --comet-angle: -34deg;
  --comet-delay: -5.2s;
}

.wish-table-comet--7 {
  --comet-length: 126px;
  --comet-from-x: 360px;
  --comet-from-y: 220px;
  --comet-angle: -148deg;
  --comet-delay: -1.2s;
}

.wish-table-comet--8 {
  --comet-length: 118px;
  --comet-from-x: 0px;
  --comet-from-y: -520px;
  --comet-angle: 90deg;
  --comet-delay: -6.1s;
}

.wish-table-dust-dot {
  border-radius: 50%;
  background:
    radial-gradient(circle at 40% 38%, rgba(255, 249, 236, 0.96), rgba(255, 220, 150, 0.68) 42%, rgba(255, 220, 150, 0.08) 74%, transparent 100%);
  box-shadow:
    0 0 12px rgba(255, 223, 162, 0.3),
    0 0 24px rgba(235, 183, 94, 0.14);
  opacity: 0;
  animation: wishDustFloat 9s ease-in-out infinite;
}

.wish-table-dust-dot--1 {
  left: 39%;
  top: 122px;
  width: 8px;
  height: 8px;
  animation-delay: -1.2s;
}

.wish-table-dust-dot--2 {
  left: 45%;
  top: 90px;
  width: 5px;
  height: 5px;
  animation-delay: -4.4s;
}

.wish-table-dust-dot--3 {
  left: 54%;
  top: 118px;
  width: 7px;
  height: 7px;
  animation-delay: -2.8s;
}

.wish-table-dust-dot--4 {
  left: 58%;
  top: 164px;
  width: 6px;
  height: 6px;
  animation-delay: -6.1s;
}

.wish-table-dust-dot--5 {
  left: 43%;
  top: 198px;
  width: 4px;
  height: 4px;
  animation-delay: -3.6s;
}

.wish-table-dust-dot--6 {
  left: 52%;
  top: 212px;
  width: 5px;
  height: 5px;
  animation-delay: -5.2s;
}

.wish-table-dust-dot--7 {
  left: 48%;
  top: 146px;
  width: 10px;
  height: 10px;
  animation-delay: -7s;
}

.wish-table-mist-band {
  top: 146px;
  width: 220px;
  height: 132px;
  border-radius: 50%;
  background:
    radial-gradient(ellipse at center, rgba(255, 222, 163, 0.16) 0, rgba(255, 210, 128, 0.08) 36%, rgba(92, 56, 20, 0.04) 58%, transparent 82%);
  filter: blur(24px);
  opacity: 0.34;
  mix-blend-mode: screen;
  animation: wishMistDrift 10s ease-in-out infinite;
}

.wish-table-mist-band--left {
  left: 25%;
  transform: translateX(-50%);
  animation-delay: -3s;
}

.wish-table-mist-band--center {
  left: 50%;
  width: 290px;
  height: 170px;
  transform: translateX(-50%);
  opacity: 0.42;
  animation-delay: -1s;
}

.wish-table-mist-band--right {
  left: 75%;
  transform: translateX(-50%);
  animation-delay: -5s;
}

.wish-table-object {
  bottom: 164px;
  width: 92px;
  height: 96px;
  opacity: 0.42;
  filter: saturate(0.8);
}

.wish-table-object--incense {
  left: 164px;
}

.wish-table-object--jade {
  right: 164px;
}

.wish-table-stick,
.wish-table-smoke,
.wish-table-jade-core,
.wish-table-jade-ring {
  position: absolute;
}

.wish-table-stick {
  bottom: 4px;
  width: 1px;
  background: linear-gradient(180deg, rgba(200, 137, 94, 0.52), rgba(88, 44, 26, 0.58));
  box-shadow: 0 0 10px rgba(183, 124, 84, 0.1);
}

.wish-table-stick--1 {
  left: 24px;
  height: 46px;
}

.wish-table-stick--2 {
  left: 44px;
  height: 64px;
}

.wish-table-stick--3 {
  left: 64px;
  height: 50px;
}

.wish-table-smoke {
  width: 26px;
  height: 46px;
  border-radius: 50%;
  border-top: 1px solid rgba(217, 194, 154, 0.12);
  border-left: 1px solid transparent;
  border-right: 1px solid transparent;
  filter: blur(0.2px);
  opacity: 0.34;
}

.wish-table-smoke--1 {
  left: 10px;
  top: 8px;
  transform: rotate(-12deg);
}

.wish-table-smoke--2 {
  left: 28px;
  top: -2px;
}

.wish-table-smoke--3 {
  left: 46px;
  top: 6px;
  transform: rotate(14deg);
}

.wish-table-jade-core {
  left: 50%;
  top: 24px;
  width: 54px;
  height: 54px;
  transform: translateX(-50%);
  border-radius: 50%;
  background:
    radial-gradient(circle at 34% 30%, rgba(220, 244, 228, 0.52), rgba(98, 142, 122, 0.34) 44%, rgba(28, 38, 34, 0.16) 76%);
  box-shadow: inset 0 0 12px rgba(241, 255, 244, 0.06), 0 0 18px rgba(107, 156, 131, 0.08);
}

.wish-table-jade-ring {
  left: 50%;
  top: 14px;
  width: 78px;
  height: 78px;
  transform: translateX(-50%);
  border-radius: 50%;
  border: 1px solid rgba(184, 214, 193, 0.14);
}

.wish-table-altar {
  left: 50%;
  bottom: 34px;
  width: 620px;
  height: 260px;
  --wish-altar-center-y: 106px;
  transform: translateX(-50%);
  overflow: visible;
}

.wish-table-altar::before,
.wish-table-altar::after {
  content: "";
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  pointer-events: none;
}

.wish-table-altar::before {
  display: none;
  top: calc(var(--wish-altar-center-y) - 180px + var(--wish-orbit-shift-y));
  width: 360px;
  height: 360px;
  border-radius: 50%;
  border: 1px solid rgba(185, 154, 98, 0.14);
  background:
    radial-gradient(circle at center, transparent 33%, rgba(217, 194, 154, 0.18) 33.5%, transparent 34.2%),
    radial-gradient(circle at center, transparent 49%, rgba(217, 194, 154, 0.12) 49.5%, transparent 50.2%),
    radial-gradient(circle at center, rgba(255, 224, 163, 0.12), transparent 18%);
  box-shadow:
    inset 0 0 0 1px rgba(255, 244, 226, 0.04),
    0 0 60px rgba(224, 176, 91, 0.06);
  animation: slowSpinReverse 42s linear infinite;
}

.wish-table-altar::after {
  display: none;
  top: calc(var(--wish-altar-center-y) - 235px + var(--wish-orbit-shift-y));
  width: 470px;
  height: 470px;
  border-radius: 50%;
  border: 1px solid rgba(217, 194, 154, 0.08);
  background:
    radial-gradient(circle at center, transparent 66%, rgba(217, 194, 154, 0.08) 66.4%, transparent 67%),
    repeating-conic-gradient(from 0deg, rgba(217, 194, 154, 0) 0 30deg, rgba(217, 194, 154, 0.06) 30deg 31deg, rgba(217, 194, 154, 0) 31deg 60deg);
  animation: slowSpin 60s linear infinite;
}

.wish-table-altar-line,
.wish-table-flame,
.wish-table-glyph {
  position: absolute;
}

.wish-table-altar-line {
  left: 50%;
  border-radius: 50%;
}

.wish-table-altar-line--top {
  display: none;
  top: calc(var(--wish-altar-center-y) + var(--wish-orbit-shift-y));
  width: 248px;
  height: 248px;
  transform: translate(-50%, -50%);
  border: 1px solid rgba(217, 194, 154, 0.16);
  background: radial-gradient(circle at center, transparent 72%, rgba(217, 194, 154, 0.06) 72.4%, transparent 73%);
}

.wish-table-altar-line--bottom {
  display: none;
  top: calc(var(--wish-altar-center-y) + var(--wish-orbit-shift-y));
  width: 324px;
  height: 324px;
  transform: translate(-50%, -50%);
  border: 1px solid rgba(217, 194, 154, 0.08);
  background: radial-gradient(circle at center, transparent 82%, rgba(217, 194, 154, 0.04) 82.4%, transparent 83%);
}

.wish-table-lamp {
  position: absolute;
  left: 50%;
  top: 18px;
  width: 176px;
  height: 176px;
  transform: translateX(-50%);
  border-radius: 50%;
  border: 1px solid rgba(185, 154, 98, 0.2);
  background:
    radial-gradient(circle at 50% 32%, rgba(255, 239, 205, 0.22), rgba(255, 239, 205, 0.06) 24%, transparent 58%),
    radial-gradient(circle at 50% 68%, rgba(16, 18, 25, 0.92), rgba(11, 14, 20, 0.98) 76%);
  box-shadow:
    inset 0 0 0 1px rgba(255, 244, 226, 0.04),
    inset 0 0 68px rgba(255, 208, 119, 0.16),
    0 0 64px rgba(235, 180, 88, 0.18),
    0 14px 38px rgba(0, 0, 0, 0.24);
}

.wish-table-flame {
  left: 50%;
  top: 30px;
  width: 46px;
  height: 76px;
  transform: translateX(-50%);
  border-radius: 50% 50% 36% 36%;
  background: linear-gradient(180deg, rgba(255, 239, 205, 0.98), rgba(221, 167, 89, 0.86) 56%, rgba(104, 59, 28, 0.08) 100%);
  clip-path: polygon(50% 0, 82% 28%, 100% 72%, 50% 100%, 0 72%, 18% 28%);
  filter: drop-shadow(0 0 36px rgba(234, 187, 93, 0.58));
  animation: altarFlame 4.2s ease-in-out infinite;
}

.wish-table-glyph {
  left: 50%;
  bottom: 30px;
  transform: translateX(-50%);
  color: rgba(252, 242, 219, 0.94);
  font-size: 44px;
  letter-spacing: 0.12em;
  text-shadow: 0 0 18px rgba(255, 228, 176, 0.18), 0 0 32px rgba(255, 214, 138, 0.08);
}

.wish-table-shadow {
  display: none;
  left: 50%;
  bottom: 6px;
  width: 300px;
  height: 50px;
  transform: translateX(-50%);
  border-radius: 50%;
  background: radial-gradient(circle at center, rgba(0, 0, 0, 0.3), transparent 72%);
}

.wish-table-lead {
  margin: 0;
  max-width: 56rem;
  color: rgba(248, 238, 221, 0.94);
  font-size: clamp(22px, 2.1vw, 32px);
  line-height: 1.5;
}

.wish-table-streams {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 10px 18px;
  max-width: 54rem;
  margin-top: 18px;
}

.wish-table-streams span {
  position: relative;
  padding-left: 14px;
  color: rgba(244, 236, 220, 0.92);
  font-family: var(--sans);
  font-size: 13px;
  letter-spacing: 0.1em;
}

.wish-table-streams span::before {
  content: "";
  position: absolute;
  left: 0;
  top: 50%;
  width: 5px;
  height: 5px;
  border-radius: 50%;
  background: rgba(217, 194, 154, 0.88);
  transform: translateY(-50%);
}

.wish-table-process {
  margin: 18px 0 0;
  color: rgba(217, 194, 154, 0.74);
  font-family: var(--sans);
  font-size: 11px;
  letter-spacing: 0.24em;
  text-transform: uppercase;
}

.wish-table-entry {
  position: relative;
  display: grid;
  align-content: center;
  justify-items: center;
  width: fit-content;
  max-width: 100%;
  min-width: 0;
  min-height: 0;
  margin-top: 34px;
  margin-bottom: 14px;
  padding: 0;
  border: 0;
  background: none;
  color: rgba(248, 238, 221, 0.96);
  text-align: center;
  overflow: visible;
  isolation: isolate;
  appearance: none;
  box-shadow: none;
  cursor: pointer;
  transition: transform 240ms ease, opacity 240ms ease, filter 240ms ease;
  background-image: none !important;
}

.wish-table-entry::before,
.wish-table-entry::after {
  content: "";
  position: absolute;
  pointer-events: none;
  background: none !important;
  border: 0 !important;
  box-shadow: none !important;
}

.wish-table-entry:hover {
  transform: translateY(-2px);
  filter: brightness(1.08);
}

.wish-table-entry:focus-visible {
  outline: none;
}

.wish-table-entry span,
.wish-table-entry strong,
.wish-table-entry small {
  display: block;
  position: relative;
  z-index: 1;
}

.wish-table-entry span {
  color: rgba(217, 194, 154, 0.82);
  font-family: var(--sans);
  font-size: 10px;
  letter-spacing: 0.24em;
  text-transform: uppercase;
}

.wish-table-entry strong {
  margin-top: 6px;
  position: relative;
  isolation: isolate;
  overflow: visible;
  font-size: clamp(24px, 2.1vw, 36px);
  line-height: 1.02;
  color: rgba(251, 242, 220, 0.98);
  text-shadow:
    0 0 12px rgba(255, 233, 177, 0.2),
    0 0 28px rgba(247, 194, 91, 0.2),
    0 0 46px rgba(255, 118, 26, 0.12);
}

.wish-table-entry small {
  margin-top: 6px;
  color: rgba(217, 194, 154, 0.72);
  font-family: var(--sans);
  font-size: 9px;
  line-height: 1.3;
  letter-spacing: 0.1em;
}

.wish-table-entry--portal {
  min-width: 420px;
  padding: 11px 24px 12px;
  border: 1px solid rgba(217, 194, 154, 0.34);
  border-radius: 22px;
  overflow: hidden;
  background:
    radial-gradient(74px 110px at 16% 76%, rgba(255, 119, 28, 0.22), transparent 54%),
    radial-gradient(46px 74px at 18% 69%, rgba(255, 205, 104, 0.22), transparent 55%),
    radial-gradient(24px 46px at 15% 82%, rgba(255, 86, 24, 0.26), transparent 66%),
    radial-gradient(20px 38px at 20% 60%, rgba(255, 229, 147, 0.18), transparent 64%),
    radial-gradient(112px 70px at 26% 84%, rgba(255, 171, 56, 0.11), transparent 69%),
    linear-gradient(180deg, rgba(122, 89, 46, 0.22), rgba(45, 30, 14, 0.42)),
    rgba(18, 12, 6, 0.26);
  box-shadow:
    0 14px 28px rgba(10, 7, 4, 0.24),
    inset 0 1px 0 rgba(255, 241, 211, 0.1);
  backdrop-filter: blur(12px);
}

.wish-table-entry--portal::before {
  inset: 0;
  border-radius: inherit;
  border: 1px solid rgba(255, 233, 186, 0.12) !important;
  background:
    radial-gradient(92px 142px at 16% 82%, rgba(255, 116, 22, 0.3), transparent 52%),
    radial-gradient(52px 92px at 18% 71%, rgba(255, 214, 116, 0.24), transparent 56%),
    radial-gradient(22px 46px at 17% 61%, rgba(255, 245, 205, 0.22), transparent 62%),
    radial-gradient(54px 88px at 81% 78%, rgba(255, 124, 34, 0.16), transparent 58%),
    radial-gradient(26px 44px at 79% 68%, rgba(255, 215, 122, 0.16), transparent 58%) !important;
  opacity: 0.92;
  filter: blur(0.6px) saturate(1.08);
  animation: wishPortalFlameSurge 3.4s ease-in-out infinite;
}

.wish-table-entry--portal::after {
  inset: 8px;
  border-radius: 16px;
  background:
    radial-gradient(48px 86px at 18% 79%, rgba(255, 170, 74, 0.2), transparent 58%),
    radial-gradient(20px 40px at 17% 76%, rgba(255, 244, 196, 0.2), transparent 62%),
    radial-gradient(42px 76px at 82% 79%, rgba(255, 153, 61, 0.12), transparent 58%),
    radial-gradient(18px 34px at 80% 74%, rgba(255, 228, 164, 0.1), transparent 62%),
    radial-gradient(34px 58px at 18% 76%, rgba(255, 190, 86, 0.16), transparent 60%),
    radial-gradient(16px 30px at 16% 78%, rgba(255, 243, 176, 0.14), transparent 64%),
    linear-gradient(135deg, rgba(255, 227, 177, 0.08), transparent 52%),
    linear-gradient(225deg, rgba(235, 184, 87, 0.08), transparent 60%) !important;
  opacity: 0.96;
  filter: blur(0.2px);
  animation: wishPortalEmberDrift 2.4s ease-in-out infinite;
}

.wish-table-entry--portal strong::before,
.wish-table-entry--portal strong::after {
  content: "";
  position: absolute;
  pointer-events: none;
  left: -0.7em;
  right: -0.7em;
  top: -0.52em;
  bottom: -0.14em;
}

.wish-table-entry--portal strong::before {
  z-index: -1;
  background:
    radial-gradient(34px 92px at 10% 100%, rgba(255, 133, 28, 0.52), transparent 58%),
    radial-gradient(24px 58px at 15% 84%, rgba(255, 228, 161, 0.42), transparent 56%),
    radial-gradient(30px 88px at 28% 100%, rgba(255, 110, 20, 0.48), transparent 58%),
    radial-gradient(18px 50px at 32% 80%, rgba(255, 239, 192, 0.4), transparent 54%),
    radial-gradient(28px 84px at 47% 100%, rgba(255, 136, 30, 0.46), transparent 58%),
    radial-gradient(18px 52px at 51% 79%, rgba(255, 239, 188, 0.38), transparent 54%),
    radial-gradient(30px 86px at 66% 100%, rgba(255, 117, 24, 0.46), transparent 58%),
    radial-gradient(18px 52px at 70% 78%, rgba(255, 236, 180, 0.36), transparent 55%),
    radial-gradient(34px 92px at 86% 100%, rgba(255, 139, 34, 0.5), transparent 58%),
    radial-gradient(20px 56px at 82% 82%, rgba(255, 240, 196, 0.38), transparent 56%);
  opacity: 0.92;
  filter: blur(8px) saturate(1.2);
  transform-origin: 50% 100%;
  animation: wishPortalTitleBlaze 1.9s ease-in-out infinite;
}

.wish-table-entry--portal strong::after {
  z-index: 2;
  background:
    radial-gradient(16px 44px at 12% 92%, rgba(255, 250, 220, 0.28), transparent 56%),
    radial-gradient(18px 46px at 29% 92%, rgba(255, 206, 110, 0.22), transparent 58%),
    radial-gradient(18px 44px at 48% 90%, rgba(255, 248, 219, 0.24), transparent 56%),
    radial-gradient(18px 46px at 68% 92%, rgba(255, 201, 108, 0.22), transparent 58%),
    radial-gradient(16px 44px at 86% 92%, rgba(255, 246, 210, 0.26), transparent 56%);
  mix-blend-mode: screen;
  opacity: 0.86;
  filter: blur(3px) saturate(1.18);
  transform-origin: 50% 100%;
  animation: wishPortalTitleFlicker 1.15s linear infinite;
}

.wish-table-entry--portal:hover {
  transform: translateY(-3px) scale(1.01);
  filter: brightness(1.12);
  border-color: rgba(235, 210, 161, 0.56);
  box-shadow:
    0 18px 34px rgba(10, 7, 4, 0.3),
    0 0 0 1px rgba(255, 227, 177, 0.12),
    inset 0 1px 0 rgba(255, 241, 211, 0.14);
}

.wish-table-entry--portal:focus-visible {
  box-shadow:
    0 0 0 3px rgba(255, 225, 171, 0.18),
    0 18px 34px rgba(10, 7, 4, 0.3),
    inset 0 1px 0 rgba(255, 241, 211, 0.14);
}

@keyframes wishPortalFlameSurge {
  0%, 100% {
    transform: translate3d(0, 0, 0) scale(1);
    opacity: 0.88;
    filter: blur(0.9px) saturate(1.02) brightness(0.96);
  }
  28% {
    transform: translate3d(3px, -1px, 0) scale(1.05, 1.08);
    opacity: 1;
    filter: blur(0.2px) saturate(1.12) brightness(1.12);
  }
  56% {
    transform: translate3d(-2px, 1px, 0) scale(0.98, 1.02);
    opacity: 0.9;
    filter: blur(1px) saturate(1.08) brightness(1.02);
  }
  78% {
    transform: translate3d(2px, -2px, 0) scale(1.03, 1.05);
    opacity: 0.96;
    filter: blur(0.4px) saturate(1.16) brightness(1.08);
  }
}

@keyframes wishPortalEmberDrift {
  0%, 100% {
    transform: translate3d(0, 0, 0) scale(1);
    opacity: 0.86;
    filter: blur(0.5px) brightness(0.95);
  }
  33% {
    transform: translate3d(2px, -1px, 0) scale(1.06, 1.04);
    opacity: 1;
    filter: blur(0px) brightness(1.14);
  }
  66% {
    transform: translate3d(-1px, 1px, 0) scale(0.97, 1.02);
    opacity: 0.9;
    filter: blur(0.6px) brightness(1.02);
  }
}

@keyframes wishPortalTitleBlaze {
  0%, 100% {
    transform: translate3d(0, 0, 0) scale(0.98, 1);
    opacity: 0.82;
    filter: blur(10px) saturate(1.08) brightness(0.92);
  }
  20% {
    transform: translate3d(-2px, -3px, 0) scale(1.03, 1.12);
    opacity: 0.96;
    filter: blur(7px) saturate(1.2) brightness(1.06);
  }
  45% {
    transform: translate3d(2px, -6px, 0) scale(1.05, 1.2);
    opacity: 1;
    filter: blur(6px) saturate(1.28) brightness(1.14);
  }
  70% {
    transform: translate3d(-1px, -4px, 0) scale(1.01, 1.1);
    opacity: 0.9;
    filter: blur(8px) saturate(1.16) brightness(1.02);
  }
}

@keyframes wishPortalTitleFlicker {
  0%, 100% {
    transform: translate3d(0, 0, 0) scale(0.98, 0.98);
    opacity: 0.68;
    filter: blur(4px) brightness(0.98);
  }
  25% {
    transform: translate3d(1px, -2px, 0) scale(1.06, 1.12);
    opacity: 0.92;
    filter: blur(2px) brightness(1.18);
  }
  50% {
    transform: translate3d(-1px, -4px, 0) scale(1.03, 1.16);
    opacity: 1;
    filter: blur(1px) brightness(1.24);
  }
  75% {
    transform: translate3d(2px, -2px, 0) scale(1.04, 1.08);
    opacity: 0.84;
    filter: blur(3px) brightness(1.08);
  }
}@media (prefers-reduced-motion: reduce){
  .wish-table-entry--portal::before,
  .wish-table-entry--portal::after,
  .wish-table-entry--portal strong::before,
  .wish-table-entry--portal strong::after {
    animation: none;
  }}

.wish-scene::before,
.wish-scene::after,
.wish-mirror-sanctum::before,
.wish-mirror-sanctum::after,
.wish-lunar-sanctum::before,
.wish-lunar-sanctum::after,
.wish-stela-sanctum::before,
.wish-stela-sanctum::after {
  display: none !important;
}

.wish-mirror-sanctum {
  position: relative;
  z-index: 1;
  width: min(1120px, 100%);
  margin: 0 auto;
  display: grid;
  justify-items: center;
  text-align: center;
}

.wish-mirror-sanctum::before,
.wish-mirror-sanctum::after {
  content: "";
  position: absolute;
  left: 4%;
  right: 4%;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(185, 154, 98, 0.34), transparent);
}

.wish-mirror-sanctum::before {
  top: 66px;
}

.wish-mirror-sanctum::after {
  bottom: 26px;
}

.wish-mirror-stage {
  position: relative;
  width: min(100%, 980px);
  display: grid;
  justify-items: center;
  gap: 0;
  margin-top: 18px;
}

.wish-mirror-title {
  margin: 0;
  max-width: 17ch;
  color: rgba(248, 238, 221, 0.98);
  font-size: clamp(40px, 4.4vw, 70px);
  line-height: 1.14;
  letter-spacing: -0.02em;
}

.wish-mirror-intro {
  max-width: 52rem;
  margin: 20px auto 0;
  color: var(--text-soft);
  font-family: var(--sans);
  font-size: 15px;
  line-height: 1.95;
}

.wish-mirror-visual {
  position: relative;
  width: min(100%, 760px);
  height: 470px;
  margin-top: 34px;
}

.wish-bronze-glow,
.wish-bronze-rings,
.wish-bronze-disc,
.wish-bronze-stars {
  position: absolute;
}

.wish-bronze-glow {
  left: 50%;
  top: 50%;
  width: 520px;
  height: 520px;
  transform: translate(-50%, -50%);
  border-radius: 50%;
  background:
    radial-gradient(circle at center, rgba(217, 194, 154, 0.16), transparent 32%),
    radial-gradient(circle at center, rgba(71, 79, 102, 0.08), transparent 54%);
  filter: blur(18px);
}

.wish-bronze-rings {
  inset: 0;
}

.wish-bronze-ring {
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  border-radius: 50%;
}

.wish-bronze-ring--outer {
  width: 460px;
  height: 460px;
  border: 1px solid rgba(185, 154, 98, 0.18);
}

.wish-bronze-ring--middle {
  width: 320px;
  height: 320px;
  border: 1px dashed rgba(217, 194, 154, 0.18);
}

.wish-bronze-ring--inner {
  width: 216px;
  height: 216px;
  border: 1px solid rgba(217, 194, 154, 0.12);
}

.wish-bronze-disc {
  left: 50%;
  top: 50%;
  width: 250px;
  height: 250px;
  transform: translate(-50%, -50%);
  border-radius: 50%;
  border: 1px solid rgba(185, 154, 98, 0.18);
  background:
    radial-gradient(circle at 50% 40%, rgba(255, 239, 205, 0.1), rgba(255, 239, 205, 0.03) 34%, transparent 66%),
    linear-gradient(180deg, rgba(22, 28, 36, 0.62), rgba(10, 12, 18, 0.2));
  box-shadow: inset 0 0 60px rgba(255, 208, 119, 0.05), 0 24px 50px rgba(0, 0, 0, 0.18);
}

.wish-bronze-rune,
.wish-bronze-flame,
.wish-bronze-glyph {
  position: absolute;
}

.wish-bronze-rune {
  color: rgba(232, 218, 191, 0.84);
  font-size: 24px;
  letter-spacing: 0.12em;
}

.wish-bronze-rune--top {
  left: 50%;
  top: 20px;
  transform: translateX(-50%);
}

.wish-bronze-rune--right {
  right: 20px;
  top: 50%;
  transform: translateY(-50%);
}

.wish-bronze-rune--bottom {
  left: 50%;
  bottom: 20px;
  transform: translateX(-50%);
}

.wish-bronze-rune--left {
  left: 20px;
  top: 50%;
  transform: translateY(-50%);
}

.wish-bronze-flame {
  left: 50%;
  top: 56px;
  width: 44px;
  height: 72px;
  transform: translateX(-50%);
  border-radius: 50% 50% 36% 36%;
  background: linear-gradient(180deg, rgba(255, 239, 205, 0.98), rgba(221, 167, 89, 0.86) 56%, rgba(104, 59, 28, 0.08) 100%);
  clip-path: polygon(50% 0, 82% 28%, 100% 72%, 50% 100%, 0 72%, 18% 28%);
  filter: drop-shadow(0 0 18px rgba(234, 187, 93, 0.34));
  animation: altarFlame 4.2s ease-in-out infinite;
}

.wish-bronze-glyph {
  left: 50%;
  bottom: 48px;
  transform: translateX(-50%);
  color: rgba(252, 242, 219, 0.94);
  font-size: 42px;
  letter-spacing: 0.16em;
}

.wish-bronze-stars {
  inset: 0;
  pointer-events: none;
}

.wish-bronze-star {
  position: absolute;
  width: 4px;
  height: 4px;
  border-radius: 50%;
  background: rgba(255, 241, 216, 0.94);
  box-shadow: 0 0 0 8px rgba(255, 241, 216, 0.04);
  animation: starlightPulse 5.5s ease-in-out infinite;
}

.wish-bronze-star--1 { left: 16%; top: 42%; }
.wish-bronze-star--2 { left: 30%; top: 18%; animation-delay: 1s; }
.wish-bronze-star--3 { right: 30%; top: 18%; animation-delay: 2s; }
.wish-bronze-star--4 { right: 16%; top: 46%; animation-delay: 0.8s; }
.wish-bronze-star--5 { left: 50%; bottom: 10%; transform: translateX(-50%); animation-delay: 1.5s; }

.wish-mirror-lead {
  margin: 2px 0 0;
  max-width: 34rem;
  color: rgba(248, 238, 221, 0.94);
  font-size: clamp(22px, 2.1vw, 32px);
  line-height: 1.5;
}

.wish-mirror-streams {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 10px 18px;
  max-width: 54rem;
  margin-top: 18px;
}

.wish-mirror-streams span {
  position: relative;
  padding-left: 14px;
  color: rgba(244, 236, 220, 0.92);
  font-family: var(--sans);
  font-size: 13px;
  letter-spacing: 0.1em;
}

.wish-mirror-streams span::before {
  content: "";
  position: absolute;
  left: 0;
  top: 50%;
  width: 5px;
  height: 5px;
  border-radius: 50%;
  background: rgba(217, 194, 154, 0.88);
  transform: translateY(-50%);
}

.wish-mirror-process {
  margin: 18px 0 0;
  color: rgba(217, 194, 154, 0.74);
  font-family: var(--sans);
  font-size: 11px;
  letter-spacing: 0.24em;
  text-transform: uppercase;
}

.wish-mirror-entry {
  position: relative;
  margin-top: 26px;
  margin-bottom: 40px;
  min-width: 300px;
  padding: 16px 46px 14px;
  border-radius: 999px;
  border: 1px solid rgba(185, 154, 98, 0.28);
  background:
    radial-gradient(circle at 50% 42%, rgba(217, 194, 154, 0.08), transparent 42%),
    rgba(10, 13, 19, 0.22);
  color: rgba(248, 238, 221, 0.96);
  text-align: center;
  overflow: hidden;
  box-shadow: inset 0 1px 0 rgba(255, 244, 226, 0.06), 0 0 24px rgba(217, 194, 154, 0.04);
  transition: transform 180ms ease, border-color 180ms ease, background 180ms ease;
}

.wish-mirror-entry:hover {
  transform: translateY(-2px);
  border-color: rgba(236, 198, 120, 0.44);
  background:
    radial-gradient(circle at 50% 42%, rgba(217, 194, 154, 0.12), transparent 42%),
    rgba(18, 22, 29, 0.38);
}

.wish-mirror-entry::before,
.wish-mirror-entry::after {
  content: "";
  position: absolute;
  top: 50%;
  width: 36px;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(217, 194, 154, 0.68));
  transform: translateY(-50%);
}

.wish-mirror-entry::before {
  left: 14px;
}

.wish-mirror-entry::after {
  right: 14px;
  transform: translateY(-50%) scaleX(-1);
}

.wish-mirror-entry span,
.wish-mirror-entry strong,
.wish-mirror-entry small {
  display: block;
}

.wish-mirror-entry span {
  color: rgba(217, 194, 154, 0.78);
  font-family: var(--sans);
  font-size: 11px;
  letter-spacing: 0.2em;
  text-transform: uppercase;
}

.wish-mirror-entry strong {
  margin-top: 6px;
  font-size: 30px;
  line-height: 1.08;
}

.wish-mirror-entry small {
  margin-top: 4px;
  color: rgba(217, 194, 154, 0.7);
  font-family: var(--sans);
  font-size: 12px;
}

.wish-lunar-sanctum {
  position: relative;
  z-index: 1;
  width: min(1120px, 100%);
  margin: 0 auto;
  display: grid;
  justify-items: center;
  text-align: center;
}

.wish-lunar-sanctum::before,
.wish-lunar-sanctum::after {
  content: "";
  position: absolute;
  left: 4%;
  right: 4%;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(185, 154, 98, 0.34), transparent);
}

.wish-lunar-sanctum::before {
  top: 66px;
}

.wish-lunar-sanctum::after {
  bottom: 26px;
}

.wish-lunar-stage {
  position: relative;
  width: min(100%, 980px);
  min-height: 720px;
  margin-top: 16px;
}

.wish-lunar-crescent {
  position: absolute;
  left: 50%;
  top: 18px;
  width: 180px;
  height: 180px;
  transform: translateX(-50%);
  border-radius: 50%;
  background:
    radial-gradient(circle at 36% 50%, rgba(243, 227, 195, 0.84) 0 44%, transparent 46%),
    radial-gradient(circle at 58% 50%, rgba(9, 12, 18, 1) 0 48%, transparent 50%);
  filter: drop-shadow(0 0 18px rgba(243, 227, 195, 0.08));
  opacity: 0.84;
}

.wish-lunar-title {
  position: relative;
  z-index: 1;
  margin: 0;
  padding-top: 112px;
  max-width: 18ch;
  color: rgba(248, 238, 221, 0.98);
  font-size: clamp(40px, 4.4vw, 70px);
  line-height: 1.14;
  letter-spacing: -0.02em;
}

.wish-lunar-intro {
  position: relative;
  z-index: 1;
  max-width: 52rem;
  margin: 24px auto 0;
  color: var(--text-soft);
  font-family: var(--sans);
  font-size: 15px;
  line-height: 1.95;
}

.wish-lunar-orbits {
  position: absolute;
  left: 50%;
  top: 330px;
  width: 760px;
  height: 340px;
  transform: translateX(-50%);
}

.wish-lunar-orbit,
.wish-lunar-star {
  position: absolute;
}

.wish-lunar-orbit {
  left: 50%;
  top: 50%;
  border-radius: 50%;
  transform: translate(-50%, -50%);
}

.wish-lunar-orbit--outer {
  width: 760px;
  height: 340px;
  border: 1px solid rgba(185, 154, 98, 0.16);
}

.wish-lunar-orbit--mid {
  width: 560px;
  height: 250px;
  border: 1px dashed rgba(217, 194, 154, 0.16);
}

.wish-lunar-orbit--inner {
  width: 360px;
  height: 160px;
  border: 1px solid rgba(217, 194, 154, 0.12);
}

.wish-lunar-star {
  width: 4px;
  height: 4px;
  border-radius: 50%;
  background: rgba(255, 241, 216, 0.94);
  box-shadow: 0 0 0 8px rgba(255, 241, 216, 0.04);
  animation: starlightPulse 5.5s ease-in-out infinite;
}

.wish-lunar-star--1 { left: 10%; top: 44%; }
.wish-lunar-star--2 { left: 24%; top: 22%; animation-delay: 1s; }
.wish-lunar-star--3 { right: 24%; top: 20%; animation-delay: 2s; }
.wish-lunar-star--4 { right: 10%; top: 50%; animation-delay: 0.8s; }
.wish-lunar-star--5 { left: 50%; bottom: 10%; transform: translateX(-50%); animation-delay: 1.5s; }

.wish-lunar-dais {
  position: absolute;
  left: 50%;
  top: 364px;
  width: 320px;
  height: 220px;
  transform: translateX(-50%);
  display: grid;
  place-items: center;
}

.wish-lunar-disc {
  position: relative;
  width: 180px;
  height: 180px;
  border-radius: 50%;
  border: 1px solid rgba(185, 154, 98, 0.18);
  background:
    radial-gradient(circle at 50% 38%, rgba(255, 239, 205, 0.12), rgba(255, 239, 205, 0.03) 34%, transparent 66%),
    linear-gradient(180deg, rgba(18, 22, 29, 0.58), rgba(10, 12, 18, 0.22));
  box-shadow: inset 0 0 56px rgba(255, 208, 119, 0.06), 0 20px 40px rgba(0, 0, 0, 0.16);
}

.wish-lunar-disc::before {
  content: "";
  position: absolute;
  left: 50%;
  bottom: -26px;
  width: 240px;
  height: 18px;
  transform: translateX(-50%);
  border-radius: 999px;
  background: linear-gradient(180deg, rgba(217, 194, 154, 0.16), rgba(80, 62, 42, 0.06));
}

.wish-lunar-flame,
.wish-lunar-glyph {
  position: absolute;
  left: 50%;
}

.wish-lunar-flame {
  top: 26px;
  width: 42px;
  height: 70px;
  transform: translateX(-50%);
  border-radius: 50% 50% 36% 36%;
  background: linear-gradient(180deg, rgba(255, 239, 205, 0.98), rgba(221, 167, 89, 0.86) 56%, rgba(104, 59, 28, 0.08) 100%);
  clip-path: polygon(50% 0, 82% 28%, 100% 72%, 50% 100%, 0 72%, 18% 28%);
  filter: drop-shadow(0 0 20px rgba(234, 187, 93, 0.34));
  animation: altarFlame 4.2s ease-in-out infinite;
}

.wish-lunar-glyph {
  bottom: 22px;
  transform: translateX(-50%);
  color: rgba(252, 242, 219, 0.94);
  font-size: 34px;
  letter-spacing: 0.16em;
}

.wish-lunar-lead {
  margin: 0;
  max-width: 34rem;
  color: rgba(248, 238, 221, 0.94);
  font-size: clamp(22px, 2.1vw, 32px);
  line-height: 1.5;
}

.wish-lunar-streams {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 10px 18px;
  max-width: 54rem;
  margin-top: 18px;
}

.wish-lunar-streams span {
  position: relative;
  padding-left: 14px;
  color: rgba(244, 236, 220, 0.92);
  font-family: var(--sans);
  font-size: 13px;
  letter-spacing: 0.1em;
}

.wish-lunar-streams span::before {
  content: "";
  position: absolute;
  left: 0;
  top: 50%;
  width: 5px;
  height: 5px;
  border-radius: 50%;
  background: rgba(217, 194, 154, 0.88);
  transform: translateY(-50%);
}

.wish-lunar-process {
  margin: 18px 0 0;
  color: rgba(217, 194, 154, 0.74);
  font-family: var(--sans);
  font-size: 11px;
  letter-spacing: 0.24em;
  text-transform: uppercase;
}

.wish-lunar-entry {
  position: relative;
  margin-top: 26px;
  margin-bottom: 40px;
  min-width: 300px;
  padding: 16px 46px 14px;
  border-radius: 999px;
  border: 1px solid rgba(185, 154, 98, 0.28);
  background:
    radial-gradient(circle at 50% 42%, rgba(240, 188, 92, 0.08), transparent 42%),
    rgba(10, 13, 19, 0.22);
  color: rgba(248, 238, 221, 0.96);
  text-align: center;
  overflow: hidden;
  box-shadow: inset 0 1px 0 rgba(255, 244, 226, 0.06), 0 0 24px rgba(240, 188, 92, 0.04);
  transition: transform 180ms ease, border-color 180ms ease, background 180ms ease;
}

.wish-lunar-entry:hover {
  transform: translateY(-2px);
  border-color: rgba(236, 198, 120, 0.44);
  background:
    radial-gradient(circle at 50% 42%, rgba(240, 188, 92, 0.12), transparent 42%),
    rgba(18, 22, 29, 0.38);
}

.wish-lunar-entry::before,
.wish-lunar-entry::after {
  content: "";
  position: absolute;
  top: 50%;
  width: 36px;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(217, 194, 154, 0.68));
  transform: translateY(-50%);
}

.wish-lunar-entry::before {
  left: 14px;
}

.wish-lunar-entry::after {
  right: 14px;
  transform: translateY(-50%) scaleX(-1);
}

.wish-lunar-entry span,
.wish-lunar-entry strong,
.wish-lunar-entry small {
  display: block;
}

.wish-lunar-entry span {
  color: rgba(217, 194, 154, 0.78);
  font-family: var(--sans);
  font-size: 11px;
  letter-spacing: 0.2em;
  text-transform: uppercase;
}

.wish-lunar-entry strong {
  margin-top: 6px;
  font-size: 30px;
  line-height: 1.08;
}

.wish-lunar-entry small {
  margin-top: 4px;
  color: rgba(217, 194, 154, 0.7);
  font-family: var(--sans);
  font-size: 12px;
}

.wish-stela-sanctum {
  position: relative;
  z-index: 1;
  width: min(1120px, 100%);
  margin: 0 auto;
  display: grid;
  justify-items: center;
  text-align: center;
}

.wish-stela-sanctum::before,
.wish-stela-sanctum::after {
  content: "";
  position: absolute;
  left: 4%;
  right: 4%;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(185, 154, 98, 0.34), transparent);
}

.wish-stela-sanctum::before {
  top: 66px;
}

.wish-stela-sanctum::after {
  bottom: 28px;
}

.wish-stela-stage {
  position: relative;
  width: min(100%, 980px);
  min-height: 650px;
  margin-top: 18px;
}

.wish-stela-crown,
.wish-stela-body {
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
}

.wish-stela-crown {
  top: 0;
  width: min(100%, 840px);
  height: 180px;
}

.wish-stela-light {
  position: absolute;
  top: 0;
  width: 220px;
  height: 180px;
  background: radial-gradient(circle at 50% 0%, rgba(227, 201, 152, 0.18), transparent 68%);
  filter: blur(6px);
}

.wish-stela-light--left {
  left: 10%;
}

.wish-stela-light--center {
  left: 50%;
  transform: translateX(-50%);
  width: 320px;
  background: radial-gradient(circle at 50% 0%, rgba(247, 220, 173, 0.22), transparent 70%);
}

.wish-stela-light--right {
  right: 10%;
}

.wish-stela-body {
  top: 104px;
  width: 440px;
  height: 372px;
}

.wish-stela-surface {
  position: absolute;
  inset: 0 74px 62px;
  border-radius: 34px 34px 22px 22px;
  border: 1px solid rgba(185, 154, 98, 0.18);
  background:
    linear-gradient(180deg, rgba(46, 42, 36, 0.84), rgba(16, 17, 20, 0.96)),
    linear-gradient(180deg, rgba(255, 237, 199, 0.08), transparent 30%);
  box-shadow:
    inset 0 0 80px rgba(255, 214, 138, 0.04),
    0 24px 54px rgba(0, 0, 0, 0.22);
}

.wish-stela-incense {
  position: absolute;
  inset: 12px 112px auto;
  height: 120px;
  opacity: 0.7;
}

.wish-stela-incense-line {
  position: absolute;
  bottom: 0;
  width: 1px;
  height: 84px;
  background: linear-gradient(180deg, rgba(217, 194, 154, 0), rgba(217, 194, 154, 0.46), rgba(217, 194, 154, 0));
}

.wish-stela-incense-line--1 { left: 22%; }
.wish-stela-incense-line--2 { left: 50%; transform: translateX(-50%); height: 104px; }
.wish-stela-incense-line--3 { right: 22%; }

.wish-stela-flame {
  position: absolute;
  left: 50%;
  top: 118px;
  width: 54px;
  height: 86px;
  transform: translateX(-50%);
  border-radius: 50% 50% 36% 36%;
  background: linear-gradient(180deg, rgba(255, 239, 205, 0.98), rgba(221, 167, 89, 0.86) 56%, rgba(104, 59, 28, 0.08) 100%);
  clip-path: polygon(50% 0, 82% 28%, 100% 72%, 50% 100%, 0 72%, 18% 28%);
  filter: drop-shadow(0 0 20px rgba(234, 187, 93, 0.34));
  animation: altarFlame 4.2s ease-in-out infinite;
}

.wish-stela-glyph {
  position: absolute;
  left: 50%;
  top: 214px;
  transform: translateX(-50%);
  color: rgba(252, 242, 219, 0.94);
  font-size: 46px;
  letter-spacing: 0.18em;
}

.wish-stela-base {
  position: absolute;
  left: 50%;
  bottom: 0;
  width: 320px;
  height: 26px;
  transform: translateX(-50%);
  border-radius: 999px;
  background: linear-gradient(180deg, rgba(217, 194, 154, 0.18), rgba(80, 62, 42, 0.08));
}

.wish-stela-title {
  position: relative;
  z-index: 1;
  margin: 0;
  padding-top: 62px;
  max-width: 18ch;
  color: rgba(248, 238, 221, 0.98);
  font-size: clamp(40px, 4.5vw, 70px);
  line-height: 1.14;
  letter-spacing: -0.02em;
}

.wish-stela-intro {
  position: relative;
  z-index: 1;
  max-width: 52rem;
  margin: 22px auto 0;
  color: var(--text-soft);
  font-family: var(--sans);
  font-size: 15px;
  line-height: 1.95;
}

.wish-stela-lead {
  margin: 0;
  max-width: 34rem;
  color: rgba(248, 238, 221, 0.94);
  font-size: clamp(22px, 2.1vw, 32px);
  line-height: 1.5;
}

.wish-stela-streams {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 10px 18px;
  max-width: 54rem;
  margin-top: 18px;
}

.wish-stela-streams span {
  position: relative;
  padding-left: 14px;
  color: rgba(244, 236, 220, 0.92);
  font-family: var(--sans);
  font-size: 13px;
  letter-spacing: 0.1em;
}

.wish-stela-streams span::before {
  content: "";
  position: absolute;
  left: 0;
  top: 50%;
  width: 5px;
  height: 5px;
  border-radius: 50%;
  background: rgba(217, 194, 154, 0.88);
  transform: translateY(-50%);
}

.wish-stela-process {
  margin: 18px 0 0;
  color: rgba(217, 194, 154, 0.74);
  font-family: var(--sans);
  font-size: 11px;
  letter-spacing: 0.24em;
  text-transform: uppercase;
}

.wish-stela-entry {
  position: relative;
  margin-top: 26px;
  margin-bottom: 40px;
  min-width: 300px;
  padding: 16px 46px 14px;
  border-radius: 999px;
  border: 1px solid rgba(185, 154, 98, 0.28);
  background:
    linear-gradient(180deg, rgba(56, 45, 31, 0.2), rgba(10, 13, 19, 0.2)),
    rgba(10, 13, 19, 0.22);
  color: rgba(248, 238, 221, 0.96);
  text-align: center;
  overflow: hidden;
  box-shadow: inset 0 1px 0 rgba(255, 244, 226, 0.06), 0 0 24px rgba(240, 188, 92, 0.04);
  transition: transform 180ms ease, border-color 180ms ease, background 180ms ease;
}

.wish-stela-entry:hover {
  transform: translateY(-2px);
  border-color: rgba(236, 198, 120, 0.44);
  background:
    linear-gradient(180deg, rgba(82, 62, 36, 0.26), rgba(18, 22, 29, 0.3)),
    rgba(18, 22, 29, 0.38);
}

.wish-stela-entry::before,
.wish-stela-entry::after {
  content: "";
  position: absolute;
  top: 50%;
  width: 36px;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(217, 194, 154, 0.68));
  transform: translateY(-50%);
}

.wish-stela-entry::before {
  left: 14px;
}

.wish-stela-entry::after {
  right: 14px;
  transform: translateY(-50%) scaleX(-1);
}

.wish-stela-entry span,
.wish-stela-entry strong,
.wish-stela-entry small {
  display: block;
}

.wish-stela-entry span {
  color: rgba(217, 194, 154, 0.78);
  font-family: var(--sans);
  font-size: 11px;
  letter-spacing: 0.2em;
  text-transform: uppercase;
}

.wish-stela-entry strong {
  margin-top: 6px;
  font-size: 30px;
  line-height: 1.08;
}

.wish-stela-entry small {
  margin-top: 4px;
  color: rgba(217, 194, 154, 0.7);
  font-family: var(--sans);
  font-size: 12px;
}

.wish-axis-sanctum {
  position: relative;
  z-index: 1;
  width: min(1100px, 100%);
  margin: 0 auto;
  display: grid;
  justify-items: center;
  text-align: center;
  gap: 0;
}

.wish-axis-sanctum::before,
.wish-axis-sanctum::after {
  content: "";
  position: absolute;
  left: 2%;
  right: 2%;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(185, 154, 98, 0.34), transparent);
}

.wish-axis-sanctum::before {
  top: 66px;
}

.wish-axis-sanctum::after {
  bottom: 26px;
}

.wish-axis-title {
  margin: 22px 0 0;
  max-width: 17ch;
  color: rgba(248, 238, 221, 0.98);
  font-size: clamp(40px, 4.4vw, 72px);
  line-height: 1.14;
  letter-spacing: -0.02em;
}

.wish-axis-intro {
  margin: 20px 0 0;
  max-width: 50rem;
  color: var(--text-soft);
  font-family: var(--sans);
  font-size: 15px;
  line-height: 1.95;
}

.wish-axis-altar {
  position: relative;
  width: min(100%, 860px);
  height: 420px;
  margin-top: 26px;
}

.wish-axis-radiance,
.wish-axis-rings,
.wish-axis-seal,
.wish-axis-line,
.wish-axis-stars {
  position: absolute;
}

.wish-axis-radiance {
  left: 50%;
  top: 50%;
  width: 520px;
  height: 520px;
  transform: translate(-50%, -50%);
  border-radius: 50%;
  background:
    radial-gradient(circle at center, rgba(217, 194, 154, 0.16), transparent 32%),
    radial-gradient(circle at center, rgba(112, 80, 45, 0.12), transparent 54%);
  filter: blur(18px);
}

.wish-axis-rings {
  inset: 0;
}

.wish-axis-ring {
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  border-radius: 50%;
}

.wish-axis-ring--outer {
  width: 420px;
  height: 420px;
  border: 1px solid rgba(185, 154, 98, 0.18);
}

.wish-axis-ring--middle {
  width: 286px;
  height: 286px;
  border: 1px dashed rgba(217, 194, 154, 0.18);
}

.wish-axis-ring--inner {
  width: 190px;
  height: 190px;
  border: 1px solid rgba(217, 194, 154, 0.12);
}

.wish-axis-seal {
  left: 50%;
  top: 50%;
  width: 148px;
  height: 148px;
  transform: translate(-50%, -50%);
  border-radius: 50%;
  border: 1px solid rgba(217, 194, 154, 0.16);
  background:
    radial-gradient(circle at 50% 40%, rgba(255, 239, 205, 0.12), rgba(255, 239, 205, 0.03) 34%, transparent 66%),
    linear-gradient(180deg, rgba(20, 24, 30, 0.58), rgba(10, 12, 18, 0.2));
  box-shadow: inset 0 0 56px rgba(255, 208, 119, 0.06);
}

.wish-axis-flame,
.wish-axis-glyph {
  position: absolute;
  left: 50%;
}

.wish-axis-flame {
  top: 26px;
  width: 42px;
  height: 70px;
  transform: translateX(-50%);
  border-radius: 50% 50% 36% 36%;
  background: linear-gradient(180deg, rgba(255, 239, 205, 0.98), rgba(221, 167, 89, 0.86) 56%, rgba(104, 59, 28, 0.08) 100%);
  clip-path: polygon(50% 0, 82% 28%, 100% 72%, 50% 100%, 0 72%, 18% 28%);
  filter: drop-shadow(0 0 18px rgba(234, 187, 93, 0.34));
  animation: altarFlame 4.2s ease-in-out infinite;
}

.wish-axis-glyph {
  bottom: 22px;
  transform: translateX(-50%);
  color: rgba(252, 242, 219, 0.94);
  font-size: 32px;
  letter-spacing: 0.16em;
}

.wish-axis-line {
  left: 50%;
  width: 1px;
  transform: translateX(-50%);
  background: linear-gradient(180deg, rgba(217, 194, 154, 0.14), rgba(217, 194, 154, 0.7), rgba(217, 194, 154, 0.14));
}

.wish-axis-line--top {
  top: 0;
  height: 98px;
}

.wish-axis-line--bottom {
  bottom: 0;
  height: 104px;
}

.wish-axis-stars {
  inset: 0;
  pointer-events: none;
}

.wish-axis-star {
  position: absolute;
  width: 4px;
  height: 4px;
  border-radius: 50%;
  background: rgba(255, 241, 216, 0.94);
  box-shadow: 0 0 0 8px rgba(255, 241, 216, 0.04);
  animation: starlightPulse 5.5s ease-in-out infinite;
}

.wish-axis-star--1 { left: 25%; top: 34%; }
.wish-axis-star--2 { right: 25%; top: 30%; animation-delay: 1s; }
.wish-axis-star--3 { left: 31%; bottom: 26%; animation-delay: 2s; }
.wish-axis-star--4 { right: 31%; bottom: 22%; animation-delay: 0.8s; }

.wish-axis-lead {
  margin: 4px 0 0;
  max-width: 34rem;
  color: rgba(248, 238, 221, 0.94);
  font-size: clamp(22px, 2.1vw, 32px);
  line-height: 1.5;
}

.wish-axis-streams {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 10px 18px;
  max-width: 54rem;
  margin-top: 18px;
}

.wish-axis-streams span {
  position: relative;
  padding-left: 14px;
  color: rgba(244, 236, 220, 0.92);
  font-family: var(--sans);
  font-size: 13px;
  letter-spacing: 0.1em;
}

.wish-axis-streams span::before {
  content: "";
  position: absolute;
  left: 0;
  top: 50%;
  width: 5px;
  height: 5px;
  border-radius: 50%;
  background: rgba(217, 194, 154, 0.88);
  transform: translateY(-50%);
}

.wish-axis-process {
  margin: 18px 0 0;
  color: rgba(217, 194, 154, 0.74);
  font-family: var(--sans);
  font-size: 11px;
  letter-spacing: 0.24em;
  text-transform: uppercase;
}

.wish-axis-entry {
  position: relative;
  margin-top: 26px;
  margin-bottom: 40px;
  min-width: 300px;
  padding: 16px 46px 14px;
  border-radius: 999px;
  border: 1px solid rgba(185, 154, 98, 0.28);
  background:
    radial-gradient(circle at 50% 42%, rgba(240, 188, 92, 0.08), transparent 42%),
    rgba(10, 13, 19, 0.22);
  color: rgba(248, 238, 221, 0.96);
  text-align: center;
  overflow: hidden;
  box-shadow: inset 0 1px 0 rgba(255, 244, 226, 0.06), 0 0 24px rgba(240, 188, 92, 0.06);
  transition: transform 180ms ease, border-color 180ms ease, background 180ms ease;
}

.wish-axis-entry:hover {
  transform: translateY(-2px);
  border-color: rgba(236, 198, 120, 0.44);
  background:
    radial-gradient(circle at 50% 42%, rgba(240, 188, 92, 0.12), transparent 42%),
    rgba(18, 22, 29, 0.38);
}

.wish-axis-entry::before,
.wish-axis-entry::after {
  content: "";
  position: absolute;
  top: 50%;
  width: 36px;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(217, 194, 154, 0.68));
  transform: translateY(-50%);
}

.wish-axis-entry::before {
  left: 14px;
}

.wish-axis-entry::after {
  right: 14px;
  transform: translateY(-50%) scaleX(-1);
}

.wish-axis-entry span,
.wish-axis-entry strong,
.wish-axis-entry small {
  display: block;
}

.wish-axis-entry span {
  color: rgba(217, 194, 154, 0.78);
  font-family: var(--sans);
  font-size: 11px;
  letter-spacing: 0.2em;
  text-transform: uppercase;
}

.wish-axis-entry strong {
  margin-top: 6px;
  font-size: 30px;
  line-height: 1.08;
}

.wish-axis-entry small {
  margin-top: 4px;
  color: rgba(217, 194, 154, 0.7);
  font-family: var(--sans);
  font-size: 12px;
}

.wish-gallery {
  position: relative;
  z-index: 1;
  width: min(1120px, 100%);
  margin: 0 auto;
  display: grid;
  gap: 86px;
}

.wish-gallery-intro {
  display: grid;
  justify-items: center;
  gap: 10px;
  text-align: center;
  max-width: 60rem;
  margin: 0 auto;
}

.wish-gallery-intro h2,
.wish-proposal-meta h3 {
  margin: 0;
}

.wish-gallery-intro h2 {
  font-size: clamp(32px, 3vw, 42px);
  line-height: 1.12;
}

.wish-gallery-intro p:last-child {
  margin: 0;
  color: var(--text-soft);
  font-family: var(--sans);
  font-size: 14px;
}

.wish-proposal {
  position: relative;
  display: grid;
  gap: 24px;
  padding-top: 28px;
}

.wish-proposal::before {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  top: 0;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(185, 154, 98, 0.36), transparent);
}

.wish-proposal-meta {
  display: grid;
  justify-items: center;
  gap: 8px;
  text-align: center;
}

.wish-proposal-meta span {
  color: rgba(217, 194, 154, 0.72);
  font-family: var(--sans);
  font-size: 11px;
  letter-spacing: 0.24em;
  text-transform: uppercase;
}

.wish-proposal-meta h3 {
  font-size: clamp(28px, 2.5vw, 38px);
  line-height: 1.1;
}

.wish-proposal-meta p {
  margin: 0;
  color: rgba(217, 194, 154, 0.76);
  font-family: var(--sans);
  font-size: 14px;
}

.wish-stage {
  position: relative;
  padding: 12px 0 12px;
  display: grid;
  justify-items: center;
  overflow: hidden;
}

.wish-stage::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
}

.wish-stage-tag {
  margin: 0;
  color: rgba(217, 194, 154, 0.82);
  font-family: var(--sans);
  font-size: 12px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
}

.wish-stage-copyblock,
.wish-stage--axis {
  width: 100%;
  display: grid;
  justify-items: center;
}

.wish-stage-title {
  margin: 18px 0 0;
  max-width: 18ch;
  color: rgba(248, 238, 221, 0.98);
  font-size: clamp(38px, 4vw, 62px);
  line-height: 1.12;
  text-align: center;
}

.wish-stage-copy {
  margin: 16px 0 0;
  max-width: 52rem;
  color: var(--text-soft);
  font-family: var(--sans);
  font-size: 15px;
  line-height: 1.95;
  text-align: center;
}

.wish-stage-lead {
  margin: 26px 0 0;
  max-width: 34rem;
  color: rgba(248, 238, 221, 0.94);
  font-size: clamp(20px, 2vw, 30px);
  line-height: 1.5;
  text-align: center;
}

.wish-stage-streams {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 10px 18px;
  margin-top: 18px;
  max-width: 52rem;
}

.wish-stage-streams span {
  position: relative;
  padding-left: 14px;
  color: rgba(244, 236, 220, 0.92);
  font-family: var(--sans);
  font-size: 13px;
  letter-spacing: 0.1em;
}

.wish-stage-streams span::before {
  content: "";
  position: absolute;
  left: 0;
  top: 50%;
  width: 5px;
  height: 5px;
  border-radius: 50%;
  background: rgba(217, 194, 154, 0.88);
  transform: translateY(-50%);
}

.wish-stage-process {
  margin: 20px 0 0;
  color: rgba(217, 194, 154, 0.74);
  font-family: var(--sans);
  font-size: 11px;
  letter-spacing: 0.24em;
  text-transform: uppercase;
}

.wish-stage-emblem {
  position: relative;
  margin-top: 32px;
}

.wish-stage-orbit,
.wish-stage-flame,
.wish-stage-glyph,
.wish-mirror-ring,
.wish-mirror-disc,
.wish-tablet-stone,
.wish-tablet-base {
  position: absolute;
}

.wish-stage-flame {
  left: 50%;
  top: 50%;
  width: 54px;
  height: 86px;
  transform: translate(-50%, -58%);
  border-radius: 50% 50% 36% 36%;
  background: linear-gradient(180deg, rgba(255, 239, 205, 0.98), rgba(221, 167, 89, 0.86) 56%, rgba(104, 59, 28, 0.08) 100%);
  clip-path: polygon(50% 0, 82% 28%, 100% 72%, 50% 100%, 0 72%, 18% 28%);
  filter: drop-shadow(0 0 18px rgba(234, 187, 93, 0.32));
  animation: altarFlame 4.2s ease-in-out infinite;
}

.wish-stage-glyph {
  left: 50%;
  top: 50%;
  transform: translate(-50%, 36%);
  color: rgba(252, 242, 219, 0.94);
  font-size: 40px;
  letter-spacing: 0.16em;
}

.wish-entry {
  position: relative;
  margin-top: 28px;
  min-width: 290px;
  padding: 16px 44px 14px;
  border-radius: 999px;
  border: 1px solid rgba(185, 154, 98, 0.26);
  background: rgba(10, 13, 19, 0.22);
  color: rgba(248, 238, 221, 0.96);
  text-align: center;
  overflow: hidden;
  box-shadow: inset 0 1px 0 rgba(255, 244, 226, 0.05);
  transition: transform 180ms ease, border-color 180ms ease, background 180ms ease;
}

.wish-entry:hover {
  transform: translateY(-2px);
  border-color: rgba(236, 198, 120, 0.42);
  background: rgba(18, 22, 29, 0.4);
}

.wish-entry span,
.wish-entry strong,
.wish-entry small {
  display: block;
}

.wish-entry span {
  color: rgba(217, 194, 154, 0.78);
  font-family: var(--sans);
  font-size: 11px;
  letter-spacing: 0.2em;
  text-transform: uppercase;
}

.wish-entry strong {
  margin-top: 6px;
  font-size: 30px;
  line-height: 1.08;
}

.wish-entry small {
  margin-top: 4px;
  color: rgba(217, 194, 154, 0.7);
  font-family: var(--sans);
  font-size: 12px;
}

.wish-entry::before,
.wish-entry::after {
  content: "";
  position: absolute;
  top: 50%;
  width: 34px;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(217, 194, 154, 0.68));
  transform: translateY(-50%);
}

.wish-entry::before {
  left: 12px;
}

.wish-entry::after {
  right: 12px;
  transform: translateY(-50%) scaleX(-1);
}

.wish-stage--tablet {
  padding-bottom: 26px;
}

.wish-stage--tablet::before {
  background:
    linear-gradient(180deg, rgba(255, 239, 205, 0.03), transparent 24%),
    radial-gradient(circle at 50% 46%, rgba(217, 194, 154, 0.08), transparent 28%);
}

.wish-stage--tablet .wish-stage-title {
  max-width: 20ch;
}

.wish-stage-emblem--tablet {
  width: 460px;
  height: 320px;
  margin-top: 34px;
}

.wish-tablet-stone {
  left: 50%;
  top: 18px;
  width: 220px;
  height: 220px;
  transform: translateX(-50%);
  border-radius: 28px 28px 20px 20px;
  border: 1px solid rgba(185, 154, 98, 0.2);
  background:
    linear-gradient(180deg, rgba(34, 32, 29, 0.82), rgba(16, 17, 19, 0.92)),
    linear-gradient(180deg, rgba(255, 237, 199, 0.08), transparent 30%);
  box-shadow: inset 0 0 56px rgba(255, 214, 138, 0.04), 0 20px 40px rgba(0, 0, 0, 0.16);
}

.wish-tablet-base {
  left: 50%;
  bottom: 28px;
  width: 300px;
  height: 18px;
  transform: translateX(-50%);
  border-radius: 999px;
  background: linear-gradient(180deg, rgba(217, 194, 154, 0.18), rgba(80, 62, 42, 0.08));
}

.wish-stage--tablet .wish-stage-flame {
  top: 102px;
}

.wish-stage--tablet .wish-stage-glyph {
  top: 150px;
  transform: translate(-50%, 0);
  font-size: 44px;
}

.wish-entry--tablet {
  border-radius: 22px;
  border-color: rgba(185, 154, 98, 0.24);
  background:
    linear-gradient(180deg, rgba(56, 45, 31, 0.2), rgba(10, 13, 19, 0.2)),
    rgba(10, 13, 19, 0.22);
}

.wish-modal[hidden] {
  display: none;
}

.wish-modal {
  position: fixed;
  inset: 0;
  z-index: 90;
}

.wish-modal-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(4, 6, 10, 0.72);
  backdrop-filter: blur(14px);
}

.wish-dialog {
  position: relative;
  z-index: 1;
  width: min(920px, calc(100% - 24px));
  max-height: min(90vh, 960px);
  margin: min(5vh, 40px) auto;
  overflow: auto;
  padding: 30px;
  border-radius: 24px;
  border: 1px solid rgba(185, 154, 98, 0.14);
  background:
    radial-gradient(circle at 84% 14%, rgba(217, 194, 154, 0.08), transparent 18%),
    linear-gradient(180deg, rgba(16, 20, 27, 0.94), rgba(10, 13, 19, 0.94));
  box-shadow: 0 24px 70px rgba(0, 0, 0, 0.28);
}

.wish-dialog-close {
  position: sticky;
  top: 0;
  margin-left: auto;
  width: 42px;
  height: 42px;
  display: grid;
  place-items: center;
  border-radius: 50%;
  border: 1px solid rgba(185, 154, 98, 0.18);
  color: rgba(244, 236, 220, 0.9);
  background: rgba(10, 13, 19, 0.88);
  font-size: 22px;
}

.wish-dialog-copy {
  display: grid;
  gap: 10px;
  margin-top: 10px;
}

.wish-dialog-kicker {
  margin: 0;
  color: rgba(236, 200, 136, 0.86);
  font-family: var(--sans);
  font-size: 13px;
  letter-spacing: 0.22em;
}

.wish-dialog-copy h3 {
  margin: 0;
  font-size: clamp(34px, 4vw, 48px);
  line-height: 1.1;
}

.wish-dialog-copy p:last-child {
  margin: 0;
  max-width: 50rem;
  color: var(--text-soft);
  font-family: var(--sans);
  font-size: 14px;
}

.wish-form {
  margin-top: 24px;
}

.wish-form-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 18px;
}

.wish-field {
  display: grid;
  gap: 10px;
}

.wish-field--full {
  grid-column: 1 / -1;
}

.wish-field span {
  color: rgba(250, 240, 220, 0.92);
  font-family: var(--sans);
  font-size: 13px;
  letter-spacing: 0.08em;
}

.wish-field input,
.wish-field textarea,
.wish-custom-amount {
  width: 100%;
  padding: 14px 16px;
  border-radius: 18px;
  border: 1px solid rgba(185, 154, 98, 0.14);
  color: var(--text);
  background: rgba(9, 12, 18, 0.54);
  font-family: var(--sans);
  font-size: 15px;
}

.wish-field textarea {
  resize: vertical;
  min-height: 140px;
}

.wish-field input:focus,
.wish-field textarea:focus,
.wish-custom-amount:focus {
  outline: none;
  border-color: rgba(236, 198, 120, 0.48);
  box-shadow: 0 0 0 4px rgba(236, 198, 120, 0.08);
}

.wish-option-row {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.wish-option {
  min-height: 44px;
  padding: 10px 16px;
  border-radius: 999px;
  border: 1px solid rgba(185, 154, 98, 0.14);
  color: rgba(244, 236, 220, 0.9);
  font-family: var(--sans);
  font-size: 14px;
  background: rgba(13, 17, 24, 0.76);
  transition: transform 160ms ease, border-color 160ms ease, background 160ms ease;
}

.wish-option:hover,
.wish-option.is-active {
  transform: translateY(-1px);
  border-color: rgba(236, 198, 120, 0.34);
  background: rgba(62, 42, 20, 0.4);
}

.wish-custom-amount {
  margin-top: 12px;
}

.wish-form-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 20px;
  margin-top: 24px;
  padding-top: 22px;
  border-top: 1px solid rgba(185, 154, 98, 0.1);
}

.wish-form-note {
  margin: 0;
  max-width: 30rem;
  color: rgba(217, 194, 154, 0.78);
  font-family: var(--sans);
  font-size: 13px;
  line-height: 1.8;
}

.wish-submit {
  min-width: 240px;
  padding: 16px 22px;
  border-radius: 999px;
  border: 1px solid rgba(236, 198, 120, 0.28);
  background:
    radial-gradient(circle at 50% 30%, rgba(255, 238, 199, 0.18), transparent 34%),
    linear-gradient(180deg, rgba(56, 39, 20, 0.96), rgba(20, 16, 14, 0.98));
  box-shadow: inset 0 1px 0 rgba(255, 244, 226, 0.1), 0 20px 36px rgba(0, 0, 0, 0.24);
}

.wish-submit span,
.wish-submit small {
  display: block;
}

.wish-submit span {
  color: rgba(252, 243, 220, 0.96);
  font-size: 18px;
}

.wish-submit small {
  margin-top: 4px;
  color: rgba(217, 194, 154, 0.68);
  font-family: var(--sans);
  font-size: 11px;
  letter-spacing: 0.08em;
}

.wish-submit[disabled] {
  opacity: 0.7;
  cursor: wait;
}

.wish-form-status {
  min-height: 26px;
  margin: 16px 0 0;
  color: rgba(208, 232, 178, 0.92);
  font-family: var(--sans);
  font-size: 14px;
}

.wish-form-status.is-error {
  color: rgba(255, 182, 157, 0.92);
}

@keyframes cosmosDrift {
  0% {
    transform: translate3d(0, 0, 0) scale(1);
    opacity: 0.76;
  }
  100% {
    transform: translate3d(0, -14px, 0) scale(1.04);
    opacity: 1;
  }
}

@keyframes starlightPulse {
  0%, 100% {
    opacity: 0.3;
    filter: blur(0);
  }
  50% {
    opacity: 0.56;
    filter: blur(0.2px);
  }
}

@keyframes haloBreath {
  0%, 100% {
    opacity: 0.42;
    transform: scale(1);
  }
  50% {
    opacity: 0.68;
    transform: scale(1.04);
  }
}

@keyframes wishLightBreath {
  0%, 100% {
    opacity: 0.72;
    transform: translateX(-50%) scale(1);
  }
  50% {
    opacity: 1;
    transform: translateX(-50%) scale(1.04);
  }
}

@keyframes wishDustFloat {
  0% {
    opacity: 0;
    transform: translate3d(0, 12px, 0) scale(0.86);
  }
  18% {
    opacity: 0.9;
  }
  60% {
    opacity: 0.48;
    transform: translate3d(8px, -18px, 0) scale(1.04);
  }
  100% {
    opacity: 0;
    transform: translate3d(-4px, -36px, 0) scale(0.92);
  }
}

@keyframes wishMistDrift {
  0%, 100% {
    opacity: 0.24;
    transform: translateX(-50%) scale(0.96);
  }
  50% {
    opacity: 0.46;
    transform: translateX(calc(-50% + 10px)) scale(1.05);
  }
}

@keyframes wishCometRush {
  0% {
    opacity: 0;
    transform: translate(calc(var(--comet-from-x) * var(--wish-stage-flight-scale)), calc(var(--comet-from-y) * var(--wish-stage-flight-scale))) rotate(var(--comet-angle)) scaleX(0.18);
  }
  12% {
    opacity: 0.96;
  }
  76% {
    opacity: 0.24;
    transform: translate(0, 0) rotate(var(--comet-angle)) scaleX(0.94);
  }
  100% {
    opacity: 0;
    transform: translate(0, 0) rotate(var(--comet-angle)) scaleX(0.04);
  }
}

@keyframes wishRadianceWave {
  0% {
    opacity: 0;
    transform: translate(-50%, -50%) scale(0.12);
  }
  18% {
    opacity: 0.36;
  }
  58% {
    opacity: 0.18;
  }
  100% {
    opacity: 0;
    transform: translate(-50%, -50%) scale(2.02);
  }
}

@keyframes wishPulseExpand {
  0% {
    opacity: 0;
    filter: blur(6px);
    transform: translate(-50%, -50%) scale(0.1);
  }
  18% {
    opacity: 0.72;
    filter: blur(10px);
  }
  34% {
    opacity: 0.5;
  }
  54% {
    opacity: 0.22;
  }
  100% {
    opacity: 0;
    filter: blur(30px);
    transform: translate(-50%, -50%) scale(1.72);
  }
}

@keyframes wishEntryStream {
  0% {
    opacity: 0.72;
    filter: blur(0);
    transform: translateX(-2%);
  }
  50% {
    opacity: 1;
    filter: blur(0.2px);
    transform: translateX(2%);
  }
  100% {
    opacity: 0.72;
    filter: blur(0);
    transform: translateX(-2%);
  }
}

@keyframes wishEntryBeacon {
  0%, 100% {
    opacity: 0.8;
    transform: translateX(-50%) rotate(45deg) scale(0.94);
  }
  50% {
    opacity: 1;
    transform: translateX(-50%) rotate(45deg) scale(1.08);
  }
}

@keyframes slowSpin {
  from {
    transform: translate(-50%, -50%) rotate(0deg);
  }
  to {
    transform: translate(-50%, -50%) rotate(360deg);
  }
}

@keyframes slowSpinReverse {
  from {
    transform: translate(-50%, -50%) rotate(360deg);
  }
  to {
    transform: translate(-50%, -50%) rotate(0deg);
  }
}

@keyframes altarFlame {
  0%, 100% {
    transform: translateX(-50%) scale(1);
    opacity: 0.92;
  }
  50% {
    transform: translateX(-50%) scale(1.06);
    opacity: 1;
  }
}

@keyframes altarFlicker {
  0%, 100% {
    transform: scale(1);
    opacity: 0.92;
  }
  50% {
    transform: scale(1.08);
    opacity: 1;
  }
}@media (max-width: 1100px){
  .hero-layout,
  .library-layout,
  .oracle-reference-grid,
  .trust-field {
    grid-template-columns: 1fr;
  }
  .trust-field {
    padding: 22px 180px 0 0;
  }
  .trust-main {
    gap: 24px;
  }
  .trust-vows {
    max-width: none;
    margin: 0;
  }
  .trust-vow {
    grid-template-columns: 56px minmax(160px, 210px) minmax(0, 1fr);
    gap: 14px;
  }
  .hero {
    min-height: 0;
  }
  .hero::before {
    background:
      linear-gradient(180deg, rgba(7, 8, 12, 0.78) 0%, rgba(7, 8, 12, 0.52) 18%, rgba(7, 8, 12, 0.58) 100%),
      linear-gradient(90deg, rgba(7, 8, 12, 0.94) 0%, rgba(7, 8, 12, 0.8) 32%, rgba(7, 8, 12, 0.24) 72%, rgba(7, 8, 12, 0.54) 100%);
  }
  .hero-media img {
    object-position: 72% center;
  }
  .hero-media::after {
    height: 180px;
  }
  .hero-layout {
    grid-template-columns: minmax(24px, 1fr) minmax(260px, 360px) minmax(40px, 0.3fr) 1fr;
    grid-template-rows: auto auto auto 1fr auto;
    align-items: end;
    min-height: 760px;
    padding: 114px 0 74px;
  }
  .hero-intro,
  .hero-support {
    grid-column: 2;
  }
  .hero-intro {
    margin-left: 0;
    transform: translateY(-34px);
  }
  .hero-headline {
    grid-column: 1 / span 4;
    width: min(820px, calc(100% - 40px));
    margin-left: 0;
  }
  .hero-headline h1 {
    max-width: 780px;
    font-size: clamp(30px, 3.8vw, 46px);
  }
  .hero-support {
    grid-column: 1 / span 3;
    max-width: 320px;
    margin-left: 0;
  }
  .hero-actions {
    grid-column: 1 / span 4;
    margin-left: 0;
    width: min(680px, calc(100% - 12px));
    grid-template-columns: repeat(2, minmax(240px, 1fr));
  }
  .hero-copy-cover::before {
    inset: -14px -14px -10px -8px;
  }
  .hero-edge-copy {
    display: none;
  }
  .question-doorways {
    margin-top: 32px;
    padding-bottom: 20px;
  }
  .question-compass-frame {
    min-height: 0;
    padding: 28px 22px;
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    grid-template-rows: auto;
    grid-template-areas:
      "core core"
      "north east"
      "west south";
    gap: 18px;
  }
  .question-compass-frame::before,
  .question-compass-frame::after,
  .orbit-outer,
  .orbit-inner {
    display: none;
  }
  .question-compass-core {
    position: relative;
    width: 100%;
    height: auto;
    min-height: 208px;
    border-radius: 28px;
    grid-column: 1 / -1;
  }
  .question-compass-core::before,
  .question-compass-core::after {
    border-radius: 22px;
  }
  .doorway {
    position: relative;
    width: 100%;
    min-height: 0;
    max-width: none;
    transform: none;
  }
  .doorway:hover,
  .doorway.is-active,
  .doorway:hover.doorway-north,
  .doorway.is-active.doorway-north,
  .doorway:hover.doorway-south,
  .doorway.is-active.doorway-south,
  .doorway:hover.doorway-west,
  .doorway.is-active.doorway-west,
  .doorway:hover.doorway-east,
  .doorway.is-active.doorway-east {
    transform: translateY(-2px);
  }
  .question-stage {
    padding: 28px 24px;
    grid-template-columns: 1fr;
    grid-template-areas:
      "copy"
      "visual"
      "guide";
    column-gap: 0;
    row-gap: 22px;
  }
  .question-visual {
    padding-left: 0;
    border-left: 0;
  }
  .oracle-reference-overlay {
    position: relative;
    inset: auto;
    display: grid;
    grid-template-columns: 1fr;
    min-height: 0;
    gap: 24px;
    padding: 28px 20px 24px;
    background: none;
  }
  .oracle-reference-scene--image {
    --oracle-bg-position: center 28%;
    min-height: 0;
    padding: 16px 12px 20px;
  }
  .oracle-hotspot {
    position: relative;
    left: auto;
    right: auto;
    bottom: auto;
    width: 100%;
    transform: none;
    margin-top: 0;
  }
  .oracle-hotspot-label {
    position: static;
    margin-bottom: 10px;
  }
  .wish-table-title {
    font-size: clamp(28px, 3.2vw, 44px);
  }
  .wish-table-intro {
    max-width: 46rem;
  }
  .wish-table-mark {
    margin-top: 18px;
  }
  .wish-table-stage {
    margin-top: 34px;
  }
  .wish-table-scene {
    width: min(100%, 780px);
    height: 328px;
    margin-top: 64px;
    margin-bottom: 0;
    --wish-scene-center-y: 191px;
    --wish-orbit-shift-y: 112px;
    --wish-pulse-origin-y: 56%;
  }
  .wish-table-celestial {
    inset: -86px -10% -18px;
    --wish-stage-flight-scale: 0.78;
    --wish-impact-y: 78%;
  }
  .wish-table-stage {
    --wish-radiance-origin-y: 50%;
    margin-bottom: 0;
    padding-bottom: 56px;
  }
  .wish-table-radiance {
    inset: -124px -8% -52px;
  }
  .wish-table-radiance-wave {
    width: 820px;
    height: 820px;
    filter: blur(26px);
  }
  .wish-table-scene::before {
    top: 24px;
    width: 780px;
    height: 500px;
  }
  .wish-table-scene::after {
    top: auto;
    bottom: 16px;
    width: 640px;
    height: 300px;
  }
  .wish-table-aura {
    width: 560px;
    height: 240px;
    bottom: 22px;
    filter: blur(34px);
  }
  .wish-table-pulse {
    inset: -18% -8% -12%;
  }
  .wish-table-pulse-ring {
    width: 840px;
    height: 840px;
  }
  .wish-table-comet--1 {
    --comet-length: 132px;
  }
  .wish-table-comet--2 {
    --comet-length: 116px;
  }
  .wish-table-comet--3 {
    --comet-length: 142px;
  }
  .wish-table-comet--4 {
    --comet-length: 110px;
  }
  .wish-table-comet--5 {
    --comet-length: 118px;
  }
  .wish-table-comet--6 {
    --comet-length: 106px;
  }
  .wish-table-comet--7 {
    --comet-length: 100px;
  }
  .wish-table-comet--8 {
    --comet-length: 92px;
  }
  .wish-table-dust-dot--1 {
    top: 90px;
  }
  .wish-table-dust-dot--2 {
    top: 72px;
  }
  .wish-table-dust-dot--3 {
    top: 96px;
  }
  .wish-table-dust-dot--4 {
    top: 136px;
  }
  .wish-table-dust-dot--5 {
    top: 162px;
  }
  .wish-table-dust-dot--6 {
    top: 174px;
  }
  .wish-table-dust-dot--7 {
    top: 120px;
  }
  .wish-table-mist-band {
    top: 122px;
    width: 170px;
    height: 100px;
  }
  .wish-table-mist-band--center {
    width: 220px;
    height: 128px;
  }
  .wish-table-object {
    width: 110px;
    height: 120px;
    bottom: 102px;
  }
  .wish-table-object--incense {
    left: 24px;
  }
  .wish-table-object--jade {
    right: 24px;
  }
  .wish-table-altar {
    width: 560px;
    height: 220px;
    bottom: 20px;
    --wish-altar-center-y: 103px;
  }
  .wish-table-altar::before {
    top: calc(var(--wish-altar-center-y) - 88px + var(--wish-orbit-shift-y));
    width: 296px;
    height: 176px;
  }
  .wish-table-altar::after {
    top: calc(var(--wish-altar-center-y) - 11px + var(--wish-orbit-shift-y));
    width: 448px;
    height: 22px;
  }
  .wish-table-altar-line {
    width: 280px;
  }
  .wish-table-altar-line--top {
    top: calc(var(--wish-altar-center-y) + var(--wish-orbit-shift-y));
  }
  .wish-table-altar-line--bottom {
    top: calc(var(--wish-altar-center-y) + var(--wish-orbit-shift-y));
    height: 38px;
  }
  .wish-table-lamp {
    top: 34px;
    width: 184px;
    height: 138px;
    border-radius: 92px 92px 20px 20px;
  }
  .wish-table-flame {
    top: 22px;
    width: 44px;
    height: 72px;
  }
  .wish-table-glyph {
    bottom: 22px;
    font-size: 42px;
  }
  .wish-table-shadow {
    width: 310px;
    height: 34px;
  }
  .wish-table-lead {
    max-width: 30rem;
  }
  .wish-table-entry {
    width: min(100%, 620px);
    min-height: 118px;
    margin-top: 28px;
    margin-bottom: 12px;
    padding: 12px 20px 14px;
  }
  .wish-table-entry strong {
    font-size: clamp(21px, 2.1vw, 28px);
  }
  .wish-table-entry--portal {
    min-width: 380px;
    padding: 10px 20px 12px;
    border-radius: 20px;
  }
  .wish-mirror-title {
    max-width: 16ch;
    font-size: clamp(36px, 4.6vw, 58px);
  }
  .wish-mirror-intro {
    max-width: 46rem;
  }
  .wish-mirror-visual {
    width: min(100%, 620px);
    height: 400px;
  }
  .wish-bronze-glow {
    width: 420px;
    height: 420px;
  }
  .wish-bronze-ring--outer {
    width: 360px;
    height: 360px;
  }
  .wish-bronze-ring--middle {
    width: 250px;
    height: 250px;
  }
  .wish-bronze-ring--inner {
    width: 170px;
    height: 170px;
  }
  .wish-bronze-disc {
    width: 198px;
    height: 198px;
  }
  .wish-bronze-flame {
    top: 44px;
  }
  .wish-bronze-glyph {
    bottom: 36px;
    font-size: 34px;
  }
  .wish-mirror-lead {
    max-width: 30rem;
  }
  .wish-mirror-entry {
    min-width: 280px;
  }
  .wish-lunar-stage {
    min-height: 640px;
  }
  .wish-lunar-title {
    max-width: 16ch;
    font-size: clamp(36px, 4.6vw, 58px);
  }
  .wish-lunar-intro {
    max-width: 46rem;
  }
  .wish-lunar-orbits {
    width: 620px;
    height: 290px;
    top: 312px;
  }
  .wish-lunar-orbit--outer {
    width: 620px;
    height: 290px;
  }
  .wish-lunar-orbit--mid {
    width: 460px;
    height: 214px;
  }
  .wish-lunar-orbit--inner {
    width: 300px;
    height: 132px;
  }
  .wish-lunar-dais {
    top: 348px;
  }
  .wish-lunar-lead {
    max-width: 30rem;
  }
  .wish-lunar-entry {
    min-width: 280px;
  }
  .wish-stela-stage {
    min-height: 590px;
  }
  .wish-stela-title {
    max-width: 16ch;
    font-size: clamp(36px, 4.6vw, 58px);
  }
  .wish-stela-intro {
    max-width: 46rem;
  }
  .wish-stela-body {
    width: 360px;
    height: 320px;
  }
  .wish-stela-surface {
    inset: 0 58px 52px;
  }
  .wish-stela-flame {
    top: 98px;
  }
  .wish-stela-glyph {
    top: 188px;
    font-size: 40px;
  }
  .wish-stela-base {
    width: 270px;
  }
  .wish-stela-lead {
    max-width: 30rem;
  }
  .wish-stela-entry {
    min-width: 280px;
  }
  .wish-axis-title {
    max-width: 15ch;
    font-size: clamp(36px, 4.6vw, 58px);
  }
  .wish-axis-intro {
    max-width: 44rem;
  }
  .wish-axis-altar {
    height: 360px;
  }
  .wish-axis-radiance {
    width: 420px;
    height: 420px;
  }
  .wish-axis-ring--outer {
    width: 340px;
    height: 340px;
  }
  .wish-axis-ring--middle {
    width: 236px;
    height: 236px;
  }
  .wish-axis-ring--inner {
    width: 160px;
    height: 160px;
  }
  .wish-axis-line--top,
  .wish-axis-line--bottom {
    height: 84px;
  }
  .wish-axis-lead {
    max-width: 30rem;
  }
  .wish-axis-entry {
    min-width: 280px;
  }
  .wish-gallery {
    gap: 72px;
  }
  .wish-stage-title {
    max-width: 16ch;
    font-size: clamp(34px, 4.4vw, 54px);
  }
  .wish-stage-copy {
    max-width: 46rem;
  }
  .wish-stage-emblem--mirror {
    width: 420px;
    height: 300px;
  }
  .wish-stage-emblem--tablet {
    width: 380px;
    height: 280px;
  }
  .wish-tablet-stone {
    width: 190px;
    height: 190px;
  }
  .wish-tablet-base {
    width: 250px;
  }
  .wish-entry {
    min-width: 260px;
  }
  .wish-scene::before,
  .wish-scene::after {
    left: 6%;
    right: 6%;
  }
  .wish-axis {
    grid-template-columns: 1fr;
    min-height: 0;
    gap: 14px;
  }
  .wish-copy,
  .wish-axis-copy {
    justify-items: center;
    text-align: center;
  }
  .wish-altar {
    min-height: 300px;
    width: min(100%, 360px);
    margin: 0 auto;
  }
  .wish-dialog {
    width: min(920px, calc(100% - 18px));
    padding: 24px;
  }
  .wish-form-grid {
    grid-template-columns: 1fr;
  }
  .wish-form-footer {
    flex-direction: column;
    align-items: stretch;
  }
  .wish-form-note {
    max-width: none;
  }
  .wish-submit {
    width: 100%;
    min-width: 0;
  }}@media (max-width: 760px){
  .trust-field {
    padding: 10px 0 0;
  }
  .trust-main {
    row-gap: 20px;
  }
  .trust-copy {
    gap: 14px;
  }
  .trust-copy .intro-en {
    font-size: 10px;
    letter-spacing: 0.12em;
    white-space: normal;
  }
  .trust-copy h2 {
    max-width: 8.5ch;
    font-size: clamp(30px, 8vw, 42px);
    white-space: normal;
  }
  .trust-copy p {
    font-size: 15px;
    line-height: 1.9;
  }
  .trust-words {
    gap: 8px 12px;
  }
  .trust-words span {
    font-size: 11px;
  }
  .trust-vow {
    grid-template-columns: 1fr;
    gap: 10px;
    min-height: 0;
    padding: 18px 0 20px;
  }
  .trust-vow-head {
    display: grid;
    grid-template-columns: 34px minmax(0, 1fr);
    gap: 10px;
  }
  .trust-vow-index,
  .trust-vow strong,
  .trust-vow p {
    grid-column: auto;
  }
  .trust-vow strong {
    font-size: 20px;
  }
  .trust-vow p {
    max-width: none;
    font-size: 15px;
  }}@media (max-width: 760px){
  .home-page .site-header {
    position: sticky;
    top: 0;
    z-index: 120;
    overflow: visible;
    background: rgba(7, 9, 13, 0.9);
    border-bottom: 1px solid rgba(185, 154, 98, 0.12);
    backdrop-filter: blur(18px);
    box-shadow: 0 1px 0 rgba(16, 20, 26, 0.12);
  }
  .home-page .mobile-premium-strip {
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 32px;
    padding: 0 10px;
    background: #2f2d2d;
    color: rgba(255, 255, 255, 0.92);
    font-family: var(--sans);
    font-size: 9px;
    font-weight: 600;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    text-align: center;
  }
  .home-page .header-inner {
    display: grid;
    grid-template-columns: 48px minmax(0, 1fr) 48px;
    align-items: center;
    gap: 12px;
    width: 100%;
    max-width: none;
    min-height: 0;
    max-height: 64px;
    padding: 6px 12px;
    overflow: visible;
    background:
      linear-gradient(180deg, rgba(18, 22, 30, 0.96), rgba(10, 13, 18, 0.98)),
      radial-gradient(circle at top left, rgba(217, 194, 154, 0.06), transparent 42%);
    transition:
      max-height 420ms cubic-bezier(0.22, 1, 0.36, 1),
      padding-top 420ms cubic-bezier(0.22, 1, 0.36, 1),
      padding-bottom 420ms cubic-bezier(0.22, 1, 0.36, 1),
      opacity 260ms ease,
      transform 420ms cubic-bezier(0.22, 1, 0.36, 1);
    transform: none;
  }
  body.home-page.mobile-nav-no-transition .header-inner {
    transition: none;
  }
  .home-page .mobile-nav-button {
    display: inline-grid;
    align-content: center;
    justify-items: center;
    gap: 6px;
    width: 44px;
    height: 44px;
    border-radius: 0;
    border: 0;
    background: transparent;
  }
  .home-page .mobile-nav-button span {
    display: block;
    width: 26px;
    height: 2px;
    border-radius: 999px;
    background: rgba(244, 234, 216, 0.92);
  }
  .home-page .brand {
    justify-self: center;
    gap: 10px;
  }
  .home-page .brand-mark {
    width: 36px;
    height: 36px;
    color: var(--gold-soft);
    border-color: rgba(185, 154, 98, 0.24);
    background:
      radial-gradient(circle at 34% 34%, rgba(217, 194, 154, 0.16), rgba(217, 194, 154, 0.04) 28%, transparent 31%),
      radial-gradient(circle at 56% 58%, rgba(12, 16, 24, 0.24), transparent 52%),
      rgba(255, 244, 226, 0.02);
    box-shadow:
      inset 0 0 20px rgba(217, 194, 154, 0.05),
      0 0 18px rgba(185, 154, 98, 0.08);
    font-size: 16px;
  }
  .home-page .brand-copy strong {
    color: var(--paper);
    font-size: 16px;
    letter-spacing: 0.14em;
    font-weight: 500;
  }
  .home-page .brand-copy small {
    display: none;
  }
  .home-page .mobile-header-spacer {
    display: block;
    width: 44px;
    height: 44px;
    justify-self: end;
  }
  body.home-page.mobile-nav-hidden .header-inner {
    min-height: 0;
    max-height: 0;
    padding-top: 0;
    padding-bottom: 0;
    opacity: 0;
    pointer-events: none;
    transform: translateY(-18px);
  }
  .home-page .header-nav {
    position: fixed;
    top: 96px;
    left: 0;
    right: 0;
    z-index: 140;
    display: grid;
    align-content: start;
    gap: 0;
    width: auto;
    height: auto;
    max-height: calc(100svh - 96px);
    padding: 28px 28px 36px;
    overflow: hidden;
    isolation: isolate;
    background:
      linear-gradient(180deg, rgba(8, 10, 14, 0.96), rgba(8, 10, 14, 0.88) 76%, rgba(8, 10, 14, 0.08)),
      radial-gradient(circle at 78% 0%, rgba(217, 194, 154, 0.14), transparent 30%);
    border: 0;
    border-radius: 0;
    box-shadow:
      0 28px 70px rgba(0, 0, 0, 0.28),
      inset 0 1px 0 rgba(255, 244, 226, 0.06);
    backdrop-filter: blur(18px);
    transform: translateY(-18px);
    transform-origin: top center;
    opacity: 0;
    pointer-events: none;
    transition: transform 240ms cubic-bezier(0.22, 1, 0.36, 1), opacity 200ms ease;
  }
  body.home-page.mobile-nav-no-transition .header-nav,
  body.home-page.mobile-nav-no-transition .mobile-nav-overlay,
  body.home-page.mobile-nav-no-transition .mobile-nav-close-fab {
    transition: none;
  }
  .home-page .header-nav::before {
    content: "";
    position: absolute;
    inset: 0;
    z-index: 0;
    pointer-events: none;
    background:
      linear-gradient(90deg, transparent, rgba(217, 194, 154, 0.18), transparent) 0 0 / 100% 1px no-repeat,
      linear-gradient(90deg, transparent, rgba(217, 194, 154, 0.12), transparent) 0 calc(100% - 18px) / 100% 1px no-repeat;
  }
  .home-page .mobile-nav-panel-head {
    position: relative;
    z-index: 1;
    display: inline-flex;
    align-items: center;
    justify-content: flex-start;
    width: fit-content;
    min-height: 0;
    margin: 0 0 18px;
    padding: 0;
    border-bottom: 0;
  }
  .home-page .mobile-nav-panel-head span {
    color: rgba(217, 194, 154, 0.72);
    font-family: var(--sans);
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 0.34em;
    text-transform: uppercase;
  }
  .home-page .mobile-nav-panel-head::after {
    display: none;
  }
  .home-page .header-nav a {
    position: relative;
    z-index: 1;
    display: flex;
    align-items: baseline;
    justify-content: flex-start;
    min-height: 54px;
    padding: 0 0 14px;
    border: 0;
    border-radius: 0;
    color: rgba(246, 237, 220, 0.9);
    background: transparent;
    font-family: var(--sans);
    font-size: clamp(20px, 6.4vw, 30px);
    font-weight: 700;
    line-height: 1;
    letter-spacing: 0.08em;
    box-shadow: none;
    text-transform: none;
    transition: color 180ms ease, transform 180ms ease;
  }
  .home-page .header-nav a::before {
    content: "";
    width: 0;
    height: 1px;
    margin-right: 0;
    background: rgba(217, 194, 154, 0.72);
    transition: width 180ms ease, margin-right 180ms ease;
  }
  .home-page .header-nav a:hover,
  .home-page .header-nav a:focus-visible {
    color: rgba(255, 246, 229, 0.98);
    transform: none;
  }
  .home-page .header-nav a:hover::before,
  .home-page .header-nav a:focus-visible::before {
    width: 28px;
    margin-right: 12px;
  }
  .home-page .header-nav a::after {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    bottom: 4px;
    display: block;
    height: 1px;
    background: linear-gradient(90deg, rgba(217, 194, 154, 0.18), rgba(217, 194, 154, 0.05), transparent);
    opacity: 1;
    transform: none;
  }
  .home-page .mobile-nav-overlay {
    display: block;
    position: fixed;
    inset: 96px 0 0;
    z-index: 130;
    background:
      radial-gradient(circle at 24% 20%, rgba(185, 154, 98, 0.08), transparent 28%),
      rgba(5, 7, 10, 0.22);
    backdrop-filter: blur(1px);
    opacity: 0;
    pointer-events: none;
    transition: opacity 220ms ease;
  }
  .home-page .mobile-nav-close-fab {
    position: fixed;
    top: 110px;
    right: 28px;
    left: auto;
    z-index: 142;
    display: inline-grid;
    place-items: center;
    width: auto;
    height: 24px;
    border-radius: 0;
    border: 0;
    background: transparent;
    color: rgba(217, 194, 154, 0.72);
    font-family: var(--sans);
    font-size: 0;
    font-weight: 700;
    line-height: 1;
    letter-spacing: 0.24em;
    box-shadow: none;
    opacity: 0;
    pointer-events: none;
    transform: translateX(-16px);
    transition: opacity 220ms ease, transform 220ms ease;
  }
  .home-page .mobile-nav-close-fab::before {
    content: "CLOSE";
    font-size: 10px;
  }
  .home-page .mobile-nav-toggle:checked ~ .header-nav {
    transform: translateY(0);
    opacity: 1;
    pointer-events: auto;
  }
  .home-page .mobile-nav-toggle:checked ~ .mobile-nav-close-fab {
    opacity: 1;
    pointer-events: auto;
    transform: translateX(0);
  }
  .home-page .mobile-nav-toggle:checked ~ .mobile-nav-overlay {
    opacity: 1;
    pointer-events: auto;
  }
  .home-page .site-language-switcher {
    position: absolute;
    top: 50%;
    right: 14px;
    justify-self: end;
    margin: 0;
    transform: translateY(-50%);
    z-index: 146;
  }
  .home-page .site-language-switcher__current {
    min-width: 58px;
    min-height: 29px;
    padding: 4px 8px 4px 8px;
  }
  .home-page .site-language-switcher__menu {
    right: 0;
    left: auto;
  }
  .home-page .hero {
    min-height: clamp(460px, 68svh, 600px);
  }
  .home-page .hero::before {
    background:
      linear-gradient(180deg, rgba(8, 10, 14, 0.24) 0%, rgba(8, 10, 14, 0.08) 18%, rgba(8, 10, 14, 0.24) 48%, rgba(8, 10, 14, 0.84) 100%),
      linear-gradient(180deg, rgba(7, 8, 12, 0.06) 0%, rgba(7, 8, 12, 0.22) 58%, rgba(7, 8, 12, 0.78) 100%);
  }
  .home-page .hero::after {
    background:
      radial-gradient(circle at 50% 28%, rgba(255, 245, 224, 0.12), transparent 20%),
      radial-gradient(circle at 50% 62%, rgba(216, 155, 89, 0.12), transparent 18%);
    filter: blur(28px);
  }
  .home-page .hero-media::after {
    content: "";
    position: absolute;
    inset: 68% 0 0;
    height: auto;
    pointer-events: none;
    background:
      linear-gradient(180deg, rgba(8, 10, 14, 0.04) 0%, rgba(8, 10, 14, 0.42) 24%, rgba(8, 10, 14, 0.82) 62%, rgba(8, 10, 14, 0.98) 100%);
  }
  .home-page .hero-media img {
    object-position: center bottom;
    filter: brightness(0.66) saturate(0.86) contrast(0.94);
    transform: none;
  }
  .home-page .hero-layout {
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    align-items: center;
    min-height: clamp(460px, 68svh, 600px);
    padding: 24px 0 30px;
    text-align: center;
  }
  .home-page .hero-copy-cover::before {
    display: none;
  }
  .home-page .hero-intro,
  .home-page .hero-headline,
  .home-page .hero-support,
  .home-page .hero-actions {
    width: 100%;
    margin-left: 0;
  }
  .home-page .hero-intro {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 10px;
    transform: none;
  }
  .home-page .hero-meta-line {
    max-width: none;
    margin: 0;
    color: rgba(246, 236, 219, 0.86);
    font-size: 10px;
    letter-spacing: 0.12em;
    line-height: 1.4;
    white-space: nowrap;
  }
  .home-page .section-tag {
    display: none;
  }
  .home-page .hero-preface {
    margin: 0;
    color: rgba(255, 243, 220, 0.82);
    font-size: 11px;
    letter-spacing: 0.14em;
  }
  .home-page .hero-preface::before,
  .home-page .hero-preface::after {
    width: 24px;
  }
  .home-page .hero-headline {
    margin-top: auto;
  }
  .home-page .hero-headline h1 {
    max-width: none;
    margin: 0 auto;
    font-size: clamp(28px, 9.2vw, 38px);
    line-height: 1;
    letter-spacing: -0.045em;
  }
  .home-page .hero-title-line {
    white-space: nowrap;
  }
  .home-page .hero-title-line--lead {
    white-space: nowrap;
  }
  .home-page .hero-support {
    display: grid;
    justify-items: center;
    gap: 12px;
    width: 100%;
    max-width: none;
    margin-top: 14px;
  }
  .home-page .hero-sub {
    width: 100%;
    max-width: none;
    margin: 0;
    color: rgba(247, 239, 225, 0.92);
    font-size: 11px;
    line-height: 1.42;
    letter-spacing: -0.02em;
    text-wrap: normal;
  }
  .home-page .hero-note,
  .home-page .hero-ritual-entries {
    display: none;
  }
  .home-page .hero-mobile-cta {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: min(100%, 340px);
    min-height: 58px;
    padding: 0 24px;
    border: 2px solid rgba(193, 173, 212, 0.58);
    border-radius: 2px;
    color: #4b4d6f;
    font-family: var(--sans);
    font-size: 14px;
    font-weight: 700;
    letter-spacing: 0.24em;
    text-transform: uppercase;
    background: rgba(249, 245, 240, 0.96);
    box-shadow:
      0 18px 30px rgba(0, 0, 0, 0.16),
      inset 0 1px 0 rgba(255, 255, 255, 0.7);
  }
  .home-page .hero-mobile-cta:hover,
  .home-page .hero-mobile-cta:focus-visible {
    background: rgba(255, 250, 244, 1);
  }
  .hero {
    min-height: 0;
  }
  .hero::before {
    background:
      linear-gradient(180deg, rgba(7, 8, 12, 0.86) 0%, rgba(7, 8, 12, 0.56) 18%, rgba(7, 8, 12, 0.68) 100%),
      linear-gradient(90deg, rgba(7, 8, 12, 0.96) 0%, rgba(7, 8, 12, 0.84) 48%, rgba(7, 8, 12, 0.3) 100%);
  }
  .hero::after {
    background:
      radial-gradient(circle at 66% 36%, rgba(216, 155, 89, 0.16), transparent 9%),
      radial-gradient(circle at 62% 70%, rgba(255, 245, 224, 0.03), transparent 16%);
  }
  .hero-media img {
    object-position: 76% center;
    transform: scale(1.02);
  }
  .hero-media::after {
    height: 140px;
  }
  .hero-layout {
    grid-template-columns: 1fr;
    grid-template-rows: auto auto auto auto;
    align-items: end;
    min-height: 680px;
    padding: 98px 0 52px;
  }
  .hero-meta-line {
    margin-bottom: 4px;
    font-size: 10px;
    letter-spacing: 0.18em;
    line-height: 1.8;
    white-space: normal;
  }
  .hero-copy-cover::before {
    inset: -14px -10px -12px -8px;
    filter: blur(8px);
  }
  .hero-preface {
    gap: 10px;
    margin-bottom: 16px;
    font-size: 11px;
    letter-spacing: 0.14em;
  }
  .hero-preface::before,
  .hero-preface::after {
    width: 28px;
  }
  .hero-intro,
  .hero-headline,
  .hero-support,
  .hero-actions {
    grid-column: 1;
  }
  .hero-intro {
    margin-left: 0;
  }
  .hero-headline {
    width: 100%;
    margin-top: 16px;
    margin-left: 0;
  }
  .hero-headline h1 {
    max-width: none;
    font-size: clamp(24px, 7vw, 34px);
    line-height: 1.02;
  }
  .hero-title-line--lead {
    white-space: normal;
  }
  .hero-sub {
    max-width: none;
    margin-top: 12px;
    font-size: 11px;
    line-height: 1.6;
  }
  .hero-support {
    max-width: 26rem;
    margin-top: 14px;
    margin-left: 0;
  }
  .hero-actions {
    display: grid;
    grid-template-columns: 1fr;
    gap: 12px;
    margin-top: 18px;
    width: 100%;
  }
  .ritual-entry {
    min-height: 0;
    min-width: 0;
    grid-template-columns: 40px 1fr;
    gap: 10px;
    padding: 4px 0 0;
  }
  .ritual-entry::before {
    width: 54px;
    height: 54px;
  }
  .ritual-entry::after {
    left: 48px;
  }
  .ritual-entry-seal {
    width: 40px;
    height: 40px;
    font-size: 12px;
  }
  .ritual-entry-copy strong {
    font-size: 15px;
  }
  .ritual-entry-copy small {
    max-width: none;
    font-size: 10px;
    white-space: normal;
  }
  .hero-note {
    margin-top: 18px;
    max-width: none;
    padding-top: 12px;
    font-size: 10px;
    white-space: normal;
  }
  .hero-edge-copy {
    display: none;
  }
  .question-doorways {
    padding-bottom: 14px;
  }
  .question-compass-frame {
    grid-template-columns: 1fr;
    grid-template-areas:
      "core"
      "north"
      "west"
      "east"
      "south";
    gap: 14px;
    padding: 18px 16px;
    border-radius: 28px;
  }
  .question-compass-core {
    min-height: 0;
    padding: 24px 18px;
  }
  .compass-core-title {
    font-size: 20px;
  }
  .compass-core-note {
    max-width: 18ch;
  }
  .question-stage {
    padding: 22px 18px;
    row-gap: 18px;
  }
  .question-visual {
    padding-top: 0;
  }
  .doorway strong {
    font-size: 20px;
  }
  .doorway em,
  .doorway-direction,
  .doorway-gate {
    font-size: 10px;
    letter-spacing: 0.12em;
  }
  .doorway-copy {
    max-width: none;
  }
  .doorway-omen {
    white-space: normal;
    font-size: 10px;
  }
  .questions-section .section-intro h2 {
    font-size: 44px;
    white-space: normal;
  }
  .questions-section .intro-copy {
    font-size: 15px;
  }
  .oracle-hotspot-seal {
    width: 54px;
    height: 54px;
    font-size: 28px;
  }
  .oracle-hotspot h3 {
    position: static;
    left: auto;
    transform: none;
    width: auto;
    max-width: none;
    font-size: 34px;
    text-align: left;
  }
  .oracle-hotspot-cn {
    font-size: 13px;
  }
  .oracle-hotspot-en {
    font-size: 10px;
  }
  .oracle-hotspot-link {
    position: static;
    left: auto;
    z-index: auto;
    min-width: 0;
    width: fit-content;
    max-width: none;
    transform: none;
    text-align: left;
    justify-items: start;
  }
  .oracle-hotspot-link:hover,
  .oracle-hotspot-link:focus-visible {
    transform: translateY(-1px);
  }
  .wish-table-sanctum::before {
    top: 52px;
  }
  .wish-table-mark {
    min-height: 74px;
    gap: 6px;
    margin-top: 14px;
  }
  .wish-table-mark .intro-en {
    padding: 0 12px;
  }
  .wish-table-stage {
    width: 100%;
    margin-top: 24px;
  }
  .wish-table-celestial {
    inset: -52px -12% -10px;
    --wish-stage-flight-scale: 0.5;
    --wish-impact-y: 74%;
  }
  .wish-table-stage {
    --wish-radiance-origin-y: 50%;
    margin-bottom: 0;
    padding-bottom: 40px;
  }
  .wish-table-radiance {
    inset: -52px -6% -18px;
  }
  .wish-table-radiance-wave {
    width: 380px;
    height: 380px;
    filter: blur(18px);
  }
  .wish-table-title {
    font-size: 26px;
    line-height: 1.18;
  }
  .wish-table-title span {
    white-space: normal;
  }
  .wish-kicker {
    gap: 12px;
    padding: 0 12px;
    transform: translateY(8px);
  }
  .wish-kicker span {
    padding: 8px 14px;
    font-size: 11px;
    letter-spacing: 0.14em;
  }
  .wish-kicker em {
    font-size: 11px;
    letter-spacing: 0.18em;
  }
  .wish-table-intro {
    margin-top: 16px;
    font-size: 14px;
    line-height: 1.85;
  }
  .wish-table-scene {
    width: min(100%, 320px);
    height: 250px;
    margin-top: 44px;
    margin-bottom: 0;
    --wish-scene-center-y: 170px;
    --wish-orbit-shift-y: 84px;
    --wish-pulse-origin-y: 68%;
  }
  .wish-table-scene::before {
    top: 20px;
    width: 360px;
    height: 260px;
    border-radius: 50%;
  }
  .wish-table-scene::after {
    top: auto;
    bottom: 18px;
    width: 320px;
    height: 180px;
    border-radius: 50%;
  }
  .wish-table-aura {
    width: 280px;
    height: 150px;
    bottom: 18px;
  }
  .wish-table-pulse {
    inset: -14% -8% -4%;
  }
  .wish-table-pulse-ring {
    width: 380px;
    height: 380px;
    filter: blur(12px);
  }
  .wish-table-celestial::after {
    opacity: 0.32;
  }
  .wish-table-comet {
    --comet-size: 1.5px;
    --comet-head: 6px;
  }
  .wish-table-comet--1 {
    --comet-length: 86px;
  }
  .wish-table-comet--2 {
    --comet-length: 72px;
  }
  .wish-table-comet--3 {
    --comet-length: 94px;
  }
  .wish-table-comet--4 {
    --comet-length: 76px;
  }
  .wish-table-comet--5 {
    --comet-length: 82px;
  }
  .wish-table-comet--6 {
    --comet-length: 70px;
  }
  .wish-table-comet--7 {
    --comet-length: 66px;
  }
  .wish-table-comet--8 {
    --comet-length: 60px;
  }
  .wish-table-dust-dot {
    box-shadow:
      0 0 10px rgba(255, 223, 162, 0.24),
      0 0 18px rgba(235, 183, 94, 0.12);
  }
  .wish-table-dust-dot--1 {
    left: 36%;
    top: 82px;
    width: 6px;
    height: 6px;
  }
  .wish-table-dust-dot--2 {
    left: 44%;
    top: 66px;
    width: 4px;
    height: 4px;
  }
  .wish-table-dust-dot--3 {
    left: 57%;
    top: 86px;
    width: 5px;
    height: 5px;
  }
  .wish-table-dust-dot--4 {
    left: 61%;
    top: 114px;
    width: 5px;
    height: 5px;
  }
  .wish-table-dust-dot--5 {
    left: 40%;
    top: 138px;
    width: 4px;
    height: 4px;
  }
  .wish-table-dust-dot--6 {
    left: 54%;
    top: 146px;
    width: 4px;
    height: 4px;
  }
  .wish-table-dust-dot--7 {
    left: 49%;
    top: 102px;
    width: 7px;
    height: 7px;
  }
  .wish-table-mist-band {
    top: 108px;
    width: 110px;
    height: 72px;
    filter: blur(18px);
  }
  .wish-table-mist-band--center {
    width: 156px;
    height: 90px;
  }
  .wish-table-object {
    width: 52px;
    height: 84px;
    bottom: 86px;
    opacity: 0.34;
  }
  .wish-table-object--incense {
    left: 10px;
  }
  .wish-table-object--jade {
    right: 10px;
  }
  .wish-table-stick--1 {
    left: 10px;
    height: 42px;
  }
  .wish-table-stick--2 {
    left: 25px;
    height: 58px;
  }
  .wish-table-stick--3 {
    left: 40px;
    height: 46px;
  }
  .wish-table-smoke {
    width: 18px;
    height: 42px;
  }
  .wish-table-smoke--1 {
    left: 2px;
  }
  .wish-table-smoke--2 {
    left: 14px;
    top: -8px;
  }
  .wish-table-smoke--3 {
    left: 26px;
  }
  .wish-table-jade-core {
    width: 36px;
    height: 36px;
    top: 20px;
  }
  .wish-table-jade-ring {
    width: 50px;
    height: 50px;
    top: 13px;
  }
  .wish-table-altar {
    width: 228px;
    height: 148px;
    bottom: 18px;
    --wish-altar-center-y: 86px;
  }
  .wish-table-altar::before {
    top: calc(var(--wish-altar-center-y) - 52px + var(--wish-orbit-shift-y));
    width: 134px;
    height: 104px;
    border-radius: 68px 68px 18px 18px;
  }
  .wish-table-altar::after {
    top: calc(var(--wish-altar-center-y) - 7px + var(--wish-orbit-shift-y));
    width: 178px;
    height: 14px;
  }
  .wish-table-altar-line {
    width: 134px;
  }
  .wish-table-altar-line--top {
    top: calc(var(--wish-altar-center-y) + var(--wish-orbit-shift-y));
  }
  .wish-table-altar-line--bottom {
    top: calc(var(--wish-altar-center-y) + var(--wish-orbit-shift-y));
    height: 24px;
  }
  .wish-table-lamp {
    top: 24px;
    width: 112px;
    height: 112px;
    border-radius: 50%;
  }
  .wish-table-flame {
    top: 16px;
    width: 28px;
    height: 46px;
  }
  .wish-table-glyph {
    bottom: 14px;
    font-size: 24px;
  }
  .wish-table-shadow {
    width: 150px;
    height: 18px;
  }
  .wish-table-lead {
    max-width: 18rem;
    font-size: 22px;
  }
  .wish-table-streams {
    gap: 10px 14px;
    margin-top: 16px;
  }
  .wish-table-streams span {
    font-size: 12px;
  }
  .wish-table-process {
    font-size: 10px;
    letter-spacing: 0.2em;
    line-height: 1.8;
  }
  .wish-table-process .wish-process-line {
    display: block;
    white-space: nowrap;
  }
  .wish-table-entry {
    width: 100%;
    min-width: 0;
    min-height: 90px;
    margin-top: 22px;
    margin-bottom: 10px;
    padding: 8px 12px 10px;
  }
  .wish-table-entry span[data-text-style-key="wish-entry-label"] {
    letter-spacing: 0.12em !important;
  }
  .wish-table-entry strong {
    font-size: 16px;
  }
  .wish-table-entry small {
    font-size: 8px;
    letter-spacing: 0.08em;
  }
  .wish-table-entry--portal {
    min-width: 0;
    padding: 8px 14px 10px;
    border-radius: 16px;
  }
  .wish-mirror-sanctum::before {
    top: 52px;
  }
  .wish-mirror-stage {
    width: 100%;
    margin-top: 14px;
  }
  .wish-mirror-title {
    max-width: none;
    font-size: 32px;
    line-height: 1.18;
  }
  .wish-mirror-intro {
    margin-top: 16px;
    font-size: 14px;
    line-height: 1.85;
  }
  .wish-mirror-visual {
    width: min(100%, 320px);
    height: 270px;
    margin-top: 22px;
  }
  .wish-bronze-glow {
    width: 240px;
    height: 240px;
  }
  .wish-bronze-ring--outer {
    width: 230px;
    height: 230px;
  }
  .wish-bronze-ring--middle {
    width: 160px;
    height: 160px;
  }
  .wish-bronze-ring--inner {
    width: 108px;
    height: 108px;
  }
  .wish-bronze-disc {
    width: 128px;
    height: 128px;
  }
  .wish-bronze-rune {
    font-size: 16px;
  }
  .wish-bronze-rune--top { top: 12px; }
  .wish-bronze-rune--right { right: 12px; }
  .wish-bronze-rune--bottom { bottom: 12px; }
  .wish-bronze-rune--left { left: 12px; }
  .wish-bronze-flame {
    top: 24px;
    width: 28px;
    height: 46px;
  }
  .wish-bronze-glyph {
    bottom: 20px;
    font-size: 24px;
  }
  .wish-bronze-star--1 { left: 8%; top: 46%; }
  .wish-bronze-star--2 { left: 22%; top: 18%; }
  .wish-bronze-star--3 { right: 22%; top: 18%; }
  .wish-bronze-star--4 { right: 8%; top: 50%; }
  .wish-bronze-star--5 { bottom: 8%; }
  .wish-mirror-lead {
    max-width: 18rem;
    font-size: 22px;
  }
  .wish-mirror-streams {
    gap: 10px 14px;
    margin-top: 16px;
  }
  .wish-mirror-streams span {
    font-size: 12px;
  }
  .wish-mirror-process {
    font-size: 10px;
    letter-spacing: 0.2em;
  }
  .wish-mirror-entry {
    width: 100%;
    min-width: 0;
    margin-top: 22px;
    margin-bottom: 24px;
    padding: 15px 38px 13px;
  }
  .wish-mirror-entry strong {
    font-size: 24px;
  }
  .wish-lunar-sanctum::before {
    top: 52px;
  }
  .wish-lunar-stage {
    width: 100%;
    min-height: 496px;
    margin-top: 14px;
  }
  .wish-lunar-crescent {
    top: 10px;
    width: 108px;
    height: 108px;
  }
  .wish-lunar-title {
    max-width: none;
    padding-top: 82px;
    font-size: 32px;
    line-height: 1.18;
  }
  .wish-lunar-intro {
    margin-top: 16px;
    font-size: 14px;
    line-height: 1.85;
  }
  .wish-lunar-orbits {
    top: 262px;
    width: 320px;
    height: 170px;
  }
  .wish-lunar-orbit--outer {
    width: 320px;
    height: 170px;
  }
  .wish-lunar-orbit--mid {
    width: 236px;
    height: 126px;
  }
  .wish-lunar-orbit--inner {
    width: 148px;
    height: 80px;
  }
  .wish-lunar-star--1 { left: 6%; top: 48%; }
  .wish-lunar-star--2 { left: 19%; top: 24%; }
  .wish-lunar-star--3 { right: 19%; top: 22%; }
  .wish-lunar-star--4 { right: 6%; top: 54%; }
  .wish-lunar-star--5 { bottom: 8%; }
  .wish-lunar-dais {
    top: 290px;
    width: 220px;
    height: 160px;
  }
  .wish-lunar-disc {
    width: 122px;
    height: 122px;
  }
  .wish-lunar-disc::before {
    bottom: -18px;
    width: 172px;
    height: 12px;
  }
  .wish-lunar-flame {
    top: 18px;
    width: 28px;
    height: 46px;
  }
  .wish-lunar-glyph {
    bottom: 16px;
    font-size: 22px;
  }
  .wish-lunar-lead {
    max-width: 18rem;
    font-size: 22px;
  }
  .wish-lunar-streams {
    gap: 10px 14px;
    margin-top: 16px;
  }
  .wish-lunar-streams span {
    font-size: 12px;
  }
  .wish-lunar-process {
    font-size: 10px;
    letter-spacing: 0.2em;
  }
  .wish-lunar-entry {
    width: 100%;
    min-width: 0;
    margin-top: 22px;
    margin-bottom: 24px;
    padding: 15px 38px 13px;
  }
  .wish-lunar-entry strong {
    font-size: 24px;
  }
  .wish-stela-sanctum::before {
    top: 52px;
  }
  .wish-stela-stage {
    width: 100%;
    min-height: 474px;
    margin-top: 14px;
  }
  .wish-stela-title {
    max-width: none;
    padding-top: 52px;
    font-size: 32px;
    line-height: 1.18;
  }
  .wish-stela-intro {
    margin-top: 16px;
    font-size: 14px;
    line-height: 1.85;
  }
  .wish-stela-crown {
    height: 132px;
  }
  .wish-stela-light {
    width: 120px;
    height: 132px;
  }
  .wish-stela-light--center {
    width: 180px;
  }
  .wish-stela-body {
    top: 94px;
    width: 260px;
    height: 248px;
  }
  .wish-stela-surface {
    inset: 0 34px 42px;
    border-radius: 24px 24px 16px 16px;
  }
  .wish-stela-incense {
    inset: 10px 64px auto;
    height: 84px;
  }
  .wish-stela-incense-line {
    height: 56px;
  }
  .wish-stela-incense-line--2 {
    height: 74px;
  }
  .wish-stela-flame {
    top: 72px;
    width: 34px;
    height: 54px;
  }
  .wish-stela-glyph {
    top: 134px;
    font-size: 28px;
  }
  .wish-stela-base {
    width: 188px;
    height: 18px;
  }
  .wish-stela-lead {
    max-width: 18rem;
    font-size: 22px;
  }
  .wish-stela-streams {
    gap: 10px 14px;
    margin-top: 16px;
  }
  .wish-stela-streams span {
    font-size: 12px;
  }
  .wish-stela-process {
    font-size: 10px;
    letter-spacing: 0.2em;
  }
  .wish-stela-entry {
    width: 100%;
    min-width: 0;
    margin-top: 22px;
    margin-bottom: 24px;
    padding: 15px 38px 13px;
  }
  .wish-stela-entry strong {
    font-size: 24px;
  }
  .wish-axis-sanctum::before {
    top: 52px;
  }
  .wish-axis-title {
    max-width: none;
    font-size: 32px;
    line-height: 1.18;
  }
  .wish-axis-intro {
    margin-top: 16px;
    font-size: 14px;
    line-height: 1.85;
  }
  .wish-axis-altar {
    height: 286px;
    margin-top: 20px;
  }
  .wish-axis-radiance {
    width: 300px;
    height: 300px;
  }
  .wish-axis-ring--outer {
    width: 240px;
    height: 240px;
  }
  .wish-axis-ring--middle {
    width: 168px;
    height: 168px;
  }
  .wish-axis-ring--inner {
    width: 118px;
    height: 118px;
  }
  .wish-axis-seal {
    width: 104px;
    height: 104px;
  }
  .wish-axis-flame {
    top: 18px;
    width: 30px;
    height: 48px;
  }
  .wish-axis-glyph {
    bottom: 16px;
    font-size: 22px;
  }
  .wish-axis-line--top,
  .wish-axis-line--bottom {
    height: 58px;
  }
  .wish-axis-star--1 { left: 18%; top: 36%; }
  .wish-axis-star--2 { right: 18%; top: 32%; }
  .wish-axis-star--3 { left: 24%; bottom: 28%; }
  .wish-axis-star--4 { right: 24%; bottom: 24%; }
  .wish-axis-lead {
    margin-top: 0;
    max-width: 18rem;
    font-size: 22px;
  }
  .wish-axis-streams {
    gap: 10px 14px;
    margin-top: 16px;
  }
  .wish-axis-streams span {
    font-size: 12px;
  }
  .wish-axis-process {
    font-size: 10px;
    letter-spacing: 0.2em;
  }
  .wish-axis-entry {
    width: 100%;
    min-width: 0;
    margin-top: 22px;
    margin-bottom: 24px;
    padding: 15px 38px 13px;
  }
  .wish-axis-entry strong {
    font-size: 24px;
  }
  .wish-gallery {
    gap: 58px;
  }
  .wish-gallery-intro h2 {
    font-size: 30px;
  }
  .wish-proposal {
    gap: 18px;
    padding-top: 22px;
  }
  .wish-proposal-meta h3 {
    font-size: 28px;
  }
  .wish-stage-title {
    max-width: none;
    font-size: 32px;
  }
  .wish-stage-copy {
    font-size: 14px;
    line-height: 1.85;
  }
  .wish-stage-lead {
    font-size: 22px;
    max-width: 22rem;
  }
  .wish-stage-streams {
    gap: 10px 14px;
  }
  .wish-stage-streams span {
    font-size: 12px;
  }
  .wish-stage-emblem {
    margin-top: 24px;
  }
  .wish-stage--axis .wish-stage-emblem {
    width: 280px;
    height: 280px;
  }
  .wish-stage--axis .wish-stage-orbit--inner {
    inset: 40px;
  }
  .wish-stage-emblem--mirror {
    width: 320px;
    height: 240px;
  }
  .wish-mirror-disc {
    width: 180px;
    height: 180px;
  }
  .wish-mirror-ring--one {
    inset: 16px 24px;
  }
  .wish-mirror-ring--two {
    inset: 42px 58px;
  }
  .wish-stage-emblem--tablet {
    width: 300px;
    height: 240px;
  }
  .wish-tablet-stone {
    top: 14px;
    width: 156px;
    height: 156px;
  }
  .wish-tablet-base {
    bottom: 24px;
    width: 214px;
  }
  .wish-stage-flame {
    width: 38px;
    height: 58px;
  }
  .wish-stage-glyph {
    font-size: 32px;
  }
  .wish-stage--tablet .wish-stage-flame {
    top: 78px;
  }
  .wish-stage--tablet .wish-stage-glyph {
    top: 114px;
    font-size: 34px;
  }
  .wish-entry {
    width: 100%;
    min-width: 0;
    padding: 15px 38px 13px;
  }
  .wish-entry strong {
    font-size: 24px;
  }
  .wish-copy h2 {
    font-size: 42px;
  }
  .wish-axis {
    gap: 8px;
  }
  .wish-axis-lead {
    font-size: 24px;
  }
  .wish-process {
    font-size: 10px;
    letter-spacing: 0.22em;
  }
  .wish-altar {
    min-height: 280px;
  }
  .wish-altar-orbit--outer {
    width: 220px;
    height: 220px;
  }
  .wish-altar-orbit--inner {
    width: 152px;
    height: 152px;
  }
  .wish-altar-core {
    width: 112px;
    height: 112px;
  }
  .wish-core-flame {
    top: 24px;
    width: 34px;
    height: 52px;
  }
  .wish-core-seal {
    bottom: 16px;
    font-size: 22px;
  }
  .wish-altar-pillars {
    left: 18px;
    right: 18px;
    bottom: 14px;
    font-size: 9px;
  }
  .wish-trigger {
    width: 100%;
    padding: 16px 42px 14px;
  }
  .wish-trigger-main {
    font-size: 24px;
  }
  .wish-dialog {
    margin: 12px auto;
    max-height: calc(100vh - 24px);
    padding: 20px 16px;
    border-radius: 24px;
  }
  .wish-dialog-copy h3 {
    font-size: 34px;
  }
  .wish-option-row {
    gap: 8px;
  }
  .wish-option {
    width: calc(50% - 4px);
  }}

/* Scheme A: altar compass */

.questions-section .section-intro {
  justify-items: center;
  text-align: center;
  width: 100%;
  max-width: none;
  margin: 0 auto;
}

.questions-section .section-intro h2 {
  max-width: none;
  font-size: clamp(34px, 3.5vw, 54px);
  white-space: nowrap;
  text-wrap: nowrap;
  width: fit-content;
  max-inline-size: none;
  justify-self: center;
  margin-inline: auto;
}

.questions-section .intro-copy {
  max-width: 38rem;
}

.question-layout {
  display: grid;
  grid-template-columns: 1fr;
  gap: 0;
  max-width: 1240px;
  margin: 20px auto 0;
  padding: 0;
}

.question-doorways {
  margin-top: 0;
}

.question-tablist-shell--altar .question-tablist-mark {
  gap: 8px;
  margin-bottom: 22px;
}

.question-tablist-shell--altar .question-tablist-mark span {
  font-size: 14px;
  letter-spacing: 0.38em;
}

.question-tablist-shell--altar .question-tablist-mark em {
  letter-spacing: 0.18em;
}

.question-compass-frame {
  min-height: 612px;
  padding: 44px 24px 44px;
  grid-template-columns: minmax(230px, 1fr) 248px minmax(230px, 1fr);
  grid-template-rows: minmax(134px, auto) minmax(236px, auto) minmax(134px, auto);
  background: none;
  border-radius: 0;
  border: 0;
  box-shadow: none;
  overflow: visible;
}

.question-compass-frame::before {
  width: min(84%, 688px);
  border-width: 24px;
  border-color: rgba(119, 90, 52, 0.12);
}

.question-compass-frame::after {
  width: min(58%, 470px);
  border-color: rgba(185, 154, 98, 0.12);
}

.orbit-outer {
  width: min(88%, 720px);
  border-color: rgba(185, 154, 98, 0.09);
  opacity: 0.24;
}

.orbit-inner {
  width: min(42%, 332px);
  border-color: rgba(217, 194, 154, 0.12);
  opacity: 0.24;
}

.question-compass-core {
  width: 248px;
  height: 248px;
  padding: 30px 26px;
  background:
    radial-gradient(circle at 50% 20%, rgba(255, 241, 214, 0.16), transparent 26%),
    radial-gradient(circle at 50% 50%, rgba(10, 14, 21, 0.92), rgba(7, 9, 13, 0.96) 68%, rgba(7, 9, 13, 0.76));
  box-shadow:
    inset 0 0 0 20px rgba(8, 10, 15, 0.76),
    inset 0 0 0 1px rgba(255, 244, 226, 0.06),
    0 24px 48px rgba(0, 0, 0, 0.26);
}

.compass-core-seal {
  width: 48px;
  height: 48px;
  border-radius: 14px;
  font-size: 20px;
}

.question-compass-core--wealth .compass-core-seal {
  font-size: 20px !important;
}

.compass-core-title {
  font-size: 23px;
  letter-spacing: 0.04em;
  white-space: nowrap;
}

.question-compass-core--timing .compass-core-title {
  font-size: 21px;
  letter-spacing: 0.01em;
}

.compass-core-copy {
  font-size: 10px;
  letter-spacing: 0.28em;
  white-space: nowrap;
}

.compass-core-note {
  max-width: none;
  color: rgba(232, 222, 204, 0.72);
  white-space: nowrap;
}

.doorway {
  width: 100%;
  min-height: 148px;
  max-width: none;
  padding: 16px 18px 18px;
  border-radius: 28px;
  background:
    linear-gradient(180deg, rgba(255, 244, 226, 0.06), rgba(255, 244, 226, 0)),
    linear-gradient(180deg, rgba(29, 35, 45, 0.94), rgba(14, 17, 24, 0.94));
  border: 1px solid rgba(185, 154, 98, 0.14);
  box-shadow:
    inset 0 1px 0 rgba(255, 244, 226, 0.06),
    0 14px 28px rgba(0, 0, 0, 0.18);
  backdrop-filter: blur(10px);
}

.doorway::before {
  inset: 12px;
  top: 12px;
  border-radius: 22px;
  background:
    linear-gradient(180deg, rgba(255, 244, 226, 0.04), rgba(255, 244, 226, 0)),
    radial-gradient(circle at 50% 0%, rgba(217, 194, 154, 0.08), transparent 48%);
  filter: none;
  opacity: 1;
}

.doorway::after {
  left: 18px;
  right: 18px;
  bottom: 14px;
  opacity: 0.48;
}

.doorway:not(.is-active) {
  opacity: 0.78;
}

.doorway:hover {
  background:
    linear-gradient(180deg, rgba(255, 244, 226, 0.12), rgba(255, 244, 226, 0.03)),
    linear-gradient(180deg, rgba(42, 50, 62, 0.98), rgba(24, 29, 39, 0.97));
  border-color: rgba(239, 216, 176, 0.2);
  box-shadow:
    inset 0 1px 0 rgba(255, 244, 226, 0.14),
    inset 0 10px 22px rgba(255, 244, 226, 0.04),
    0 24px 46px rgba(0, 0, 0, 0.28),
    0 0 18px rgba(255, 244, 226, 0.04);
}

.doorway.is-active {
  border-color: rgba(247, 225, 188, 0.34);
  box-shadow:
    inset 0 1px 0 rgba(255, 244, 226, 0.22),
    inset 0 18px 34px rgba(255, 244, 226, 0.08),
    0 30px 58px rgba(0, 0, 0, 0.32),
    0 0 32px rgba(255, 244, 226, 0.09);
}

.doorway.is-active:hover {
  background:
    linear-gradient(180deg, rgba(255, 244, 226, 0.18), rgba(255, 244, 226, 0.06)),
    linear-gradient(180deg, rgba(50, 58, 70, 1), rgba(28, 33, 43, 0.99));
  border-color: rgba(247, 225, 188, 0.4);
  box-shadow:
    inset 0 1px 0 rgba(255, 244, 226, 0.24),
    inset 0 20px 36px rgba(255, 244, 226, 0.09),
    0 34px 64px rgba(0, 0, 0, 0.34),
    0 0 36px rgba(255, 244, 226, 0.12);
}

.doorway-copy {
  gap: 6px;
  padding-top: 12px;
}

.doorway strong {
  font-size: 26px;
  white-space: nowrap;
}

.doorway em {
  letter-spacing: 0.18em;
}

.doorway-omen {
  max-width: none;
  font-size: 11px;
  line-height: 1.7;
  white-space: nowrap;
}

.doorway-north,
.doorway-south {
  max-width: 360px;
}

.doorway-north {
  margin-bottom: 28px;
  justify-items: center;
}

.doorway-south {
  margin-top: 28px;
}

.doorway-south[data-topic="timing"] {
  justify-items: center;
}

.doorway-south[data-topic="timing"] .doorway-axis,
.doorway-south[data-topic="timing"] .doorway-copy,
.doorway-south[data-topic="timing"] .doorway-omen {
  width: 100%;
  justify-self: center;
  text-align: center;
}

.doorway-south[data-topic="timing"] .doorway-axis {
  display: grid;
  grid-template-columns: max-content auto max-content;
  justify-content: center;
  justify-items: center;
  column-gap: 10px;
}

.doorway-south[data-topic="timing"] .doorway-copy {
  justify-items: center;
  align-content: start;
}

.doorway-south[data-topic="timing"] .doorway-omen {
  margin-inline: auto;
}

.doorway-north .doorway-axis,
.doorway-north .doorway-copy,
.doorway-north .doorway-omen {
  width: 100%;
  justify-self: center;
  text-align: center;
}

.doorway-north .doorway-axis {
  display: grid;
  grid-template-columns: max-content auto max-content;
  justify-content: center;
  justify-items: center;
  column-gap: 10px;
}

.doorway-north .doorway-copy {
  justify-items: center;
  align-content: start;
}

.doorway-north .doorway-omen {
  margin-inline: auto;
}

.doorway-west,
.doorway-east {
  max-width: 300px;
}

.doorway.is-active.doorway-north,
.doorway.is-active.doorway-south {
  transform: translateY(-4px);
}

.doorway:hover.doorway-north,
.doorway:hover.doorway-south {
  transform: translateY(-14px) scale(1.02);
}

.doorway:hover.doorway-west {
  transform: translateX(12px) scale(1.02);
}

.doorway:hover.doorway-east {
  transform: translateX(-12px) scale(1.02);
}

@media (min-width: 761px) {
  body.home-page[data-site-language="fr"] .question-compass-core {
    padding-inline: 22px;
  }

  body.home-page[data-site-language="fr"] .compass-core-title {
    max-width: 100%;
    font-size: 20px !important;
    line-height: 1.12;
    letter-spacing: 0;
    text-align: center;
    white-space: normal;
  }

  body.home-page[data-site-language="fr"] .compass-core-copy {
    max-width: 100%;
    font-size: 9px;
    letter-spacing: 0;
  }

  body.home-page[data-site-language="fr"] .compass-core-copy::before,
  body.home-page[data-site-language="fr"] .compass-core-copy::after {
    width: 12px;
    margin-inline: 6px;
  }

  body.home-page[data-site-language="fr"] .compass-core-note {
    max-width: 18ch;
    font-size: 10px;
    line-height: 1.38;
    text-align: center;
    white-space: normal;
  }

  body.home-page[data-site-language="fr"] .doorway-axis {
    grid-template-columns: max-content auto max-content;
    justify-content: center;
    justify-items: center;
    column-gap: 8px;
    max-width: 100%;
  }

  body.home-page[data-site-language="fr"] .doorway-direction,
  body.home-page[data-site-language="fr"] .doorway-gate {
    min-width: 0;
    max-width: 100%;
    font-size: 9px;
    letter-spacing: 0;
  }

  body.home-page[data-site-language="fr"] .doorway-copy {
    width: 100%;
    justify-self: center;
    justify-items: center;
  }

  body.home-page[data-site-language="fr"] .doorway strong {
    max-width: 100%;
    font-size: 22px !important;
    line-height: 1.16;
    letter-spacing: 0;
    text-align: center;
    white-space: nowrap;
  }

  body.home-page[data-site-language="fr"] .doorway-omen {
    max-width: 100%;
    font-size: 10px;
    line-height: 1.45;
    letter-spacing: 0;
    text-align: center;
    white-space: normal;
  }

  body.home-page[data-site-language="pt"] .question-compass-core {
    padding-inline: 22px;
  }

  body.home-page[data-site-language="pt"] .compass-core-title {
    max-width: 100%;
    font-size: 20px !important;
    line-height: 1.12;
    letter-spacing: 0;
    text-align: center;
    white-space: normal;
  }

  body.home-page[data-site-language="pt"] .compass-core-copy {
    max-width: 100%;
    font-size: 9px;
    letter-spacing: 0;
  }

  body.home-page[data-site-language="pt"] .compass-core-copy::before,
  body.home-page[data-site-language="pt"] .compass-core-copy::after {
    width: 12px;
    margin-inline: 6px;
  }

  body.home-page[data-site-language="pt"] .compass-core-note {
    max-width: 18ch;
    font-size: 10px;
    line-height: 1.38;
    text-align: center;
    white-space: normal;
  }

  body.home-page[data-site-language="pt"] .doorway-axis {
    grid-template-columns: max-content auto max-content;
    justify-content: center;
    justify-items: center;
    column-gap: 8px;
    max-width: 100%;
  }

  body.home-page[data-site-language="pt"] .doorway-direction,
  body.home-page[data-site-language="pt"] .doorway-gate {
    min-width: 0;
    max-width: 100%;
    font-size: 9px;
    letter-spacing: 0;
  }

  body.home-page[data-site-language="pt"] .doorway-copy {
    width: 100%;
    justify-self: center;
    justify-items: center;
  }

  body.home-page[data-site-language="pt"] .doorway strong {
    max-width: 100%;
    font-size: 22px !important;
    line-height: 1.16;
    letter-spacing: 0;
    text-align: center;
    white-space: nowrap;
  }

  body.home-page[data-site-language="pt"] .doorway-omen {
    max-width: 100%;
    font-size: 10px;
    line-height: 1.45;
    letter-spacing: 0;
    text-align: center;
    white-space: normal;
  }

  body.home-page[data-site-language="es"] .question-compass-core {
    padding-inline: 22px;
  }

  body.home-page[data-site-language="es"] .compass-core-title {
    max-width: 100%;
    font-size: 20px !important;
    line-height: 1.12;
    letter-spacing: 0;
    text-align: center;
    white-space: normal;
  }

  body.home-page[data-site-language="es"] .compass-core-copy {
    max-width: 100%;
    font-size: 9px;
    letter-spacing: 0;
  }

  body.home-page[data-site-language="es"] .compass-core-copy::before,
  body.home-page[data-site-language="es"] .compass-core-copy::after {
    width: 12px;
    margin-inline: 6px;
  }

  body.home-page[data-site-language="es"] .compass-core-note {
    max-width: 18ch;
    font-size: 10px;
    line-height: 1.38;
    text-align: center;
    white-space: normal;
  }

  body.home-page[data-site-language="es"] .doorway-axis {
    grid-template-columns: max-content auto max-content;
    justify-content: center;
    justify-items: center;
    column-gap: 8px;
    max-width: 100%;
  }

  body.home-page[data-site-language="es"] .doorway-direction,
  body.home-page[data-site-language="es"] .doorway-gate {
    min-width: 0;
    max-width: 100%;
    font-size: 9px;
    letter-spacing: 0;
  }

  body.home-page[data-site-language="es"] .doorway-copy {
    width: 100%;
    justify-self: center;
    justify-items: center;
  }

  body.home-page[data-site-language="es"] .doorway strong {
    max-width: 100%;
    font-size: 22px !important;
    line-height: 1.16;
    letter-spacing: 0;
    text-align: center;
    white-space: nowrap;
  }

  body.home-page[data-site-language="es"] .doorway-omen {
    max-width: 100%;
    font-size: 10px;
    line-height: 1.45;
    letter-spacing: 0;
    text-align: center;
    white-space: normal;
  }
}

.question-stage {
  max-width: none;
  margin: 0;
  padding: 26px 6px 0;
  grid-template-columns: minmax(0, 1.08fr) minmax(290px, 0.82fr);
  column-gap: 24px;
  row-gap: 16px;
  border-radius: 0;
  border: 0;
  border-top: 1px solid rgba(185, 154, 98, 0.08);
  background: none;
  box-shadow: none;
}

.question-stage::before {
  display: none;
}

.question-copy,
.question-visual,
.question-stage-detail {
  position: relative;
  z-index: 1;
}

.question-stage-detail {
  display: block;
}

.question-copy {
  gap: 8px;
  max-width: none;
}

.stage-kicker {
  margin: 0;
  font-size: 12px;
  letter-spacing: 0.16em;
}

.question-copy h3 {
  max-width: 34ch;
  font-size: clamp(20px, 2.1vw, 32px);
  line-height: 1.18;
}

.stage-summary {
  max-width: 35rem;
  font-size: 15px;
  line-height: 1.72;
}

.question-stage-actions {
  grid-template-columns: 1fr;
  align-items: start;
  gap: 8px;
  max-width: none;
}

.stage-actions {
  display: flex;
  align-items: flex-start;
}

.question-detail-column--guide {
  padding-top: 0;
  border-top: 0;
}

.stage-list-wrap {
  display: grid;
  gap: 6px;
}

.stage-list-title {
  font-size: 18px;
  line-height: 1.4;
}

.stage-list {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 4px;
}

.stage-list li {
  margin: 0;
  padding: 4px 0 4px 22px;
  border-radius: 0;
  border: 0;
  background: none;
  line-height: 1.5;
}

.stage-list li::before {
  left: 4px;
  top: 50%;
  transform: translateY(-50%);
}

.question-stage-actions .button.primary {
  position: relative;
  min-width: 280px;
  padding: 16px 56px 16px 20px;
  border: 1px solid rgba(185, 154, 98, 0.22);
  border-radius: 18px;
  background:
    linear-gradient(180deg, rgba(185, 154, 98, 0.1), rgba(185, 154, 98, 0.02)),
    linear-gradient(180deg, rgba(16, 20, 28, 0.92), rgba(10, 13, 19, 0.96));
  box-shadow:
    inset 0 1px 0 rgba(255, 244, 226, 0.05),
    0 12px 24px rgba(0, 0, 0, 0.16);
  justify-items: start;
  text-align: left;
  gap: 0;
  transition: transform 180ms ease, box-shadow 180ms ease, border-color 180ms ease;
}

.question-stage-actions .button.primary:hover {
  transform: translateY(-2px);
  border-color: rgba(217, 194, 154, 0.48);
  background:
    linear-gradient(180deg, rgba(185, 154, 98, 0.18), rgba(185, 154, 98, 0.05)),
    linear-gradient(180deg, rgba(22, 28, 38, 0.96), rgba(12, 15, 22, 0.98));
  box-shadow:
    inset 0 1px 0 rgba(255, 244, 226, 0.1),
    0 20px 38px rgba(0, 0, 0, 0.24);
}

.question-stage-actions .button.primary::after {
  content: "";
  position: absolute;
  right: 24px;
  top: 50%;
  width: 10px;
  height: 10px;
  border-top: 1.5px solid rgba(217, 194, 154, 0.86);
  border-right: 1.5px solid rgba(217, 194, 154, 0.86);
  transform: translateY(-50%) rotate(45deg);
}

.question-stage-actions .button.primary:hover::after {
  border-top-color: rgba(247, 237, 221, 0.96);
  border-right-color: rgba(247, 237, 221, 0.96);
}

.question-stage-actions .button.primary span {
  display: none;
}

.question-stage-actions .button.primary small {
  margin-top: 0;
  color: rgba(247, 237, 221, 0.96);
  font-size: 17px;
  line-height: 1.2;
  letter-spacing: 0.04em;
}

.question-stage {
  align-items: start;
}

.question-visual {
  display: grid;
  grid-template-rows: auto minmax(0, 1fr) auto auto;
  gap: 10px;
  padding: 0 0 0 20px;
  border-left: 0;
  position: relative;
  isolation: isolate;
  align-self: stretch;
  height: 100%;
  min-height: 100%;
}

.visual-heading {
  gap: 6px;
}

.visual-heading em {
  font-size: 16px;
}

.visual-caption {
  font-size: 13px;
  line-height: 1.72;
  position: relative;
  z-index: 3;
}

.question-stage[data-topic="wealth"] .visual-caption,
.question-stage[data-topic="relationship"] .visual-caption,
.question-stage[data-topic="child"] .visual-caption,
.question-stage[data-topic="timing"] .visual-caption {
  margin-top: 0;
  align-self: end;
  transform: translateY(-20px);
}

.question-stage[data-topic="wealth"],
.question-stage[data-topic="relationship"],
.question-stage[data-topic="child"],
.question-stage[data-topic="timing"] {
  grid-template-columns: minmax(0, 1fr) minmax(360px, 0.9fr);
}

.question-stage[data-topic="wealth"] .question-visual,
.question-stage[data-topic="relationship"] .question-visual,
.question-stage[data-topic="child"] .question-visual,
.question-stage[data-topic="timing"] .question-visual {
  grid-template-rows: auto auto auto;
  justify-items: center;
  align-content: start;
  align-self: start;
  min-height: 0;
  height: auto;
}

.question-stage[data-topic="wealth"] .topic-diagram,
.question-stage[data-topic="relationship"] .topic-diagram,
.question-stage[data-topic="child"] .topic-diagram,
.question-stage[data-topic="timing"] .topic-diagram {
  display: grid;
  place-items: stretch;
  width: min(100%, 440px);
  max-width: 440px;
  min-height: 0;
  height: 550px;
  aspect-ratio: 4 / 5;
  margin-inline: auto;
}


.visual-insights {
  display: none;
}@media (max-width: 1100px){
  .question-layout {
    padding: 0;
  }

  .question-compass-frame {
    min-height: 0;
    padding: 20px 0 26px;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    grid-template-rows: auto;
    grid-template-areas:
      "core core"
      "north east"
      "west south";
    gap: 18px;
  }

  .question-compass-frame::before,
  .question-compass-frame::after,
  .orbit-outer,
  .orbit-inner {
    display: none;
  }

  .question-compass-core {
    width: 100%;
    height: auto;
    min-height: 220px;
    border-radius: 28px;
  }

  .question-compass-core::before,
  .question-compass-core::after {
    border-radius: 20px;
  }

  .doorway,
  .doorway-north,
  .doorway-south,
  .doorway-west,
  .doorway-east {
    max-width: none;
  }

  .question-stage {
    max-width: none;
    margin-top: 0;
    padding: 22px 0 0;
    grid-template-columns: 1fr;
  }

  .question-visual {
    padding-left: 0;
    border-left: 0;
    border-top: 1px solid rgba(185, 154, 98, 0.06);
    padding-top: 18px;
  }}@media (max-width: 720px){
  .question-layout {
    margin-top: 18px;
    padding: 0;
  }

  .questions-section .section-intro h2 {
    font-size: 42px;
    white-space: normal;
  }

  .question-compass-frame {
    grid-template-columns: 1fr;
    grid-template-areas:
      "core"
      "north"
      "west"
      "east"
      "south";
    gap: 14px;
    padding: 18px 16px 24px;
    border-radius: 28px;
  }

  .question-compass-core {
    min-height: 0;
    padding: 24px 18px;
  }

  .doorway {
    min-height: 0;
    padding: 15px 16px 16px;
  }

  .doorway strong {
    font-size: 22px;
  }

  .question-stage {
    margin-top: 0;
    padding: 18px 0 0;
    row-gap: 18px;
  }

  .question-stage-actions {
    grid-template-columns: 1fr;
  }

  .stage-list {
    gap: 8px;
  }

  .stage-list li {
    width: 100%;
  }}@media (max-width: 760px){
  .stage-actions {
    width: 100%;
  }

  .question-stage-actions .button.primary {
    width: min(100%, 360px);
    min-width: 0;
    min-height: 54px;
    padding: 12px 58px 12px 22px;
    border-color: rgba(217, 194, 154, 0.42);
    background:
      linear-gradient(180deg, rgba(185, 154, 98, 0.28), rgba(116, 76, 35, 0.16)),
      linear-gradient(180deg, rgba(20, 24, 31, 0.96), rgba(12, 15, 20, 0.98));
    box-shadow:
      inset 0 1px 0 rgba(255, 244, 226, 0.12),
      0 16px 30px rgba(0, 0, 0, 0.2);
  }

  .question-stage-actions .button.primary:hover {
    border-color: rgba(217, 194, 154, 0.58);
    background:
      linear-gradient(180deg, rgba(196, 132, 58, 0.34), rgba(130, 82, 36, 0.2)),
      linear-gradient(180deg, rgba(23, 28, 36, 0.98), rgba(13, 16, 22, 0.99));
  }

  .question-stage-actions .button.primary::after {
    border-top-color: rgba(238, 211, 166, 0.92);
    border-right-color: rgba(238, 211, 166, 0.92);
  }

  .question-stage-actions .button.primary small {
    font-size: 18px;
    font-weight: 700;
    letter-spacing: 0.025em;
  }}

/* Transparent base for the entire questions block */
.question-doorways::before,
.question-doorways::after,
.question-stage::before {
  display: none !important;
}

.question-stage[data-topic="wealth"],
.question-stage[data-topic="relationship"],
.question-stage[data-topic="child"],
.question-stage[data-topic="timing"] {
  box-shadow: none !important;
}

.questions-section,
.questions-section .container,
.question-layout,
.question-doorways,
.question-compass-frame,
.question-stage,
.question-stage-main,
.question-stage-detail,
.question-detail-column,
.question-detail-column--guide {
  background: none !important;
  box-shadow: none !important;
}

.question-layout,
.question-stage,
.question-compass-frame,
.question-stage-detail,
.question-detail-column--guide {
  border: 0 !important;
}@media (min-width: 761px){
  body.home-page #questions .diagram-depth__mid {
    background:
      linear-gradient(180deg, rgba(17, 22, 31, 0.96), rgba(9, 12, 18, 0.98));
  }}

.visual-caption {
  max-width: none;
  padding: 12px 12px 0;
  color: rgba(231, 216, 186, 0.9);
  line-height: 1.84;
  font-size: 13px;
  letter-spacing: 0.02em;
}

.question-visual {
  align-self: start;
  min-height: 0;
  height: auto;
}

.question-stage[data-topic="wealth"] .question-visual,
.question-stage[data-topic="relationship"] .question-visual,
.question-stage[data-topic="child"] .question-visual,
.question-stage[data-topic="timing"] .question-visual {
  justify-items: center;
  align-content: start;
  align-self: start;
  min-height: 0;
  height: auto;
}

.question-stage[data-topic="wealth"] .topic-diagram,
.question-stage[data-topic="relationship"] .topic-diagram,
.question-stage[data-topic="child"] .topic-diagram,
.question-stage[data-topic="timing"] .topic-diagram {
  width: min(100%, 440px);
  max-width: 440px;
  min-height: 0;
  height: 550px;
  aspect-ratio: 4 / 5;
  margin-inline: auto;
  overflow: visible;
  border-radius: 0;
}@media (max-width: 700px){
  .question-stage[data-topic="wealth"] .question-visual,
  .question-stage[data-topic="relationship"] .question-visual,
  .question-stage[data-topic="child"] .question-visual,
  .question-stage[data-topic="timing"] .question-visual {
    grid-template-rows: auto auto auto;
    align-self: start;
    min-height: 0;
    height: auto;
  }

  .question-stage[data-topic="wealth"] .topic-diagram,
  .question-stage[data-topic="relationship"] .topic-diagram,
  .question-stage[data-topic="child"] .topic-diagram,
  .question-stage[data-topic="timing"] .topic-diagram {
    width: 100%;
    max-width: 440px;
    min-height: 0;
    height: auto;
    aspect-ratio: 4 / 5;
    margin-inline: auto;
  }

  .question-stage[data-topic="wealth"],
  .question-stage[data-topic="relationship"],
  .question-stage[data-topic="child"],
  .question-stage[data-topic="timing"] {
    grid-template-columns: 1fr;
  }

  .question-visual {
    display: grid;
    grid-template-rows: auto auto auto auto;
    height: auto;
    min-height: 0;
  }}

.question-stage-actions {
  gap: 6px;
}

.stage-soft-note {
  margin: 0;
  line-height: 1.62;
}

.stage-soft-note.en {
  line-height: 1.42;
}

@media (min-width: 761px) {
  body.home-page[data-site-language]:not([data-site-language="en"]) .question-stage[data-topic="wealth"],
  body.home-page[data-site-language]:not([data-site-language="en"]) .question-stage[data-topic="relationship"],
  body.home-page[data-site-language]:not([data-site-language="en"]) .question-stage[data-topic="child"],
  body.home-page[data-site-language]:not([data-site-language="en"]) .question-stage[data-topic="timing"] {
    align-items: center;
  }

  body.home-page[data-site-language]:not([data-site-language="en"]) .question-stage[data-topic="wealth"] .question-visual,
  body.home-page[data-site-language]:not([data-site-language="en"]) .question-stage[data-topic="relationship"] .question-visual,
  body.home-page[data-site-language]:not([data-site-language="en"]) .question-stage[data-topic="child"] .question-visual,
  body.home-page[data-site-language]:not([data-site-language="en"]) .question-stage[data-topic="timing"] .question-visual {
    align-self: center;
  }

  body.home-page[data-site-language]:not([data-site-language="en"]) .question-stage[data-topic="wealth"] .topic-diagram,
  body.home-page[data-site-language]:not([data-site-language="en"]) .question-stage[data-topic="relationship"] .topic-diagram,
  body.home-page[data-site-language]:not([data-site-language="en"]) .question-stage[data-topic="child"] .topic-diagram,
  body.home-page[data-site-language]:not([data-site-language="en"]) .question-stage[data-topic="timing"] .topic-diagram {
    height: var(--topic-diagram-height, 620px);
    transform: translateY(var(--topic-diagram-offset, 0px));
  }

  body.home-page[data-site-language]:not([data-site-language="en"]) .question-stage[data-topic="wealth"] .diagram-shell,
  body.home-page[data-site-language]:not([data-site-language="en"]) .question-stage[data-topic="relationship"] .diagram-shell,
  body.home-page[data-site-language]:not([data-site-language="en"]) .question-stage[data-topic="child"] .diagram-shell,
  body.home-page[data-site-language]:not([data-site-language="en"]) .question-stage[data-topic="timing"] .diagram-shell,
  body.home-page[data-site-language]:not([data-site-language="en"]) .question-stage[data-topic="wealth"] .diagram-depth,
  body.home-page[data-site-language]:not([data-site-language="en"]) .question-stage[data-topic="relationship"] .diagram-depth,
  body.home-page[data-site-language]:not([data-site-language="en"]) .question-stage[data-topic="child"] .diagram-depth,
  body.home-page[data-site-language]:not([data-site-language="en"]) .question-stage[data-topic="timing"] .diagram-depth {
    height: 100%;
  }
}

.directory-list {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 12px;
  margin-top: 0;
}

.directory-item {
  display: flex;
  align-items: center;
  gap: 12px;
  min-height: 74px;
  padding: 14px 16px;
  border-radius: 18px;
  border: 1px solid rgba(216, 223, 226, 0.08);
  background: rgba(12, 17, 22, 0.42);
  transition: transform 180ms ease, border-color 180ms ease, background-color 180ms ease, box-shadow 180ms ease;
}

.directory-item:hover,
.directory-item.is-active {
  transform: translateY(-1px);
  border-color: rgba(185, 154, 98, 0.26);
  background: rgba(14, 20, 26, 0.74);
  box-shadow: inset 0 1px 0 rgba(255, 244, 226, 0.04);
}

.directory-item-order {
  flex: 0 0 auto;
  min-width: 1.7rem;
  color: rgba(185, 154, 98, 0.7);
}

.directory-item-seal {
  flex: 0 0 auto;
  width: 34px;
  height: 34px;
  border-radius: 50%;
  display: grid;
  place-items: center;
  color: var(--paper);
  font-size: 13px;
  border: 1px solid rgba(185, 154, 98, 0.14);
  background: radial-gradient(circle at 36% 32%, rgba(217, 194, 154, 0.12), transparent 42%), rgba(255, 255, 255, 0.015);
}

.directory-item-copy {
  display: grid;
  gap: 6px;
  text-align: left;
}

.directory-item strong {
  display: block;
  color: rgba(250, 244, 234, 0.96);
  font-size: 17px;
  line-height: 1.1;
}

.directory-item em {
  color: rgba(216, 223, 226, 0.5);
  font-family: var(--sans);
  font-size: 10px;
  font-style: normal;
  letter-spacing: 0.08em;
}

.scroll-mark {
  color: rgba(217, 194, 154, 0.82);
}

.volume-list {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
  align-content: start;
}

.volume.volume--fold {
  display: grid;
  gap: 16px;
  padding: 24px 24px 26px;
  border-radius: 22px;
  border: 1px solid rgba(216, 223, 226, 0.08);
  background: rgba(12, 17, 22, 0.46);
  box-shadow: 0 14px 36px rgba(0, 0, 0, 0.12);
}

.volume-top {
  display: flex;
  align-items: center;
  gap: 12px;
}

.volume-index {
  color: rgba(217, 194, 154, 0.74);
}

.volume-kicker {
  margin: 0;
}

.volume-body {
  display: grid;
  gap: 8px;
}

.volume h3 {
  margin: 0;
  color: rgba(250, 244, 234, 0.96);
  font-size: 22px;
  line-height: 1.32;
  letter-spacing: -0.02em;
}

.volume-en {
  margin: -2px 0 0;
  color: rgba(216, 223, 226, 0.48);
}

.volume-summary {
  margin: 4px 0 0;
  color: rgba(244, 234, 216, 0.68);
  font-family: var(--sans);
  font-size: 14px;
  line-height: 1.82;
}@media (max-width: 1180px){

  .directory-list {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }}@media (max-width: 760px){

  .directory-list {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .directory-item {
    min-height: 70px;
    padding: 14px 16px;
  }

  .volume-list {
    grid-template-columns: 1fr;
  }

  .volume.volume--fold {
    padding: 20px;
  }

  .volume h3 {
    font-size: 22px;
  }}@media (max-width: 760px){
  body.home-page #questions .question-layout {
    margin-top: 20px !important;
  }

  body.home-page #questions .question-doorways {
    margin-top: 0 !important;
  }

  body.home-page #questions .question-tablist-shell--altar .question-tablist-mark {
    margin-bottom: 16px !important;
  }

  body.home-page #questions .question-compass-frame {
    display: block !important;
    min-height: 0 !important;
    padding: 0 !important;
    overflow: visible !important;
  }

  body.home-page #questions .question-compass-frame::before,
  body.home-page #questions .question-compass-frame::after,
  body.home-page #questions .orbit-outer,
  body.home-page #questions .orbit-inner {
    display: none !important;
  }

  body.home-page #questions .question-compass-core {
    display: none !important;
  }

  body.home-page #questions .question-mobile-topic-stage {
    display: none !important;
  }

  body.home-page #questions .question-doorway-rail {
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 12px !important;
    width: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
    overflow: visible !important;
  }

  body.home-page #questions .question-doorway-rail .doorway,
  body.home-page .mobile-doorway-transition-clone {
    --mobile-door-frame-image: url("/images/mobile-door-frame-clean.png?v=20260406mobile25");
    --mobile-door-panel-image: url("/images/mobile-door-panel-masked.png?v=20260406mobile25");
    --mobile-door-panel-position: center 57%;
    --mobile-door-panel-size: 130% auto;
    --mobile-door-surface-background:
      var(--mobile-door-frame-image) center / 100% 100% no-repeat,
      linear-gradient(180deg, rgba(255, 244, 226, 0.02), rgba(255, 244, 226, 0)),
      linear-gradient(180deg, rgba(16, 19, 26, 0.08), rgba(8, 10, 15, 0.16)),
      var(--mobile-door-panel-image) var(--mobile-door-panel-position) / var(--mobile-door-panel-size) no-repeat,
      linear-gradient(180deg, rgba(21, 26, 35, 0.96), rgba(11, 14, 20, 0.98));
    --mobile-door-flat-background:
      var(--mobile-door-frame-image) center / 100% 100% no-repeat,
      var(--mobile-door-panel-image) var(--mobile-door-panel-position) / var(--mobile-door-panel-size) no-repeat;
    --mobile-door-surface-shadow:
      inset 0 0 0 1px rgba(242, 225, 189, 0.06),
      inset 0 22px 34px rgba(255, 244, 226, 0.02),
      0 14px 26px rgba(0, 0, 0, 0.18);
    --mobile-door-transition-shadow:
      inset 0 0 0 1px rgba(242, 225, 189, 0.06),
      0 14px 26px rgba(0, 0, 0, 0.18);
    --mobile-door-meta-color: rgba(245, 232, 212, 0.92);
    --mobile-door-title-color: rgba(255, 248, 236, 0.99);
    --mobile-door-title-shadow:
      0 1px 0 rgba(255, 244, 226, 0.18),
      0 2px 8px rgba(0, 0, 0, 0.28);
    --mobile-door-support-color: rgba(246, 233, 206, 0.92);
    --mobile-door-omen-color: rgba(206, 174, 126, 0.82);
    --mobile-door-meta-shadow: 0 1px 3px rgba(0, 0, 0, 0.2);
    --mobile-door-support-shadow: 0 1px 4px rgba(0, 0, 0, 0.18);
    --mobile-door-seal-size: 42px;
    --mobile-door-seal-font-size: 17px;
    --mobile-door-title-font-size: clamp(12px, 3.2vw, 14px);
    --mobile-door-support-font-size: 8px;
    --mobile-door-meta-font-size: 7px;
    --mobile-door-omen-font-size: 8px;
    --mobile-door-clone-filter: drop-shadow(0 12px 20px rgba(0, 0, 0, 0.18));
    --mobile-door-clone-entering-transform: none;
    --mobile-door-clone-entering-filter: var(--mobile-door-clone-filter);
  }

  body.home-page #questions .question-doorway-rail .doorway,
  body.home-page #questions .question-doorway-rail .doorway-north,
  body.home-page #questions .question-doorway-rail .doorway-south,
  body.home-page #questions .question-doorway-rail .doorway-west,
  body.home-page #questions .question-doorway-rail .doorway-east {
    grid-area: auto !important;
    position: relative !important;
    flex: none !important;
    width: 100% !important;
    max-width: none !important;
    min-width: 0 !important;
    min-height: 248px !important;
    margin: 0 !important;
    padding: 14px 8px 18px !important;
    border-radius: 8px !important;
    display: grid !important;
    grid-template-columns: 1fr !important;
    column-gap: 0 !important;
    row-gap: 2px !important;
    justify-items: center !important;
    align-items: start !important;
    align-content: start !important;
    text-align: center !important;
    align-self: stretch !important;
    transform-origin: center center !important;
    transform: none !important;
    filter: none !important;
    overflow: hidden !important;
    opacity: 1 !important;
    border: none !important;
    background: var(--mobile-door-surface-background) !important;
    box-shadow: var(--mobile-door-surface-shadow) !important;
    transition:
      opacity 220ms ease,
      transform 420ms cubic-bezier(0.22, 1, 0.36, 1),
      filter 240ms ease,
      border-color 240ms ease,
      box-shadow 280ms ease !important;
  }

  body.home-page #questions .question-doorway-rail .doorway::before {
    display: none !important;
  }

  body.home-page #questions .question-doorway-rail .doorway[data-topic="relationship"],
  body.home-page .mobile-doorway-transition-clone[data-topic="relationship"] {
    --mobile-door-frame-image: url("/images/mobile-door-frame-relationship-clean.png?v=20260409relationshipClean01");
    --mobile-door-panel-image: url("/images/mobile-door-panel-relationship.png?v=20260407relationship02");
    --mobile-door-panel-position: center 6px;
    --mobile-door-panel-size: 100% 100%;
  }

  body.home-page #questions .question-doorway-rail .doorway[data-topic="wealth"],
  body.home-page .mobile-doorway-transition-clone[data-topic="wealth"] {
    --mobile-door-frame-image: url("/images/mobile-door-frame-wealth-threshold.png?v=20260409wealthThreshold01");
    --mobile-door-panel-image: url("/images/mobile-door-panel-wealth-custom.png?v=20260409wealthCustom04");
    --mobile-door-panel-position: center 6px;
    --mobile-door-panel-size: 100% 100%;
  }

  body.home-page #questions .question-doorway-rail .doorway[data-topic="child"],
  body.home-page .mobile-doorway-transition-clone[data-topic="child"] {
    --mobile-door-frame-image: url("/images/mobile-door-frame-wealth-threshold.png?v=20260409wealthThreshold01");
    --mobile-door-panel-image: url("/images/mobile-door-panel-child-custom.png?v=20260409childCustom03");
    --mobile-door-panel-position: center 6px;
    --mobile-door-panel-size: 100% 100%;
  }

  body.home-page #questions .question-doorway-rail .doorway[data-topic="timing"],
  body.home-page .mobile-doorway-transition-clone[data-topic="timing"] {
    --mobile-door-frame-image: url("/images/mobile-door-frame-wealth-threshold.png?v=20260409wealthThreshold01");
    --mobile-door-panel-image: url("/images/mobile-door-panel-timing-custom.png?v=20260409timingCustom03");
    --mobile-door-panel-position: center 6px;
    --mobile-door-panel-size: 100% 100%;
  }

  body.home-page #questions .question-doorway-rail .doorway[data-topic] {
    --mobile-door-surface-background: var(--mobile-door-flat-background);
    --mobile-door-surface-shadow: 0 14px 26px rgba(0, 0, 0, 0.18);
  }

  body.home-page .mobile-doorway-transition-clone--left {
    --mobile-door-clone-entering-transform: perspective(1400px) rotateY(-72deg) translateX(-8px) scale(1.03);
    --mobile-door-clone-entering-filter: drop-shadow(18px 18px 26px rgba(0, 0, 0, 0.2));
  }

  body.home-page .mobile-doorway-transition-clone--right {
    --mobile-door-clone-entering-transform: perspective(1400px) rotateY(72deg) translateX(8px) scale(1.03);
    --mobile-door-clone-entering-filter: drop-shadow(-18px 18px 26px rgba(0, 0, 0, 0.2));
  }

  body.home-page #questions .question-doorway-rail .doorway:nth-child(odd) {
    transform-origin: left center !important;
  }

  body.home-page #questions .question-doorway-rail .doorway:nth-child(even) {
    transform-origin: right center !important;
  }

  body.home-page #questions .question-doorway-rail .doorway::after {
    display: none !important;
  }

  body.home-page #questions .question-doorway-rail .doorway:hover,
  body.home-page #questions .question-doorway-rail .doorway.is-active,
  body.home-page #questions .question-doorway-rail .doorway:hover.doorway-north,
  body.home-page #questions .question-doorway-rail .doorway:hover.doorway-south,
  body.home-page #questions .question-doorway-rail .doorway:hover.doorway-west,
  body.home-page #questions .question-doorway-rail .doorway:hover.doorway-east,
  body.home-page #questions .question-doorway-rail .doorway.is-active.doorway-north,
  body.home-page #questions .question-doorway-rail .doorway.is-active.doorway-south,
  body.home-page #questions .question-doorway-rail .doorway.is-active.doorway-west,
  body.home-page #questions .question-doorway-rail .doorway.is-active.doorway-east {
    transform: none !important;
  }

  body.home-page #questions .question-doorway-rail .doorway-axis {
    grid-column: 1 !important;
    width: auto !important;
    display: grid !important;
    grid-template-columns: auto auto !important;
    grid-template-areas:
      "seal seal"
      "direction gate" !important;
    justify-content: center !important;
    justify-items: center !important;
    align-items: center !important;
    column-gap: 10px !important;
    row-gap: 6px !important;
    margin-top: 10px !important;
  }

  body.home-page #questions .question-doorway-rail .doorway-copy {
    grid-column: 1 !important;
    width: calc(100% - 26px) !important;
    gap: 6px !important;
    padding-top: 48px !important;
    justify-items: center !important;
    text-align: center !important;
    isolation: isolate !important;
    position: relative !important;
    z-index: 2 !important;
  }

  body.home-page #questions .question-doorway-rail .doorway-copy::after {
    content: "" !important;
    position: absolute !important;
    left: 50% !important;
    top: 30px !important;
    width: calc(100% + 8px) !important;
    height: 122px !important;
    transform: translateX(-50%) !important;
    border-radius: 26px !important;
    background:
      radial-gradient(ellipse at center, rgba(15, 11, 9, 0.46) 0%, rgba(15, 11, 9, 0.34) 46%, rgba(15, 11, 9, 0.14) 72%, rgba(15, 11, 9, 0) 100%),
      linear-gradient(180deg, rgba(30, 21, 16, 0.08), rgba(30, 21, 16, 0)) !important;
    box-shadow:
      inset 0 1px 0 rgba(255, 244, 226, 0.04),
      0 10px 24px rgba(0, 0, 0, 0.08) !important;
    pointer-events: none !important;
    z-index: 0 !important;
  }

  body.home-page :is(#questions .question-doorway-rail .doorway, .mobile-doorway-transition-clone) .doorway-direction,
  body.home-page :is(#questions .question-doorway-rail .doorway, .mobile-doorway-transition-clone) .doorway-gate {
    display: block !important;
    max-width: 100% !important;
    color: var(--mobile-door-meta-color) !important;
    font-size: var(--mobile-door-meta-font-size) !important;
    line-height: 1.15 !important;
    letter-spacing: 0.14em !important;
    white-space: normal !important;
    overflow-wrap: anywhere !important;
    text-wrap: balance !important;
    opacity: 1 !important;
    text-shadow: var(--mobile-door-meta-shadow) !important;
    position: relative !important;
    z-index: 2 !important;
  }

  body.home-page #questions .question-doorway-rail .doorway-direction {
    grid-area: direction !important;
    justify-self: end !important;
    text-align: right !important;
  }

  body.home-page #questions .question-doorway-rail .doorway-gate {
    grid-area: gate !important;
    justify-self: start !important;
    text-align: left !important;
  }

  body.home-page :is(#questions .question-doorway-rail .doorway, .mobile-doorway-transition-clone) .doorway-seal {
    display: grid !important;
    place-items: center !important;
    grid-area: seal !important;
    width: var(--mobile-door-seal-size) !important;
    height: var(--mobile-door-seal-size) !important;
    border-radius: 12px !important;
    font-size: var(--mobile-door-seal-font-size) !important;
    transform: translateY(2px) !important;
    position: relative !important;
    z-index: 3 !important;
  }

  body.home-page :is(#questions .question-doorway-rail .doorway, .mobile-doorway-transition-clone) strong {
    width: auto !important;
    max-width: none !important;
    font-size: var(--mobile-door-title-font-size) !important;
    line-height: 1.05 !important;
    white-space: normal !important;
    letter-spacing: 0 !important;
    color: var(--mobile-door-title-color) !important;
    text-align: center !important;
    overflow-wrap: anywhere !important;
    text-wrap: balance !important;
    text-shadow: var(--mobile-door-title-shadow) !important;
    position: relative !important;
    z-index: 2 !important;
  }

  body.home-page :is(#questions .question-doorway-rail .doorway, .mobile-doorway-transition-clone) em {
    width: auto !important;
    max-width: none !important;
    font-size: var(--mobile-door-support-font-size) !important;
    color: var(--mobile-door-support-color) !important;
    line-height: 1.2 !important;
    letter-spacing: 0.14em !important;
    white-space: normal !important;
    overflow-wrap: anywhere !important;
    text-wrap: balance !important;
    opacity: 1 !important;
    text-shadow: var(--mobile-door-support-shadow) !important;
    text-align: center !important;
    justify-self: center !important;
    position: relative !important;
    z-index: 2 !important;
  }

  body.home-page #questions .question-doorway-rail .doorway-omen {
    display: block !important;
    width: auto !important;
    max-width: calc(100% - 20px) !important;
    margin: 10px auto 0 !important;
    color: var(--mobile-door-omen-color) !important;
    font-size: var(--mobile-door-omen-font-size) !important;
    line-height: 1.2 !important;
    letter-spacing: 0.03em !important;
    white-space: nowrap !important;
    text-align: center !important;
    justify-self: center !important;
    position: relative !important;
    z-index: 2 !important;
  }

  body.home-page #questions .question-stage {
    display: none !important;
  }

  body.home-page:is(.mobile-doorway-transitioning, .mobile-doorway-entered) {
    overflow: hidden !important;
  }

  body.home-page.mobile-doorway-transitioning #questions .question-doorway-rail .doorway {
    opacity: 0.14 !important;
    transform: scale(0.94) !important;
    filter: blur(1.2px) !important;
    will-change: transform, opacity, filter !important;
  }

  body.home-page.mobile-doorway-transitioning #questions .question-doorway-rail .doorway.is-entering {
    opacity: 1 !important;
    transform: none !important;
    filter: none !important;
    background: var(--mobile-door-frame-image) center / 100% 100% no-repeat !important;
    box-shadow: var(--mobile-door-transition-shadow) !important;
    position: relative !important;
    z-index: 119 !important;
  }

  body.home-page.mobile-doorway-transitioning #questions .question-doorway-rail .doorway.is-entering .doorway-axis,
  body.home-page.mobile-doorway-transitioning #questions .question-doorway-rail .doorway.is-entering .doorway-copy,
  body.home-page.mobile-doorway-transitioning #questions .question-doorway-rail .doorway.is-entering .doorway-omen {
    opacity: 0 !important;
    visibility: hidden !important;
  }

  body.home-page.mobile-doorway-transitioning #questions .question-tablist-mark,
  body.home-page.mobile-doorway-transitioning #questions .section-intro,
  body.home-page.mobile-doorway-transitioning .question-layout {
    position: relative !important;
    z-index: 0 !important;
  }

  body.home-page .mobile-doorway-transition-portal {
    position: fixed !important;
    z-index: 118 !important;
    pointer-events: none !important;
    overflow: hidden !important;
    filter: saturate(108%) !important;
    opacity: 0 !important;
    will-change: clip-path, opacity !important;
    transition:
      -webkit-clip-path 640ms cubic-bezier(0.2, 0.84, 0.24, 1),
      clip-path 640ms cubic-bezier(0.2, 0.84, 0.24, 1),
      opacity 320ms ease !important;
  }

  body.home-page .mobile-doorway-transition-portal:is(.is-entering, .is-settled) {
    opacity: 1 !important;
  }

  body.home-page .mobile-doorway-transition-portal.is-expanded {
    z-index: 121 !important;
  }

  body.home-page .mobile-doorway-transition-portal.is-settled {
    pointer-events: auto !important;
    clip-path: none !important;
    -webkit-clip-path: none !important;
  }

  body.home-page .mobile-doorway-preview {
    position: absolute !important;
    inset: 0 !important;
    opacity: 0 !important;
    overflow: hidden !important;
    will-change: opacity !important;
    transition:
      opacity 180ms ease !important;
  }

  body.home-page .mobile-doorway-transition-portal.is-revealed .mobile-doorway-preview {
    opacity: 1 !important;
  }

  body.home-page .mobile-doorway-preview-page {
    position: absolute !important;
    inset: 0 !important;
    width: 100% !important;
    height: 100% !important;
    border: 0 !important;
    background: #0a0d13 !important;
    pointer-events: none !important;
  }

  body.home-page .mobile-doorway-click-proxy {
    position: absolute !important;
    inset: 0 !important;
    z-index: 2 !important;
    display: none !important;
    background: transparent !important;
    touch-action: pan-y !important;
  }

  body.home-page .mobile-doorway-transition-portal.is-settled :is(.mobile-doorway-preview, .mobile-doorway-preview-page) {
    overflow: auto !important;
    -webkit-overflow-scrolling: touch !important;
    touch-action: pan-y !important;
  }

  body.home-page .mobile-doorway-transition-portal.is-settled .mobile-doorway-click-proxy {
    display: block !important;
  }

  body.home-page .mobile-doorway-transition-portal.is-settled .mobile-doorway-preview-page {
    pointer-events: auto !important;
  }

  body.home-page .mobile-doorway-transition-clone {
    position: fixed !important;
    z-index: 120 !important;
    margin: 0 !important;
    padding: 0 !important;
    border-radius: 0 !important;
    display: grid !important;
    grid-template-columns: 1fr !important;
    row-gap: 6px !important;
    justify-items: center !important;
    align-items: start !important;
    align-content: start !important;
    text-align: center !important;
    overflow: visible !important;
    pointer-events: none !important;
    border: none !important;
    background: var(--mobile-door-panel-image) center / 100% 100% no-repeat !important;
    -webkit-mask-image: var(--mobile-door-panel-image) !important;
    mask-image: var(--mobile-door-panel-image) !important;
    -webkit-mask-repeat: no-repeat !important;
    mask-repeat: no-repeat !important;
    -webkit-mask-position: center !important;
    mask-position: center !important;
    -webkit-mask-size: 100% 100% !important;
    mask-size: 100% 100% !important;
    box-shadow: none !important;
    filter: var(--mobile-door-clone-filter) !important;
    transform-style: preserve-3d !important;
    backface-visibility: hidden !important;
    will-change: transform, opacity, filter !important;
    transition:
      transform 560ms cubic-bezier(0.2, 0.84, 0.24, 1),
      filter 560ms cubic-bezier(0.2, 0.84, 0.24, 1),
      opacity 220ms ease !important;
  }

  body.home-page .mobile-doorway-transition-clone::before,
  body.home-page .mobile-doorway-transition-clone::after {
    display: none !important;
  }

  body.home-page .mobile-doorway-transition-clone--left {
    transform-origin: 16.562% 52% !important;
  }

  body.home-page .mobile-doorway-transition-clone--right {
    transform-origin: 83.438% 52% !important;
  }

  body.home-page .mobile-doorway-transition-clone.is-entering {
    transform: var(--mobile-door-clone-entering-transform) !important;
    filter: var(--mobile-door-clone-entering-filter) !important;
  }

  body.home-page .mobile-doorway-transition-clone.is-settled {
    opacity: 0 !important;
  }

  body.home-page .mobile-doorway-transition-clone .doorway-axis,
  body.home-page .mobile-doorway-transition-clone .doorway-copy,
  body.home-page .mobile-doorway-transition-clone .doorway-omen {
    display: none !important;
  }

  body.home-page #questions,
  body.home-page #library,
  body.home-page #deeper,
  body.home-page #trust,
  body.home-page #wish {
    position: relative !important;
    padding-top: 36px !important;
    padding-bottom: 32px !important;
  }

  body.home-page #questions {
    padding-top: 56px !important;
    padding-bottom: 12px !important;
  }

  body.home-page #questions .section-intro,
  body.home-page #deeper .section-intro,
  body.home-page #trust .trust-copy {
    justify-items: center !important;
    text-align: center !important;
    gap: 16px !important;
  }

  body.home-page #wish .wish-table-mark {
    gap: 16px !important;
  }

  body.home-page #questionsIntroEn,
  body.home-page #deeperIntroEn,
  body.home-page #trustIntroEn,
  body.home-page #wishIntroEn {
    color: var(--muted) !important;
    font-family: var(--sans) !important;
    font-size: 11px !important;
    line-height: 1.85 !important;
    letter-spacing: 0.08em !important;
  }

  body.home-page #trustIntroEn,
  body.home-page #wishIntroEn {
    white-space: normal !important;
  }

  body.home-page #questionsTitle,
  body.home-page #trustTitle,
  body.home-page #wishTitle,
  body.home-page #deeperTitle {
    font-family: var(--hero-title-display) !important;
    font-size: clamp(36px, 4vw, 54px) !important;
    line-height: 1.08 !important;
    letter-spacing: -0.05em !important;
    text-align: center !important;
    white-space: normal !important;
    transform: none !important;
  }

  body.home-page #deeperTitle,
  body.home-page #deeperTitle .deeper-title-line {
    text-wrap: balance !important;
  }

  body.home-page #deeperTitle {
    width: min(100%, 23.5ch) !important;
    max-width: min(100%, 23.5ch) !important;
    font-size: clamp(28px, 7.8vw, 34px) !important;
    line-height: 1.08 !important;
    letter-spacing: -0.018em !important;
  }

  body.home-page #deeperTitle .deeper-title-line,
  body.home-page #wishTitle .wish-title-desktop-line {
    display: none !important;
  }

  body.home-page #deeperTitle .deeper-title-mobile-line,
  body.home-page #wishTitle .wish-title-mobile-line,
  body.home-page #wishLead .wish-lead-line {
    display: block !important;
    white-space: nowrap !important;
  }

  body.home-page #trustTitle {
    max-width: none !important;
  }

  body.home-page #wishTitle span {
    font-family: inherit !important;
    font-size: inherit !important;
    line-height: inherit !important;
    letter-spacing: inherit !important;
  }

  body.home-page #wishTitle,
  body.home-page #wishLead {
    width: 100% !important;
    max-width: 100% !important;
  }

  body.home-page #wishTitle {
    font-size: clamp(22px, 6.2vw, 28px) !important;
    line-height: 1.08 !important;
  }

  body.home-page #wishLead {
    font-size: clamp(15px, 4.8vw, 20px) !important;
    line-height: 1.28 !important;
  }

  body.home-page #questionsCopy,
  body.home-page #trustBody,
  body.home-page #wishIntro,
  body.home-page #deeperCopy {
    max-width: 100% !important;
    color: rgba(244, 234, 216, 0.7) !important;
    font-family: inherit !important;
    font-size: 14px !important;
    line-height: 1.95 !important;
  }

  body.home-page #deeper .oracle-reference-scene--image {
    min-height: 0 !important;
    padding: 0 !important;
    overflow: visible !important;
    background: none !important;
    border-radius: 0 !important;
  }

  body.home-page #deeper .oracle-reference-scene--image::before {
    display: none !important;
  }

  body.home-page #deeper .oracle-reference-overlay {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 16px !important;
    min-height: 0 !important;
    padding: 0 !important;
  }

  body.home-page #deeper .oracle-hotspot {
    display: grid !important;
    height: auto !important;
    min-height: 0 !important;
    margin: 0 !important;
    padding: 22px 20px 24px !important;
    border: 1px solid rgba(216, 223, 226, 0.08) !important;
    border-radius: 22px !important;
    background: rgba(12, 17, 22, 0.46) !important;
    box-shadow: 0 14px 36px rgba(0, 0, 0, 0.12) !important;
  }

  body.home-page #deeper :is(.oracle-hotspot--left, .oracle-hotspot--center, .oracle-hotspot--right) {
    isolation: isolate !important;
    overflow: hidden !important;
  }

  body.home-page #deeper :is(.oracle-hotspot--left, .oracle-hotspot--center, .oracle-hotspot--right)::before {
    content: "" !important;
    position: absolute !important;
    left: 50% !important;
    right: auto !important;
    z-index: 0 !important;
    opacity: 0.36 !important;
    transform: translate(-50%, -50%) !important;
    pointer-events: none !important;
  }

  body.home-page #deeper .oracle-hotspot--left::before {
    top: 48% !important;
    width: min(76%, 292px) !important;
    aspect-ratio: 460 / 443 !important;
    background: url("/images/jade-disc-mobile.png?v=20260407jade05") center / contain no-repeat !important;
  }

  body.home-page #deeper .oracle-hotspot--center::before {
    top: 50% !important;
    width: min(66%, 250px) !important;
    aspect-ratio: 400 / 504 !important;
    background: url("/images/bronze-mirror-mobile.png?v=20260407mirror01") center / contain no-repeat !important;
  }

  body.home-page #deeper .oracle-hotspot--right::before {
    top: 50% !important;
    width: min(64%, 240px) !important;
    aspect-ratio: 350 / 450 !important;
    background: url("/images/compass-mobile.png?v=20260407compass01") center / contain no-repeat !important;
  }

  body.home-page #deeper .oracle-hotspot--left > *,
  body.home-page #deeper .oracle-hotspot--center > *,
  body.home-page #deeper .oracle-hotspot--right > * {
    position: relative !important;
    z-index: 1 !important;
  }

  body.home-page #deeper .oracle-hotspot h3,
  body.home-page #deeper .oracle-hotspot-link {
    position: static !important;
    left: auto !important;
    bottom: auto !important;
    width: auto !important;
    max-width: 100% !important;
    transform: none !important;
    text-align: left !important;
    justify-items: start !important;
  }

  body.home-page #deeper .oracle-hotspot-seal {
    order: 1 !important;
    font-size: 22px !important;
  }

  body.home-page #deeper .oracle-hotspot-cn,
  body.home-page #deeper .oracle-hotspot-en {
    order: 2 !important;
  }

  body.home-page #deeper .oracle-hotspot h3 {
    order: 3 !important;
    margin-top: 24px !important;
    font-size: 26px !important;
  }

  body.home-page #deeper [data-text-style-key="path-learn-title"],
  body.home-page #deeper [data-text-style-key="path-wish-title"],
  body.home-page #deeper [data-text-style-key="path-reading-title"] {
    font-size: 18px !important;
    line-height: 1.08 !important;
  }

  body.home-page #deeper .oracle-hotspot-link {
    order: 4 !important;
    margin-top: 8px !important;
  }

  body.home-page #questions .section-intro {
    position: relative !important;
    gap: 16px !important;
    margin-top: 0 !important;
    padding-top: 58px !important;
  }

  body.home-page #questionsIntroEn {
    position: absolute !important;
    top: 14px !important;
    left: 50% !important;
    width: max-content !important;
    max-width: calc(100% - 32px) !important;
    margin: 0 !important;
    transform: translateX(-50%) !important;
  }

  body.home-page #questionsTitle {
    width: min(96vw, 22ch) !important;
    max-width: min(96vw, 22ch) !important;
    margin: 0 auto !important;
    font-size: clamp(36px, 4vw, 54px) !important;
    line-height: 1.08 !important;
    letter-spacing: -0.05em !important;
    white-space: normal !important;
    text-wrap: balance !important;
    transform: none !important;
  }

  body.home-page .hero-layout {
    position: relative !important;
    justify-content: flex-start !important;
    padding-top: 82px !important;
  }

  body.home-page .hero-preface,
  body.home-page #heroMetaLine {
    display: none !important;
  }

  body.home-page .hero-headline {
    position: absolute !important;
    top: 48px !important;
    left: 18px !important;
    display: flex !important;
    justify-content: flex-start !important;
    align-self: auto !important;
    width: min(100%, 18rem) !important;
    margin: 0 !important;
    padding-left: 0 !important;
    transform: none !important;
    z-index: 3 !important;
  }

  body.home-page #heroMainTitle {
    display: grid !important;
    justify-items: start !important;
    width: fit-content !important;
    max-width: 100% !important;
    margin: 0 !important;
    font-size: 30px !important;
    line-height: 1 !important;
    letter-spacing: -0.04em !important;
    text-align: left !important;
  }

  body.home-page #heroMainTitle .hero-title-desktop-copy {
    display: none !important;
  }

  body.home-page #heroMainTitle .hero-title-line,
  body.home-page #heroMainTitle .hero-title-mobile-line {
    width: fit-content !important;
    margin: 0 !important;
    white-space: nowrap !important;
  }

  body.home-page #heroMainTitle .hero-title-mobile-line {
    display: block !important;
  }

  body.home-page .hero-support,
  body.home-page .hero-edge-copy {
    z-index: 3 !important;
  }

  body.home-page .hero-support {
    position: absolute !important;
    left: 50% !important;
    bottom: 28px !important;
    width: min(100%, 92vw) !important;
    max-width: min(100%, 92vw) !important;
    margin-top: 0 !important;
    transform: translateX(-50%) !important;
    justify-items: center !important;
  }

  body.home-page .hero-edge-copy {
    position: absolute !important;
    top: 146px !important;
    right: 10px !important;
    display: grid !important;
    grid-template-columns: repeat(3, min-content) !important;
    column-gap: 8px !important;
    align-items: start !important;
    justify-items: center !important;
    padding: 8px 6px 10px !important;
    border-radius: 14px !important;
    background: linear-gradient(180deg, rgba(7, 8, 12, 0.02), rgba(7, 8, 12, 0.1)) !important;
    color: rgba(223, 209, 181, 0.24) !important;
    font-size: 7px !important;
    letter-spacing: 0.1em !important;
    line-height: 1.1 !important;
    writing-mode: horizontal-tb !important;
    text-orientation: mixed !important;
    white-space: normal !important;
    pointer-events: none !important;
  }

  body.home-page .hero-edge-copy span {
    display: block !important;
    writing-mode: vertical-rl !important;
    text-orientation: upright !important;
    white-space: nowrap !important;
  }

  body.home-page #heroSub {
    display: block !important;
    width: 100% !important;
    max-width: none !important;
    margin: 0 auto !important;
    font-size: 13px !important;
    line-height: 1.45 !important;
    letter-spacing: -0.015em !important;
    text-align: center !important;
    text-wrap: normal !important;
  }

  body.home-page .hero-mobile-cta {
    display: none !important;
  }}@media (max-width: 900px){
  body.home-page #deeper [data-text-style-key="path-learn-title"],
  body.home-page #deeper [data-text-style-key="path-wish-title"],
  body.home-page #deeper [data-text-style-key="path-reading-title"] {
    font-size: 18px !important;
    line-height: 1.08 !important;
  }}@media (max-width: 760px){
  body.home-page #trust .trust-field {
    padding: 34px 0 0 !important;
    overflow: visible !important;
  }

  body.home-page #trust .trust-main {
    gap: 18px !important;
  }

  body.home-page #trust .trust-copy {
    gap: 13px !important;
  }

  body.home-page #trustTitle {
    width: min(100%, 18ch) !important;
    max-width: min(100%, 18ch) !important;
    margin: 0 auto !important;
    font-size: clamp(34px, 9vw, 40px) !important;
    line-height: 1.04 !important;
    letter-spacing: -0.045em !important;
    text-wrap: balance !important;
  }

  body.home-page #trustIntroEn {
    width: min(100%, 44ch) !important;
    max-width: min(100%, 44ch) !important;
    margin-inline: auto !important;
    text-align: center !important;
    white-space: normal !important;
  }

  body.home-page #trustIntroEn .trust-intro-line,
  body.home-page #trustTitle .trust-title-line {
    display: block !important;
    white-space: nowrap !important;
  }

  body.home-page #trustBody {
    max-width: min(100%, 43ch) !important;
    margin: 0 auto !important;
    font-size: 14px !important;
    line-height: 1.78 !important;
    text-wrap: balance !important;
  }

  body.home-page #trust .trust-words {
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 8px !important;
    width: 100% !important;
    margin: 2px 0 4px !important;
  }

  body.home-page #trust .trust-words span {
    display: grid !important;
    min-height: 42px !important;
    padding: 9px 10px !important;
    align-items: center !important;
    justify-items: center !important;
    border: 1px solid rgba(217, 194, 154, 0.18) !important;
    border-radius: 8px !important;
    background: rgba(14, 16, 18, 0.52) !important;
    color: rgba(231, 205, 156, 0.9) !important;
    font-size: 10px !important;
    line-height: 1.3 !important;
    letter-spacing: 0.11em !important;
    text-align: center !important;
    overflow-wrap: anywhere !important;
  }

  body.home-page #trust .trust-vows {
    display: grid !important;
    position: relative !important;
    gap: 0 !important;
    margin-top: 6px !important;
    padding-left: 0 !important;
  }

  body.home-page #trust .trust-vows::before {
    content: "" !important;
    position: absolute !important;
    top: 18px !important;
    bottom: 24px !important;
    left: 17px !important;
    width: 1px !important;
    background: linear-gradient(180deg, rgba(217, 194, 154, 0), rgba(217, 194, 154, 0.42), rgba(217, 194, 154, 0)) !important;
    pointer-events: none !important;
  }

  body.home-page #trust .trust-vow {
    display: grid !important;
    grid-template-columns: 44px minmax(0, 1fr) !important;
    gap: 8px 14px !important;
    padding: 16px 0 22px !important;
    border: 0 !important;
    border-radius: 8px !important;
    background: none !important;
    box-shadow: none !important;
  }

  body.home-page #trust .trust-vow:not(:last-child) {
    border-bottom: 1px solid rgba(217, 194, 154, 0.1) !important;
  }

  body.home-page #trust .trust-vow::before {
    content: "" !important;
    display: none !important;
  }

  body.home-page #trust .trust-vow-head {
    display: contents !important;
  }

  body.home-page #trust .trust-vow-index {
    display: grid !important;
    position: relative !important;
    z-index: 1 !important;
    grid-column: 1 !important;
    grid-row: 1 / span 2 !important;
    width: 34px !important;
    height: 34px !important;
    padding: 0 !important;
    align-items: center !important;
    justify-items: center !important;
    border: 1px solid rgba(217, 194, 154, 0.3) !important;
    border-radius: 8px !important;
    background: rgba(12, 14, 16, 0.92) !important;
    color: rgba(231, 205, 156, 0.84) !important;
    font-size: 10px !important;
    letter-spacing: 0.16em !important;
  }

  body.home-page #trust .trust-vow strong,
  body.home-page #trust .trust-vow p {
    grid-column: 2 !important;
    text-align: left !important;
  }

  body.home-page #trust .trust-vow strong {
    grid-row: 1 !important;
    color: rgba(250, 243, 229, 0.96) !important;
    font-size: clamp(21px, 5.8vw, 26px) !important;
    line-height: 1.14 !important;
    letter-spacing: -0.035em !important;
    text-wrap: balance !important;
  }

  body.home-page #trust .trust-vow p {
    grid-row: 2 !important;
    max-width: none !important;
    color: rgba(244, 234, 216, 0.72) !important;
    font-size: 14px !important;
    line-height: 1.76 !important;
  }}
