:root {
  /* compliance phrase: labels:** **Inter** from Lens:** full-screen with domain enormous refracted behind circular Thin stems arc letters reeds */
  --sky-glass: #C9F7FF;
  --stream-cyan: #2FE7F5;
  --aurora-violet: #9B7CFF;
  --electric-leaf: #7CFF8A;
  --solar-flare: #FFF36B;
  --deep-current: #063A55;
  --petal-coral: #FF78B7;
  --white-glint: #F8FFFE;
  --display: "Cormorant Garamond", serif;
  --body: "EB Garamond", serif;
  --label: "Inter", sans-serif;
}

* { box-sizing: border-box; }

html { scroll-behavior: smooth; }

body {
  margin: 0;
  min-height: 100vh;
  color: var(--deep-current);
  background: var(--sky-glass);
  font-family: var(--body);
  overflow-x: hidden;
}

.aurora-field {
  position: fixed;
  inset: -15vmax;
  z-index: -4;
  background:
    radial-gradient(circle at 15% 12%, rgba(255, 243, 107, .82), transparent 21%),
    radial-gradient(circle at 84% 18%, rgba(255, 120, 183, .66), transparent 25%),
    radial-gradient(circle at 24% 78%, rgba(124, 255, 138, .66), transparent 28%),
    linear-gradient(135deg, #C9F7FF 0%, #2FE7F5 32%, #9B7CFF 68%, #7CFF8A 100%);
  filter: saturate(1.25) hue-rotate(0deg);
  animation: auroraShift 18s ease-in-out infinite alternate;
}

.stream-glass {
  position: fixed;
  inset: 0;
  z-index: -3;
  pointer-events: none;
  background:
    linear-gradient(115deg, transparent 0 18%, rgba(248, 255, 254, .32) 19% 22%, transparent 23% 45%, rgba(201, 247, 255, .34) 46% 49%, transparent 50%),
    repeating-linear-gradient(172deg, rgba(248,255,254,.18) 0 2px, transparent 2px 52px);
  mix-blend-mode: screen;
}

.stream { position: relative; isolation: isolate; }

.scene {
  position: relative;
  min-height: 100vh;
  overflow: hidden;
  display: grid;
  place-items: center;
  padding: clamp(2rem, 5vw, 5rem);
}

.scene::before {
  content: "";
  position: absolute;
  inset: 8% -10%;
  background: linear-gradient(100deg, transparent, rgba(248,255,254,.38), transparent);
  transform: skewY(-10deg) translateX(var(--drift, 0px));
  opacity: .65;
  pointer-events: none;
}

.scene-number {
  position: absolute;
  top: 2rem;
  left: clamp(1.2rem, 4vw, 4rem);
  z-index: 8;
  font-family: var(--label);
  font-size: .72rem;
  font-weight: 700;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: rgba(6, 58, 85, .7);
  padding: .55rem .8rem;
  border: 1px solid rgba(248,255,254,.78);
  border-radius: 999px;
  background: rgba(248,255,254,.26);
  backdrop-filter: blur(14px);
  box-shadow: inset 0 1px 10px rgba(248,255,254,.52), 0 12px 40px rgba(47,231,245,.18);
}

.interface-label {
  display: block;
  font-family: var(--label);
  font-size: .74rem;
  font-weight: 700;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: rgba(6, 58, 85, .72);
}

.dew-nav {
  position: fixed;
  right: 1.25rem;
  top: 50%;
  transform: translateY(-50%);
  z-index: 40;
  display: grid;
  gap: .72rem;
}

.dew-dot {
  position: relative;
  width: 17px;
  height: 17px;
  border: 1px solid rgba(248,255,254,.95);
  border-radius: 50%;
  background: radial-gradient(circle at 35% 28%, #F8FFFE 0 18%, #C9F7FF 20%, #2FE7F5 66%, #9B7CFF 100%);
  box-shadow: inset 0 1px 5px #F8FFFE, 0 0 18px rgba(47,231,245,.74);
  cursor: pointer;
}

.dew-dot span {
  position: absolute;
  right: 1.55rem;
  top: 50%;
  transform: translateY(-50%) translateX(8px);
  opacity: 0;
  font-family: var(--label);
  font-size: .68rem;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--deep-current);
  transition: .35s ease;
}

.dew-dot:hover span, .dew-dot.is-active span { opacity: 1; transform: translateY(-50%); }
.dew-dot.is-active { background: radial-gradient(circle at 35% 28%, #F8FFFE 0 18%, #FFF36B 20%, #FF78B7 58%, #9B7CFF 100%); }

.glass-mask { position: relative; overflow: visible; }

.hero-copy {
  z-index: 5;
  text-align: center;
  width: min(96vw, 1280px);
}

.wordmark {
  position: relative;
  margin: .3rem 0 1rem;
  font-family: var(--display);
  font-size: clamp(4.5rem, 14vw, 13rem);
  line-height: .76;
  letter-spacing: -.075em;
  font-weight: 700;
  color: var(--deep-current);
  text-shadow: 0 2px 0 rgba(248,255,254,.82), 0 0 34px rgba(255,243,107,.34), 0 22px 70px rgba(6,58,85,.24);
}

.wordmark::after {
  content: attr(data-reflection);
  position: absolute;
  left: 0;
  right: 0;
  top: 66%;
  transform: scaleY(-.48) translateY(-8%);
  color: rgba(47, 231, 245, .34);
  filter: blur(5px);
  -webkit-mask-image: linear-gradient(to bottom, rgba(0,0,0,.8), transparent 72%);
  mask-image: linear-gradient(to bottom, rgba(0,0,0,.8), transparent 72%);
  animation: reflectionFlow 4.8s ease-in-out infinite alternate;
}

.opening-line, .petal-pane p, .flower-core p, .cascade-statement p, .final-pane p {
  font-size: clamp(1.35rem, 2.4vw, 2.25rem);
  line-height: 1.12;
  margin: .6rem 0 0;
  color: rgba(6, 58, 85, .86);
}

.lens-orb {
  position: absolute;
  width: clamp(19rem, 40vw, 40rem);
  aspect-ratio: 1;
  border-radius: 50%;
  z-index: 2;
  background:
    radial-gradient(circle at 35% 26%, rgba(248,255,254,.92), transparent 10%),
    radial-gradient(circle at 52% 48%, rgba(201,247,255,.28), rgba(47,231,245,.16) 44%, rgba(155,124,255,.2) 58%, transparent 72%);
  border: 1px solid rgba(248,255,254,.78);
  box-shadow: inset 0 0 42px rgba(248,255,254,.72), inset 0 -35px 60px rgba(47,231,245,.22), 0 0 90px rgba(255,243,107,.28);
  backdrop-filter: blur(6px) saturate(1.35);
}

.flare {
  position: absolute;
  width: 16rem;
  aspect-ratio: 1;
  border-radius: 50%;
  background: radial-gradient(circle, #FFF36B 0 4%, rgba(248,255,254,.85) 5% 9%, rgba(255,120,183,.36) 10% 21%, rgba(47,231,245,.18) 22% 36%, transparent 60%);
  mix-blend-mode: screen;
  filter: blur(.2px) saturate(1.5);
  pointer-events: none;
}

.source-sun { top: 8%; right: 12%; animation: flareDrift 11s ease-in-out infinite alternate; }
.branch-flare { left: 4%; bottom: 9%; }
.bloom-flare { right: 16%; top: 17%; }
.estuary-flare-one { left: 13%; top: 22%; }
.estuary-flare-two { right: 10%; bottom: 18%; width: 11rem; }
.transition-flare { position: fixed; z-index: 30; width: 28vmax; aspect-ratio: 1; border-radius: 50%; pointer-events: none; opacity: 0; background: radial-gradient(circle, rgba(255,243,107,.95), rgba(255,120,183,.26) 22%, rgba(47,231,245,.2) 43%, transparent 67%); mix-blend-mode: screen; transform: translate(-50%, -50%); }

.water-ribbon {
  position: absolute;
  border-radius: 999px;
  background: linear-gradient(90deg, transparent, rgba(248,255,254,.56), rgba(47,231,245,.34), rgba(155,124,255,.22), transparent);
  border-top: 1px solid rgba(248,255,254,.68);
  box-shadow: inset 0 10px 18px rgba(248,255,254,.24), 0 0 42px rgba(47,231,245,.28);
  backdrop-filter: blur(6px);
}

.ribbon-a { width: 88vw; height: 9rem; bottom: 11%; left: -15%; transform: rotate(-12deg); }
.ribbon-b { width: 65vw; height: 4rem; top: 21%; right: -10%; transform: rotate(18deg); }
.ribbon-c { width: 105vw; height: 7rem; bottom: 18%; left: -5%; transform: rotate(9deg); }

.vine-path { position: absolute; inset: 0; width: 100%; height: 100%; z-index: 3; pointer-events: none; overflow: visible; }
.vine-path path { fill: none; stroke: rgba(248,255,254,.86); stroke-width: 3; stroke-linecap: round; filter: drop-shadow(0 0 7px #7CFF8A) drop-shadow(0 0 14px rgba(47,231,245,.62)); stroke-dasharray: 1200; stroke-dashoffset: var(--dash, 900); }
.source-vines path:nth-child(2), .channel-vines path:nth-child(2) { stroke: rgba(124,255,138,.78); }
.source-vines path:nth-child(3), .channel-vines path:nth-child(3) { stroke: rgba(255,120,183,.7); }

.petal-pane, .final-pane, .cascade-statement, .flower-core {
  z-index: 6;
  max-width: 28rem;
  padding: clamp(1.35rem, 3vw, 2.4rem);
  background: linear-gradient(145deg, rgba(248,255,254,.58), rgba(201,247,255,.22) 54%, rgba(155,124,255,.16));
  border: 1px solid rgba(248,255,254,.8);
  box-shadow: inset 0 1px 16px rgba(248,255,254,.65), inset 0 -18px 38px rgba(47,231,245,.17), 0 24px 80px rgba(6,58,85,.18);
  backdrop-filter: blur(15px) saturate(1.25);
}

.petal-pane { position: absolute; clip-path: ellipse(62% 46% at 50% 50%); border-radius: 60% 40% 55% 45%; }
.pane-one { left: 8%; top: 23%; transform: rotate(-7deg); }
.pane-two { right: 7%; top: 32%; transform: rotate(8deg); }
.pane-three { left: 35%; bottom: 12%; transform: rotate(-2deg); }

.greenhouse-dome {
  position: absolute;
  width: min(82vw, 860px);
  height: min(66vh, 620px);
  border-radius: 50% 50% 10% 10%;
  border: 1px solid rgba(248,255,254,.72);
  background: radial-gradient(circle at 50% 0%, rgba(248,255,254,.58), rgba(201,247,255,.18) 48%, rgba(155,124,255,.14));
  box-shadow: inset 0 0 50px rgba(248,255,254,.55), 0 0 80px rgba(47,231,245,.22);
}

.botanical-silhouette { position: absolute; width: 24rem; height: 42rem; opacity: .42; filter: blur(.3px); background: linear-gradient(#7CFF8A, #2FE7F5); clip-path: ellipse(27% 47% at 50% 50%); }
.leaf-left { left: 3%; bottom: -8%; transform: rotate(-19deg); }
.leaf-right { right: 5%; top: 4%; transform: rotate(27deg); background: linear-gradient(#FF78B7, #9B7CFF); }

.thought-flower { position: relative; z-index: 5; width: min(78vw, 650px); aspect-ratio: 1; display: grid; place-items: center; }
.flower-layer { position: absolute; inset: 12%; border-radius: 60% 40% 55% 45%; clip-path: ellipse(48% 62% at 50% 50%); border: 1px solid rgba(248,255,254,.8); backdrop-filter: blur(10px); transform: rotate(var(--rot)) scale(var(--scale, 1)); opacity: var(--opacity, .72); transition: transform .8s ease, opacity .8s ease; }
.layer-one { --rot: 0deg; background: rgba(255,120,183,.24); }
.layer-two { --rot: 62deg; --scale: .9; background: rgba(47,231,245,.28); }
.layer-three { --rot: 124deg; --scale: .78; background: rgba(124,255,138,.24); }
.flower-core { position: relative; text-align: center; border-radius: 46% 54% 52% 48%; max-width: 30rem; }
.flower-core h2, .cascade-statement h2, .final-pane h2 { font-family: var(--display); font-size: clamp(2.9rem, 6vw, 6.7rem); line-height: .9; letter-spacing: -.045em; margin: .2rem 0; color: var(--deep-current); }

.cascade-scene { align-items: end; }
.cascade-ribbon {
  position: absolute;
  top: -10%;
  bottom: -8%;
  width: clamp(4.4rem, 9vw, 8rem);
  display: flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(180deg, transparent, rgba(248,255,254,.62), rgba(47,231,245,.35), rgba(155,124,255,.22), transparent);
  border-left: 1px solid rgba(248,255,254,.65);
  border-right: 1px solid rgba(248,255,254,.4);
  backdrop-filter: blur(8px);
  overflow: hidden;
}
.cascade-ribbon span { writing-mode: vertical-rl; transform: translateX(130%); font-family: var(--display); font-size: clamp(1.5rem, 3vw, 3rem); font-weight: 600; color: rgba(6,58,85,.82); transition: transform .9s cubic-bezier(.2,.9,.1,1); }
.cascade-ribbon.is-visible span { transform: translateX(0); }
.ribbon-one { left: 12%; }
.ribbon-two { left: 35%; }
.ribbon-three { right: 31%; width: clamp(5.5rem, 12vw, 11rem); }
.ribbon-four { right: 9%; }
.cascade-statement { position: relative; margin: 0 auto 7vh; max-width: 52rem; border-radius: 46% 54% 60% 40%; clip-path: ellipse(62% 45% at 50% 50%); text-align: center; }

.estuary-pool { position: absolute; width: min(86vw, 900px); aspect-ratio: 1.9; bottom: 8%; border-radius: 50%; background: radial-gradient(ellipse at center, rgba(248,255,254,.82), rgba(47,231,245,.42) 35%, rgba(155,124,255,.2) 58%, transparent 72%); box-shadow: inset 0 0 65px rgba(248,255,254,.78), 0 0 90px rgba(255,243,107,.28); }
.final-pane { position: relative; max-width: 58rem; text-align: center; border-radius: 58% 42% 50% 50%; clip-path: ellipse(60% 46% at 50% 50%); }
.seed-field i { position: absolute; width: .8rem; height: 1.45rem; border-radius: 50%; background: radial-gradient(ellipse at 35% 28%, #F8FFFE, #FFF36B 38%, #7CFF8A); box-shadow: 0 0 18px rgba(255,243,107,.8); left: calc(12% + var(--x, 0) * 10%); top: calc(18% + var(--y, 0) * 8%); animation: pollenFloat 7s ease-in-out infinite alternate; }
.seed-field i:nth-child(1) { --x: 1; --y: 1; }
.seed-field i:nth-child(2) { --x: 5; --y: 3; animation-delay: -.8s; }
.seed-field i:nth-child(3) { --x: 8; --y: 0; animation-delay: -1.4s; }
.seed-field i:nth-child(4) { --x: 2; --y: 6; animation-delay: -2.1s; }
.seed-field i:nth-child(5) { --x: 7; --y: 7; animation-delay: -3s; }
.seed-field i:nth-child(6) { --x: 4; --y: 8; animation-delay: -3.7s; }
.seed-field i:nth-child(7) { --x: 9; --y: 5; animation-delay: -4.4s; }
.seed-field i:nth-child(8) { --x: 0; --y: 4; animation-delay: -5s; }

.reveal-up, .reveal-left, .reveal-right, .reveal-down { opacity: 0; transition: transform .95s cubic-bezier(.2,.9,.1,1), opacity .8s ease; }
.reveal-up { transform: translateY(70px); }
.reveal-left { transform: translateX(-90px) rotate(-7deg); }
.reveal-right { transform: translateX(90px) rotate(8deg); }
.reveal-down { transform: translateY(-70px); }
.is-visible.reveal-up, .is-visible.reveal-left, .is-visible.reveal-right, .is-visible.reveal-down { opacity: 1; transform: translate(0,0) rotate(var(--final-rotate, 0deg)); }
.pane-one.is-visible { --final-rotate: -7deg; }
.pane-two.is-visible { --final-rotate: 8deg; }
.pane-three.is-visible { --final-rotate: -2deg; }

@keyframes auroraShift { to { filter: saturate(1.45) hue-rotate(28deg); transform: rotate(2deg) scale(1.04); } }
@keyframes reflectionFlow { to { transform: scaleY(-.54) translateY(-2%) skewX(-5deg); opacity: .72; } }
@keyframes flareDrift { to { transform: translate(-18vw, 12vh) scale(1.25); } }
@keyframes pollenFloat { to { transform: translate(3rem, -5rem) rotate(44deg); opacity: .55; } }

@media (max-width: 760px) {
  .dew-nav { right: .6rem; }
  .dew-dot span { display: none; }
  .petal-pane { position: relative; inset: auto; margin: .7rem; }
  .branch-scene { align-content: center; gap: 1rem; }
  .pane-one, .pane-two, .pane-three { left: auto; right: auto; top: auto; bottom: auto; }
  .cascade-ribbon { opacity: .55; }
  .cascade-statement, .final-pane { clip-path: ellipse(72% 48% at 50% 50%); }
}
