:root {
  --cream: #f6efe2;
  --ivory: #fbf6ec;
  --paper: #fffdf8;
  --ink: #16352b;
  --ink-soft: #4a5f54;
  --ink-faint: #78877e;
  --green: #1f7a5c;
  --green-deep: #14503c;
  --green-pale: #cfe6d6;
  --sage: #8fb89a;
  --butter: #f4c95d;
  --coral: #ef9a6e;
  --sky: #8fc3db;
  --berry: #e59ab0;
  --line: rgba(22, 53, 43, 0.14);
  --line-soft: rgba(22, 53, 43, 0.08);
  --shadow: 0 30px 80px -45px rgba(20, 80, 60, 0.48);
  --display: "Baloo 2", system-ui, sans-serif;
  --sans: "Hanken Grotesk", system-ui, sans-serif;
  --script: "Dancing Script", cursive;
  --max: 1280px;
  --gutter: clamp(1.15rem, 4.5vw, 4.5rem);
  --radius: 18px;
  --radius-lg: 32px;
  --pill: 999px;
  --ease: cubic-bezier(0.16, 1, 0.3, 1);
  --page-accent: var(--green);
  --page-wash: var(--green-pale);
}

*,
*::before,
*::after {
  box-sizing: border-box;
}

html {
  scroll-behavior: auto;
  scroll-padding-top: 7rem;
  -webkit-text-size-adjust: 100%;
}

body {
  min-width: 320px;
  margin: 0;
  overflow-x: hidden;
  color: var(--ink);
  background:
    radial-gradient(circle at 86% 4%, color-mix(in srgb, var(--page-wash) 60%, transparent), transparent 29rem),
    linear-gradient(180deg, var(--ivory), #f1e7d5);
  font: 400 clamp(1rem, 0.97rem + 0.14vw, 1.08rem) / 1.65 var(--sans);
  -webkit-font-smoothing: antialiased;
}

body.menu-open {
  overflow: hidden;
}

::selection {
  color: var(--paper);
  background: var(--page-accent);
}

:focus-visible {
  outline: 3px solid var(--butter);
  outline-offset: 4px;
  border-radius: 7px;
}

a {
  color: inherit;
  text-decoration: none;
}

button,
input,
select,
textarea {
  font: inherit;
}

button {
  color: inherit;
}

img,
svg {
  display: block;
  max-width: 100%;
}

h1,
h2,
h3,
h4,
p,
figure,
blockquote {
  margin: 0;
}

h1,
h2,
h3,
h4 {
  font-family: var(--display);
  font-weight: 700;
  line-height: 1.04;
  letter-spacing: -0.025em;
  text-wrap: balance;
}

h2 {
  font-size: clamp(2.2rem, 1.65rem + 2.45vw, 4.2rem);
}

h3 {
  font-size: clamp(1.45rem, 1.2rem + 0.8vw, 2.2rem);
}

.skip-link {
  position: fixed;
  top: 0.75rem;
  left: 0.75rem;
  z-index: 1000;
  padding: 0.7rem 1rem;
  border-radius: var(--pill);
  color: var(--paper);
  background: var(--green-deep);
  transform: translateY(-160%);
}

.skip-link:focus {
  transform: none;
}

.grain {
  position: fixed;
  inset: 0;
  z-index: -1;
  pointer-events: none;
  opacity: 0.035;
  mix-blend-mode: multiply;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

.site-wrap {
  width: min(100%, var(--max));
  margin-inline: auto;
  padding-inline: var(--gutter);
}

.eyebrow {
  display: flex;
  align-items: center;
  gap: 0.65rem;
  color: var(--page-accent);
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}

.eyebrow::before {
  width: 1.8rem;
  height: 2px;
  border-radius: 2px;
  background: currentColor;
  content: "";
}

.script {
  font-family: var(--script);
  font-weight: 700;
  color: var(--page-accent);
  letter-spacing: 0;
}

.lede {
  color: var(--ink-soft);
  font-size: clamp(1.1rem, 1rem + 0.38vw, 1.35rem);
  line-height: 1.55;
}

.small-note {
  color: var(--ink-faint);
  font-size: 0.82rem;
}

/* Shared navigation */
.site-nav {
  position: fixed;
  top: 0.72rem;
  right: var(--gutter);
  left: var(--gutter);
  z-index: 60;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding: 0.48rem 0.55rem 0.48rem 0.85rem;
  border: 1px solid rgba(255, 255, 255, 0.7);
  border-radius: var(--pill);
  background: rgba(255, 253, 248, 0.9);
  box-shadow: 0 18px 50px -32px rgba(20, 80, 60, 0.44);
  backdrop-filter: blur(12px);
}

.site-brand {
  display: flex;
  align-items: center;
  gap: 0.55rem;
  min-width: max-content;
}

.site-brand img {
  width: 45px;
  height: 45px;
  object-fit: contain;
}

.site-brand span {
  display: flex;
  flex-direction: column;
  line-height: 1;
}

.site-brand b {
  color: var(--green-deep);
  font-family: var(--script);
  font-size: 1.35rem;
}

.site-brand small {
  margin-top: 0.2rem;
  color: var(--ink-faint);
  font-size: 0.47rem;
  font-weight: 700;
  letter-spacing: 0.24em;
  text-transform: uppercase;
}

.site-links {
  display: flex;
  align-items: center;
  gap: clamp(0.8rem, 1.5vw, 1.5rem);
}

.site-links > a:not(.btn) {
  position: relative;
  padding-block: 0.45rem;
  color: var(--ink-soft);
  font-family: var(--display);
  font-size: 0.85rem;
  font-weight: 600;
}

.site-links > a:not(.btn)::after {
  position: absolute;
  right: 0;
  bottom: 0.15rem;
  left: 0;
  height: 2px;
  border-radius: 2px;
  background: var(--page-accent);
  transform: scaleX(0);
  transform-origin: right;
  transition: transform 170ms var(--ease);
  content: "";
}

.site-links > a:not(.btn):hover::after,
.site-links > a.current::after {
  transform: scaleX(1);
  transform-origin: left;
}

.site-menu-toggle,
.site-links .mobile-cta {
  display: none;
}

/* Buttons */
.btn {
  position: relative;
  isolation: isolate;
  display: inline-flex;
  min-height: 46px;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  overflow: hidden;
  padding: 0.7rem 1.25rem;
  border: 1px solid transparent;
  border-radius: var(--pill);
  color: var(--paper);
  background: var(--page-accent);
  box-shadow: 0 14px 28px -18px color-mix(in srgb, var(--page-accent) 75%, black);
  font-family: var(--display);
  font-weight: 700;
  line-height: 1;
  cursor: pointer;
  touch-action: manipulation;
  transition: transform 160ms var(--ease), box-shadow 160ms ease;
}

.btn::before {
  position: absolute;
  inset: 0;
  z-index: -1;
  background: var(--green-deep);
  transform: translateY(102%);
  transition: transform 180ms var(--ease);
  content: "";
}

.btn:hover {
  box-shadow: 0 20px 35px -18px color-mix(in srgb, var(--page-accent) 85%, black);
  transform: translateY(-2px);
}

.btn:hover::before {
  transform: none;
}

.btn:active {
  transform: translateY(1px) scale(0.985);
}

.btn-secondary {
  color: var(--ink);
  border-color: var(--line);
  background: var(--paper);
  box-shadow: none;
}

.btn-secondary::before {
  background: var(--page-wash);
}

.text-link {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  color: var(--page-accent);
  font-family: var(--display);
  font-weight: 700;
  text-decoration: underline;
  text-decoration-color: transparent;
  text-underline-offset: 0.28em;
  transition: color 160ms ease, text-decoration-color 160ms ease;
}

.text-link:hover {
  color: var(--green-deep);
  text-decoration-color: currentColor;
}

/* Page portal */
.page-portal {
  position: relative;
  isolation: isolate;
  z-index: 1;
  min-height: 86svh;
  overflow: hidden;
  padding: clamp(9rem, 14vw, 12rem) 0 clamp(4rem, 8vw, 7rem);
}

.portal-scene {
  position: absolute;
  inset: 0;
  z-index: -3;
  overflow: hidden;
  pointer-events: none;
}

.portal-scene img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  opacity: 1;
  filter: none;
  transform: scale(1.035);
}

.portal-scene::after {
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 72% 28%, color-mix(in srgb, var(--page-wash) 20%, transparent), transparent 31rem),
    linear-gradient(90deg, rgba(251, 246, 236, 0.10) 0%, rgba(251, 246, 236, 0.08) 35%, rgba(251, 246, 236, 0.04) 62%, rgba(251, 246, 236, 0.06) 100%),
    linear-gradient(180deg, rgba(251, 246, 236, 0.10), rgba(246, 239, 226, 0.10));
  content: "";
}

.page-portal::before {
  position: absolute;
  top: -12rem;
  right: -8rem;
  z-index: -2;
  width: min(52vw, 720px);
  aspect-ratio: 1;
  border-radius: 42% 58% 63% 37% / 45% 36% 64% 55%;
  background:
    radial-gradient(circle at 35% 28%, rgba(255, 255, 255, 0.88), transparent 22%),
    linear-gradient(145deg, var(--page-wash), color-mix(in srgb, var(--page-accent) 26%, var(--paper)));
  box-shadow: var(--shadow);
  transform: rotate(12deg);
  content: "";
}

