:root {
  /* DESIGN TYPO TOKENS: IBM Plex Monoooo labels */
  --adobe: #B85F3A;
  --clay: #7A2E1D;
  --marigold: #F2A51A;
  --cactus: #182A1F;
  --parchment: #F3D7A4;
  --ink: #17110E;
  --bougainvillea: #D9366F;
  --turquoise: #1C8C8C;
  --display: "Bungee Shade", "Impact", fantasy;
  --serif: "Fraunces", Georgia, serif;
  --mono: "IBM Plex Mono", "Courier New", monospace;
  --scrawl: "Barriecito", "Comic Sans MS", cursive;
}

* { box-sizing: border-box; }

html {
  height: 100%;
  scroll-behavior: smooth;
  background: var(--ink);
}

body {
  margin: 0;
  color: var(--ink);
  font-family: var(--mono);
  overflow: hidden;
}

button {
  font: inherit;
  color: inherit;
}

.grain {
  position: fixed;
  inset: 0;
  z-index: 20;
  pointer-events: none;
  opacity: .2;
  mix-blend-mode: multiply;
  background-image:
    radial-gradient(circle at 20% 10%, rgba(23,17,14,.35) 0 1px, transparent 1px),
    radial-gradient(circle at 75% 45%, rgba(243,215,164,.28) 0 1px, transparent 1px),
    linear-gradient(115deg, transparent 0 48%, rgba(23,17,14,.14) 49% 50%, transparent 51% 100%);
  background-size: 19px 23px, 31px 29px, 13px 13px;
}

.quest-scroll {
  height: 100vh;
  overflow-y: auto;
  overflow-x: hidden;
  scroll-snap-type: y mandatory;
  perspective: 2px;
}

.chapter {
  position: relative;
  min-height: 100vh;
  scroll-snap-align: start;
  overflow: hidden;
  isolation: isolate;
  padding: clamp(28px, 5vw, 72px);
  background:
    radial-gradient(circle at 78% 18%, rgba(242,165,26,.35) 0 9vw, transparent 9.2vw),
    linear-gradient(135deg, rgba(122,46,29,.18) 0 12%, transparent 12.2% 48%, rgba(24,42,31,.12) 48.3% 52%, transparent 52.2%),
    var(--adobe);
}

.chapter::before,
.chapter::after {
  content: "";
  position: absolute;
  z-index: -1;
  pointer-events: none;
}

.chapter::before {
  inset: 16px;
  border: 5px solid var(--ink);
  outline: 3px dashed rgba(243,215,164,.55);
  transform: rotate(-.45deg);
  opacity: .55;
}

.chapter::after {
  left: -10vw;
  right: -10vw;
  bottom: -5vh;
  height: 22vh;
  background:
    repeating-linear-gradient(90deg, var(--parchment) 0 70px, var(--clay) 70px 76px, var(--turquoise) 76px 118px, var(--ink) 118px 124px, var(--marigold) 124px 184px),
    linear-gradient(var(--clay), var(--clay));
  transform: rotate(-3deg);
  opacity: .48;
}

.chapter > [data-depth] {
  will-change: transform;
  transition: transform .18s steps(3, end);
}

.charm-trail {
  position: fixed;
  z-index: 30;
  right: 20px;
  top: 50%;
  display: grid;
  gap: 14px;
  transform: translateY(-50%) rotate(1deg);
}

.charm {
  width: 48px;
  height: 56px;
  border: 3px solid var(--ink);
  background: var(--parchment);
  box-shadow: 5px 5px 0 var(--clay), -2px -2px 0 var(--marigold) inset;
  cursor: pointer;
  clip-path: polygon(15% 0, 85% 0, 100% 24%, 88% 100%, 12% 100%, 0 24%);
  transform: rotate(var(--tilt, -4deg));
}

.charm:nth-child(even) { --tilt: 5deg; background: var(--turquoise); }
.charm.active { background: var(--marigold); transform: rotate(var(--tilt, -4deg)) scale(1.12); }
.charm.rattle { animation: rattle .34s steps(5, end); }
.charm span { font-family: var(--display); font-size: 18px; }

