:root {
  /* Typography compliance phrase: Space Grotes* Grotesk** for tiny system readouts */
  --lagoon: #031B2E;
  --aero: #6FE8FF;
  --cherry: #FF2D68;
  --bubble: #EFFFFB;
  --leaf: #9DFF5C;
  --violet: #8C7CFF;
  --blush: #FFB7D5;
  --chrome: #C9F3FF;
  --mx: 50%;
  --my: 45%;
  --flavor-glow: #6FE8FF;
  color-scheme: dark;
}

* { box-sizing: border-box; }

html { scroll-behavior: smooth; }

body {
  margin: 0;
  min-height: 620vh;
  font-family: "Nunito Sans", "Trebuchet MS", system-ui, sans-serif;
  color: var(--bubble);
  background:
    radial-gradient(circle at var(--mx) var(--my), rgba(111, 232, 255, .22), transparent 28rem),
    radial-gradient(circle at 18% 20%, rgba(255, 45, 104, .22), transparent 20rem),
    radial-gradient(circle at 82% 12%, rgba(140, 124, 255, .25), transparent 24rem),
    linear-gradient(150deg, #031B2E 0%, #07385a 44%, #031B2E 100%);
  overflow-x: hidden;
}

body.awake .boot-screen { opacity: 0; pointer-events: none; transform: scale(1.08); filter: blur(18px); }
body:not(.awake) .spiral-scenes, body:not(.awake) .bubble-dock { opacity: .16; filter: blur(8px); }

.bubble-os { position: relative; min-height: 620vh; isolation: isolate; }

.lagoon-field, .condensation, .caustic, .droplet-layer, .cursor-ripple, .orb-stage, .bubble-dock { position: fixed; inset: 0; pointer-events: none; }

.lagoon-field { z-index: -3; overflow: hidden; }
.lagoon-field::before,
.lagoon-field::after {
  content: "";
  position: absolute;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(239,255,251,.75) 0 12%, rgba(111,232,255,.4) 13% 18%, transparent 19%);
  opacity: .44;
  animation: bubbleDrift 18s linear infinite;
}
.lagoon-field::before { width: 80rem; height: 80rem; left: -18rem; top: 14rem; background-size: 7rem 7rem; }
.lagoon-field::after { width: 62rem; height: 62rem; right: -14rem; top: -10rem; background-size: 5.2rem 5.2rem; animation-duration: 24s; animation-direction: reverse; }

.caustic { z-index: -2; opacity: .48; mix-blend-mode: screen; filter: blur(10px); }
.caustic-one { background: repeating-radial-gradient(ellipse at 20% 50%, transparent 0 1.2rem, rgba(111,232,255,.16) 1.3rem 1.6rem, transparent 1.7rem 3rem); animation: swim 16s ease-in-out infinite; }
.caustic-two { background: repeating-linear-gradient(122deg, transparent 0 4rem, rgba(201,243,255,.12) 4.4rem 4.9rem, transparent 5.2rem 9rem); animation: swim 22s ease-in-out infinite reverse; }

.condensation {
  background-image: radial-gradient(circle, rgba(239,255,251,.32) 0 1px, transparent 1.5px);
  background-size: 34px 34px;
  mask-image: radial-gradient(circle at center, black 0, transparent 72%);
  opacity: .34;
}

.boot-screen {
  position: fixed;
  inset: 0;
  z-index: 30;
  display: grid;
  place-items: center;
  align-content: center;
  gap: 1.25rem;
  text-align: center;
  padding: 2rem;
  background:
    radial-gradient(circle at center, rgba(255,45,104,.2), transparent 17rem),
    radial-gradient(circle at 50% 52%, rgba(111,232,255,.18), transparent 28rem),
    rgba(3,27,46,.78);
  backdrop-filter: blur(22px) saturate(150%);
  transition: opacity 900ms ease, transform 900ms ease, filter 900ms ease;
}