.page-portal::after {
  position: absolute;
  top: 23%;
  right: clamp(-5rem, 5vw, 4rem);
  z-index: -1;
  width: clamp(180px, 23vw, 330px);
  aspect-ratio: 1;
  border: 1px dashed color-mix(in srgb, var(--page-accent) 50%, transparent);
  border-radius: 50%;
  content: "";
}

.portal-grid {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: 1.12fr 0.88fr;
  align-items: center;
  gap: clamp(3rem, 8vw, 8rem);
}

.breadcrumb {
  display: flex;
  flex-wrap: wrap;
  gap: 0.45rem;
  margin-bottom: 2rem;
  color: var(--ink-faint);
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.breadcrumb a:hover {
  color: var(--page-accent);
}

.portal-copy {
  background: rgba(255, 253, 248, 0.25);
  backdrop-filter: blur(8px);
  padding: 1.5rem 2rem;
  border-radius: 16px;
}

.portal-copy h1 {
  max-width: 11ch;
  margin-top: 1rem;
  font-size: clamp(3.2rem, 1.8rem + 6vw, 7.4rem);
  line-height: 0.88;
  letter-spacing: -0.05em;
}

.portal-copy .lede {
  max-width: 55ch;
  margin-top: 1.6rem;
}

.portal-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
  margin-top: 1.8rem;
}

.portal-art {
  position: relative;
  min-height: 560px;
}

.portal-photo {
  position: absolute;
  inset: 3% 7% 3% 3%;
  overflow: hidden;
  border: 9px solid rgba(255, 253, 248, 0.9);
  border-radius: 46% 54% 42% 58% / 58% 42% 58% 42%;
  box-shadow: var(--shadow);
  transform: rotate(2.3deg);
}

.portal-photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.chapter-stamp {
  position: absolute;
  right: 1%;
  bottom: 3%;
  display: grid;
  width: 145px;
  aspect-ratio: 1;
  place-content: center;
  border: 1px solid rgba(255, 255, 255, 0.8);
  border-radius: 50%;
  color: var(--paper);
  background: var(--page-accent);
  box-shadow: 0 22px 45px -25px color-mix(in srgb, var(--page-accent) 80%, black);
  text-align: center;
}

.chapter-stamp b {
  font-family: var(--display);
  font-size: 2.5rem;
  line-height: 0.9;
}

.chapter-stamp span {
  margin-top: 0.3rem;
  font-size: 0.56rem;
  font-weight: 700;
  letter-spacing: 0.15em;
  text-transform: uppercase;
}

.toy-token {
  position: absolute;
  z-index: 3;
  filter: drop-shadow(0 18px 22px rgba(20, 80, 60, 0.18));
}

.toy-token.block {
  top: 2%;
  left: -2%;
  width: 76px;
  aspect-ratio: 1;
  border-radius: 16px;
  background: linear-gradient(145deg, var(--butter), #f7dc8f);
  transform: rotate(-14deg);
}

.toy-token.ring {
  right: 5%;
  bottom: -2%;
  width: 88px;
  aspect-ratio: 1;
  border: 20px solid var(--coral);
  border-radius: 50%;
  transform: rotate(18deg);
}

.portal-facts {
  position: absolute;
  right: 5%;
  bottom: 21%;
  z-index: 4;
  display: grid;
  gap: 0.5rem;
  width: min(270px, 52%);
}

.portal-facts span {
  padding: 0.58rem 0.75rem;
  border: 1px solid rgba(255, 255, 255, 0.78);
  border-radius: 12px;
  color: var(--ink-soft);
  background: rgba(255, 253, 248, 0.9);
  box-shadow: 0 10px 24px -20px rgba(20, 80, 60, 0.5);
  font-size: 0.76rem;
  font-weight: 700;
}

/* Atlas body */
.atlas {
  position: relative;
  z-index: 1;
  padding-top: 4.75rem;
  padding-bottom: clamp(5rem, 10vw, 9rem);
}

.atlas::before {
  position: absolute;
  top: 0;
  bottom: 3rem;
  left: max(var(--gutter), calc((100vw - var(--max)) / 2 + var(--gutter) + 110px));
  width: 1px;
  background: linear-gradient(var(--page-accent), transparent);
  opacity: 0.28;
  content: "";
}

.atlas-grid {
  display: grid;
  grid-template-columns: 220px minmax(0, 1fr);
  gap: clamp(2.5rem, 8vw, 7rem);
  align-items: start;
}

.atlas-rail {
  position: sticky;
  top: 7rem;
  z-index: 2;
  padding: 1.1rem;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: rgba(255, 253, 248, 0.78);
  box-shadow: 0 20px 45px -38px rgba(20, 80, 60, 0.45);
}

.atlas-rail b {
  display: block;
  margin-bottom: 0.7rem;
  color: var(--page-accent);
  font-size: 0.64rem;
  letter-spacing: 0.15em;
  text-transform: uppercase;
}

.atlas-rail a {
  display: block;
  padding: 0.45rem 0;
  color: var(--ink-soft);
  font-family: var(--display);
  font-size: 0.88rem;
  font-weight: 600;
}

.atlas-rail a:hover {
  color: var(--page-accent);
}
.atlas-rail a.active {
  position: relative;
  color: var(--page-accent);
  font-weight: 700;
  padding-left: 1.1rem;
}
.atlas-rail a.active::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0.35rem;
  bottom: 0.35rem;
  width: 3px;
  background: var(--page-accent);
  border-radius: 3px;
}

.content-flow {
  display: grid;
  gap: clamp(4rem, 8vw, 7rem);
  min-width: 0;
}

.chapter {
  position: relative;
  scroll-margin-top: 7rem;
}

.chapter-number {
  display: block;
  margin-bottom: 1rem;
  color: color-mix(in srgb, var(--page-accent) 24%, transparent);
  font-family: var(--display);
  font-size: clamp(4rem, 10vw, 8rem);
  font-weight: 700;
  line-height: 0.7;
}

.chapter-head {
  display: grid;
  grid-template-columns: 1.05fr 0.95fr;
  gap: clamp(2rem, 6vw, 5rem);
  align-items: end;
}

.chapter-head p {
  color: var(--ink-soft);
}

.chapter-copy {
  max-width: 72ch;
  margin-top: 1.5rem;
  color: var(--ink-soft);
}

.chapter-copy p + p {
  margin-top: 1rem;
}

.chapter-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.7rem;
  margin-top: 1.6rem;
}

.chapter-visual {
  position: relative;
  isolation: isolate;
  display: grid;
  grid-template-columns: minmax(280px, 0.82fr) minmax(0, 1.18fr);
  align-items: center;
  gap: clamp(2rem, 6vw, 5.5rem);
  overflow: hidden;
  padding: clamp(1.1rem, 2.5vw, 2rem);
  border: 1px solid color-mix(in srgb, var(--page-accent) 18%, var(--line));
  border-radius: clamp(30px, 5vw, 58px);
  background:
    radial-gradient(circle at 92% 8%, color-mix(in srgb, var(--page-wash) 76%, transparent), transparent 21rem),
    linear-gradient(135deg, rgba(255, 253, 248, 0.96), color-mix(in srgb, var(--page-wash) 34%, var(--paper)));
  box-shadow: 0 38px 85px -58px color-mix(in srgb, var(--page-accent) 72%, black);
}

.chapter-visual::before {
  position: absolute;
  right: -4rem;
  bottom: -5rem;
  z-index: -1;
  width: clamp(180px, 26vw, 360px);
  aspect-ratio: 1;
  border: clamp(22px, 3vw, 42px) solid color-mix(in srgb, var(--page-accent) 11%, transparent);
  border-radius: 50%;
  content: "";
}

.chapter-visual.reverse {
  grid-template-columns: minmax(0, 1.18fr) minmax(280px, 0.82fr);
}

.chapter-visual.reverse .chapter-visual-media {
  order: 2;
  transform: rotate(1.25deg);
}

.chapter-visual-media {
  position: relative;
  overflow: hidden;
  aspect-ratio: 4 / 5;
  border: 8px solid rgba(255, 253, 248, 0.92);
  border-radius: 34px 92px 34px 76px;
  background: var(--page-wash);
  box-shadow: 0 28px 60px -38px rgba(20, 80, 60, 0.52);
  transform: rotate(-1.25deg);
}

.chapter-visual-media img,
.chapter-visual-media video {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 600ms var(--ease);
}

.chapter-visual:hover .chapter-visual-media img,
.chapter-visual:hover .chapter-visual-media video {
  transform: scale(1.025);
}

.chapter-visual figcaption {
  max-width: 48ch;
  padding: clamp(0.5rem, 2vw, 1.5rem);
}

