/* ============================================================
   California Consciousness — "Heaven on Earth: A Liquid Light Letter"
   ============================================================ */

:root {
  /* Palette */
  --indigo:    #1A0E2E;
  --plum:      #3D1F5C;
  --marigold:  #FFB627;
  --tangerine: #FF6B35;
  --magenta:   #E2386D;
  --turquoise: #1FB7B0;
  --avocado:   #7A8B3C;
  --cream:     #F6ECD9;
  --sand:      #D9C4A3;
  --violet:    #8A2BE2;
  --blue:      #3D6BE2;
  --red:       #FF3B30;

  --ink: var(--cream);
  --muted: rgba(217,196,163,.82);
  --muted: color-mix(in srgb, var(--sand) 82%, transparent);
  --magenta-text: #F472A0;

  --rainbow: linear-gradient(90deg,#FF3B30,#FF6B35,#FFB627,#7A8B3C,#1FB7B0,#3D6BE2,#8A2BE2);

  --maxw: 1180px;
  --gap: clamp(1.25rem, 4vw, 3rem);
  --pad-y: clamp(5rem, 12vh, 11rem);

  --font-display: "Righteous", system-ui, sans-serif;
  --font-neon: "Monoton", "Righteous", sans-serif;
  --font-body: "Inter", system-ui, -apple-system, sans-serif;
  --font-script: "Caveat", "Segoe Script", cursive;

  --radius: 18px;
  --shadow: 0 24px 60px -20px rgba(0,0,0,.65);
  --glow: 0 0 40px -8px var(--marigold);
}

* { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; overflow-x: clip; }
@media (prefers-reduced-motion: reduce) { html { scroll-behavior: auto; } }

body {
  font-family: var(--font-body);
  color: var(--ink);
  background: var(--indigo);
  line-height: 1.7;
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

a { color: var(--marigold); text-decoration: none; transition: color .25s; }
a:hover { color: var(--tangerine); }
a:focus-visible, button:focus-visible, .skip-link:focus {
  outline: 3px solid var(--marigold);
  outline-offset: 3px;
  border-radius: 4px;
}

.skip-link {
  position: fixed; top: -100px; left: 1rem; z-index: 999;
  background: var(--marigold); color: var(--indigo); font-weight: 700;
  padding: .7rem 1.1rem; border-radius: 10px; transition: top .2s;
}
.skip-link:focus { top: 1rem; }

/* ---------- WebGL backdrop ---------- */
#lightshow, #lightshow-fallback {
  position: fixed; inset: 0; width: 100vw; height: 100vh;
  z-index: -2; display: block;
}
#lightshow { opacity: 0; transition: opacity 1.2s ease; }
#lightshow.ready { opacity: .92; }
#lightshow-fallback {
  background:
    radial-gradient(120% 90% at 20% 10%, rgba(255,107,53,.35), transparent 55%),
    radial-gradient(120% 90% at 85% 25%, rgba(226,56,109,.30), transparent 55%),
    radial-gradient(120% 110% at 50% 100%, rgba(31,183,176,.28), transparent 60%),
    var(--indigo);
}
/* a soft vignette to keep text legible over the light show */
body::after {
  content: ""; position: fixed; inset: 0; z-index: -1; pointer-events: none;
  background: radial-gradient(140% 100% at 50% 40%, transparent 40%, rgba(10,5,20,.55) 100%);
}