.site-title {
  position: absolute;
  left: 6vw;
  top: 25vh;
  margin: 0;
  max-width: 74vw;
  font-family: var(--display);
  font-size: clamp(4rem, 14vw, 13rem);
  line-height: .78;
  letter-spacing: -.08em;
  color: var(--parchment);
  text-shadow: 8px 8px 0 var(--clay), 13px 13px 0 var(--ink), -4px 3px 0 var(--marigold);
  transform: rotate(-3deg);
}

.poster-label,
.artifact {
  display: inline-block;
  padding: 8px 13px;
  background: var(--ink);
  color: var(--parchment);
  border: 2px solid var(--parchment);
  font-family: var(--mono);
  font-size: .78rem;
  text-transform: uppercase;
  letter-spacing: .08em;
  box-shadow: 4px 4px 0 var(--marigold);
}

.poster-label { position: absolute; left: 9vw; top: 14vh; transform: rotate(3deg); }

.scrawl {
  position: absolute;
  left: 15vw;
  bottom: 19vh;
  width: 240px;
  font-family: var(--scrawl);
  color: var(--cactus);
  font-size: 1.45rem;
  transform: rotate(-7deg);
}

.sun.disk {
  position: absolute;
  width: clamp(180px, 28vw, 430px);
  aspect-ratio: 1;
  border-radius: 50%;
  background: radial-gradient(circle, var(--marigold) 0 18%, rgba(242,165,26,.72) 19% 44%, transparent 45%), repeating-conic-gradient(from 8deg, rgba(242,165,26,.45) 0 8deg, transparent 8deg 17deg);
  filter: blur(.2px);
  animation: wobble 5.5s steps(6, end) infinite;
}

.disk.one { right: 9vw; top: 8vh; }
.disk.two { left: 4vw; top: 13vh; opacity: .75; }

.clay-crack {
  position: absolute;
  right: 23vw;
  top: 5vh;
  width: 18vw;
  height: 80vh;
  border-left: 8px solid var(--clay);
  border-bottom: 4px solid var(--clay);
  clip-path: polygon(40% 0, 48% 12%, 38% 21%, 54% 33%, 45% 45%, 64% 60%, 49% 78%, 60% 100%, 33% 100%, 43% 78%, 28% 61%, 41% 47%, 25% 31%, 35% 18%, 28% 0);
  background: rgba(122,46,29,.28);
}

.glyph-locks {
  position: absolute;
  right: 10vw;
  bottom: 15vh;
  display: flex;
  gap: 22px;
  flex-wrap: wrap;
  max-width: 360px;
}

.glyph,
.tile-glyph,
.ritual {
  position: relative;
  border: 4px solid var(--ink);
  background: var(--parchment);
  box-shadow: 7px 7px 0 var(--ink), -4px -4px 0 rgba(242,165,26,.65) inset;
  cursor: pointer;
  transition: transform .18s steps(3, end), background .18s steps(2, end);
}

.glyph {
  width: 112px;
  min-height: 112px;
  padding: 12px 8px;
  color: var(--ink);
  transform: rotate(var(--r, -5deg));
}

.glyph:nth-child(2n) { --r: 4deg; background: var(--marigold); }
.glyph:nth-child(3n) { --r: -1deg; background: var(--turquoise); }
.glyph:hover,
.glyph.open,
.tile-glyph:hover,
.tile-glyph.open,
.ritual:hover { transform: rotate(var(--r, -5deg)) translate(-3px, -3px); background: var(--bougainvillea); }

.glyph span { display: block; font-size: 3rem; line-height: 1; }
.glyph em { display: block; margin-top: 8px; font-size: .65rem; font-style: normal; text-transform: uppercase; }

.secret-panel {
  position: absolute;
  z-index: 5;
  max-width: 330px;
  padding: 18px 20px;
  border: 4px solid var(--ink);
  background: var(--parchment);
  box-shadow: 9px 9px 0 var(--clay);
  font-family: var(--mono);
  line-height: 1.45;
  transform: translateY(18px) rotate(-2deg) scale(.88);
  opacity: 0;
  pointer-events: none;
  transition: opacity .28s steps(4, end), transform .28s steps(4, end);
}