.chapter-visual .tag {
  color: var(--page-accent);
  font-size: 0.66rem;
  font-weight: 800;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

.chapter-visual h3 {
  max-width: 12ch;
  margin-top: 1.1rem;
  font-size: clamp(2.2rem, 1.55rem + 2.5vw, 4.4rem);
  line-height: 0.96;
}

.chapter-visual p {
  max-width: 52ch;
  margin-top: 1.2rem;
  color: var(--ink-soft);
}

.chapter-visual.tone-butter {
  --story-glow: rgba(244, 201, 93, 0.35);
}

.chapter-visual.tone-coral {
  --story-glow: rgba(239, 154, 110, 0.32);
}

.chapter-visual.tone-sage {
  --story-glow: rgba(143, 184, 154, 0.34);
}

.chapter-visual.tone-sky {
  --story-glow: rgba(143, 195, 219, 0.35);
}

.chapter-visual[class*="tone-"] {
  background:
    radial-gradient(circle at 92% 8%, var(--story-glow), transparent 22rem),
    linear-gradient(135deg, rgba(255, 253, 248, 0.97), color-mix(in srgb, var(--page-wash) 30%, var(--paper)));
}

.chapter-video {
  grid-template-columns: minmax(0, 1.08fr) minmax(280px, 0.92fr);
  align-items: start;
}

.chapter-video .chapter-visual-media {
  aspect-ratio: 16 / 11;
  border-radius: 38px 110px 38px 80px;
}

.chapter-video .chapter-visual-media video {
  transform: scale(1.08);
}

.chapter-video:hover .chapter-visual-media video {
  transform: scale(1.1);
}

.chapter-video h3 {
  max-width: 14ch;
}

.field-note {
  position: relative;
  margin-top: 2rem;
  padding: clamp(1.5rem, 3vw, 2.5rem);
  border: 1px solid color-mix(in srgb, var(--page-accent) 22%, transparent);
  border-radius: 8px 28px 8px 28px;
  background:
    linear-gradient(90deg, transparent 2.3rem, rgba(239, 154, 110, 0.22) 2.35rem, rgba(239, 154, 110, 0.22) 2.45rem, transparent 2.5rem),
    repeating-linear-gradient(180deg, var(--paper) 0 2rem, rgba(143, 195, 219, 0.17) 2.04rem 2.1rem);
  box-shadow: var(--shadow);
}

.field-note::before {
  position: absolute;
  top: -13px;
  left: 20%;
  width: 110px;
  height: 26px;
  background: rgba(244, 201, 93, 0.52);
  transform: rotate(-2deg);
  content: "";
}

.field-note h3 {
  margin-left: 1.6rem;
}

.field-note p,
.field-note ul {
  margin: 0.8rem 0 0 1.6rem;
  color: var(--ink-soft);
}

.artifact-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: clamp(1.15rem, 2.6vw, 2rem);
  margin-top: 2rem;
}

.artifact {
  position: relative;
  min-height: 220px;
  overflow: hidden;
  padding: clamp(1.55rem, 3vw, 2.55rem);
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  background: var(--paper);
  box-shadow: 0 20px 50px -43px rgba(20, 80, 60, 0.55);
  transition: transform 180ms var(--ease), border-color 180ms ease;
}

.artifact:hover {
  border-color: var(--page-accent);
  transform: translateY(-5px) rotate(-0.4deg);
}

.artifact::after {
  position: absolute;
  right: -1.5rem;
  bottom: -1.5rem;
  width: 95px;
  aspect-ratio: 1;
  border: 18px solid color-mix(in srgb, var(--page-wash) 65%, transparent);
  border-radius: 50%;
  content: "";
}

.artifact .tag {
  color: var(--page-accent);
  font-size: 0.64rem;
  font-weight: 700;
  letter-spacing: 0.13em;
  text-transform: uppercase;
}

.artifact h3 {
  margin-top: 2.4rem;
}

.artifact p {
  max-width: 45ch;
  margin-top: 0.65rem;
  color: var(--ink-soft);
  font-size: 0.92rem;
}

.artifact a {
  position: relative;
  z-index: 2;
  margin-top: 1.2rem;
}

.wide-artifact {
  grid-column: 1 / -1;
  display: grid;
  grid-template-columns: 0.75fr 1.25fr;
  gap: clamp(1.8rem, 4vw, 3rem);
  align-items: center;
  color: var(--paper);
  border: 0;
  background: linear-gradient(145deg, var(--green-deep), var(--page-accent));
}

.wide-artifact p {
  color: rgba(255, 253, 248, 0.76);
}

.wide-artifact::after {
  border-color: rgba(255, 255, 255, 0.12);
}

.evidence-strip {
  display: flex;
  flex-wrap: wrap;
  gap: 0.65rem;
  margin-top: 1.6rem;
}

.evidence-strip span {
  padding: 0.6rem 0.8rem;
  border: 1px solid var(--line);
  border-radius: var(--pill);
  color: var(--ink-soft);
  background: rgba(255, 253, 248, 0.78);
  font-size: 0.78rem;
  font-weight: 700;
}

.rhythm-table {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  margin-top: 2rem;
  border-top: 1px solid var(--line);
  border-left: 1px solid var(--line);
}

.rhythm-item {
  min-height: 180px;
  padding: 1.2rem;
  border-right: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
  background: rgba(255, 253, 248, 0.7);
  transition: transform 170ms var(--ease), background 170ms ease;
}

.rhythm-item:hover {
  z-index: 1;
  background: var(--paper);
  transform: translateY(-3px);
}

.rhythm-item time {
  color: var(--page-accent);
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.07em;
}

.rhythm-item b,
.rhythm-item span {
  display: block;
}

.rhythm-item b {
  margin-top: 2.1rem;
  font-family: var(--display);
  font-size: 1.05rem;
}

.rhythm-item span {
  margin-top: 0.35rem;
  color: var(--ink-soft);
  font-size: 0.85rem;
}

.pathway {
  position: relative;
  display: grid;
  gap: 0.8rem;
  margin-top: 2rem;
  padding-left: 3.2rem;
}

.pathway::before {
  position: absolute;
  top: 1rem;
  bottom: 1rem;
  left: 1.05rem;
  width: 3px;
  border-radius: 3px;
  background: linear-gradient(var(--page-accent), var(--butter));
  content: "";
}

.path-step {
  position: relative;
  padding: 1.2rem 1.3rem;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--paper);
}

.path-step::before {
  position: absolute;
  top: 1.45rem;
  left: -2.62rem;
  width: 16px;
  aspect-ratio: 1;
  border: 4px solid var(--ivory);
  border-radius: 50%;
  background: var(--page-accent);
  box-shadow: 0 0 0 1px var(--page-accent);
  content: "";
}

.path-step b {
  font-family: var(--display);
  font-size: 1.05rem;
}

.path-step p {
  margin-top: 0.35rem;
  color: var(--ink-soft);
  font-size: 0.9rem;
}

.quote-artifact {
  position: relative;
  margin-top: 2rem;
  padding: clamp(2rem, 5vw, 4rem);
  overflow: hidden;
  border-radius: 42px 120px 42px 120px;
  color: var(--paper);
  background: linear-gradient(145deg, var(--green-deep), var(--green));
  box-shadow: var(--shadow);
}

.quote-artifact::before {
  position: absolute;
  top: -4rem;
  right: 2rem;
  color: rgba(255, 255, 255, 0.09);
  font-family: Georgia, serif;
  font-size: 18rem;
  line-height: 1;
  content: "\201C";
}

.quote-artifact p {
  position: relative;
  max-width: 23ch;
  font-family: var(--display);
  font-size: clamp(1.7rem, 1.25rem + 1.8vw, 3rem);
  font-weight: 600;
  line-height: 1.2;
}

.quote-artifact cite {
  position: relative;
  display: block;
  margin-top: 1rem;
  color: rgba(255, 253, 248, 0.68);
  font-size: 0.72rem;
  font-style: normal;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
}

.branch-map {
  display: grid;
  gap: clamp(1rem, 2.2vw, 1.7rem);
  margin-top: 2rem;
}

.branch-row {
  display: grid;
  grid-template-columns: 170px 1fr auto;
  gap: clamp(1.2rem, 3vw, 2rem);
  align-items: center;
  padding: clamp(1.25rem, 2.6vw, 1.8rem);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--paper);
  transition: transform 170ms var(--ease), border-color 170ms ease;
}

.branch-row:hover {
  border-color: var(--page-accent);
  transform: translateX(5px);
}

.branch-row h3 {
  font-size: 1.45rem;
}

.branch-row p {
  color: var(--ink-soft);
  font-size: 0.9rem;
}

.branch-row .branch-actions {
  display: flex;
  gap: 0.55rem;
}

.status-banner {
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: 1rem;
  align-items: center;
  margin-top: 2rem;
  padding: 1.1rem 1.25rem;
  border: 1px solid color-mix(in srgb, var(--page-accent) 28%, transparent);
  border-radius: var(--radius);
  background: var(--page-wash);
}

.status-dot {
  width: 13px;
  aspect-ratio: 1;
  border-radius: 50%;
  background: var(--page-accent);
  box-shadow: 0 0 0 7px color-mix(in srgb, var(--page-accent) 15%, transparent);
}

.status-banner b {
  display: block;
  font-family: var(--display);
}

.status-banner span {
  color: var(--ink-soft);
  font-size: 0.84rem;
}

/* Article pages */
.article-layout {
  display: grid;
  grid-template-columns: minmax(0, 760px) 250px;
  gap: clamp(2rem, 7vw, 6rem);
  align-items: start;
}

.article-body {
  color: var(--ink-soft);
}

.article-body h2 {
  margin: 3rem 0 1rem;
  color: var(--ink);
  font-size: clamp(2rem, 1.6rem + 1.45vw, 3.2rem);
}

.article-body h3 {
  margin: 2rem 0 0.7rem;
  color: var(--ink);
}

