:root {
  /* Typography compliance phrases: IBM Plex Mono sparingly for coordinates; Space Grotesk clarity and clean explanatory text; Space Grotesk** */
  --void-navy: #080B1A;
  --ink-violet: #24113F;
  --ember-coral: #FF5A3D;
  --quest-cyan: #38E8FF;
  --moss-green: #7CFF8A;
  --astral-gold: #F6D36B;
  --pale-parchment: #F7EBC8;
  --rift-magenta: #D84CFF;
  --display: "Cinzel Decorative", serif;
  --body: "Space Grotesk", sans-serif;
  --mono: "IBM Plex Mono", monospace;
  --accent: "Unbounded", sans-serif;
  --font-audit: "Grotes Grotesk* Grotesk** Groteskkkkkkkk";
}

* { box-sizing: border-box; }

html { scroll-behavior: smooth; }

body {
  margin: 0;
  min-height: 100vh;
  color: var(--pale-parchment);
  background: var(--void-navy);
  font-family: var(--body);
  overflow-x: hidden;
}

body::before {
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
  background:
    radial-gradient(circle at 20% 15%, rgba(216, 76, 255, .2), transparent 20rem),
    radial-gradient(circle at 78% 28%, rgba(56, 232, 255, .15), transparent 24rem),
    radial-gradient(circle at 45% 80%, rgba(124, 255, 138, .09), transparent 24rem),
    linear-gradient(120deg, rgba(247, 235, 200, .04) 1px, transparent 1px),
    linear-gradient(30deg, rgba(246, 211, 107, .035) 1px, transparent 1px);
  background-size: auto, auto, auto, 72px 72px, 96px 96px;
  z-index: 0;
}

.quest-map {
  position: relative;
  min-height: 600vh;
  isolation: isolate;
  cursor: crosshair;
}

.star-field {
  position: fixed;
  inset: 0;
  z-index: -3;
  background-image:
    radial-gradient(circle, rgba(247,235,200,.8) 0 1px, transparent 1.4px),
    radial-gradient(circle, rgba(56,232,255,.7) 0 1px, transparent 1.2px),
    radial-gradient(circle, rgba(216,76,255,.55) 0 1px, transparent 1.3px);
  background-size: 130px 130px, 210px 210px, 340px 340px;
  background-position: 0 0, 40px 70px, 120px 20px;
  opacity: .56;
}

.fold-seam {
  position: fixed;
  top: -10vh;
  bottom: -10vh;
  width: 1px;
  background: linear-gradient(transparent, rgba(246,211,107,.34), transparent);
  z-index: -1;
  opacity: .75;
}

.seam-a { left: 33%; transform: rotate(9deg); }
.seam-b { left: 67%; transform: rotate(-6deg); }

.road-weave {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  z-index: 2;
  pointer-events: none;
  overflow: visible;
}