/* ---------- Top bar ---------- */
.topbar {
  position: fixed; top: 0; left: 0; right: 0; z-index: 50;
  display: flex; align-items: center; justify-content: space-between;
  padding: .85rem clamp(1rem, 4vw, 2.5rem);
  background: linear-gradient(to bottom, rgba(10,5,20,.6), transparent);
  backdrop-filter: blur(2px);
}
.topbar__mark {
  display: inline-flex; align-items: center; gap: .55rem;
  font-family: var(--font-display); font-size: clamp(.95rem, 2.5vw, 1.15rem);
  color: var(--cream); letter-spacing: .04em;
}
.topbar__sun {
  width: 14px; height: 14px; border-radius: 50%;
  background: var(--marigold); box-shadow: 0 0 14px var(--marigold);
}
.topbar__nav { display: flex; align-items: center; gap: 1rem; }
.timeline-marker {
  font-family: var(--font-display); font-size: 1.05rem; color: var(--marigold);
  letter-spacing: .12em; min-width: 3.2ch; text-align: right;
  text-shadow: 0 0 12px rgba(255,182,39,.5);
}
.motion-toggle {
  display: inline-flex; align-items: center; gap: .45rem;
  background: rgba(246,236,217,.08); border: 1px solid rgba(246,236,217,.25);
  color: var(--cream); font-family: var(--font-body); font-size: .8rem;
  padding: .35rem .7rem; border-radius: 999px; cursor: pointer; transition: background .2s;
}
.motion-toggle:hover { background: rgba(246,236,217,.16); }
.motion-toggle__dot { width: 9px; height: 9px; border-radius: 50%; background: var(--turquoise); box-shadow: 0 0 8px var(--turquoise); }
body[data-motion="off"] .motion-toggle__dot { background: var(--sand); box-shadow: none; }

/* ---------- Typography helpers ---------- */
.kicker {
  font-family: var(--font-body); font-weight: 600; letter-spacing: .28em;
  text-transform: uppercase; font-size: .72rem; color: var(--marigold);
}
.display {
  font-family: var(--font-display); font-weight: 400; line-height: 1.04;
  font-size: clamp(2rem, 6vw, 4rem); letter-spacing: .005em;
  color: var(--cream); text-wrap: balance;
}
.display--xl { font-size: clamp(2.4rem, 8vw, 6rem); }
.script { font-family: var(--font-script); color: var(--marigold); }
.script--xl { font-family: var(--font-script); font-size: clamp(2.6rem, 9vw, 6rem); line-height: 1.05; color: var(--marigold); }
.lede { font-size: clamp(1.05rem, 1.6vw, 1.3rem); color: var(--cream); max-width: 60ch; }
.body { color: var(--sand); color: color-mix(in srgb, var(--cream) 88%, transparent); max-width: 62ch; }
.mono { font-family: ui-monospace, "SFMono-Regular", Menlo, monospace; color: var(--turquoise); }

/* text legibility scrim behind copy blocks (they sit over the moving light show) */
.chapter__text, .eleven, .feature__text, .band__text, .becoming,
.benediction__inner, .chapter__head, .talk {
  position: relative; isolation: isolate;
}
.chapter__text::before, .eleven::before, .feature__text::before, .band__text::before,
.becoming::before, .benediction__inner::before, .chapter__head::before, .talk::before {
  content: ""; position: absolute; inset: clamp(-1rem, -3vw, -2.6rem); z-index: -1;
  border-radius: 30px; pointer-events: none;
  background: radial-gradient(115% 115% at 50% 45%, rgba(12,6,24,.8), rgba(12,6,24,.46) 62%, transparent 100%);
  -webkit-backdrop-filter: blur(6px); backdrop-filter: blur(6px);
}

/* ---------- Section scaffolding ---------- */
main { position: relative; z-index: 1; }
.chapter {
  max-width: var(--maxw); margin-inline: auto;
  padding: var(--pad-y) clamp(1.15rem, 4vw, 2.5rem);
}
.chapter__head { max-width: 64ch; margin-bottom: clamp(2rem,5vw,3.5rem); display: grid; gap: 1rem; }
.chapter__head .display { margin-top: .2rem; }

/* HERO */
.hero {
  min-height: 100svh; display: grid; place-items: center; text-align: center;
  padding: 6rem 1.25rem 4rem;
  position: relative; overflow: clip; perspective: 1000px;
}
.hero__inner { display: grid; gap: 1.1rem; justify-items: center; max-width: 100%; position: relative; z-index: 1; }