.article-body p + p {
  margin-top: 1rem;
}

.article-body ul {
  display: grid;
  gap: 0.55rem;
  margin: 1rem 0 0;
  padding-left: 1.2rem;
}

.article-body .pull-quote {
  margin-block: 2.5rem;
  padding: 1.5rem 1.8rem;
  border-left: 4px solid var(--page-accent);
  color: var(--ink);
  background: var(--paper);
  font-family: var(--display);
  font-size: 1.35rem;
  font-weight: 600;
}

.article-aside {
  position: sticky;
  top: 7rem;
  padding: 1.2rem;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: rgba(255, 253, 248, 0.82);
}

.article-aside b {
  color: var(--page-accent);
  font-size: 0.65rem;
  letter-spacing: 0.13em;
  text-transform: uppercase;
}

.article-aside a {
  display: block;
  margin-top: 0.85rem;
  font-family: var(--display);
  font-weight: 600;
  line-height: 1.25;
}

/* Enquiry desk */
.enquiry-desk {
  display: grid;
  grid-template-columns: 0.8fr 1.2fr;
  gap: clamp(2rem, 6vw, 5rem);
  align-items: start;
  margin-top: 2rem;
}

.contact-ledger {
  display: grid;
  gap: 0.8rem;
}

.contact-entry {
  padding: 1.2rem;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--paper);
}

.contact-entry.active {
  border-color: var(--page-accent);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--page-accent) 12%, transparent);
}

.contact-entry h3 {
  font-size: 1.35rem;
}

.contact-entry address,
.contact-entry a {
  display: block;
  margin-top: 0.35rem;
  color: var(--ink-soft);
  font-size: 0.87rem;
}

.contact-entry a:hover {
  color: var(--page-accent);
}

.enquiry-form {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0.85rem;
  padding: clamp(1.4rem, 3vw, 2.3rem);
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  background: rgba(255, 253, 248, 0.82);
  box-shadow: var(--shadow);
}

.form-field {
  display: flex;
  flex-direction: column;
  gap: 0.4rem;
}

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

.form-field label {
  color: var(--ink-faint);
  font-size: 0.64rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
}

.form-field input,
.form-field select,
.form-field textarea {
  width: 100%;
  min-height: 48px;
  padding: 0.78rem 0.9rem;
  border: 1.5px solid var(--line);
  border-radius: 12px;
  color: var(--ink);
  background: var(--paper);
  outline: none;
  transition: border-color 150ms ease, box-shadow 150ms ease;
}

.form-field textarea {
  min-height: 120px;
  resize: vertical;
}

.form-field input:focus,
.form-field select:focus,
.form-field textarea:focus {
  border-color: var(--page-accent);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--page-accent) 14%, transparent);
}

.enquiry-form .btn {
  grid-column: 1 / -1;
}

.form-disclosure {
  grid-column: 1 / -1;
  color: var(--ink-faint);
  font-size: 0.75rem;
  text-align: center;
}

/* Next chapter and footer */
.next-chapter {
  position: relative;
  z-index: 1;
  padding-block: clamp(4rem, 8vw, 7rem);
  color: var(--paper);
  background:
    linear-gradient(180deg, rgba(0,0,0,0.3) 0%, transparent 40%),
    linear-gradient(0deg, rgba(0,0,0,0.15) 0%, transparent 30%),
    var(--page-bg, linear-gradient(145deg, var(--green-deep), var(--green))) center 50% / cover no-repeat;
}

.next-grid {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 2rem;
  align-items: center;
}

.next-grid p {
  color: rgba(255, 253, 248, 0.7);
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

.next-grid h2 {
  margin-top: 0.6rem;
  font-size: clamp(2.3rem, 1.7rem + 2.5vw, 4.5rem);
}

.next-grid .btn {
  color: var(--green-deep);
  background: var(--butter);
}

.next-grid .btn::before {
  background: #ffe493;
}

.site-footer {
  position: relative;
  z-index: 1;
  padding-block: clamp(3.5rem, 7vw, 6rem) 2rem;
  background:
    linear-gradient(180deg, transparent 0%, rgba(0,0,0,0.1) 50%, rgba(0,0,0,0.45) 100%),
    var(--page-bg, #e9ddc7) center 50% / cover no-repeat;
}

.footer-script {
  color: rgba(255, 253, 248, 0.85);
  font-family: var(--script);
  font-size: clamp(4rem, 16vw, 12rem);
  font-weight: 700;
  line-height: 0.8;
  text-align: center;
  text-shadow: 0 2px 8px rgba(0,0,0,0.2);
}

.footer-grid {
  display: grid;
  grid-template-columns: 1.6fr 1fr 1fr 1fr;
  gap: 2rem;
  margin-top: clamp(3rem, 6vw, 5rem);
}

.footer-brand img {
  width: min(230px, 100%);
}

.footer-brand p {
  max-width: 34ch;
  margin-top: 0.8rem;
  color: rgba(255, 253, 248, 0.65);
  font-size: 0.85rem;
}

.footer-col {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
}

.footer-col b {
  margin-bottom: 0.7rem;
  color: var(--butter);
  font-size: 0.67rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.footer-col a {
  padding-block: 0.25rem;
  color: rgba(255, 253, 248, 0.75);
  font-size: 0.86rem;
}

.footer-col a:hover {
  color: var(--butter);
}

.footer-bottom {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  gap: 0.7rem 1.4rem;
  margin-top: 3rem;
  padding-top: 1.3rem;
  border-top: 1px solid rgba(255, 255, 255, 0.15);
  color: rgba(255, 253, 248, 0.55);
  font-size: 0.65rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

/* Scroll progress bar */
#scrollProgress {
  position: fixed;
  top: 0;
  left: 0;
  z-index: 100;
  width: 100%;
  height: 3px;
  background: transparent;
  pointer-events: none;
}
#scrollProgress span {
  display: block;
  width: 0%;
  height: 100%;
  background: linear-gradient(90deg, var(--green), #7ddfb0);
  transition: width 80ms linear;
  border-radius: 0 2px 2px 0;
}

/* Reveal */
.js .reveal {
  opacity: 0;
  transform: translateY(28px) scale(0.97);
  transition: opacity 580ms var(--ease), transform 580ms var(--ease);
}

.js .reveal.visible {
  opacity: 1;
  transform: translateY(0) scale(1);
}

/* Card hover lift */
.artifact:hover,
.branch-row:hover {
  transform: translateY(-3px);
  box-shadow: 0 16px 40px -20px rgba(20,80,60,0.2);
  transition: transform 250ms var(--ease), box-shadow 250ms var(--ease);
}

@media (max-width: 1040px) {
  .site-links {
    gap: 0.75rem;
  }

  .site-links > a:not(.btn) {
    font-size: 0.76rem;
  }

  .portal-grid {
    grid-template-columns: 1fr 0.8fr;
  }

  .atlas-grid {
    grid-template-columns: 190px minmax(0, 1fr);
    gap: 2rem;
  }

  .branch-row {
    grid-template-columns: 140px 1fr;
  }

  .branch-row .branch-actions {
    grid-column: 1 / -1;
  }
}

@media (max-width: 860px) {
  .site-links {
    position: fixed;
    inset: 0;
    z-index: -1;
    flex-direction: column;
    justify-content: center;
    gap: 0.7rem;
    padding: 6rem 2rem 2rem;
    background: var(--ivory);
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transform: translateY(-1rem);
    transition:
      opacity 180ms ease,
      visibility 180ms ease,
      transform 280ms var(--ease);
  }

  body.menu-open .site-links {
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
    transform: none;
  }

  .site-links > a:not(.btn) {
    color: var(--ink);
    font-size: 1.35rem;
  }

  .site-links .mobile-cta {
    display: inline-flex;
    margin-top: 0.65rem;
  }

  .desktop-cta {
    display: none;
  }

  .site-menu-toggle {
    display: inline-flex;
    width: 44px;
    height: 44px;
    align-items: center;
    justify-content: center;
    border: 0;
    border-radius: 50%;
    background: var(--paper);
    cursor: pointer;
  }

  .site-menu-toggle span,
  .site-menu-toggle span::before,
  .site-menu-toggle span::after {
    display: block;
    width: 20px;
    height: 2px;
    border-radius: 2px;
    background: var(--green-deep);
    transition: transform 180ms var(--ease), opacity 180ms ease;
  }

  .site-menu-toggle span {
    position: relative;
  }

  .site-menu-toggle span::before,
  .site-menu-toggle span::after {
    position: absolute;
    left: 0;
    content: "";
  }

  .site-menu-toggle span::before {
    transform: translateY(-6px);
  }

  .site-menu-toggle span::after {
    transform: translateY(6px);
  }

  body.menu-open .site-menu-toggle span {
    background: transparent;
  }

  body.menu-open .site-menu-toggle span::before {
    transform: rotate(45deg);
  }

  body.menu-open .site-menu-toggle span::after {
    transform: rotate(-45deg);
  }

  .portal-grid {
    grid-template-columns: 1fr;
  }

  .portal-copy h1 {
    max-width: 12ch;
  }

  .atlas::before {
    display: none;
  }

  .atlas-grid,
  .article-layout {
    grid-template-columns: 1fr;
  }

  .atlas-rail,
  .article-aside {
    position: static;
  }

  .atlas-rail {
    display: flex;
    overflow-x: auto;
    gap: 1rem;
    padding: 0.8rem 1rem;
  }

  .atlas-rail b {
    display: none;
  }

  .atlas-rail a {
    flex: none;
    white-space: nowrap;
  }

  .chapter-head,
  .wide-artifact,
  .chapter-visual,
  .chapter-visual.reverse,
  .chapter-video,
  .enquiry-desk {
    grid-template-columns: 1fr;
  }

  .chapter-visual.reverse .chapter-visual-media {
    order: 0;
  }

  .chapter-visual-media,
  .chapter-video .chapter-visual-media {
    width: min(100%, 620px);
    aspect-ratio: 16 / 11;
  }

  .branch-row {
    grid-template-columns: 1fr;
  }

  .branch-row .branch-actions {
    grid-column: auto;
  }

  .footer-grid {
    grid-template-columns: 1fr 1fr;
  }
}

@media (max-width: 600px) {
  html {
    scroll-padding-top: 5.7rem;
  }

  .site-nav {
    top: 0.55rem;
    right: 0.7rem;
    left: 0.7rem;
    padding-left: 0.6rem;
  }

  .site-brand b {
    font-size: 1.12rem;
  }

  .site-brand small {
    display: none;
  }

  .page-portal {
    min-height: auto;
    padding-top: 7.5rem;
  }

  .page-portal::before {
    top: -5rem;
    right: -12rem;
    width: 430px;
  }

  .portal-scene img {
    opacity: 0.38;
  }

  .portal-copy h1 {
    max-width: 100%;
    font-size: clamp(2.65rem, 13.4vw, 4rem);
    line-height: 0.94;
    letter-spacing: -0.04em;
  }

  .portal-actions {
    align-items: stretch;
    flex-direction: column;
  }

  .portal-actions .btn {
    width: 100%;
  }

  .portal-photo {
    inset: 5% 4% 4%;
    border-width: 7px;
  }

  .chapter-visual {
    gap: 1.3rem;
    padding: 0.9rem;
    border-radius: 28px;
  }

  .chapter-visual-media,
  .chapter-video .chapter-visual-media {
    aspect-ratio: 4 / 5;
    border-width: 6px;
    border-radius: 26px 70px 26px 58px;
    transform: none;
  }

  .chapter-visual.reverse .chapter-visual-media {
    transform: none;
  }

  .chapter-visual figcaption {
    padding: 0.5rem 0.65rem 1rem;
  }

  .chapter-visual h3 {
    max-width: 14ch;
    font-size: clamp(2rem, 10vw, 3.25rem);
  }

  .chapter-stamp {
    width: 115px;
  }

  .portal-facts {
    right: 4%;
    bottom: 18%;
    width: min(68%, 250px);
  }

  .toy-token.block {
    left: 0;
  }

  .artifact-grid,
  .rhythm-table,
  .enquiry-form,
  .footer-grid {
    grid-template-columns: 1fr;
  }

  .wide-artifact {
    grid-column: auto;
  }

  .rhythm-table {
    border-left: 0;
  }

  .rhythm-item {
    min-height: 155px;
    border-left: 1px solid var(--line);
  }

  .chapter-head {
    align-items: start;
  }

  .branch-row .branch-actions,
  .next-grid {
    align-items: stretch;
    grid-template-columns: 1fr;
  }

  .branch-row .btn,
  .next-grid .btn {
    width: 100%;
  }

  .status-banner {
    grid-template-columns: auto 1fr;
  }

  .status-banner .btn {
    grid-column: 1 / -1;
  }

  .form-field.full,
  .enquiry-form .btn,
  .form-disclosure {
    grid-column: auto;
  }

  .footer-bottom {
    flex-direction: column;
  }
}

@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    animation-duration: 0.001ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.001ms !important;
  }

  .js .reveal {
    opacity: 1;
    transform: none;
  }
}

/* ── Calibrator toggle button ── */
#cal-toggle {
  position: fixed;
  bottom: 20px;
  right: 20px;
  z-index: 9999;
  width: 48px;
  height: 48px;
  border: none;
  border-radius: 50%;
  background: #1a7a5c;
  color: #fff;
  font-size: 1.4rem;
  cursor: pointer;
  box-shadow: 0 4px 16px rgba(0,0,0,0.35);
  line-height: 1;
}
#cal-toggle:hover { transform: scale(1.1); }