.secret-panel.open {
  opacity: 1;
  pointer-events: auto;
  transform: translateY(0) rotate(-2deg) scale(1);
}

#thorn-note { right: 26vw; bottom: 9vh; }
#key-note { right: 17vw; bottom: 37vh; transform: translateY(18px) rotate(3deg) scale(.88); }
#key-note.open { transform: translateY(0) rotate(3deg) scale(1); }
#eye-note { right: 6vw; bottom: 30vh; }

.seed-packet,
.orchard-copy,
.ledger-sheet,
.final-note {
  position: absolute;
  max-width: min(560px, 78vw);
  padding: clamp(24px, 4vw, 46px);
  border: 5px solid var(--ink);
  background:
    linear-gradient(110deg, rgba(216,54,111,.12), transparent 38%),
    repeating-linear-gradient(0deg, rgba(122,46,29,.08) 0 2px, transparent 2px 10px),
    var(--parchment);
  box-shadow: 13px 13px 0 var(--clay), -7px -7px 0 var(--marigold);
  transform: rotate(-2deg);
}

.seed-packet { right: 10vw; top: 17vh; }
.orchard-copy { left: 7vw; top: 14vh; transform: rotate(2deg); }
.ledger-sheet { left: 12vw; top: 12vh; transform: rotate(-1deg); }
.final-note { right: 10vw; top: 18vh; transform: rotate(2deg); }

h2 {
  margin: 16px 0 12px;
  font-family: var(--serif);
  font-size: clamp(3rem, 8vw, 8rem);
  line-height: .85;
  color: var(--clay);
}

p { font-size: clamp(1rem, 1.7vw, 1.25rem); }
.pull { font-family: var(--display); color: var(--ink); font-size: clamp(2rem, 5vw, 4.8rem); line-height: .9; }

.tile-row {
  position: absolute;
  left: 0;
  bottom: 18vh;
  display: flex;
  width: 92vw;
  transform: rotate(5deg);
}

.tile-row i {
  display: block;
  width: 18vw;
  height: 18vw;
  border: 5px solid var(--ink);
  background: conic-gradient(var(--turquoise), var(--parchment), var(--marigold), var(--clay), var(--turquoise));
  box-shadow: 8px 8px 0 var(--ink);
  animation: tileFlip 8s steps(4, end) infinite;
}

.beetle { left: 11vw; top: 44vh; position: absolute; animation: crawl 6s steps(4, end) infinite; }
.match { left: 25vw; bottom: 12vh; position: absolute; }
.packet { left: 10vw; bottom: 8vh; }
#match-manifesto { left: 31vw; bottom: 24vh; }

.chapter-orchard { background-color: var(--cactus); color: var(--parchment); }
.chapter-orchard::before { border-color: var(--parchment); }
.chapter-orchard::after { opacity: .7; }

.vine {
  position: absolute;
  left: -4vw;
  top: 48vh;
  width: 108vw;
  height: 18vh;
  border-top: 12px solid var(--bougainvillea);
  border-radius: 50%;
  transform: rotate(-8deg);
}
.vine::before,
.vine::after {
  content: "✿ ✹ ✿ ✹ ✿ ✹ ✿";
  position: absolute;
  inset: -32px auto auto 7vw;
  color: var(--marigold);
  font-size: clamp(2rem, 5vw, 5rem);
  letter-spacing: 2vw;
  animation: blink 2.2s steps(2, end) infinite;
}

.icon-constellation {
  position: absolute;
  right: 8vw;
  top: 16vh;
  width: min(470px, 78vw);
  display: grid;
  grid-template-columns: repeat(2, minmax(130px, 1fr));
  gap: 28px;
}