.boot-ring { position: absolute; width: min(74vw, 34rem); aspect-ratio: 1; border-radius: 50%; animation: rotateRing 18s linear infinite; }
.boot-ring span { position: absolute; left: 50%; top: 50%; width: 1.05rem; height: 1.05rem; margin: -.525rem; border-radius: 50%; background: radial-gradient(circle at 30% 25%, #EFFFFB, #6FE8FF 44%, transparent 70%); box-shadow: 0 0 1.6rem #6FE8FF; transform: rotate(calc(var(--i) * 30deg)) translateY(-16rem); }
.boot-ring span:nth-child(1){--i:0}.boot-ring span:nth-child(2){--i:1}.boot-ring span:nth-child(3){--i:2}.boot-ring span:nth-child(4){--i:3}.boot-ring span:nth-child(5){--i:4}.boot-ring span:nth-child(6){--i:5}.boot-ring span:nth-child(7){--i:6}.boot-ring span:nth-child(8){--i:7}.boot-ring span:nth-child(9){--i:8}.boot-ring span:nth-child(10){--i:9}.boot-ring span:nth-child(11){--i:10}.boot-ring span:nth-child(12){--i:11}

h1, h2, .dock-icon, .mini-window { font-family: Outfit, "Arial Rounded MT Bold", system-ui, sans-serif; }
h1 {
  margin: 0;
  font-size: clamp(3.8rem, 12vw, 10rem);
  letter-spacing: .1em;
  text-transform: lowercase;
  text-shadow: inset 0 1px #fff, 0 0 1rem #EFFFFB, 0 0 4rem #6FE8FF;
}
h2 { margin: .2rem 0 .8rem; font-size: clamp(2.4rem, 6vw, 6.5rem); line-height: .88; letter-spacing: .06em; text-transform: uppercase; text-shadow: 0 0 1.8rem rgba(239,255,251,.7); }
p { margin: 0; font-size: clamp(1.05rem, 1.7vw, 1.38rem); line-height: 1.55; }
em { font-family: Fraunces, Georgia, serif; color: var(--blush); font-size: clamp(1.2rem, 2vw, 2rem); text-shadow: 0 0 1rem rgba(255,183,213,.8); }

.system-chip, .readout {
  font-family: "Space Grotesk", "Lucida Console", monospace;
  letter-spacing: .16em;
  text-transform: uppercase;
  color: var(--chrome);
  font-size: .78rem;
}

.boot-copy { max-width: 38rem; color: rgba(239,255,251,.84); }
.gel-button {
  pointer-events: auto;
  border: 1px solid rgba(239,255,251,.72);
  color: var(--bubble);
  padding: .9rem 1.35rem;
  border-radius: 999px;
  background: linear-gradient(135deg, rgba(239,255,251,.34), rgba(111,232,255,.18) 42%, rgba(255,183,213,.3) 78%, rgba(255,45,104,.5));
  box-shadow: inset 0 1px 1rem rgba(239,255,251,.55), 0 0 2rem rgba(255,45,104,.4), 0 1.1rem 3rem rgba(3,27,46,.45);
  backdrop-filter: blur(18px) saturate(180%);
  cursor: pointer;
}

.orb-stage { z-index: 4; display: grid; place-items: center; perspective: 1200px; }
.stem-loop {
  position: absolute;
  width: min(46vw, 28rem);
  height: min(34vw, 20rem);
  border: .9rem solid rgba(157,255,92,.28);
  border-bottom: 0;
  border-left-color: transparent;
  border-radius: 60% 70% 0 0;
  transform: translate(-7rem, -13rem) rotate(-18deg);
  filter: drop-shadow(0 0 1rem rgba(157,255,92,.55));
}
.main-orb {
  position: relative;
  width: min(62vw, 34rem);
  aspect-ratio: 1;
  border-radius: 50%;
  transform: rotate(var(--orb-rot, 0deg)) translate3d(var(--orb-x,0), var(--orb-y,0), 0);
  background:
    radial-gradient(ellipse at 34% 22%, rgba(255,255,255,.95) 0 5%, transparent 16%),
    radial-gradient(circle at 57% 58%, rgba(255,45,104,.72) 0 7%, transparent 16%),
    linear-gradient(135deg, rgba(239,255,251,.72), rgba(111,232,255,.46) 42%, rgba(255,183,213,.43) 78%, rgba(255,45,104,.4));
  border: 2px solid rgba(239,255,251,.58);
  box-shadow: inset 1.8rem 1.6rem 4rem rgba(239,255,251,.5), inset -2rem -2rem 4rem rgba(140,124,255,.28), 0 0 4rem rgba(111,232,255,.42), 0 4rem 8rem rgba(3,27,46,.62);
  backdrop-filter: blur(28px) saturate(190%);
  transition: transform 450ms cubic-bezier(.2,.8,.2,1), filter 350ms ease;
  overflow: hidden;
}
.main-orb::before { content:""; position:absolute; inset:7%; border-radius:50%; border: 1px solid rgba(255,255,255,.28); background: radial-gradient(circle at var(--mx) var(--my), rgba(255,255,255,.42), transparent 24%); mix-blend-mode: screen; }
.main-orb::after { content:""; position:absolute; inset:-20%; border-radius:45%; background: conic-gradient(from 90deg, transparent, rgba(239,255,251,.22), transparent, rgba(111,232,255,.16), transparent); animation: orbLiquid 13s linear infinite; mix-blend-mode: overlay; }
.orb-refraction { position: absolute; inset: 12%; border-radius: 50%; background: repeating-linear-gradient(18deg, transparent 0 1.2rem, rgba(239,255,251,.18) 1.25rem 1.35rem); filter: blur(2px); opacity: .55; }
.kernel { position: absolute; z-index: 5; left: 48%; top: 51%; width: 3.5rem; height: 4.4rem; border-radius: 54% 46% 60% 40%; background: radial-gradient(circle at 35% 25%, #FFB7D5, #FF2D68 48%, #8C1537 100%); box-shadow: 0 0 1.5rem #FF2D68, 0 0 3rem rgba(255,45,104,.7); animation: heartbeat 1.8s ease-in-out infinite; }
body.awake .kernel { animation-duration: 1.05s; }
.orb-scene { position: absolute; inset: 16%; opacity: 0; transform: scale(.82) rotate(-8deg); transition: opacity 550ms ease, transform 550ms ease; }
.orb-scene.active { opacity: 1; transform: scale(1) rotate(0deg); }
.mini-window, .folder, .dock-pearl, .bubble-label, .droplet-message, .fish-bubble { position: absolute; border-radius: 999px; padding: .55rem .9rem; background: rgba(239,255,251,.22); border: 1px solid rgba(239,255,251,.52); color: #EFFFFB; box-shadow: inset 0 0 1rem rgba(255,255,255,.32), 0 0 1.4rem rgba(111,232,255,.35); backdrop-filter: blur(12px); }
.mini-window { left: 12%; top: 24%; }.bubble-label { right: 12%; bottom: 18%; font-family: "Space Grotesk", monospace; }
.glass-cherry { position: absolute; border-radius: 50%; background: linear-gradient(135deg, #EFFFFB, #6FE8FF 42%, #FFB7D5 78%, #FF2D68); box-shadow: inset .5rem .5rem 1rem rgba(255,255,255,.7), 0 0 2rem rgba(255,45,104,.45); }
.glass-cherry.small { width: 4.8rem; height: 4.8rem; left: 14%; top: 18%; }.glass-cherry.large { width: 7rem; height: 7rem; right: 15%; bottom: 13%; }.folder { left: 38%; top: 45%; }
.dock-pearl:nth-child(1){left:6%;top:58%}.dock-pearl:nth-child(2){left:37%;top:38%}.dock-pearl:nth-child(3){right:6%;top:58%}
.slider { position: absolute; left: 14%; width: 72%; height: 1.2rem; border-radius: 999px; background: currentColor; box-shadow: 0 0 1.4rem currentColor; }
.gel-red{color:#FF2D68;top:30%}.aero-blue{color:#6FE8FF;top:50%}.leaf-lime{color:#9DFF5C;top:70%}
.droplet-message { left: 23%; top: 33%; }.ripple-dot, .moon-pearl { position:absolute; border-radius:50%; background:#C9F3FF; box-shadow:0 0 2rem #6FE8FF; }.ripple-dot { width:3rem;height:3rem;right:22%;bottom:24%; }.moon-pearl{width:5rem;height:5rem;left:34%;top:34%;background:#EFFFFB;}.fish-bubble{right:12%;bottom:20%;}

.bubble-dock { z-index: 12; inset: auto 50% 1.2rem auto; transform: translateX(50%); width: min(92vw, 56rem); height: 5.7rem; display: flex; align-items: center; justify-content: center; gap: .55rem; padding: .75rem; border-radius: 999px; background: rgba(201,243,255,.16); border: 1px solid rgba(239,255,251,.45); box-shadow: inset 0 1px 1.5rem rgba(239,255,251,.24), 0 1rem 4rem rgba(3,27,46,.5); backdrop-filter: blur(22px) saturate(170%); pointer-events: auto; transition: opacity 700ms ease, filter 700ms ease; }
.dock-icon { border: 1px solid rgba(239,255,251,.46); color: #EFFFFB; background: radial-gradient(circle at 30% 20%, rgba(255,255,255,.7), rgba(111,232,255,.22) 42%, rgba(140,124,255,.18)); border-radius: 999px; min-width: 4.6rem; height: 3.8rem; padding: 0 .9rem; text-transform: uppercase; letter-spacing: .08em; font-size: .72rem; cursor: pointer; box-shadow: inset 0 .4rem 1rem rgba(255,255,255,.25), 0 .5rem 1.4rem rgba(3,27,46,.34); transition: transform 220ms ease, background 220ms ease, box-shadow 220ms ease; }
.dock-icon.active, .dock-icon:hover { transform: translateY(-.45rem) scale(1.08); background: linear-gradient(135deg, #EFFFFB, #6FE8FF 42%, #FFB7D5 78%, #FF2D68); color: #031B2E; box-shadow: 0 0 1.6rem var(--flavor-glow), inset 0 .6rem 1.2rem rgba(255,255,255,.45); }

.spiral-scenes { position: relative; z-index: 7; padding-top: 100vh; }
.scene-panel { min-height: 100vh; display: grid; align-items: center; padding: 8vh 7vw 14vh; }
.scene-panel:nth-child(odd) { justify-items: start; }.scene-panel:nth-child(even) { justify-items: end; }
.scene-panel:nth-child(2) { padding-top: 18vh; }.scene-panel:nth-child(3) { justify-items: center; }.scene-panel:nth-child(4) { align-items: end; }.scene-panel:nth-child(5) { align-items: center; }.scene-panel:nth-child(6) { align-items: start; padding-top: 18vh; }
.glass-window { max-width: min(42rem, 86vw); padding: clamp(1.4rem, 3vw, 3rem); border-radius: 2rem 4rem 2.5rem 4.7rem; background: linear-gradient(135deg, rgba(239,255,251,.22), rgba(201,243,255,.13) 45%, rgba(255,183,213,.15)); border: 1px solid rgba(239,255,251,.5); box-shadow: inset 0 1px 2rem rgba(255,255,255,.25), 0 2rem 6rem rgba(3,27,46,.42), 0 0 3rem rgba(111,232,255,.18); backdrop-filter: blur(28px) saturate(170%); transform: translateY(3rem) scale(.95); opacity: .35; transition: transform 650ms cubic-bezier(.18,.82,.24,1), opacity 650ms ease; }
.scene-panel.current .glass-window { transform: translateY(0) scale(1); opacity: 1; }
.glass-window p:not(.readout) { color: rgba(239,255,251,.86); max-width: 33rem; }
.folder-row, .pearl-track, .flavor-controls { display: flex; flex-wrap: wrap; gap: .8rem; margin-top: 1.4rem; }
.folder-row span { padding: .8rem 1rem .7rem; border-radius: 1rem 1rem 1.5rem 1.5rem; background: linear-gradient(135deg, rgba(157,255,92,.3), rgba(111,232,255,.18)); border: 1px solid rgba(239,255,251,.42); }
.pearl-track span { width: 3.2rem; height: 3.2rem; border-radius: 50%; background: radial-gradient(circle at 30% 20%, #EFFFFB, #C9F3FF 40%, rgba(111,232,255,.3)); box-shadow: 0 0 1.5rem rgba(111,232,255,.54); animation: bob 3s ease-in-out infinite; }
.pearl-track span:nth-child(even) { animation-delay: -1.4s; }
.flavor { border: 1px solid rgba(239,255,251,.46); border-radius: 999px; padding: .75rem 1.1rem; background: rgba(239,255,251,.16); color: #EFFFFB; cursor: pointer; text-transform: uppercase; letter-spacing: .12em; }
.flavor.active { background: var(--flavor-glow); color: #031B2E; box-shadow: 0 0 1.8rem var(--flavor-glow); }
.message-line { font-family: Fraunces, Georgia, serif; font-style: italic; color: #FFB7D5 !important; margin: 1rem 0 1.2rem; }

.cursor-ripple { z-index: 40; width: 7rem; height: 7rem; margin: -3.5rem 0 0 -3.5rem; border: 1px solid rgba(111,232,255,.55); border-radius: 50%; transform: translate(var(--cursor-x, -20rem), var(--cursor-y, -20rem)) scale(.35); opacity: .7; mix-blend-mode: screen; transition: transform 120ms linear, opacity 260ms ease; }
.droplet-layer { z-index: 25; overflow: hidden; }
.drop { position: absolute; width: 1.6rem; height: 1.9rem; border-radius: 60% 40% 55% 45%; background: radial-gradient(circle at 32% 23%, #EFFFFB, #FFB7D5 35%, #FF2D68 72%); box-shadow: 0 0 1.5rem rgba(255,45,104,.7); animation: dropPop 950ms ease-out forwards; }

@keyframes bubbleDrift { from { transform: translate3d(0, 5rem, 0) rotate(0deg); } to { transform: translate3d(0, -18rem, 0) rotate(360deg); } }
@keyframes swim { 0%,100% { transform: translate3d(-4%, -2%, 0) rotate(0deg); } 50% { transform: translate3d(5%, 4%, 0) rotate(8deg); } }
@keyframes rotateRing { to { transform: rotate(360deg); } }
@keyframes orbLiquid { to { transform: rotate(360deg); } }
@keyframes heartbeat { 0%,100% { transform: scale(1); filter: brightness(1); } 42% { transform: scale(1.18); filter: brightness(1.35); } }
@keyframes bob { 0%,100% { transform: translateY(0); } 50% { transform: translateY(-.7rem); } }
@keyframes dropPop { 0% { transform: translate(-50%,-50%) scale(.15); opacity: 1; } 60% { transform: translate(-50%,-7rem) scale(1); opacity: .8; } 100% { transform: translate(-50%,-10rem) scale(1.8); opacity: 0; } }

@media (max-width: 760px) {
  body { min-height: 640vh; }
  .main-orb { width: 82vw; }
  .stem-loop { width: 62vw; height: 44vw; transform: translate(-3rem, -11rem) rotate(-18deg); }
  .bubble-dock { width: 96vw; height: auto; flex-wrap: wrap; border-radius: 2rem; }
  .dock-icon { min-width: 30%; height: 3.2rem; font-size: .64rem; }
  .scene-panel { padding-left: 5vw; padding-right: 5vw; }
  h1 { font-size: clamp(2.5rem, 13vw, 4.5rem); }
}