/* ── Calibrator overlay ── */
#cal-overlay {
  position: fixed;
  inset: 0;
  z-index: 9997;
  background: rgba(0,0,0,0.6);
  display: none;
  align-items: center;
  justify-content: center;
}
#cal-overlay.open { display: flex; }

#cal-panel {
  position: relative;
  width: min(96vw, 900px);
  height: min(90vh, 700px);
  background: #1a1a1a;
  color: #ddd;
  border-radius: 16px;
  box-shadow: 0 12px 60px rgba(0,0,0,0.7);
  font: 12px/1.4 system-ui, sans-serif;
  display: grid;
  grid-template-columns: 1fr 340px;
  overflow: hidden;
  cursor: default;
  resize: both;
}

#cal-header {
  grid-column: 1 / -1;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0.5rem 1rem;
  background: #222;
  border-bottom: 1px solid #333;
  cursor: grab;
  user-select: none;
}
#cal-header:active { cursor: grabbing; }
#cal-header h2 {
  font-size: 0.8rem;
  color: #888;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  margin: 0;
}
#cal-close {
  background: none;
  border: none;
  color: #888;
  font-size: 1.4rem;
  cursor: pointer;
  padding: 0 0.3rem;
  line-height: 1;
}
#cal-close:hover { color: #fff; }

/* Left side: stage preview */
#cal-stage-wrap {
  display: grid;
  place-content: center;
  padding: 1rem;
  overflow: hidden;
}
#cal-stage {
  position: relative;
  width: var(--cal-w, 450px);
  height: var(--cal-h, 560px);
  background: #e8e0d4;
  border-radius: 12px;
  overflow: hidden;
  box-shadow: 0 20px 50px rgba(0,0,0,0.3);
}
#cal-stage .photo {
  position: absolute;
  overflow: hidden;
  border-style: solid;
  border-color: rgba(255,253,248,0.9);
  box-shadow: 0 30px 55px -25px rgba(0,0,0,0.5);
  transition: all 60ms linear;
}
#cal-stage .photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

