:root {
  --pink: #FF66B3;
  --lemon: #FFE45C;
  --cyan: #4DEBFF;
  --violet: #7C4DFF;
  --cream: #FFF7E8;
  --ink: #184A3A;
  --peach: #FFB085;
  --display: "Cormorant Garamond", Georgia, "Times New Roman", serif;
  --ui: "Nunito Sans", Inter, system-ui, sans-serif;
  --mono: "IBM Plex Mono", "SFMono-Regular", Consolas, monospace;
}

/* Design terms retained: Mono** Mon 400/500 timestamps Interactions should make visitor feel like they are tuning magical webcam: hover-lift controls Interface labels and captions: Sans** San 500/700 legible dashboard */

* { box-sizing: border-box; }

html, body { margin: 0; min-height: 100%; overflow: hidden; }

body {
  color: var(--ink);
  background:
    radial-gradient(circle at 12% 14%, rgba(255, 102, 179, .34), transparent 28%),
    radial-gradient(circle at 87% 20%, rgba(77, 235, 255, .34), transparent 26%),
    radial-gradient(circle at 68% 88%, rgba(124, 77, 255, .22), transparent 28%),
    linear-gradient(135deg, var(--cream), #fff1c5 44%, #f3fff7);
  font-family: var(--ui);
}

.conservatory {
  position: relative;
  width: 100vw;
  height: 100vh;
  padding: clamp(18px, 2.8vw, 42px);
  isolation: isolate;
}

.mist-layer {
  position: absolute;
  inset: -10%;
  background:
    repeating-linear-gradient(100deg, rgba(255,255,255,.18) 0 2px, transparent 2px 18px),
    radial-gradient(ellipse at 50% 55%, rgba(255,247,232,.05), rgba(255,247,232,.72) 58%, rgba(255,247,232,.18));
  filter: blur(9px);
  opacity: .88;
  animation: mistDrift 13s ease-in-out infinite alternate;
  z-index: -2;
}

.pollen-field {
  position: absolute;
  inset: 0;
  pointer-events: none;
  z-index: 4;
}

.pollen-dot {
  position: absolute;
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: var(--lemon);
  box-shadow: 0 0 18px var(--lemon);
  opacity: .78;
  transform: translate(-50%, -50%);
  animation: pollenFloat 1.4s ease-out forwards;
}

.pressed-flower {
  position: absolute;
  width: 34vmin;
  height: 34vmin;
  border-radius: 48% 52% 44% 56%;
  opacity: .12;
  filter: blur(.5px);
  background: conic-gradient(from 20deg, transparent 0 8%, var(--violet) 8% 17%, transparent 17% 25%, var(--pink) 25% 36%, transparent 36% 45%, var(--cyan) 45% 56%, transparent 56% 67%, var(--peach) 67% 78%, transparent 78% 100%);
  mask: radial-gradient(circle, transparent 0 15%, #000 16% 54%, transparent 55%);
  z-index: -1;
}
.flower-one { left: 4vw; bottom: -8vmin; transform: rotate(-18deg); }
.flower-two { right: -5vmin; top: 15vh; transform: rotate(31deg) scale(.8); }

.vine {
  position: absolute;
  width: 30vw;
  height: 45vh;
  border: 1.5px solid rgba(24, 74, 58, .22);
  border-left: 0;
  border-bottom: 0;
  border-radius: 0 70% 0 0;
  z-index: 0;
}
.vine-left { left: 16vw; top: 22vh; transform: rotate(190deg); }
.vine-right { right: 15vw; bottom: 9vh; transform: rotate(11deg); }

.glass-title {
  position: absolute;
  top: 4.5vh;
  left: 5vw;
  width: min(430px, 38vw);
  padding: 18px 24px 20px;
  border: 1px solid rgba(77, 235, 255, .5);
  border-radius: 34px 52px 28px 46px;
  background: rgba(255, 247, 232, .5);
  box-shadow: 0 22px 70px rgba(124,77,255,.14), inset 0 0 40px rgba(255,255,255,.55);
  backdrop-filter: blur(18px);
  z-index: 5;
  animation: titleWrite 1.8s ease both;
}

.eyebrow, .instrument p, .archive p {
  margin: 0 0 4px;
  font-family: var(--mono);
  text-transform: uppercase;
  letter-spacing: .12em;
  font-size: 11px;
  color: rgba(24,74,58,.74);
}

h1, h2 { font-family: var(--display); letter-spacing: -.025em; }
h1 { margin: 0; font-size: clamp(43px, 5.8vw, 86px); line-height: .82; color: var(--ink); text-shadow: 0 0 22px rgba(255,255,255,.8); }
h2 { margin: 0 0 10px; font-size: clamp(26px, 2.4vw, 40px); line-height: .9; }
.status-dot { display: inline-block; width: 10px; height: 10px; margin-top: 14px; border-radius: 50%; background: var(--cyan); box-shadow: 0 0 18px var(--cyan); }
.status-copy { margin-left: 7px; font-size: 13px; font-weight: 700; color: var(--ink); }

.lens-stage {
  position: absolute;
  inset: 50% auto auto 50%;
  width: min(58vw, 780px);
  height: min(72vh, 680px);
  transform: translate(-50%, -48%);
  display: grid;
  place-items: center;
  z-index: 2;
}
.lens-halo {
  position: absolute;
  width: 104%;
  height: 88%;
  border-radius: 50%;
  background: radial-gradient(ellipse, rgba(255,228,92,.28), rgba(255,102,179,.14) 46%, transparent 70%);
  filter: blur(20px);
  animation: haloPulse 6s ease-in-out infinite;
}
.viewfinder {
  position: relative;
  width: min(52vw, 670px);
  height: min(64vh, 560px);
  min-height: 420px;
  border-radius: 49% 51% 48% 52% / 55% 48% 52% 45%;
  overflow: hidden;
  border: 2px solid rgba(77,235,255,.78);
  background:
    radial-gradient(circle at 47% 42%, rgba(255,228,92,.75), transparent 16%),
    radial-gradient(circle at 32% 61%, rgba(255,102,179,.65), transparent 26%),
    radial-gradient(circle at 68% 28%, rgba(77,235,255,.62), transparent 24%),
    radial-gradient(circle at 60% 73%, rgba(124,77,255,.45), transparent 24%),
    linear-gradient(140deg, rgba(255,247,232,.92), rgba(255,176,133,.6));
  box-shadow: 0 36px 100px rgba(124,77,255,.32), inset 0 0 70px rgba(255,255,255,.78), inset 0 0 0 18px rgba(255,247,232,.22);
}
.viewfinder:before {
  content: "";
  position: absolute;
  inset: 6%;
  border-radius: inherit;
  border: 1px dashed rgba(24,74,58,.26);
  filter: drop-shadow(0 0 8px rgba(77,235,255,.6));
}
.condensation {
  position: absolute;
  inset: -2%;
  background: radial-gradient(circle at var(--wipe-x, 50%) var(--wipe-y, 50%), transparent 0 18%, rgba(255,247,232,.9) 25%, rgba(255,247,232,.98) 100%);
  backdrop-filter: blur(8px);
  animation: clearLens 2.9s cubic-bezier(.4,0,.2,1) forwards;
  z-index: 7;
}
.scanlines {
  position: absolute;
  inset: 0;
  background: repeating-linear-gradient(180deg, rgba(77,235,255,.18) 0 1px, transparent 1px 8px);
  mix-blend-mode: screen;
  opacity: .72;
  animation: scan 7s linear infinite;
}
.viewfinder.fast .scanlines { animation-duration: 1.2s; opacity: .98; }

.petal, .bokeh { position: absolute; border-radius: 70% 30% 70% 30%; filter: blur(.2px); opacity: .72; }
.petal { width: 92px; height: 42px; background: linear-gradient(90deg, rgba(255,102,179,.88), rgba(255,228,92,.54)); animation: petalDrift 12s ease-in-out infinite; }
.petal-a { left: 8%; top: 36%; transform: rotate(28deg); }
.petal-b { right: 11%; top: 18%; background: linear-gradient(90deg, rgba(77,235,255,.8), rgba(255,255,255,.42)); animation-delay: -3s; }
.petal-c { left: 41%; bottom: 9%; background: linear-gradient(90deg, rgba(124,77,255,.66), rgba(255,102,179,.42)); animation-delay: -5s; }
.petal-d { right: 30%; bottom: 35%; background: linear-gradient(90deg, rgba(255,176,133,.82), rgba(255,228,92,.48)); animation-delay: -8s; }
.bokeh { width: 120px; height: 120px; border-radius: 50%; background: rgba(255,255,255,.28); box-shadow: 0 0 48px rgba(255,255,255,.6); animation: bokehRise 9s ease-in-out infinite; }
.bokeh-one { left: 14%; bottom: 16%; }
.bokeh-two { right: 16%; top: 30%; animation-delay: -4s; }

.daisy-reticle, .mini-reticle { position: absolute; left: 50%; top: 50%; transform: translate(-50%, -50%); width: 170px; height: 170px; transition: transform .18s ease; }
.daisy-reticle span, .mini-reticle span { position: absolute; left: 50%; top: 50%; width: 28px; height: 58px; margin: -86px 0 0 -14px; border: 2px solid var(--cyan); border-bottom: 0; border-radius: 50% 50% 20% 20%; transform-origin: 50% 86px; box-shadow: 0 0 14px rgba(77,235,255,.82); }
.daisy-reticle span:nth-child(2), .mini-reticle span:nth-child(2) { transform: rotate(60deg); }
.daisy-reticle span:nth-child(3), .mini-reticle span:nth-child(3) { transform: rotate(120deg); }
.daisy-reticle span:nth-child(4), .mini-reticle span:nth-child(4) { transform: rotate(180deg); }
.daisy-reticle span:nth-child(5), .mini-reticle span:nth-child(5) { transform: rotate(240deg); }
.daisy-reticle span:nth-child(6), .mini-reticle span:nth-child(6) { transform: rotate(300deg); }
.daisy-reticle i, .mini-reticle i { position: absolute; left: 50%; top: 50%; width: 16px; height: 16px; margin: -8px; border-radius: 50%; background: var(--lemon); box-shadow: 0 0 22px var(--lemon); }

.timestamp { position: absolute; left: 13%; bottom: 13%; padding: 8px 12px; border-radius: 999px; background: rgba(24,74,58,.78); color: var(--cream); font-family: var(--mono); font-size: 12px; letter-spacing: .08em; }
.metadata { position: absolute; padding: 7px 10px; border: 1px solid rgba(255,255,255,.5); border-radius: 999px; background: rgba(255,247,232,.38); color: var(--ink); font-family: var(--mono); font-size: 11px; backdrop-filter: blur(8px); }
.meta-one { left: 10%; top: 20%; }.meta-two { right: 8%; top: 44%; }.meta-three { left: 45%; top: 11%; }

.instrument, .archive {
  position: absolute;
  z-index: 5;
  padding: 18px;
  border: 1px solid rgba(255,255,255,.64);
  background: linear-gradient(145deg, rgba(255,247,232,.66), rgba(255,255,255,.26));
  backdrop-filter: blur(18px);
  box-shadow: 0 20px 60px rgba(124,77,255,.14), inset 0 0 28px rgba(255,255,255,.48);
  transition: transform .35s ease, box-shadow .35s ease, filter .35s ease;
}
.panel-lift:hover { transform: translateY(-10px) rotate(var(--tilt, 0deg)); box-shadow: 0 30px 80px rgba(124,77,255,.28), 0 0 38px rgba(77,235,255,.24), inset 0 0 34px rgba(255,255,255,.55); filter: saturate(1.12); }
.instrument small, .archive small { display: block; font-size: 12px; line-height: 1.35; color: rgba(24,74,58,.7); }
.exposure { left: 6vw; top: 35vh; width: 230px; border-radius: 34px 58px 38px 46px; --tilt: -1.5deg; }
.temperature { right: 6vw; top: 10vh; width: 250px; border-radius: 60px 30px 54px 36px; --tilt: 1.2deg; }
.pollen { right: 5vw; top: 45vh; width: 300px; border-radius: 32px 70px 30px 58px; --tilt: -1deg; }
.focus { left: 24vw; bottom: 4.5vh; width: 245px; border-radius: 62px 36px 44px 30px; --tilt: .8deg; }
.hue { right: 29vw; bottom: 5vh; width: 270px; border-radius: 36px 42px 66px 30px; --tilt: -1.1deg; }
.archive { left: 4vw; bottom: 8vh; width: 245px; border-radius: 32px 46px 66px 36px; --tilt: 1.4deg; }

.dial { position: relative; width: 138px; height: 138px; margin: 10px auto 12px; border-radius: 50%; background: conic-gradient(var(--pink) 0 72%, rgba(255,255,255,.38) 72% 100%); box-shadow: inset 0 0 0 14px rgba(255,247,232,.76), 0 0 30px rgba(255,102,179,.26); }
.dial span { position: absolute; inset: 28px; border-radius: 50%; background: radial-gradient(circle, var(--cream), rgba(255,247,232,.62)); }
.dial b { position: absolute; inset: 0; display: grid; place-items: center; font-family: var(--mono); font-size: 28px; color: var(--ink); }
.thermo { height: 18px; margin: 28px 0 19px; border-radius: 999px; background: rgba(255,255,255,.46); border: 1px solid rgba(24,74,58,.12); overflow: hidden; }
.thermo i { display: block; width: 68%; height: 100%; background: linear-gradient(90deg, var(--peach), var(--lemon), var(--pink)); border-radius: inherit; animation: warmPulse 4s ease-in-out infinite; }
.waveform { width: 100%; height: 86px; overflow: visible; }
.waveform path { fill: none; stroke: var(--ink); stroke-width: 3; stroke-linecap: round; filter: drop-shadow(0 0 8px rgba(77,235,255,.5)); stroke-dasharray: 340; animation: drawWave 5s ease-in-out infinite alternate; }
.waveform circle { fill: var(--lemon); stroke: var(--pink); stroke-width: 2; }
.mini-reticle { position: relative; width: 105px; height: 105px; margin: 8px auto 14px; left: auto; top: auto; transform: none; }
.mini-reticle span { width: 18px; height: 36px; margin: -53px 0 0 -9px; transform-origin: 50% 53px; }
.hue-ribbon { display: flex; gap: 7px; margin: 18px 0; }
.hue-ribbon span { height: 54px; flex: 1; border-radius: 22px; box-shadow: inset 0 0 18px rgba(255,255,255,.45); }
.hue-ribbon span:nth-child(1) { background: var(--peach); }.hue-ribbon span:nth-child(2) { background: var(--lemon); }.hue-ribbon span:nth-child(3) { background: var(--pink); }.hue-ribbon span:nth-child(4) { background: var(--cyan); }.hue-ribbon span:nth-child(5) { background: var(--violet); }
.archive-constellation { display: grid; grid-template-columns: repeat(2, 1fr); gap: 12px; margin-top: 12px; }
.capture-chip { border: 0; border-radius: 999px; padding: 9px 10px; background: rgba(255,176,133,.56); color: var(--ink); font-family: var(--mono); box-shadow: inset 0 0 16px rgba(255,255,255,.5); transition: transform .25s ease, background .25s ease; }
.capture-chip:hover { transform: translateY(-4px) rotate(-2deg); background: rgba(255,102,179,.54); }
.capture-chip i { display: inline-block; width: 12px; height: 12px; margin-right: 6px; border-radius: 50% 50% 50% 0; background: var(--lemon); transform: rotate(-45deg); }
.cursor-bloom { position: fixed; left: 0; top: 0; width: 20px; height: 20px; pointer-events: none; border-radius: 50%; border: 1px solid var(--cyan); box-shadow: 0 0 20px rgba(77,235,255,.8); opacity: 0; transform: translate(-50%, -50%); z-index: 20; transition: opacity .2s ease; }

@keyframes clearLens { 0% { opacity: 1; clip-path: circle(7% at 50% 50%); } 55% { opacity: .72; clip-path: circle(40% at 50% 50%); } 100% { opacity: 0; clip-path: circle(88% at 50% 50%); visibility: hidden; } }
@keyframes scan { from { transform: translateY(-18px); } to { transform: translateY(18px); } }
@keyframes mistDrift { from { transform: translate3d(-1%, -1%, 0) rotate(-1deg); } to { transform: translate3d(1%, 1%, 0) rotate(1deg); } }
@keyframes titleWrite { from { opacity: 0; filter: blur(12px); transform: translateY(-14px); } to { opacity: 1; filter: blur(0); transform: translateY(0); } }
@keyframes haloPulse { 50% { transform: scale(1.06); opacity: .82; } }
@keyframes petalDrift { 0%,100% { translate: 0 0; rotate: 0deg; } 50% { translate: 32px -26px; rotate: 14deg; } }
@keyframes bokehRise { 50% { transform: translateY(-34px) scale(1.2); opacity: .42; } }
@keyframes warmPulse { 50% { width: 82%; } }
@keyframes drawWave { to { stroke-dashoffset: -120; } }
@keyframes pollenFloat { to { transform: translate(var(--dx), var(--dy)) scale(.2); opacity: 0; } }

@media (max-width: 980px) {
  html, body { overflow: auto; }
  .conservatory { min-height: 1500px; height: auto; }
  .lens-stage { top: 360px; width: 92vw; }
  .viewfinder { width: 88vw; height: 520px; }
  .glass-title, .instrument, .archive { position: relative; left: auto; right: auto; top: auto; bottom: auto; width: min(92vw, 430px); margin: 18px auto; }
  .glass-title { margin-top: 0; }
  .exposure { margin-top: 720px; }
}
