:root {
  /* IBM Plex Sans Condense* Condensed* Condensed** from Google Fonts for short license metadata */
  --loam: #1A1210;
  --plum: #4B1F5E;
  --magenta: #FF4FD8;
  --cyan: #3DEBFF;
  --green: #67D37A;
  --gold: #F6C445;
  --parchment: #F3E2B8;
  --clay: #A65F3D;
  --error: #FF6B35;
  --display: "Kalam", "Comic Sans MS", cursive;
  --scribble: "Caveat", "Bradley Hand", cursive;
  --meta: "IBM Plex Sans Condensed", "Arial Narrow", sans-serif;
  --hex: polygon(25% 5%, 75% 5%, 100% 50%, 75% 95%, 25% 95%, 0% 50%);
}

* { box-sizing: border-box; }

html { scroll-behavior: smooth; }

body {
  margin: 0;
  background: var(--loam);
  color: var(--parchment);
  font-family: var(--meta);
  overflow-x: hidden;
}

body::before {
  content: "";
  position: fixed;
  inset: 0;
  background:
    radial-gradient(circle at 24% 14%, rgba(61, 235, 255, .22), transparent 28%),
    radial-gradient(circle at 82% 10%, rgba(255, 79, 216, .20), transparent 25%),
    linear-gradient(135deg, #1A1210 0%, #4B1F5E 48%, #FF4FD8 100%);
  z-index: -5;
}

.atmosphere, .scanlines, .grain { position: fixed; inset: 0; pointer-events: none; }
.atmosphere { z-index: -2; overflow: hidden; }
.scanlines {
  background: repeating-linear-gradient(to bottom, rgba(243, 226, 184, .05) 0 1px, transparent 1px 5px);
  mix-blend-mode: screen;
}
.grain {
  background-image: radial-gradient(circle, rgba(246, 196, 69, .18) 0 1px, transparent 1.7px);
  background-size: 31px 27px;
  opacity: .32;
  animation: driftGrain 12s linear infinite;
}
.sunset-band {
  position: absolute;
  width: 140vw;
  height: 18vh;
  left: -16vw;
  transform: rotate(-10deg);
  opacity: .32;
  filter: blur(1px);
}
.band-one { top: 10vh; background: linear-gradient(90deg, transparent, #FF6B35, #F6C445, transparent); }
.band-two { bottom: 9vh; background: linear-gradient(90deg, transparent, #3DEBFF, #67D37A, transparent); opacity: .18; }

.legend {
  position: fixed;
  top: 18px;
  right: 18px;
  z-index: 20;
  display: grid;
  gap: 6px;
  padding: 12px;
  background: rgba(26, 18, 16, .72);
  border: 1px solid rgba(61, 235, 255, .45);
  box-shadow: 0 0 18px rgba(255, 79, 216, .24), inset 0 0 24px rgba(166, 95, 61, .18);
  transform: skew(-7deg);
}
.legend a {
  color: var(--parchment);
  text-decoration: none;
  text-transform: uppercase;
  letter-spacing: .13em;
  font-size: 12px;
  transition: color .25s ease, text-shadow .25s ease;
}
.legend a.active, .legend a:hover { color: var(--cyan); text-shadow: 2px 0 var(--magenta), -2px 0 var(--green); }

.scene {
  position: relative;
  min-height: 100vh;
  padding: clamp(60px, 8vw, 110px) clamp(24px, 7vw, 110px);
  display: grid;
  align-items: center;
  isolation: isolate;
}
.scene::after {
  content: attr(data-chapter);
  position: absolute;
  left: 22px;
  bottom: 22px;
  font-family: var(--scribble);
  color: rgba(243, 226, 184, .64);
  font-size: clamp(22px, 3vw, 38px);
  transform: rotate(-4deg);
}

.scene-entry { overflow: hidden; }
.corner-note, .acetate-note, .annotation {
  font-family: var(--scribble);
  font-size: clamp(23px, 2.5vw, 34px);
  color: var(--parchment);
  text-shadow: 1px 0 var(--magenta);
}
.corner-note { position: absolute; left: 7vw; top: 7vh; transform: rotate(-8deg); }

.hive-field {
  width: min(940px, 94vw);
  height: min(720px, 75vh);
  margin: 0 auto;
  position: relative;
  transform: rotate(-9deg);
  filter: drop-shadow(0 24px 50px rgba(0,0,0,.45));
}
.hex, .node-hex, .shard-hex, .archive-cell {
  clip-path: var(--hex);
  display: grid;
  place-items: center;
  text-align: center;
  position: absolute;
  background: linear-gradient(145deg, rgba(243, 226, 184, .13), rgba(75, 31, 94, .72));
  border: 0;
  color: var(--parchment);
}
.hex::before, .node-hex::before, .shard-hex::before, .archive-cell::before {
  content: "";
  position: absolute;
  inset: 4px;
  clip-path: var(--hex);
  border: 2px solid rgba(61, 235, 255, .46);
  box-shadow: inset 0 0 25px rgba(61, 235, 255, .16), 0 0 18px rgba(255, 79, 216, .18);
}
.cell { width: 150px; height: 130px; padding: 22px; animation: waxSnap .9s cubic-bezier(.2,1.45,.38,1) both, hivePulse 5s ease-in-out infinite; }
.cell span { font-family: var(--display); font-weight: 700; font-size: 25px; line-height: .85; position: relative; z-index: 2; }
.cell i { font-style: normal; color: var(--gold); font-size: 25px; position: relative; z-index: 2; }
.cell:nth-child(1) { left: 68px; top: 150px; animation-delay: .04s; }
.cell:nth-child(2) { left: 193px; top: 74px; animation-delay: .13s; }
.cell:nth-child(3) { left: 324px; top: 150px; animation-delay: .21s; }
.cell:nth-child(5) { left: 577px; top: 150px; animation-delay: .29s; }
.cell:nth-child(6) { left: 704px; top: 73px; animation-delay: .37s; }
.cell:nth-child(7) { left: 706px; top: 225px; animation-delay: .45s; }
.cell:nth-child(8) { left: 577px; top: 302px; animation-delay: .53s; }
.cell:nth-child(9) { left: 324px; top: 302px; animation-delay: .61s; }
.cell:nth-child(10) { left: 193px; top: 379px; animation-delay: .69s; }
.cell:nth-child(11) { left: 68px; top: 302px; animation-delay: .77s; }
.central {
  left: 428px; top: 183px; width: 220px; height: 194px;
  background: linear-gradient(145deg, #A65F3D, #F6C445 62%, #F3E2B8);
  color: var(--loam);
  padding: 28px;
  animation: sealBreathe 4.8s ease-in-out infinite;
}
.central b { font-family: var(--display); font-size: clamp(31px, 5vw, 51px); line-height: .82; position: relative; z-index: 2; }
.central em { font-family: var(--scribble); font-size: 23px; position: relative; z-index: 2; }
.amber { background: linear-gradient(145deg, rgba(246, 196, 69, .28), rgba(75,31,94,.76)); }
.cyan { background: linear-gradient(145deg, rgba(61, 235, 255, .30), rgba(26,18,16,.72)); }
.green { background: linear-gradient(145deg, rgba(103, 211, 122, .30), rgba(26,18,16,.74)); }
.magenta { background: linear-gradient(145deg, rgba(255, 79, 216, .32), rgba(26,18,16,.74)); }
.clay { background: linear-gradient(145deg, rgba(166, 95, 61, .55), rgba(26,18,16,.74)); }
.red { background: linear-gradient(145deg, rgba(255, 107, 53, .38), rgba(26,18,16,.74)); }
.parchment { background: linear-gradient(145deg, rgba(243, 226, 184, .34), rgba(75,31,94,.72)); }
.jitter, .ambiguous { animation: waxSnap .9s cubic-bezier(.2,1.45,.38,1) both, ambiguousJitter 1.7s steps(2,end) infinite; }
.split::after { content: ""; position: absolute; inset: 8px; clip-path: var(--hex); background: rgba(255,79,216,.12); transform: translate(8px, -4px); mix-blend-mode: screen; }
.sprout::after { content: "⌇⌇"; color: var(--green); position: absolute; bottom: 16px; right: 24px; font-size: 26px; transform: rotate(20deg); }

.trace-button {
  position: absolute;
  right: 12vw;
  bottom: 16vh;
  width: 138px;
  height: 120px;
  clip-path: var(--hex);
  border: 0;
  background: var(--clay);
  color: var(--parchment);
  font-family: var(--scribble);
  font-size: 29px;
  cursor: pointer;
  box-shadow: 0 0 28px rgba(255,107,53,.4);
  transform: rotate(8deg);
}
.scene-copy { max-width: 560px; margin: -5vh 0 0 5vw; color: rgba(243,226,184,.88); font-size: 19px; line-height: 1.45; }

.chapter-title { font-family: var(--display); font-weight: 700; font-size: clamp(52px, 9vw, 118px); color: var(--parchment); line-height: .8; }
.glitch-word { position: relative; text-shadow: 3px 0 var(--magenta), -3px 2px var(--cyan); }
.glitch-word::before, .glitch-word::after { content: attr(data-text); position: absolute; inset: 0; opacity: .42; pointer-events: none; }
.glitch-word::before { color: var(--cyan); transform: translate(-3px, 2px); mix-blend-mode: screen; }
.glitch-word::after { color: var(--magenta); transform: translate(3px, -1px); mix-blend-mode: screen; }

.scene-custody { grid-template-rows: auto 1fr; gap: 28px; overflow: hidden; }
.corridor { position: relative; min-height: 330px; transform: rotate(-5deg); }
.node-hex { width: 210px; height: 182px; padding: 36px; animation: corridorSnap .7s cubic-bezier(.2,1.5,.4,1) both; }
.node-hex span { font-family: var(--display); font-size: 30px; line-height: .9; z-index: 2; }
.node-hex small { font-size: 13px; letter-spacing: .08em; text-transform: uppercase; z-index: 2; color: var(--gold); }
.node-hex:nth-child(1) { left: 2%; top: 74px; }
.node-hex:nth-child(2) { left: 21%; top: 20px; animation-delay: .12s; }
.node-hex:nth-child(3) { left: 41%; top: 95px; animation-delay: .24s; }
.node-hex:nth-child(4) { left: 61%; top: 30px; animation-delay: .36s; }
.node-hex:nth-child(5) { left: 80%; top: 105px; animation-delay: .48s; background: linear-gradient(145deg, rgba(246,196,69,.42), rgba(166,95,61,.8)); }
.path-line { position: absolute; inset: 34vh 4vw auto; height: 260px; width: 92vw; z-index: -1; transform: rotate(-5deg); }
.path-line path { fill: none; stroke: var(--green); stroke-width: 8; stroke-linecap: round; stroke-dasharray: 1400; stroke-dashoffset: 1400; filter: drop-shadow(0 0 11px #67D37A); }
.path-line.draw path { animation: drawPath 2.5s ease-out forwards; }
.acetate-note { max-width: 430px; justify-self: end; transform: rotate(4deg); background: rgba(243,226,184,.08); border: 1px solid rgba(243,226,184,.25); padding: 18px 24px; }

.scene-separation { grid-template-columns: .8fr 1.2fr; gap: 4vw; }
.slanted-panel { background: rgba(26,18,16,.62); border: 1px solid rgba(246,196,69,.45); padding: clamp(28px, 5vw, 60px); transform: skew(-8deg) rotate(-2deg); box-shadow: inset 0 0 45px rgba(166,95,61,.25); }
.slanted-panel > * { transform: skew(8deg); }
.slanted-panel h2 { font-family: var(--display); color: var(--gold); font-size: clamp(42px, 7vw, 84px); line-height: .82; margin: 0 0 20px; }
.slanted-panel p { font-size: 20px; line-height: 1.45; }
.split-cluster { position: relative; height: 600px; }
.shard-hex { width: 190px; height: 166px; padding: 28px; transition: transform .45s cubic-bezier(.2,1.45,.4,1), filter .3s ease; }
.shard-hex strong { font-family: var(--display); color: var(--cyan); font-size: 36px; z-index: 2; }
.shard-hex span { font-family: var(--scribble); color: var(--parchment); font-size: 24px; z-index: 2; }
.shard-hex:nth-child(1) { left: 33%; top: 10px; }
.shard-hex:nth-child(2) { left: 7%; top: 150px; }
.shard-hex:nth-child(3) { left: 55%; top: 142px; }
.shard-hex:nth-child(4) { left: 27%; top: 285px; }
.shard-hex:nth-child(5) { left: 68%; top: 330px; }
.shard-hex:nth-child(6) { left: 2%; top: 390px; }
.shard-hex.awake { transform: translateY(-16px) rotate(5deg); filter: drop-shadow(0 0 20px rgba(61,235,255,.42)); }

.scene-branch { overflow: hidden; }
.branch-map { height: 560px; position: relative; margin-top: -40px; }
.map-shard {
  position: absolute;
  width: 230px;
  height: 150px;
  display: grid;
  place-items: center;
  text-align: center;
  font-family: var(--display);
  font-size: 54px;
  clip-path: polygon(0 18%, 76% 0, 100% 52%, 55% 100%, 11% 82%);
  background: linear-gradient(135deg, rgba(61,235,255,.24), rgba(255,79,216,.24), rgba(166,95,61,.72));
  border: 1px solid rgba(243,226,184,.4);
  box-shadow: 0 0 30px rgba(61,235,255,.2);
}
.map-shard small { display: block; font-family: var(--meta); font-size: 15px; letter-spacing: .16em; text-transform: uppercase; color: var(--gold); }
.north { left: 42%; top: 5%; transform: rotate(-8deg); }
.west { left: 15%; top: 35%; transform: rotate(12deg); }
.center { left: 43%; top: 35%; background: linear-gradient(135deg, rgba(103,211,122,.34), rgba(75,31,94,.78)); }
.east { right: 11%; top: 30%; transform: rotate(-15deg); }
.south { left: 36%; bottom: 2%; transform: rotate(8deg); }
.warning-tape { font-family: var(--meta); text-transform: uppercase; letter-spacing: .25em; color: var(--loam); background: repeating-linear-gradient(60deg, #F6C445 0 20px, #FF6B35 20px 30px, #F6C445 30px 50px); padding: 14px 30px; transform: rotate(-4deg); box-shadow: 0 0 20px rgba(255,107,53,.35); }

.scene-bloom { place-items: center; overflow: hidden; }
.bloom-core { width: min(680px, 90vw); height: min(680px, 90vw); position: relative; animation: bloomTurn 18s linear infinite; }
.bloom-center { width: 190px; height: 166px; left: calc(50% - 95px); top: calc(50% - 83px); background: linear-gradient(145deg, #67D37A, #F3E2B8); color: var(--loam); font-family: var(--display); font-size: 38px; z-index: 3; }
.petal { position: absolute; width: 190px; height: 105px; display: grid; place-items: center; color: var(--parchment); font-family: var(--scribble); font-size: 32px; clip-path: polygon(10% 0, 100% 12%, 80% 100%, 0 82%); background: linear-gradient(135deg, rgba(255,79,216,.36), rgba(61,235,255,.22), rgba(166,95,61,.68)); box-shadow: 0 0 24px rgba(255,79,216,.24); }
.p1 { left: 39%; top: 3%; transform: rotate(-7deg); }
.p2 { right: 4%; top: 29%; transform: rotate(45deg); }
.p3 { right: 10%; bottom: 15%; transform: rotate(95deg); }
.p4 { left: 34%; bottom: 3%; transform: rotate(180deg); }
.p5 { left: 5%; bottom: 23%; transform: rotate(235deg); }
.p6 { left: 4%; top: 24%; transform: rotate(300deg); }
.annotation { max-width: 560px; text-align: center; margin-top: -40px; }

.scene-seal { grid-template-columns: 1fr 1fr; gap: 4vw; background: radial-gradient(circle at 70% 50%, rgba(166,95,61,.18), transparent 34%); }
.archive-grid { position: relative; height: 560px; transform: rotate(-4deg); }
.archive-cell { width: 230px; height: 200px; padding: 32px; position: absolute; font-family: var(--display); font-size: 31px; background: linear-gradient(145deg, rgba(243,226,184,.12), rgba(26,18,16,.88)); }
.archive-cell span { display: block; font-family: var(--meta); color: var(--gold); text-transform: uppercase; letter-spacing: .12em; font-size: 13px; margin-top: 8px; }
.archive-cell:nth-child(1) { left: 12%; top: 4%; }
.archive-cell:nth-child(2) { left: 45%; top: 20%; }
.archive-cell:nth-child(3) { left: 8%; top: 42%; }
.archive-cell:nth-child(4) { left: 47%; top: 58%; }
.archive-cell.sealed { background: linear-gradient(145deg, rgba(246,196,69,.35), rgba(166,95,61,.78)); color: var(--loam); }
.final-seal { position: relative; justify-self: center; width: min(430px, 88vw); min-height: 430px; clip-path: var(--hex); background: linear-gradient(145deg, #A65F3D, #F6C445 58%, #F3E2B8); color: var(--loam); display: grid; place-items: center; text-align: center; padding: 58px; box-shadow: 0 0 65px rgba(246,196,69,.34), inset 0 0 45px rgba(26,18,16,.2); }
.final-seal h2 { font-family: var(--display); font-size: clamp(44px, 6vw, 78px); line-height: .82; margin: 0; }
.final-seal p { font-size: 20px; line-height: 1.35; }
.seed-dot { position: absolute; width: 22px; height: 22px; border-radius: 50%; background: var(--cyan); box-shadow: 0 0 18px var(--cyan), 4px 0 0 var(--magenta); top: 38px; right: 92px; animation: seedTravel 4.5s ease-in-out infinite; }

.activated .cell { animation-duration: .42s, 2.8s; }
.glitching { animation: textBurst .34s steps(2,end) 2; }

@keyframes waxSnap { from { opacity: 0; transform: scale(.64) translateY(24px) skew(8deg); } 70% { opacity: 1; transform: scale(1.08) translateY(-8px) skew(-4deg); } to { transform: scale(1) translateY(0) skew(0); } }
@keyframes hivePulse { 0%,100% { filter: brightness(1); } 50% { filter: brightness(1.25) saturate(1.25); } }
@keyframes sealBreathe { 0%,100% { transform: scale(1); } 50% { transform: scale(1.04) rotate(1deg); } }
@keyframes ambiguousJitter { 0%,100% { transform: translate(0,0); } 20% { transform: translate(3px,-2px) skew(4deg); } 40% { transform: translate(-2px,2px) skew(-3deg); } }
@keyframes drawPath { to { stroke-dashoffset: 0; } }
@keyframes corridorSnap { from { opacity: 0; transform: translateX(-50px) scale(.8); } to { opacity: 1; transform: translateX(0) scale(1); } }
@keyframes bloomTurn { to { transform: rotate(360deg); } }
@keyframes seedTravel { 0%,100% { transform: translate(0,0); } 35% { transform: translate(-130px, 150px); } 65% { transform: translate(-18px, 285px); } }
@keyframes driftGrain { to { background-position: 31px 54px; } }
@keyframes textBurst { 0% { transform: skew(0); } 50% { transform: skew(12deg) translateX(5px); } 100% { transform: skew(-7deg) translateX(-3px); } }

@media (max-width: 900px) {
  .legend { left: 12px; right: 12px; top: 10px; grid-template-columns: repeat(6, 1fr); transform: none; }
  .legend a { font-size: 10px; text-align: center; }
  .hive-field { transform: rotate(-9deg) scale(.74); transform-origin: center; margin-left: -8vw; }
  .scene-separation, .scene-seal { grid-template-columns: 1fr; }
  .corridor, .split-cluster, .archive-grid { transform: scale(.76) rotate(-4deg); transform-origin: left center; width: 125vw; }
  .node-hex { width: 170px; height: 148px; }
  .scene-copy { margin-top: -14vh; }
  .trace-button { right: 4vw; bottom: 10vh; }
}