/* Right side: controls */
#cal-controls {
  display: flex;
  flex-direction: column;
  gap: 0.2rem;
  padding: 0.8rem;
  overflow-y: auto;
  background: #1e1e1e;
  border-left: 1px solid #333;
}
#cal-controls h3 {
  font-size: 0.7rem;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: #888;
  margin: 0.4rem 0 0.1rem;
}
#cal-controls h3:first-child { margin-top: 0; }
.cal-row {
  display: flex;
  align-items: center;
  gap: 0.3rem;
}
.cal-row label {
  font-size: 0.65rem;
  color: #aaa;
  min-width: 28px;
}
.cal-row input[type="range"] {
  flex: 1;
  height: 1rem;
  max-width: 160px;
}
.cal-row .cal-val {
  font-size: 0.65rem;
  color: #0ae;
  min-width: 42px;
  text-align: right;
  font-family: monospace;
}
.cal-btn-row {
  display: flex;
  gap: 0.3rem;
  margin-top: 0.3rem;
  flex-wrap: wrap;
}
.cal-btn-row button {
  flex: 1;
  min-width: 65px;
  padding: 0.4rem 0.3rem;
  border: none;
  border-radius: 6px;
  font-weight: 700;
  cursor: pointer;
  font-size: 0.7rem;
}
.cal-save { background: #2a8; color: #fff; }
.cal-copy { background: #0ae; color: #000; }
.cal-reset { background: #555; color: #ddd; }
.cal-lock { background: #e67e22; color: #fff; }
.cal-status {
  font-size: 0.65rem;
  color: #888;
  text-align: center;
  min-height: 1rem;
  margin-top: 0.2rem;
}

/* Image select */
#cal-img-select {
  width: 100%;
  padding: 0.3rem;
  background: #333;
  color: #ddd;
  border: 1px solid #555;
  border-radius: 4px;
  font-size: 0.75rem;
  margin-bottom: 0.2rem;
}

/* saved list indicator */
#cal-saved-list {
  display: flex;
  flex-wrap: wrap;
  gap: 2px;
  margin-top: 0.2rem;
}
#cal-saved-list span {
  display: inline-block;
  font-size: 0.55rem;
  padding: 1px 5px;
  border-radius: 3px;
}
#cal-saved-list .done { background: #2a8; color: #fff; }
#cal-saved-list .pending { background: #333; color: #666; }

/* ── Nurseries page: clean (no photo, no decorations) ── */
body[data-page="nurseries"] .portal-photo,
body[data-page="nurseries"] .toy-token,
body[data-page="nurseries"] .chapter-stamp,
body[data-page="nurseries"] .portal-facts {
  display: none !important;
}

/* ════════════════════════════════════════════════════════════════
   SCRAPBOOK + PREMIUM — inner pages (additive · matches the homepage)
   ════════════════════════════════════════════════════════════════ */
body[data-page]{
  background:
    radial-gradient(40% 32% at 88% 3%, color-mix(in srgb, var(--page-wash) 70%, transparent), transparent 60%),
    radial-gradient(34% 28% at 5% 12%, rgba(244,201,93,.16), transparent 62%),
    radial-gradient(38% 30% at 4% 46%, rgba(143,195,219,.26), transparent 64%),
    radial-gradient(34% 26% at 96% 64%, rgba(143,195,219,.18), transparent 64%),
    radial-gradient(50% 44% at 50% 102%, rgba(143,184,154,.20), transparent 64%),
    linear-gradient(180deg, var(--ivory), #efe5d1) !important;
}
body[data-page] .grain::after{
  content:""; position:fixed; inset:0; z-index:-1; pointer-events:none; opacity:.5;
  background-image:radial-gradient(rgba(20,80,60,.05) 1.1px, transparent 1.5px); background-size:30px 30px;
}
/* hand-drawn underline under chapter script-headings */
.chapter-head h2 .script{ position:relative; display:inline-block; }
.chapter-head h2 .script::after{ content:""; position:absolute; left:-2%; right:-2%; bottom:-.16em; height:.34em; opacity:.95;
  background:no-repeat center/100% 100% url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 300 16' preserveAspectRatio='none'%3E%3Cpath d='M4 11 C 78 3 158 16 296 6' fill='none' stroke='%23F4C95D' stroke-width='6' stroke-linecap='round'/%3E%3C/svg%3E"); }
/* day cards → separate paper cards, pinned with washi tape, hand-tilt + hover-lift */
.rhythm-table{ border:0 !important; gap:clamp(.8rem,1.4vw,1.15rem); }
.rhythm-item{ position:relative; overflow:visible; border:1px solid rgba(20,80,60,.09) !important; border-radius:18px;
  background:linear-gradient(168deg,#fffdf8,#fbf4e6)!important;
  box-shadow:0 1px 0 rgba(255,255,255,.7) inset, 0 24px 46px -32px rgba(16,44,32,.5);
  transition:transform .5s cubic-bezier(.34,1.56,.64,1), box-shadow .5s; }
.rhythm-item::after{ content:""; position:absolute; z-index:4; width:62px; height:22px; top:-11px; left:50%; transform:translateX(-50%) rotate(-3deg); border-radius:2px;
  box-shadow:0 7px 12px -9px rgba(16,44,32,.55); background:linear-gradient(135deg, rgba(143,195,219,.78), rgba(143,195,219,.46));
  -webkit-mask:linear-gradient(90deg,transparent,#000 7px,#000 calc(100% - 7px),transparent); mask:linear-gradient(90deg,transparent,#000 7px,#000 calc(100% - 7px),transparent); }
.rhythm-item:nth-child(3n+2)::after{ background:linear-gradient(135deg, rgba(244,201,93,.8), rgba(244,201,93,.48)); }
.rhythm-item:nth-child(3n)::after{ background:linear-gradient(135deg, rgba(239,154,110,.78), rgba(239,154,110,.46)); }
.rhythm-item:nth-child(2n){ transform:rotate(.5deg); } .rhythm-item:nth-child(3n){ transform:rotate(-.5deg); }
.rhythm-item:hover{ transform:rotate(0) translateY(-7px); background:linear-gradient(168deg,#fffdf8,#fbf4e6)!important; box-shadow:0 40px 66px -38px rgba(16,44,32,.6); }
@media (prefers-reduced-motion:reduce){ .rhythm-item{ transition:none; } }

/* ── A little game in every section: memory match ── */
.game-chapter{ position:relative; margin-top:clamp(2rem,5vw,3.5rem); padding:clamp(1.6rem,3.5vw,2.6rem); border-radius:clamp(24px,4vw,40px); overflow:visible;
  border:1px solid color-mix(in srgb, var(--page-accent) 16%, var(--line));
  background:radial-gradient(60% 50% at 12% 0%, color-mix(in srgb, var(--page-wash) 60%, transparent), transparent 60%), linear-gradient(168deg, rgba(255,253,248,.96), color-mix(in srgb, var(--page-wash) 26%, var(--paper)));
  box-shadow:0 38px 85px -56px color-mix(in srgb, var(--page-accent) 70%, black); }
.game-chapter::after{ content:""; position:absolute; z-index:2; width:120px; height:32px; top:-15px; left:9%; transform:rotate(-5deg); border-radius:2px;
  box-shadow:0 8px 14px -10px rgba(16,44,32,.55); background:linear-gradient(135deg, color-mix(in srgb, var(--page-accent) 60%, #fff), color-mix(in srgb, var(--page-accent) 38%, #fff));
  -webkit-mask:linear-gradient(90deg,transparent,#000 8px,#000 calc(100% - 8px),transparent); mask:linear-gradient(90deg,transparent,#000 8px,#000 calc(100% - 8px),transparent); }
.game-chapter .chapter-number{ color:color-mix(in srgb, var(--page-accent) 30%, transparent); }
.memory{ margin-top:1.6rem; }
.memory-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:clamp(.5rem,1.2vw,.85rem); max-width:480px; }
.memory-card{ position:relative; aspect-ratio:1; border:0; padding:0; background:none; cursor:pointer; perspective:700px; }
.memory-faces{ position:absolute; inset:0; transition:transform .45s cubic-bezier(.34,1.56,.64,1); transform-style:preserve-3d; }
.memory-card.is-up .memory-faces,.memory-card.is-done .memory-faces{ transform:rotateY(180deg); }
.memory-face{ position:absolute; inset:0; display:grid; place-items:center; border-radius:16px; backface-visibility:hidden; -webkit-backface-visibility:hidden; font-size:clamp(1.4rem,4vw,2.1rem); box-shadow:0 14px 26px -18px rgba(16,44,32,.55); }
.memory-back{ background:linear-gradient(160deg, var(--page-accent), color-mix(in srgb, var(--page-accent) 55%, #14503c)); color:rgba(255,255,255,.9); font-family:var(--display); font-weight:700; }
.memory-front{ transform:rotateY(180deg); background:linear-gradient(168deg,#fffdf8,#fbf4e6); box-shadow:0 14px 26px -18px rgba(16,44,32,.55), inset 0 0 0 1px rgba(20,80,60,.08); }
.memory-card.is-done .memory-front{ box-shadow:0 14px 26px -18px rgba(16,44,32,.55), inset 0 0 0 2px var(--page-accent); }
.memory-card.is-done{ animation:memPop .5s cubic-bezier(.34,1.56,.64,1); }
@keyframes memPop{ 50%{ transform:scale(1.07); } }
.memory-card:not(.is-up):not(.is-done):hover{ transform:translateY(-3px); }
.memory-bar{ display:flex; align-items:center; gap:1.2rem; margin-top:1.4rem; flex-wrap:wrap; }
.memory-bar span{ font-family:var(--display); font-weight:600; color:var(--green-deep); }
@media (prefers-reduced-motion:reduce){ .memory-faces{ transition:none; } .memory-card.is-done{ animation:none; } }

/* ════════════════════════════════════════════════════════════════
   CUTE-PREMIUM LAYER 2 — handmade scrapbook polish + per-page games
   (additive · appended 2026-06-10 · reduced-motion safe)
   ════════════════════════════════════════════════════════════════ */

/* ── soft floating bubbles behind every page ── */
#pgBubbles{ position:fixed; inset:0; z-index:-1; pointer-events:none; }
.pgbub{ position:absolute; border-radius:50%; opacity:.4; will-change:transform;
  background:radial-gradient(circle at 34% 28%, rgba(255,255,255,.85), rgba(255,255,255,0) 42%), radial-gradient(circle at 50% 55%, var(--b,#bfe3ce), transparent 72%);
  box-shadow:inset 0 -6px 14px rgba(255,255,255,.45), inset 0 5px 14px rgba(20,53,43,.06);
  animation:pgFloat 26s ease-in-out infinite; }
@keyframes pgFloat{ 0%,100%{ transform:translate(0,0); } 33%{ transform:translate(14px,-24px); } 66%{ transform:translate(-12px,12px); } }

/* ── washi tape holding the portal photo to the page ── */
.portal-art::before,.portal-art::after{ content:""; position:absolute; z-index:5; width:clamp(74px,9vw,112px); height:clamp(26px,3vw,36px); border-radius:3px; pointer-events:none;
  box-shadow:0 9px 16px -11px rgba(16,44,32,.6);
  background:linear-gradient(135deg, rgba(244,201,93,.82), rgba(244,201,93,.5));
  -webkit-mask:linear-gradient(90deg,transparent,#000 8px,#000 calc(100% - 8px),transparent);
          mask:linear-gradient(90deg,transparent,#000 8px,#000 calc(100% - 8px),transparent); }
.portal-art::before{ top:.5%; left:-1%; transform:rotate(-39deg); }
.portal-art::after{ bottom:1.5%; right:3%; transform:rotate(41deg);
  background:linear-gradient(135deg, rgba(143,195,219,.8), rgba(143,195,219,.5)); }
body[data-page="nurseries"] .portal-art::before,
body[data-page="nurseries"] .portal-art::after{ display:none; }

/* ── hand-drawn underline beneath the script word in the big H1 ── */
.portal-copy h1 .script{ position:relative; display:inline-block; }
.portal-copy h1 .script::after{ content:""; position:absolute; left:-2%; right:-2%; bottom:-.1em; height:.3em; opacity:.95;
  background:no-repeat center/100% 100% url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 300 16' preserveAspectRatio='none'%3E%3Cpath d='M4 11 C 78 3 158 16 296 6' fill='none' stroke='%23F4C95D' stroke-width='7' stroke-linecap='round'/%3E%3C/svg%3E"); }

/* ── foil shimmer sticker on the portal eyebrow ── */
.portal-copy .eyebrow::before{ width:1.5em; height:1.5em; border-radius:50%;
  background:linear-gradient(120deg,#F4C95D,#FFF3CC,#EF9A6E,#8FC3DB,#F4C95D); background-size:220% 220%;
  box-shadow:0 0 0 2px rgba(255,255,255,.85), 0 3px 8px -3px rgba(0,0,0,.35);
  animation:pgFoil 6s linear infinite; }
@keyframes pgFoil{ to{ background-position:220% 220%; } }

/* ── artifact cards: hand-placed tilt, washi label, livelier lift ── */
.artifact:nth-child(2n){ transform:rotate(.55deg); }
.artifact:nth-child(3n){ transform:rotate(-.5deg); }
.artifact:hover{ transform:rotate(0) translateY(-6px); }
.artifact .tag,.chapter-visual .tag{ display:inline-block; padding:.32em .75em; border-radius:4px; transform:rotate(-1.4deg);
  background:color-mix(in srgb, var(--page-wash) 62%, transparent);
  -webkit-mask:linear-gradient(90deg,transparent,#000 6px,#000 calc(100% - 6px),transparent);
          mask:linear-gradient(90deg,transparent,#000 6px,#000 calc(100% - 6px),transparent); }

/* ── stitch divider between chapters ── */
.content-flow > .chapter:not(:first-child)::before{ content:""; position:absolute; top:calc(clamp(4rem,8vw,7rem) / -2); left:4%; right:4%; height:2px; pointer-events:none;
  background:repeating-linear-gradient(90deg, rgba(20,80,60,.18) 0 9px, transparent 9px 18px); }

/* ── toy tokens get a gentle bob ── */
.toy-token.block{ animation:pgBobBlock 7s ease-in-out infinite; }
.toy-token.ring{ animation:pgBobRing 8s ease-in-out infinite; animation-delay:-3s; }
@keyframes pgBobBlock{ 0%,100%{ transform:rotate(-14deg) translateY(0); } 50%{ transform:rotate(-11deg) translateY(-12px); } }
@keyframes pgBobRing{ 0%,100%{ transform:rotate(18deg) translateY(0); } 50%{ transform:rotate(22deg) translateY(-10px); } }

/* ── every button: buttery bounce + sheen sweep ── */
.btn{ transition:transform .35s cubic-bezier(.34,1.56,.64,1), box-shadow .25s ease; }
.btn::after{ content:""; position:absolute; inset:0; z-index:-1; pointer-events:none;
  background:linear-gradient(115deg, transparent 30%, rgba(255,255,255,.32) 50%, transparent 70%);
  transform:translateX(-130%); transition:transform .55s ease; }
.btn:hover{ transform:translateY(-3px) rotate(-.6deg) scale(1.015); }
.btn:hover::after{ transform:translateX(130%); }
.btn:active{ transform:translateY(1px) scale(.96); }

/* ── rail + small links wiggle to the touch ── */
.atlas-rail a{ transition:color .2s ease, transform .25s var(--ease); }
.atlas-rail a:hover{ transform:translateX(4px); }
.atlas-rail .rail-game{ color:var(--page-accent); font-weight:700; }
.text-link:hover{ transform:translateX(2px); }
.text-link{ transition:color .16s ease, text-decoration-color .16s ease, transform .25s var(--ease); }

/* ════ game shell ════ */
.game-host{ position:relative; margin-top:1.9rem; }
.game-win{ margin-top:1.2rem; font-family:var(--display); font-weight:700; font-size:1.08rem; color:var(--green-deep);
  opacity:0; transform:translateY(8px); transition:opacity .4s ease, transform .45s cubic-bezier(.34,1.56,.64,1); }
.game-win.show{ opacity:1; transform:none; }
.game-reset{ margin-top:1.2rem; }
.gconf{ position:absolute; left:50%; top:38%; z-index:6; width:10px; height:14px; border-radius:3px; pointer-events:none; opacity:0;
  animation:gconfA 1.3s cubic-bezier(.16,1,.3,1) forwards; }
@keyframes gconfA{ 0%{ opacity:0; transform:translate(-50%,-50%) rotate(0); } 8%{ opacity:1; }
  100%{ opacity:0; transform:translate(calc(-50% + var(--cx,0px)), calc(-50% + var(--cy,-120px))) rotate(var(--cr,180deg)); } }

/* ════ 1 · the pink tower ════ */
.tower-stage{ position:relative; width:100%; max-width:760px; aspect-ratio:16/9; min-height:340px; border-radius:24px; overflow:hidden;
  background:
    radial-gradient(46% 42% at 10% 0%, rgba(143,195,219,.32), transparent 70%),
    radial-gradient(40% 36% at 92% 90%, rgba(244,201,93,.22), transparent 70%),
    radial-gradient(rgba(20,80,60,.05) 1.1px, transparent 1.5px) 0 0/26px 26px,
    #fffdf8;
  box-shadow:inset 0 0 0 1px rgba(20,80,60,.09), inset 0 1px 0 rgba(255,255,255,.8), 0 36px 80px -48px rgba(16,44,32,.55); }
.tower-base{ position:absolute; left:50%; top:80%; transform:translateX(-50%); width:36%; height:14px; border-radius:7px;
  background:linear-gradient(168deg,#ecd9b4,#d9bd8f); box-shadow:0 10px 18px -10px rgba(120,84,40,.65), inset 0 2px 0 rgba(255,255,255,.5); }
.tower-status{ position:absolute; left:4%; top:5%; right:4%; z-index:2; font-family:var(--display); font-weight:700; font-size:.95rem; color:var(--green-deep); }
.tw-block{ position:absolute; z-index:3; border:0; padding:0; cursor:grab; border-radius:14%;
  background:linear-gradient(155deg,#F9C2CF,#EE8FA8 58%,#E27A96);
  box-shadow:inset 0 3px 6px rgba(255,255,255,.65), inset 0 -6px 10px rgba(160,60,90,.35), 0 14px 24px -14px rgba(160,60,90,.7);
  transition:left .5s cubic-bezier(.34,1.56,.64,1), top .5s cubic-bezier(.34,1.56,.64,1), transform .3s cubic-bezier(.34,1.56,.64,1); }
.tw-block:hover{ transform:scale(1.05) rotate(-1.5deg); }
.tw-block.dragging{ cursor:grabbing; z-index:7; transform:scale(1.08) rotate(2deg);
  box-shadow:inset 0 3px 6px rgba(255,255,255,.65), inset 0 -6px 10px rgba(160,60,90,.35), 0 26px 34px -16px rgba(160,60,90,.75); }
.tw-block.locked{ cursor:default; }
.tw-block.settle{ animation:twSettle .45s cubic-bezier(.34,1.56,.64,1); }
.tw-block.sway{ animation:twSway .55s ease; }
.tw-block.quake{ animation:twQuake .5s ease; }
.tw-block.shake,.day-card.shake{ animation:gShake .42s ease; }
.tw-block.tumbling{ animation:twTumble .9s ease-in; }
.tower-stage.built .tw-block.locked{ animation:twDance .9s cubic-bezier(.34,1.56,.64,1); }
@keyframes twSettle{ 0%{ transform:scale(1.12); } 55%{ transform:scale(.96); } 100%{ transform:none; } }
@keyframes twSway{ 25%{ transform:translateX(-3px) rotate(-1deg); } 60%{ transform:translateX(2.5px) rotate(.8deg); } 100%{ transform:none; } }
@keyframes twQuake{ 20%{ transform:translateX(-6px) rotate(-2deg); } 45%{ transform:translateX(6px) rotate(2deg); } 70%{ transform:translateX(-3px); } 100%{ transform:none; } }
@keyframes twTumble{ 30%{ transform:rotate(14deg); } 100%{ transform:rotate(-32deg); } }
@keyframes twDance{ 30%{ transform:translateY(-7px) rotate(-2deg); } 60%{ transform:translateY(0) rotate(1.6deg); } 100%{ transform:none; } }
@keyframes gShake{ 20%{ transform:translateX(-7px) rotate(-4deg); } 45%{ transform:translateX(7px) rotate(4deg); } 70%{ transform:translateX(-4px); } 100%{ transform:none; } }

/* ════ 3 · put the day in order ════ */
.day-stage{ position:relative; width:100%; max-width:760px; aspect-ratio:16/9.4; min-height:370px; border-radius:24px; overflow:hidden;
  background:
    radial-gradient(46% 42% at 90% 0%, rgba(143,195,219,.30), transparent 70%),
    radial-gradient(40% 36% at 6% 94%, rgba(244,201,93,.22), transparent 70%),
    radial-gradient(rgba(20,80,60,.05) 1.1px, transparent 1.5px) 0 0/26px 26px,
    #fffdf8;
  box-shadow:inset 0 0 0 1px rgba(20,80,60,.09), inset 0 1px 0 rgba(255,255,255,.8), 0 36px 80px -48px rgba(16,44,32,.55); }
.day-top{ position:absolute; left:4%; right:4%; top:4.5%; z-index:2; display:flex; justify-content:space-between; align-items:center; gap:1rem; flex-wrap:wrap; }
.day-status{ font-family:var(--display); font-weight:700; font-size:.95rem; color:var(--green-deep); }
.day-timer{ font-family:var(--display); font-weight:800; font-size:.92rem; color:#B66A4D; background:rgba(244,201,93,.3);
  border:1.5px dashed rgba(182,106,77,.45); padding:.25em .85em; border-radius:999px; }
.day-slots{ position:absolute; left:3.5%; right:3.5%; top:17%; display:flex; gap:2.2%; }
.day-slot{ flex:1; aspect-ratio:1/1.18; position:relative; border:2.5px dashed rgba(20,80,60,.28); border-radius:16px;
  background:rgba(207,230,214,.16); transition:background .3s ease, border-color .3s ease; }
.day-slot b{ position:absolute; top:5px; left:9px; font-family:var(--display); font-weight:800; font-size:.85rem; color:rgba(20,80,60,.42); }
.day-slot.filled{ border-style:solid; border-color:rgba(31,122,92,.5); background:rgba(207,230,214,.38); }
.day-card{ position:absolute; z-index:3; width:17.5%; aspect-ratio:1/1.18; padding:.4rem; border:1px solid rgba(20,80,60,.12); border-radius:16px;
  display:flex; flex-direction:column; align-items:center; justify-content:center; gap:.3rem;
  background:linear-gradient(168deg,#fffdf8,#fbf4e6); cursor:grab;
  box-shadow:0 16px 30px -20px rgba(16,44,32,.55), inset 0 1px 0 rgba(255,255,255,.7);
  transition:left .5s cubic-bezier(.34,1.56,.64,1), top .5s cubic-bezier(.34,1.56,.64,1), transform .3s cubic-bezier(.34,1.56,.64,1); }
.day-card:hover{ transform:scale(1.06) rotate(-1.5deg); }
.day-card.dragging{ cursor:grabbing; z-index:7; transform:scale(1.1) rotate(2deg); }
.day-card.locked{ cursor:default; }
.day-card.pop{ animation:twSettle .45s cubic-bezier(.34,1.56,.64,1); }
.day-emoji{ font-size:clamp(1.5rem,3vw,2.2rem); line-height:1; }
.day-name{ font-size:.55rem; font-weight:800; letter-spacing:.05em; text-transform:uppercase; color:var(--ink-soft); text-align:center; line-height:1.3; }

/* ════ 4 · star catcher ════ */
.catch-stage{ display:grid; gap:.9rem; max-width:760px; }
.catch-hud{ display:flex; flex-wrap:wrap; align-items:center; gap:.7rem 1rem; }
.catch-count{ font-family:var(--display); font-weight:800; color:var(--green-deep); font-size:1rem; }
.catch-count b{ font-size:1.6em; }
.catch-badge{ display:inline-block; padding:.45em 1em; border-radius:999px; border:2px dashed rgba(20,80,60,.25); color:var(--ink-faint);
  font-family:var(--display); font-weight:700; font-size:.85rem; transition:all .35s cubic-bezier(.34,1.56,.64,1); }
.catch-badge.on{ border-style:solid; border-color:transparent; background:var(--green); color:var(--paper); transform:rotate(-1.5deg) scale(1.05);
  box-shadow:0 14px 26px -14px rgba(31,122,92,.8); }
.catch-badge--30.on{ background:linear-gradient(135deg,#E9A13B,#F4C95D); color:#14503C; }
.catch-pad{ width:100%; height:auto; border-radius:24px; cursor:crosshair; touch-action:none;
  background:
    radial-gradient(50% 46% at 12% 0%, rgba(143,195,219,.42), transparent 72%),
    radial-gradient(42% 38% at 88% 6%, rgba(244,201,93,.30), transparent 70%),
    radial-gradient(rgba(20,80,60,.045) 1.1px, transparent 1.5px) 0 0/26px 26px,
    linear-gradient(180deg,#F2FAFF 0%, #FAF7EC 58%, #EFF4E3 100%);
  box-shadow:inset 0 0 0 1px rgba(20,80,60,.09), inset 0 1px 0 rgba(255,255,255,.8), 0 36px 80px -48px rgba(16,44,32,.55); }
.catch-status{ font-family:var(--display); font-weight:700; color:var(--green-deep); }

/* ════ 5 · trace the letter ════ */
.trace-stage{ display:grid; gap:1.1rem; max-width:680px; }
.trace-tools{ display:flex; flex-wrap:wrap; align-items:center; gap:1rem; }
.trace-letters{ display:inline-flex; gap:.45rem; }
.trace-pick{ width:48px; height:48px; border-radius:50%; border:1.5px solid rgba(20,80,60,.18); background:#fffdf8; cursor:pointer;
  font-family:var(--display); font-weight:800; font-size:1.25rem; color:var(--ink-soft);
  box-shadow:0 10px 18px -12px rgba(16,44,32,.5); transition:transform .3s cubic-bezier(.34,1.56,.64,1), background .2s, color .2s; }
.trace-pick:hover{ transform:translateY(-3px) rotate(-3deg); }
.trace-pick.is-on{ background:var(--page-accent); border-color:transparent; color:var(--paper); transform:scale(1.07); }
.trace-progress{ font-family:var(--display); font-weight:700; color:var(--green-deep); }
.trace-tools .game-reset{ margin:0; margin-left:auto; }
.trace-pad{ width:100%; max-width:640px; height:auto; border-radius:26px; cursor:crosshair; touch-action:none;
  background:#fffefb radial-gradient(rgba(20,80,60,.05) 1px, transparent 1.4px); background-size:auto, 24px 24px;
  box-shadow:inset 0 0 0 1px rgba(20,80,60,.09), inset 0 1px 0 rgba(255,255,255,.8), 0 36px 80px -48px rgba(16,44,32,.55);
  transition:box-shadow .4s ease; }
.trace-stage.traced .trace-pad{ box-shadow:inset 0 0 0 3px rgba(31,122,92,.55), 0 0 0 6px rgba(31,122,92,.14), 0 36px 80px -48px rgba(16,44,32,.55); }

/* ════ 6 · peek-a-boo doors ════ */
.doors-stage{ max-width:760px; }
.doors-row{ display:flex; flex-wrap:wrap; gap:clamp(.6rem,1.8vw,1.1rem); }
.door{ position:relative; width:clamp(86px,17.5%,124px); aspect-ratio:3/4.1; border:0; padding:0; background:none; cursor:pointer; }
.door-inner{ position:absolute; inset:0; perspective:720px; }
.door-back{ position:absolute; inset:0; border-radius:14px; display:grid; place-items:center; font-size:clamp(1.9rem,4vw,2.6rem);
  background:radial-gradient(circle at 50% 36%, #6b5639, #4a3a25 78%); box-shadow:inset 0 0 26px rgba(0,0,0,.55), inset 0 0 0 1px rgba(0,0,0,.3); }
.door-front{ position:absolute; inset:0; border-radius:14px; transform-origin:left center; z-index:2;
  transition:transform .55s cubic-bezier(.34,1.3,.64,1); backface-visibility:hidden; -webkit-backface-visibility:hidden;
  border:2px solid rgba(20,80,60,.22);
  background:
    repeating-linear-gradient(90deg, rgba(255,255,255,.12) 0 3px, transparent 3px 26%),
    linear-gradient(168deg, var(--door,#cfe6d6), color-mix(in srgb, var(--door,#cfe6d6) 70%, #8a9a8a));
  box-shadow:0 18px 34px -22px rgba(16,44,32,.6), inset 0 1px 0 rgba(255,255,255,.55); }
.door--0{ --door:#cfe6d6; } .door--1{ --door:#f6dca0; } .door--2{ --door:#cfe2ef; } .door--3{ --door:#f3d3c0; }
.door-knob{ position:absolute; right:9%; top:48%; width:13%; aspect-ratio:1; border-radius:50%;
  background:radial-gradient(circle at 36% 32%, #fff7e0, #d9a93f 70%); box-shadow:0 3px 6px -2px rgba(0,0,0,.5); }
.door:hover .door-front{ transform:rotateY(-14deg); }
.door.open .door-front{ transform:rotateY(-102deg); }
.door.found .door-back{ animation:teddyPop .6s cubic-bezier(.34,1.56,.64,1); box-shadow:inset 0 0 26px rgba(0,0,0,.4), 0 0 0 3px rgba(244,201,93,.8); }
@keyframes teddyPop{ 0%{ font-size:0; } 65%{ } }
.doors-bar{ margin-top:1.2rem; }
.doors-status{ font-family:var(--display); font-weight:700; color:var(--green-deep); }

/* ── small screens ── */
@media (max-width:720px){
  .tower-stage{ aspect-ratio:auto; height:420px; }
  .day-stage{ aspect-ratio:auto; height:470px; }
  .day-slots{ top:14%; }
  .day-card{ width:19%; }
  .trace-tools .game-reset{ margin-left:0; }
}
@media (prefers-reduced-motion:reduce){
  .pgbub,.portal-copy .eyebrow::before,.toy-token.block,.toy-token.ring{ animation:none !important; }
  .gconf{ display:none; }
  .tw-block,.day-card{ transition:none; }
}