/* Flower of Life — interactive sacred geometry behind the title */
.flower {
  position: absolute; left: 50%; top: 50%;
  width: min(86vmin, 720px); aspect-ratio: 1;
  transform: translate(-50%, -50%); transform-style: preserve-3d;
  z-index: 0; pointer-events: none; opacity: 0;
  transition: opacity 1.4s ease; will-change: transform;
}
.flower.ready { opacity: .46; }
.hero:hover .flower { opacity: .64; }
#flower-g { transform-box: fill-box; transform-origin: 50% 50%; animation: flower-spin 90s linear infinite; }
#flower-g circle { fill: none; stroke: url(#flowerGrad); stroke-width: 1.1; vector-effect: non-scaling-stroke; }
#flower-g .flower-ring { stroke-width: 1.7; opacity: .85; }
@keyframes flower-spin { to { transform: rotate(360deg); } }
body[data-motion="off"] #flower-g { animation: none; }

/* Topbar clickable sun (replaces the wordmark) */
.topbar__sun-link { display: inline-flex; align-items: center; justify-content: center; width: 44px; height: 44px; border-radius: 50%; }
.sun { position: relative; width: 38px; height: 38px; display: block; }
.sun__core {
  position: absolute; inset: 28%; border-radius: 50%;
  background: radial-gradient(circle at 42% 38%, #FFE6A6, var(--marigold) 55%, var(--tangerine));
  box-shadow: 0 0 14px var(--marigold); animation: sun-pulse 4.5s ease-in-out infinite;
  transition: transform .3s, box-shadow .3s;
}
.sun__rays {
  position: absolute; inset: 0; border-radius: 50%;
  background: repeating-conic-gradient(var(--marigold) 0deg 3deg, transparent 3deg 30deg);
  -webkit-mask: radial-gradient(circle, transparent 33%, #000 39%, #000 50%, transparent 60%);
          mask: radial-gradient(circle, transparent 33%, #000 39%, #000 50%, transparent 60%);
  animation: sun-spin 24s linear infinite;
}
.topbar__sun-link:hover .sun__core { transform: scale(1.18); box-shadow: 0 0 22px var(--tangerine); }
.topbar__sun-link:active .sun__core { transform: scale(.92); }
@keyframes sun-spin { to { transform: rotate(360deg); } }
@keyframes sun-pulse { 0%,100% { transform: scale(1); } 50% { transform: scale(1.1); } }

/* Rainbow arcing over the hero */
.rainbow {
  position: absolute; top: clamp(36px, 9vh, 120px); left: 50%; transform: translateX(-50%);
  width: min(640px, 94%); aspect-ratio: 2 / 1; z-index: 0; pointer-events: none; opacity: .24;
}
.rainbow path { fill: none; stroke-width: 3.2; stroke-dasharray: 1; stroke-dashoffset: 0;
  animation: rainbow-draw 2.4s ease both; }
.rainbow path:nth-child(1) { animation-delay: .25s; }
.rainbow path:nth-child(2) { animation-delay: .37s; }
.rainbow path:nth-child(3) { animation-delay: .49s; }
.rainbow path:nth-child(4) { animation-delay: .61s; }
.rainbow path:nth-child(5) { animation-delay: .73s; }
.rainbow path:nth-child(6) { animation-delay: .85s; }
.rainbow path:nth-child(7) { animation-delay: .97s; }
@keyframes rainbow-draw { from { stroke-dashoffset: 1; } to { stroke-dashoffset: 0; } }

/* Palm trees that spring up either side */
.palm-wrap {
  position: absolute; bottom: 0; width: clamp(70px, 9vw, 140px); z-index: 0;
  pointer-events: none; transform-origin: bottom center; opacity: .6;
}
.palm-wrap--left { left: clamp(0px, 1vw, 28px); }
.palm-wrap--right { right: clamp(0px, 1vw, 28px); transform: scaleX(-1); }
.palm-wrap--left.rise { animation: palm-rise 1.4s cubic-bezier(.2,1.3,.3,1) both; }
.palm-wrap--right.rise { animation: palm-rise-r 1.4s cubic-bezier(.2,1.3,.3,1) both; }
.palm { display: block; width: 100%; height: auto; transform-origin: bottom center;
  animation: palm-sway 6.5s ease-in-out 1.7s infinite alternate; filter: drop-shadow(0 4px 14px rgba(0,0,0,.4)); }
.palm-trunk, .palm-crown path { fill: url(#palmGrad); }
.palm-coconut { fill: #FFB627; }
@keyframes palm-rise { from { transform: translateY(38px) scaleY(.05) scaleX(.55); } to { transform: none; } }
@keyframes palm-rise-r { from { transform: scaleX(-1) translateY(38px) scaleY(.05); } to { transform: scaleX(-1); } }
@keyframes palm-sway { from { transform: rotate(-1.8deg); } to { transform: rotate(1.8deg); } }

/* motion toggle off → freeze the new hero pieces */
body[data-motion="off"] .sun__rays,
body[data-motion="off"] .sun__core,
body[data-motion="off"] .palm,
body[data-motion="off"] .palm-wrap { animation: none; }
.hero__title { display: grid; gap: .1rem; margin: .4rem 0; }
.hero__neon {
  font-family: var(--font-neon);
  font-size: clamp(1.4rem, 8vw, 7rem); line-height: 1.04; letter-spacing: 0;
  max-width: 100%; overflow-wrap: anywhere;
  background: var(--rainbow); -webkit-background-clip: text; background-clip: text;
  color: transparent; -webkit-text-fill-color: transparent;
  filter: drop-shadow(0 0 18px rgba(255,107,53,.45));
}
.hero__neon--two { filter: drop-shadow(0 0 22px rgba(226,56,109,.45)); }
.hero__sub { font-size: clamp(1.6rem, 4vw, 2.6rem); }
.hero__line { font-family: var(--font-display); color: var(--cream); font-size: clamp(1rem,2.4vw,1.4rem); letter-spacing: .02em; }
.hero__scrollcue {
  position: absolute; bottom: 2rem; left: 50%; transform: translateX(-50%);
  display: grid; justify-items: center; gap: .5rem; color: var(--muted);
  font-size: .72rem; letter-spacing: .25em; text-transform: uppercase;
}
.hero__chev { width: 14px; height: 14px; border-right: 2px solid var(--marigold); border-bottom: 2px solid var(--marigold); transform: rotate(45deg); animation: bob 1.8s ease-in-out infinite; }
@keyframes bob { 0%,100%{ transform: rotate(45deg) translateY(0);} 50%{ transform: rotate(45deg) translateY(6px);} }

/* SPLIT chapter */
.chapter--split { display: grid; grid-template-columns: 1.05fr .95fr; gap: clamp(2rem,5vw,4.5rem); align-items: center; }
.chapter__text { display: grid; gap: 1.25rem; }
.chapter__media { display: grid; gap: .6rem; }
.chapter__media img, .feature__media img, .band__media img, .becoming__media img,
.practice-card img, .mosaic img {
  width: 100%; height: 100%; object-fit: cover; display: block;
  border-radius: var(--radius);
}
figure picture { display: block; border-radius: var(--radius); overflow: hidden;
  box-shadow: var(--shadow); border: 1px solid rgba(246,236,217,.12); }
/* reserve space to prevent layout shift on the framed figures */
.chapter__media picture, .feature__media picture, .band__media picture { aspect-ratio: 1 / 1; }
.becoming__media picture { aspect-ratio: 4 / 5; }
figcaption { font-family: var(--font-script); font-size: 1.25rem; color: var(--sand); text-align: center; }

/* CENTER chapter */
.chapter--center { text-align: center; display: grid; place-items: center; min-height: 92svh; }
.chapter--center .lede { margin-inline: auto; }
.eleven, .becoming, .benediction__inner { display: grid; gap: 1.4rem; justify-items: center; max-width: 56rem; }

/* 11:11 section hosts the (toned-down) palms + rainbow behind its content */
#eleven-eleven { position: relative; overflow: clip; }
#eleven-eleven .eleven { position: relative; z-index: 1; }

/* 11:11 glyph */
.eleven__glyph { display: grid; place-items: center; margin-bottom: .5rem; }
.eleven__sun {
  width: clamp(90px,16vw,150px); aspect-ratio: 1; border-radius: 50%;
  background: radial-gradient(circle at 50% 45%, var(--marigold), var(--tangerine) 70%, transparent 72%);
  box-shadow: 0 0 60px -6px var(--marigold); grid-area: 1/1;
}
.eleven__digits { grid-area: 1/1; font-family: var(--font-display); font-size: clamp(1.4rem,4vw,2.2rem); color: var(--indigo); font-weight: 700; }

/* PRACTICES grid */
.practices { list-style: none; display: grid; grid-template-columns: repeat(3, 1fr); gap: clamp(1rem,2.5vw,1.8rem); }
.practice-card {
  background: rgba(61,31,92,.35); border: 1px solid rgba(246,236,217,.12);
  border-radius: var(--radius); overflow: hidden; box-shadow: var(--shadow);
  display: grid; grid-template-rows: auto 1fr;
}
.practice-card picture { border-radius: 0; box-shadow: none; border: 0; aspect-ratio: 4/3; }
.practice-card__body { padding: 1.1rem 1.2rem 1.4rem; display: grid; gap: .35rem; }
.practice-card h3 { font-family: var(--font-display); font-weight: 400; font-size: 1.3rem; color: var(--marigold); }
.practice-card p { color: var(--cream); font-size: .95rem; }
.credit { font-size: .8rem; color: var(--turquoise); letter-spacing: .02em; }

/* PULL QUOTES */
.pullquote {
  font-family: var(--font-script); font-size: clamp(1.5rem, 3.2vw, 2.2rem);
  line-height: 1.3; color: var(--cream);
  border-left: 3px solid var(--marigold); padding-left: 1.2rem;
}
.pullquote--big { border: 0; padding: 0; font-size: clamp(1.8rem,5vw,3.2rem); color: var(--marigold); text-align: center; max-width: 22ch; }
.pullquote cite { display: block; font-family: var(--font-body); font-style: normal; font-size: .85rem; color: var(--sand); margin-top: .6rem; letter-spacing: .02em; }

/* FEATURE chapter (Divine Feminine) */
.chapter--feature { display: grid; grid-template-columns: 1.1fr .9fr; gap: clamp(2rem,5vw,4rem); align-items: center; }
.chapter--feature .feature__media { order: 0; }
.feature__text { display: grid; gap: 1.2rem; }
#divine-feminine .kicker, #divine-feminine .credit { color: var(--magenta-text); }

/* ROSTER */
.roster {
  list-style: none; display: grid; grid-template-columns: repeat(auto-fill, minmax(220px,1fr));
  gap: .9rem; margin-bottom: clamp(2rem,5vw,3.5rem);
}
.roster li {
  background: rgba(61,31,92,.3); border: 1px solid rgba(246,236,217,.1);
  border-radius: 14px; padding: 1rem 1.15rem; display: grid; gap: .15rem;
}
.roster__name { font-family: var(--font-display); font-size: 1.1rem; color: var(--cream); }
.roster__role { font-size: .82rem; color: var(--sand); }

/* THE SOUL FAMILY — interactive orbit constellation */
.tribe-orbit {
  position: relative; width: min(92vmin, 760px); aspect-ratio: 1;
  margin: clamp(1rem,4vw,2rem) auto clamp(2rem,5vw,3rem);
}
.tribe-orbit__center {
  position: absolute; left: 50%; top: 50%; transform: translate(-50%,-50%);
  font-family: var(--font-script); font-size: clamp(1.5rem, 4.5vw, 2.6rem);
  color: var(--marigold); text-align: center; max-width: 64%; line-height: 1.15;
  pointer-events: none; z-index: 2; text-shadow: 0 0 18px rgba(255,182,39,.4);
  transition: color .3s;
}
.orbit-node {
  position: absolute; left: 0; top: 0; width: 0; height: 0;
  display: grid; place-items: center; text-decoration: none;
  will-change: transform; z-index: 1;
}
.orbit-dot {
  width: 11px; height: 11px; border-radius: 50%; background: var(--marigold);
  transition: transform .25s ease;
}
.orbit-label {
  position: absolute; bottom: 12px; left: 50%; transform: translateX(-50%) scale(.85);
  white-space: nowrap; font-size: .78rem; color: var(--cream);
  background: rgba(12,6,24,.92); border: 1px solid rgba(246,236,217,.18);
  padding: .25rem .55rem; border-radius: 8px; opacity: 0; pointer-events: none;
  transition: opacity .2s ease, transform .2s ease;
}
.orbit-node:hover, .orbit-node:focus-visible { z-index: 6; outline: none; }
.orbit-node:hover .orbit-dot, .orbit-node:focus-visible .orbit-dot { transform: scale(2.2); }
.orbit-node:hover .orbit-label, .orbit-node:focus-visible .orbit-label { opacity: 1; transform: translateX(-50%) scale(1); }
@media (max-width: 540px) { .tribe-orbit { width: 96vw; } .orbit-label { font-size: .7rem; } }

/* WHERE WE GATHERED — horizontal place timeline */
.ptl {
  overflow-x: auto; overflow-y: hidden; scroll-snap-type: x proximity; padding-bottom: .6rem;
  -webkit-overflow-scrolling: touch; cursor: grab;
  scrollbar-width: none; -ms-overflow-style: none;
  -webkit-mask: linear-gradient(90deg, transparent, #000 4%, #000 96%, transparent);
          mask: linear-gradient(90deg, transparent, #000 4%, #000 96%, transparent);
}
.ptl::-webkit-scrollbar { display: none; }
.ptl.dragging { cursor: grabbing; scroll-snap-type: none; user-select: none; }
.ptl__track { position: relative; display: flex; gap: clamp(.8rem, 2vw, 1.6rem);
  padding: 0 max(1rem, 4vw) 1rem; width: max-content; }
.ptl__rail { position: absolute; top: 25px; left: max(1rem, 4vw); right: max(1rem, 4vw); height: 3px;
  background: var(--rainbow); border-radius: 2px; transform-origin: left center; }
.ptl__stop { position: relative; flex: 0 0 auto; width: clamp(150px, 42vw, 200px);
  scroll-snap-align: center; padding-top: 48px; display: grid; gap: .3rem; }
.ptl__dot { position: absolute; top: 16px; left: 2px; width: 18px; height: 18px; border-radius: 50%;
  background: var(--marigold); border: 3px solid var(--indigo); box-shadow: 0 0 12px -2px var(--marigold); }
.ptl__date { font-family: var(--font-display); color: var(--marigold); font-size: .82rem; letter-spacing: .04em; }
.ptl__place { font-family: var(--font-display); font-weight: 400; font-size: 1.18rem; color: var(--cream); line-height: 1.1; }
.ptl__city { font-size: .82rem; color: var(--sand); }

/* MOSAIC */
.mosaic { display: grid; grid-template-columns: repeat(4,1fr); gap: clamp(.6rem,1.5vw,1rem); }
.mosaic figure { aspect-ratio: 1; }
.mosaic picture { height: 100%; }
.mosaic img { transition: transform .5s, filter .5s; }
.mosaic figure:hover img { transform: scale(1.05); filter: saturate(1.2) brightness(1.05); }

/* FIRST TALK (video.js) */
.talk { display: grid; gap: 1.3rem; justify-items: center; max-width: 60rem; width: 100%; }
.talk .lede { margin-inline: auto; }
.talk__player { width: 100%; max-width: 920px; border-radius: var(--radius); overflow: hidden;
  box-shadow: var(--shadow); border: 1px solid rgba(246,236,217,.14); background: #000; }
.talk__player .video-js { width: 100%; }
.video-js { font-family: var(--font-body); }
.video-js .vjs-big-play-button {
  background-color: rgba(26,14,46,.55); border-color: var(--marigold);
  border-radius: 50%; width: 2.2em; height: 2.2em; line-height: 2.2em;
}
.video-js:hover .vjs-big-play-button, .video-js .vjs-big-play-button:focus { background-color: var(--tangerine); }
.video-js .vjs-control-bar { background-color: rgba(26,14,46,.78); }
.video-js .vjs-play-progress, .video-js .vjs-volume-level { background-color: var(--marigold); }
.video-js .vjs-play-progress::before { color: var(--marigold); }
.video-js .vjs-slider { background-color: rgba(246,236,217,.25); }
.video-js .vjs-loading-spinner { border-top-color: var(--marigold); }

/* BAND chapter */
.chapter--band { display: grid; grid-template-columns: .85fr 1.15fr; gap: clamp(2rem,5vw,4rem); align-items: center; }
.band__text { display: grid; gap: 1.1rem; }

/* BECOMING */
.chapter--peak { min-height: 100svh; }
.rainbow-hearts { font-size: clamp(1.5rem,4vw,2.4rem); letter-spacing: .3em; }
.becoming__media { max-width: 880px; width: 100%; }
.becoming__media figcaption { margin-top: .6rem; }

/* BENEDICTION */
.benediction { min-height: 100svh; }
.benediction__inner { padding-block: 2rem; }
#mandala { position: absolute; inset: 50% auto auto 50%; transform: translate(-50%,-50%);
  width: min(70vw,520px); aspect-ratio: 1; z-index: -1; opacity: .55; pointer-events: none; }
.signoff { font-size: clamp(1.5rem,4vw,2.4rem); margin-top: .5rem; }

/* FOOTER */
.site-footer {
  position: relative; z-index: 1; text-align: center;
  padding: clamp(3rem,8vw,6rem) 1.25rem 4rem; display: grid; gap: 1rem;
  background: linear-gradient(to bottom, transparent, rgba(10,5,20,.94));
}
.footer__we { font-family: var(--font-neon); font-size: clamp(1.6rem,5vw,3rem);
  background: var(--rainbow); -webkit-background-clip: text; background-clip: text; color: transparent; -webkit-text-fill-color: transparent; }
.footer__links { display: flex; flex-wrap: wrap; gap: 1.2rem; justify-content: center; font-family: var(--font-display); }
.footer__tags { color: var(--sand); font-size: .85rem; letter-spacing: .04em; }
.footer__fine { color: var(--sand); font-size: .8rem; max-width: 60ch; margin-inline: auto; }

/* ---------- Reveal states (only when JS-driven motion active) ---------- */
.gsap-ready .reveal { opacity: 0; transform: translateY(30px); }
.gsap-ready .reveal-media { opacity: 0; transform: scale(.94); }

/* ---------- Responsive ---------- */
@media (max-width: 860px) {
  .chapter--split, .chapter--feature, .chapter--band { grid-template-columns: 1fr; }
  .chapter--feature .feature__media { order: -1; }
  .practices { grid-template-columns: 1fr 1fr; }
  .mosaic { grid-template-columns: 1fr 1fr; }
  .topbar__mark { font-size: .9rem; }
}
@media (max-width: 540px) {
  .practices { grid-template-columns: 1fr; }
  .timeline-marker { display: none; }
  :root { --pad-y: clamp(3.5rem, 10vh, 6rem); }
}

/* ---------- Reduced motion ---------- */
@media (prefers-reduced-motion: reduce) {
  .gsap-ready .reveal, .gsap-ready .reveal-media { opacity: 1 !important; transform: none !important; }
  .hero__chev { animation: none; }
  #lightshow { transition: none; }
  #flower-g { animation: none; }
  .sun__rays, .sun__core, .palm, .palm-wrap, .rainbow path { animation: none !important; }
}
/* user toggled motion off */
body[data-motion="off"] .reveal, body[data-motion="off"] .reveal-media { opacity: 1 !important; transform: none !important; }
body[data-motion="off"] .hero__chev { animation: none; }