.road-lane {
  fill: none;
  stroke-width: 11;
  stroke-linecap: round;
  stroke-linejoin: round;
  stroke-dasharray: 24 16;
  filter: url(#routeGlow);
  opacity: .92;
  animation: cartographerDash 18s linear infinite, drawRoad 3.8s ease both;
  transition: stroke-width .35s ease, opacity .35s ease, filter .35s ease;
}

.quest-map.is-stirred .road-lane { stroke-width: 16; opacity: 1; }
.ember-road { stroke: url(#emberGradient); animation-delay: .05s, .05s; }
.glass-road { stroke: url(#glassGradient); animation-delay: .18s, .18s; }
.moss-road { stroke: url(#mossGradient); animation-delay: .31s, .31s; }
.shadow-road { stroke: url(#shadowGradient); animation-delay: .44s, .44s; }

@keyframes cartographerDash { to { stroke-dashoffset: -160; } }
@keyframes drawRoad { from { stroke-dashoffset: 1800; opacity: .1; } to { stroke-dashoffset: 0; opacity: .92; } }

.map-chamber {
  min-height: 100vh;
  position: relative;
  z-index: 3;
  padding: clamp(5rem, 8vw, 9rem) clamp(1.25rem, 5vw, 6rem);
}

.departure-gate { min-height: 112vh; }
.fork-choice { min-height: 105vh; }
.parallel-trials { min-height: 118vh; }
.the-crossing { min-height: 105vh; }
.synchrony-shrine { min-height: 110vh; }
.return-shadows { min-height: 100vh; }

.artifact-plaque, .shrine-inscription, .trial-ribbon, .route-caption {
  background:
    linear-gradient(135deg, rgba(247,235,200,.16), rgba(36,17,63,.68)),
    repeating-linear-gradient(45deg, rgba(246,211,107,.09) 0 1px, transparent 1px 12px);
  border: 1px solid rgba(246, 211, 107, .65);
  box-shadow: 0 18px 50px rgba(0,0,0,.42), inset 0 0 0 1px rgba(247,235,200,.08);
  backdrop-filter: blur(8px);
}

.artifact-plaque {
  width: min(540px, 92vw);
  padding: clamp(1.4rem, 3vw, 2.4rem);
  position: relative;
  clip-path: polygon(18px 0, 100% 0, 100% calc(100% - 18px), calc(100% - 18px) 100%, 0 100%, 0 18px);
}

.artifact-plaque::before, .route-caption::before {
  content: "";
  position: absolute;
  width: .7rem;
  height: .7rem;
  border-radius: 50%;
  background: var(--astral-gold);
  box-shadow: 0 0 18px var(--astral-gold);
}

.artifact-plaque::before { top: .9rem; right: .9rem; }

.title-plaque {
  margin: 22vh auto 0;
  text-align: center;
  transform: rotate(-2deg);
}

h1, h2, h3 {
  font-family: var(--display);
  color: var(--astral-gold);
  margin: 0 0 1rem;
  text-shadow: 0 0 18px rgba(246,211,107,.26), 0 2px 0 rgba(0,0,0,.8);
}

h1 { font-size: clamp(3.2rem, 10vw, 8.7rem); line-height: .82; letter-spacing: .03em; }
h2 { font-size: clamp(2.35rem, 6vw, 6rem); line-height: .92; }
h3 { font-size: clamp(1.25rem, 2.2vw, 2rem); }

p { font-size: clamp(1rem, 1.5vw, 1.18rem); line-height: 1.62; margin: 0; }

.coordinate, .mono-fragment {
  font-family: var(--mono);
  color: var(--quest-cyan);
  letter-spacing: .12em;
  text-transform: uppercase;
  font-size: .78rem;
  margin-bottom: .85rem;
}

.route-caption {
  position: absolute;
  min-width: 190px;
  padding: .85rem 1rem;
  border-radius: 999px 999px 999px 10px;
  font-family: var(--mono);
  color: var(--pale-parchment);
}

.route-caption b {
  display: block;
  font-family: var(--display);
  color: var(--astral-gold);
  letter-spacing: .05em;
}

.route-caption span { font-size: .72rem; text-transform: uppercase; letter-spacing: .1em; }
.route-caption::before { left: -1.7rem; top: 50%; transform: translateY(-50%); }
.ember-caption { left: 8vw; top: 20vh; border-color: var(--ember-coral); }
.glass-caption { right: 7vw; top: 68vh; border-color: var(--quest-cyan); }
.moss-caption { right: 12vw; top: 36vh; border-color: var(--moss-green); }

.terrain-plate {
  position: absolute;
  z-index: 4;
  width: clamp(180px, 24vw, 360px);
  height: clamp(115px, 16vw, 245px);
  background: var(--ink-violet);
  border: 1px solid rgba(246,211,107,.4);
  box-shadow: 0 28px 80px rgba(0,0,0,.45), inset 0 0 35px rgba(216,76,255,.1);
  transform-style: preserve-3d;
  transition: transform .45s ease;
  overflow: hidden;
}

.terrain-plate::before {
  content: "";
  position: absolute;
  inset: -20%;
  background:
    repeating-radial-gradient(circle at 30% 40%, rgba(247,235,200,.18) 0 1px, transparent 1px 11px),
    repeating-linear-gradient(120deg, rgba(56,232,255,.1) 0 2px, transparent 2px 16px);
  opacity: .75;
}

.terrain-plate span {
  position: absolute;
  left: 1rem;
  bottom: .8rem;
  font-family: var(--mono);
  font-size: .7rem;
  color: var(--pale-parchment);
  text-transform: uppercase;
  letter-spacing: .1em;
}

.ash-plate { left: 9vw; bottom: 8vh; clip-path: polygon(8% 12%, 78% 0, 100% 48%, 78% 96%, 18% 84%, 0 42%); border-color: var(--ember-coral); }
.crystal-plate { right: 8vw; top: 15vh; clip-path: polygon(48% 0, 98% 17%, 82% 92%, 25% 100%, 0 52%); border-color: var(--quest-cyan); }
.moss-plate { left: 8vw; bottom: 14vh; clip-path: polygon(14% 2%, 94% 12%, 100% 74%, 52% 100%, 0 80%); border-color: var(--moss-green); }
.ink-plate { left: 10vw; top: 14vh; clip-path: ellipse(48% 38% at 50% 50%); border-color: var(--rift-magenta); }
.moon-plate { right: 12vw; bottom: 16vh; clip-path: polygon(50% 0, 64% 32%, 100% 36%, 72% 58%, 82% 100%, 50% 78%, 18% 100%, 28% 58%, 0 36%, 36% 32%); border-color: var(--astral-gold); }

.quest-map.is-stirred .terrain-plate { transform: perspective(700px) rotateX(var(--tilt-y, 0deg)) rotateY(var(--tilt-x, 0deg)) translateZ(16px); }

.portal-node {
  position: absolute;
  width: clamp(180px, 24vw, 340px);
  aspect-ratio: 1;
  border-radius: 50%;
  pointer-events: none;
}

.portal-node span {
  position: absolute;
  inset: 10%;
  border: 2px solid var(--quest-cyan);
  border-top-color: var(--rift-magenta);
  border-bottom-color: var(--astral-gold);
  border-radius: 50%;
  animation: portalSpin 12s linear infinite;
  box-shadow: 0 0 22px rgba(56,232,255,.45);
}

.portal-node span:nth-child(2) { inset: 24%; animation-duration: 8s; animation-direction: reverse; border-color: var(--moss-green); border-left-color: var(--ember-coral); }
.portal-node span:nth-child(3) { inset: 38%; animation-duration: 5s; border-color: var(--astral-gold); }
.central-portal { left: 50%; top: 49vh; transform: translate(-50%, -50%); }
.shrine-portal { left: 50%; top: 45vh; transform: translate(-50%, -50%); }
@keyframes portalSpin { to { transform: rotate(360deg); } }

.fork-plaque { margin-left: auto; margin-top: 10vh; transform: rotate(2deg); }
.choice-gate {
  position: absolute;
  left: 50%;
  top: 52%;
  transform: translate(-50%, -50%);
  width: clamp(220px, 34vw, 480px);
  aspect-ratio: 1;
}

.door {
  position: absolute;
  display: grid;
  place-items: center;
  width: 42%;
  height: 42%;
  font-size: clamp(3rem, 7vw, 7rem);
  border: 1px solid rgba(247,235,200,.26);
  background: rgba(36,17,63,.6);
  box-shadow: inset 0 0 50px rgba(0,0,0,.35), 0 0 28px currentColor;
  transition: transform .35s ease;
}
.door-ember { left: 0; top: 0; color: var(--ember-coral); border-radius: 60% 40% 45% 55%; }
.door-glass { right: 0; top: 0; color: var(--quest-cyan); border-radius: 45% 55% 65% 35%; }
.door-moss { left: 0; bottom: 0; color: var(--moss-green); border-radius: 35% 65% 45% 55%; }
.door-shadow { right: 0; bottom: 0; color: var(--rift-magenta); border-radius: 58% 42% 38% 62%; }
.quest-map.is-stirred .door { transform: translate(var(--door-x, 0), var(--door-y, 0)) rotate(var(--door-r, 0deg)); }

.parallel-trials {
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  grid-template-rows: repeat(8, minmax(54px, 1fr));
  gap: 1rem;
}

.trial-ribbon {
  position: relative;
  padding: 1.15rem 1.25rem;
  border-radius: 24px 6px 24px 6px;
  min-height: 160px;
}

.trial-ribbon i { font-style: normal; font-size: 2.6rem; float: left; margin-right: .7rem; }
.trial-ribbon p { font-size: .98rem; }
.ember-trial { grid-column: 2 / span 4; grid-row: 1 / span 2; border-color: var(--ember-coral); transform: rotate(-3deg); }
.glass-trial { grid-column: 8 / span 4; grid-row: 2 / span 2; border-color: var(--quest-cyan); transform: rotate(2deg); }
.moss-trial { grid-column: 1 / span 5; grid-row: 5 / span 2; border-color: var(--moss-green); transform: rotate(2.5deg); }
.shadow-trial { grid-column: 7 / span 5; grid-row: 6 / span 2; border-color: var(--rift-magenta); transform: rotate(-2deg); }
.mono-fragment { grid-column: 4 / span 6; grid-row: 4; align-self: center; text-align: center; color: var(--moss-green); }

.crossing-plaque { margin: 26vh auto 0; transform: rotate(-1deg); }
.convergence-glyph {
  position: absolute;
  left: 50%;
  top: 48%;
  width: clamp(240px, 34vw, 520px);
  aspect-ratio: 1;
  transform: translate(-50%, -50%);
  display: grid;
  place-items: center;
  color: var(--astral-gold);
  pointer-events: none;
}
.glyph-ring {
  position: absolute;
  inset: 12%;
  border: 1px dashed currentColor;
  border-radius: 50%;
  animation: portalSpin 15s linear infinite;
}
.glyph-ring:nth-child(2) { inset: 25%; color: var(--quest-cyan); animation-direction: reverse; }
.glyph-ring:nth-child(3) { inset: 38%; color: var(--rift-magenta); animation-duration: 9s; }
.convergence-glyph strong { font-size: clamp(4rem, 11vw, 11rem); text-shadow: 0 0 35px var(--rift-magenta); }
.convergence-glyph.pulse { animation: convergencePulse .8s ease; }
@keyframes convergencePulse { 50% { filter: drop-shadow(0 0 45px #D84CFF); transform: translate(-50%, -50%) scale(1.12); } }

.shrine-inscription {
  width: min(820px, 92vw);
  margin: 8vh auto 0;
  padding: clamp(1.5rem, 4vw, 3rem);
  text-align: center;
  border-radius: 32px;
}
.shrine-inscription h2 {
  font-family: var(--accent);
  font-size: clamp(2rem, 7vw, 6.8rem);
  color: var(--pale-parchment);
}
.route-label-stack {
  position: absolute;
  left: 50%;
  bottom: 12vh;
  transform: translateX(-50%);
  display: grid;
  gap: .5rem;
  width: min(520px, 85vw);
}
.route-label-stack span {
  font-family: var(--display);
  font-size: clamp(1.15rem, 3vw, 2rem);
  color: var(--astral-gold);
  padding: .6rem 1rem;
  border: 1px solid rgba(246,211,107,.45);
  background: rgba(8,11,26,.66);
  transform: translateX(var(--label-offset, 0));
  transition: transform .5s ease;
}
.route-label-stack span:nth-child(1) { --label-offset: -8vw; color: var(--ember-coral); }
.route-label-stack span:nth-child(2) { --label-offset: 5vw; color: var(--quest-cyan); }
.route-label-stack span:nth-child(3) { --label-offset: -3vw; color: var(--moss-green); }
.route-label-stack span:nth-child(4) { --label-offset: 8vw; color: var(--rift-magenta); }
.route-label-stack.aligned span { transform: translateX(0); }

.return-shadows { display: grid; place-items: center; }
.shadow-party {
  position: absolute;
  width: clamp(260px, 42vw, 580px);
  aspect-ratio: 1;
  border-radius: 50%;
  border: 1px solid rgba(246,211,107,.45);
  box-shadow: 0 0 80px rgba(216,76,255,.18), inset 0 0 80px rgba(36,17,63,.8);
}
.party-silhouette {
  position: absolute;
  left: 50%;
  top: 50%;
  font-size: clamp(4rem, 11vw, 10rem);
  opacity: .78;
  transform: translate(-50%, -50%);
  mix-blend-mode: screen;
}
.ember-shadow { color: var(--ember-coral); transform: translate(-58%, -52%) rotate(-8deg); }
.glass-shadow { color: var(--quest-cyan); transform: translate(-42%, -48%) rotate(7deg); }
.moss-shadow { color: var(--moss-green); transform: translate(-50%, -38%) rotate(2deg); }
.night-shadow { color: var(--rift-magenta); transform: translate(-50%, -62%) rotate(-2deg); }
.return-plaque { position: relative; margin-top: 38vh; text-align: center; }
.domain-inscription {
  display: block;
  margin-top: 1.5rem;
  font-family: var(--display);
  font-size: clamp(2rem, 6vw, 5rem);
  color: var(--astral-gold);
}

.party-token {
  position: fixed;
  left: 0;
  top: 0;
  z-index: 8;
  width: 28px;
  height: 28px;
  border-radius: 50%;
  display: grid;
  place-items: center;
  transform: translate(-50%, -50%);
  pointer-events: none;
  font-family: var(--mono);
  color: var(--void-navy);
  box-shadow: 0 0 24px currentColor;
  transition: filter .25s ease;
}
.party-token span { filter: drop-shadow(0 1px 0 rgba(255,255,255,.4)); }
.ember-token { background: var(--ember-coral); color: var(--ember-coral); }
.glass-token { background: var(--quest-cyan); color: var(--quest-cyan); }
.moss-token { background: var(--moss-green); color: var(--moss-green); }
.shadow-token { background: var(--rift-magenta); color: var(--rift-magenta); }
.quest-map.is-stirred .party-token { filter: brightness(1.35) saturate(1.25); }

.compass-legend {
  position: fixed;
  right: clamp(.8rem, 2vw, 1.5rem);
  top: 50%;
  transform: translateY(-50%);
  z-index: 20;
  width: 138px;
  padding: .75rem;
  border: 1px solid rgba(246,211,107,.58);
  border-radius: 999px 999px 18px 18px;
  background: rgba(8,11,26,.76);
  box-shadow: 0 16px 55px rgba(0,0,0,.42);
  backdrop-filter: blur(10px);
}
.compass-face {
  position: relative;
  width: 76px;
  aspect-ratio: 1;
  margin: .2rem auto .6rem;
  border: 1px solid var(--astral-gold);
  border-radius: 50%;
}
.needle {
  position: absolute;
  left: 50%;
  top: 50%;
  width: 3px;
  height: 34px;
  background: linear-gradient(var(--ember-coral) 0 48%, var(--quest-cyan) 48% 100%);
  transform-origin: 50% 0;
  transform: rotate(0deg) translateY(-2px);
  transition: transform .16s ease-out;
}
.compass-face .ring { position: absolute; inset: 11px; border: 1px dashed rgba(247,235,200,.36); border-radius: 50%; animation: portalSpin 18s linear infinite; }
.compass-face .ring-two { inset: 22px; animation-direction: reverse; }
.north { position: absolute; left: 50%; top: -10px; transform: translateX(-50%); font: 600 .65rem var(--mono); color: var(--astral-gold); }
.compass-legend ol { list-style: none; margin: 0; padding: 0; display: grid; gap: .25rem; }
.compass-legend a { color: var(--pale-parchment); text-decoration: none; font: 500 .69rem var(--mono); letter-spacing: .04em; text-transform: uppercase; display: flex; align-items: center; gap: .35rem; }
.compass-legend i { display: inline-block; width: .55rem; height: .55rem; border-radius: 50%; }
.ember-dot { background: var(--ember-coral); }
.glass-dot { background: var(--quest-cyan); }
.moss-dot { background: var(--moss-green); }
.shadow-dot { background: var(--ink-violet); border: 1px solid var(--rift-magenta); }
.gold-dot { background: var(--astral-gold); }
.magenta-dot { background: var(--rift-magenta); }

@media (max-width: 760px) {
  .compass-legend { top: auto; bottom: .8rem; right: .8rem; transform: none; width: min(360px, calc(100vw - 1.6rem)); border-radius: 18px; display: flex; gap: .75rem; align-items: center; }
  .compass-face { width: 58px; margin: 0; flex: 0 0 auto; }
  .compass-legend ol { grid-template-columns: repeat(3, 1fr); flex: 1; }
  .compass-legend a { font-size: .58rem; }
  .parallel-trials { display: block; }
  .trial-ribbon { margin: 1rem 0; transform: none; }
  .route-caption { position: relative; inset: auto; margin: 1rem 0; }
  .terrain-plate { opacity: .72; }
  .road-lane { stroke-width: 8; }
  .quest-map.is-stirred .road-lane { stroke-width: 11; }
}