.tile-glyph {
  min-height: 150px;
  padding: 22px;
  color: var(--ink);
  font-family: var(--display);
  font-size: 4rem;
}
.tile-glyph small { display: block; font-family: var(--mono); font-size: .7rem; text-transform: uppercase; }
.legend { right: 9vw; bottom: 9vh; }
#blade-legend { right: 25vw; bottom: 26vh; }
#coin-legend { right: 7vw; bottom: 33vh; }
#boot-legend { right: 35vw; bottom: 8vh; }

.chapter-ledger { background: linear-gradient(160deg, var(--parchment), var(--adobe) 70%); }
.banner { position: absolute; right: 18vw; top: 19vh; }
.cactus { position: absolute; right: 9vw; bottom: 18vh; }
.ledger-note { right: 18vw; bottom: 10vh; }
#cactus-warning { right: 31vw; bottom: 24vh; }

.chapter-exit {
  background: radial-gradient(circle at 18% 20%, rgba(216,54,111,.3), transparent 22%), linear-gradient(180deg, var(--clay), var(--adobe));
}
.gate {
  position: absolute;
  left: 7vw;
  bottom: -3vh;
  width: min(560px, 70vw);
  height: 78vh;
  border: 18px solid var(--ink);
  border-bottom: 0;
  border-radius: 45% 45% 0 0;
  background:
    radial-gradient(circle at 50% 18%, var(--marigold) 0 7%, transparent 7.5%),
    repeating-linear-gradient(90deg, var(--turquoise) 0 24px, var(--parchment) 24px 52px, var(--bougainvillea) 52px 70px, var(--clay) 70px 96px);
  box-shadow: 18px -12px 0 rgba(23,17,14,.45) inset, 12px 12px 0 var(--marigold);
}
.ritual {
  margin-top: 16px;
  padding: 15px 20px;
  text-transform: uppercase;
  letter-spacing: .08em;
  background: var(--marigold);
}
.last-instruction {
  position: absolute;
  left: 15vw;
  bottom: 11vh;
  max-width: 420px;
  padding: 18px;
  background: var(--ink);
  color: var(--parchment);
  border: 4px solid var(--marigold);
  font-family: var(--scrawl);
  font-size: clamp(1.6rem, 4vw, 3rem);
  transform: rotate(-4deg) translateY(120%);
  opacity: 0;
  transition: .45s steps(5, end);
}
.last-instruction.open { transform: rotate(-4deg) translateY(0); opacity: 1; }

@keyframes rattle { 0%, 100% { translate: 0 0; } 25% { translate: -4px 3px; } 50% { translate: 5px -2px; } 75% { translate: -2px -3px; } }
@keyframes wobble { 0%, 100% { transform: rotate(0deg) scale(1); } 50% { transform: rotate(8deg) scale(1.04); } }
@keyframes blink { 0%, 45% { opacity: 1; } 46%, 60% { opacity: .35; } 61%, 100% { opacity: 1; } }
@keyframes crawl { 0%, 100% { translate: 0 0; } 45% { translate: 46px 12px; } 55% { translate: 46px 12px; } }
@keyframes tileFlip { 0%, 100% { transform: rotateY(0); } 50% { transform: rotateY(180deg); } }

@media (max-width: 780px) {
  .charm-trail { right: 8px; gap: 8px; }
  .charm { width: 38px; height: 45px; }
  .site-title { left: 7vw; top: 21vh; max-width: 82vw; }
  .glyph-locks { left: 7vw; right: auto; bottom: 8vh; gap: 12px; }
  .glyph { width: 88px; min-height: 92px; }
  .glyph span { font-size: 2.2rem; }
  .seed-packet, .orchard-copy, .ledger-sheet, .final-note { left: 6vw; right: 52px; top: 12vh; }
  .icon-constellation { left: 7vw; right: 52px; top: 48vh; grid-template-columns: 1fr 1fr; gap: 14px; }
  .tile-glyph { min-height: 105px; font-size: 2.5rem; }
  .secret-panel { left: 7vw !important; right: 58px !important; bottom: 6vh !important; }
  .gate { left: -10vw; width: 78vw; opacity: .7; }
}
