:root {
  --burgundy: #2A0612;
  --black: #09030A;
  --oxblood: #5A1026;
  --cream: #F4D6B3;
  --rose: #D98A9B;
  --cyan: #46F4FF;
  --gold: #F8C85A;
  --lavender: #B9A7FF;
  --display: "Fraunces", Georgia, serif;
  --serif: "Cormorant Garamond", Georgia, serif;
  --hud: "Libre Franklin", Arial, sans-serif;
}

* { box-sizing: border-box; }

html { scroll-behavior: smooth; background: var(--black); }

body {
  margin: 0;
  min-height: 100vh;
  color: var(--cream);
  font-family: var(--serif);
  overflow-x: hidden;
  background: var(--black);
}

body::before {
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: 50;
  opacity: .18;
  background:
    repeating-linear-gradient(90deg, transparent 0 18px, rgba(244,214,179,.08) 19px 20px),
    repeating-linear-gradient(0deg, rgba(255,255,255,.06) 0 1px, transparent 1px 5px);
  mix-blend-mode: screen;
}

.site-shell {
  position: relative;
  min-height: 100vh;
  background:
    radial-gradient(circle at 18% 82%, rgba(248,200,90,.18), transparent 25%),
    radial-gradient(circle at 82% 18%, rgba(70,244,255,.12), transparent 22%),
    linear-gradient(135deg, var(--black), var(--burgundy) 45%, var(--black));
}

.velvet-curtain {
  position: fixed;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  background:
    radial-gradient(ellipse at 50% -20%, rgba(217,138,155,.18), transparent 55%),
    repeating-radial-gradient(ellipse at 10% 50%, rgba(90,16,38,.45) 0 16px, rgba(42,6,18,.2) 17px 32px),
    linear-gradient(90deg, rgba(9,3,10,.8), transparent 28%, transparent 70%, rgba(9,3,10,.88));
  filter: blur(.2px) saturate(1.1);
}

.transmissions { position: relative; z-index: 2; }

.scene {
  position: relative;
  min-height: 100vh;
  display: grid;
  align-items: center;
  overflow: hidden;
  padding: 8rem clamp(1.4rem, 5vw, 5.5rem);
  isolation: isolate;
}

.scene::before {
  content: attr(data-label);
  position: absolute;
  top: 7.1rem;
  left: clamp(1.2rem, 4vw, 4.2rem);
  font-family: var(--hud);
  font-size: .68rem;
  font-weight: 800;
  letter-spacing: .26em;
  color: var(--cyan);
  opacity: .75;
}

.scene::after {
  content: "";
  position: absolute;
  inset: 8% 6%;
  border: 1px solid rgba(244,214,179,.16);
  transform: skewY(-5deg);
  pointer-events: none;
  z-index: -1;
}

.scene-bg-word {
  position: absolute;
  z-index: -2;
  font-size: clamp(7rem, 24vw, 25rem);
  line-height: .72;
  font-weight: 900;
  color: rgba(244,214,179,.075);
  letter-spacing: -.09em;
  text-shadow: 18px 14px 0 rgba(217,138,155,.09), -10px -8px 0 rgba(70,244,255,.08);
  transform: rotate(-10deg);
  white-space: nowrap;
}

.scene-one .scene-bg-word { left: -4vw; bottom: 7vh; }
.scene-two .scene-bg-word { right: -8vw; top: 9vh; }
.scene-three .scene-bg-word { left: 4vw; top: 10vh; }
.scene-four .scene-bg-word { right: -6vw; bottom: 8vh; }
.scene-five .scene-bg-word { left: 8vw; top: 17vh; }

.serif-signal { font-family: var(--display); }

.hud-frame {
  position: fixed;
  inset: 1.1rem;
  z-index: 30;
  pointer-events: none;
  opacity: 0;
  filter: blur(8px);
  transition: opacity 1.4s ease, filter 1.4s ease;
}

body.loaded .hud-frame { opacity: 1; filter: blur(0); }

.corner {
  position: absolute;
  width: clamp(3rem, 8vw, 6rem);
  height: clamp(3rem, 8vw, 6rem);
  border-color: rgba(244,214,179,.7);
}

.corner-tl { top: 0; left: 0; border-top: 2px solid; border-left: 2px solid; }
.corner-tr { top: 0; right: 0; border-top: 2px solid; border-right: 2px solid; }
.corner-bl { bottom: 0; left: 0; border-bottom: 2px solid; border-left: 2px solid; }
.corner-br { bottom: 0; right: 0; border-bottom: 2px solid; border-right: 2px solid; }

.edge-label {
  position: absolute;
  font-family: var(--hud);
  font-size: .58rem;
  font-weight: 600;
  letter-spacing: .24em;
  color: rgba(244,214,179,.64);
  text-transform: uppercase;
}

.edge-top { top: .7rem; left: 8rem; }
.edge-bottom { bottom: .7rem; right: 8rem; }
.edge-left { left: .65rem; top: 48%; transform: rotate(-90deg); transform-origin: left center; }
.edge-right { right: .65rem; top: 33%; transform: rotate(90deg); transform-origin: right center; }

.hud-ring {
  position: absolute;
  border-radius: 50%;
  border: 1px solid rgba(70,244,255,.28);
  background: repeating-conic-gradient(from 10deg, rgba(248,200,90,.7) 0deg 2deg, transparent 2deg 11deg);
  mask: radial-gradient(circle, transparent 58%, #000 59% 61%, transparent 62%);
  opacity: .75;
  transition: transform .22s ease-out;
}

.hud-ring span { position: absolute; inset: 15%; border: 1px dashed rgba(244,214,179,.28); border-radius: 50%; }
.hud-ring-a { width: 38vmin; height: 38vmin; left: 7vw; bottom: 10vh; animation: slowSpin 32s linear infinite; }
.hud-ring-b { width: 24vmin; height: 24vmin; right: 10vw; top: 13vh; animation: slowSpin 24s linear infinite reverse; }

.signal-nav {
  position: fixed;
  right: 2rem;
  top: 50%;
  transform: translateY(-50%);
  z-index: 35;
  display: flex;
  flex-direction: column;
  gap: .7rem;
  font-family: var(--hud);
  font-size: .58rem;
  letter-spacing: .18em;
}

.signal-nav a {
  color: rgba(244,214,179,.72);
  text-decoration: none;
  padding: .35rem .5rem;
  border-right: 2px solid rgba(70,244,255,.28);
  background: rgba(9,3,10,.2);
}

.signal-nav a.active { color: var(--cyan); border-right-color: var(--gold); }

.particle-dust {
  position: fixed;
  inset: 0;
  z-index: 28;
  pointer-events: none;
  opacity: 0;
  transition: opacity 1.5s ease .45s;
}

body.loaded .particle-dust { opacity: 1; }

.particle {
  position: absolute;
  width: var(--size);
  height: var(--size);
  left: var(--x);
  top: var(--y);
  border-radius: 50%;
  background: var(--color);
  box-shadow: 0 0 18px var(--color);
  opacity: .55;
  animation: drift var(--duration) ease-in-out var(--delay) infinite alternate, pulse 3.8s ease-in-out var(--delay) infinite;
}

.particle.cross { border-radius: 0; background: transparent; }
.particle.cross::before, .particle.cross::after { content: ""; position: absolute; background: var(--color); }
.particle.cross::before { width: 100%; height: 1px; top: 50%; }
.particle.cross::after { height: 100%; width: 1px; left: 50%; }

.comic-panel,
.name-panel,
.closing-transmission,
.instrument-cluster,
.caption-bubble,
.contact-strip,
.photo-negative {
  transition: transform .24s ease-out;
}

.opening-panel {
  width: min(72rem, 82vw);
  margin-left: 4vw;
  padding: clamp(2rem, 5vw, 4.5rem);
  border: 1px solid rgba(244,214,179,.38);
  background: linear-gradient(135deg, rgba(42,6,18,.72), rgba(90,16,38,.38));
  box-shadow: 22px 26px 0 rgba(217,138,155,.2), -12px -12px 0 rgba(70,244,255,.1), inset 0 0 80px rgba(9,3,10,.55);
  transform: rotate(-3deg);
  clip-path: polygon(2% 0, 100% 4%, 96% 92%, 0 100%);
}

.hud-kicker {
  margin: 0 0 1rem;
  font-family: var(--hud);
  font-size: .68rem;
  font-weight: 800;
  color: var(--gold);
  letter-spacing: .24em;
}

.domain-title {
  position: relative;
  margin: 0;
  font-size: clamp(4rem, 13vw, 13rem);
  line-height: .72;
  letter-spacing: -.08em;
  color: var(--cream);
  text-shadow: 12px 9px 0 rgba(217,138,155,.56), -7px -4px 0 rgba(70,244,255,.46), 0 0 45px rgba(244,214,179,.16);
}

.domain-title::after {
  content: attr(data-text);
  position: absolute;
  inset: 0;
  color: transparent;
  -webkit-text-stroke: 1px rgba(248,200,90,.75);
  transform: translate(16px, 10px);
  opacity: .36;
}

.caption-bubble {
  max-width: 27rem;
  padding: 1.1rem 1.35rem;
  background: rgba(244,214,179,.88);
  color: var(--burgundy);
  border: 2px solid rgba(9,3,10,.35);
  border-radius: 60% 40% 48% 52% / 58% 38% 62% 42%;
  font-size: clamp(1.15rem, 2vw, 1.6rem);
  line-height: 1.15;
  box-shadow: 8px 8px 0 rgba(70,244,255,.25), -7px -5px 0 rgba(248,200,90,.22);
}

.opening-panel .caption-bubble { margin: 2rem 0 0 auto; transform: rotate(3deg); }

.photo-negative {
  position: absolute;
  width: min(26rem, 38vw);
  aspect-ratio: 3 / 4;
  background:
    radial-gradient(circle at 47% 30%, rgba(244,214,179,.7), transparent 8%),
    radial-gradient(ellipse at 50% 40%, rgba(217,138,155,.65), transparent 19%),
    linear-gradient(145deg, rgba(244,214,179,.82), rgba(90,16,38,.78));
  border: .8rem solid rgba(244,214,179,.72);
  box-shadow: 16px 18px 0 rgba(9,3,10,.55), -9px -8px 0 rgba(70,244,255,.17);
  filter: sepia(.5) contrast(1.08) saturate(1.3);
  overflow: hidden;
}

.photo-negative::before {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(circle, rgba(9,3,10,.24) 1px, transparent 1.7px);
  background-size: 10px 10px;
  mix-blend-mode: multiply;
}

.photo-negative::after {
  content: "";
  position: absolute;
  inset: -20%;
  background: linear-gradient(70deg, transparent 38%, rgba(255,255,255,.22), transparent 54%);
  transform: rotate(18deg);
}

.portrait-one { right: 9vw; bottom: 8vh; transform: rotate(8deg); }
.portrait-two { right: 12vw; top: 18vh; transform: rotate(-9deg); }

.face-fragment,
.silhouette-fragment {
  position: absolute;
  left: 26%;
  top: 16%;
  width: 48%;
  height: 58%;
  border-radius: 48% 52% 42% 58% / 38% 42% 58% 62%;
  background: var(--oxblood);
  box-shadow: 16px 6px 0 rgba(70,244,255,.35), -12px 8px 0 rgba(248,200,90,.28);
}

.silhouette-fragment { top: 22%; height: 52%; border-radius: 50% 50% 46% 54%; }

.photo-label {
  position: absolute;
  left: 1rem;
  bottom: 1rem;
  font-family: var(--hud);
  font-size: .58rem;
  letter-spacing: .2em;
  color: var(--black);
  z-index: 2;
}

.registration-cross {
  position: absolute;
  font-family: var(--hud);
  font-weight: 800;
  color: var(--cyan);
  text-shadow: 6px 4px 0 rgba(248,200,90,.55), -4px -3px 0 rgba(217,138,155,.48);
  opacity: .78;
}

.cross-one { left: 11vw; bottom: 17vh; font-size: 8rem; }
.cross-two { left: 7vw; top: 16vh; font-size: 7rem; }
.final-cross { right: 16vw; bottom: 18vh; font-size: 12rem; }

.contact-strip {
  width: min(63rem, 78vw);
  margin-left: 9vw;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: .85rem;
  padding: 1.1rem;
  background: rgba(9,3,10,.58);
  border: 1px solid rgba(244,214,179,.34);
  transform: rotate(-7deg);
  box-shadow: 20px 24px 0 rgba(90,16,38,.46);
}

.photo-cell {
  min-height: 38vh;
  position: relative;
  overflow: hidden;
  background:
    radial-gradient(circle at 50% 26%, rgba(248,200,90,.38), transparent 14%),
    linear-gradient(150deg, rgba(244,214,179,.72), rgba(90,16,38,.9));
}

.photo-cell::before {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(circle, rgba(42,6,18,.45) 1px, transparent 2px);
  background-size: 9px 9px;
  mix-blend-mode: multiply;
}

.photo-cell.burned { background: radial-gradient(circle at 70% 18%, rgba(70,244,255,.32), transparent 17%), linear-gradient(135deg, rgba(217,138,155,.78), rgba(42,6,18,.95)); }
.photo-cell.moon { background: radial-gradient(circle at 45% 30%, rgba(244,214,179,.84), transparent 18%), linear-gradient(160deg, rgba(9,3,10,.2), rgba(90,16,38,.9)); }
.photo-cell.curtain { background: repeating-linear-gradient(95deg, rgba(217,138,155,.32) 0 18px, rgba(90,16,38,.7) 19px 38px); }

.photo-cell span {
  position: absolute;
  left: .8rem;
  bottom: .8rem;
  font-family: var(--hud);
  font-size: .55rem;
  letter-spacing: .18em;
  color: var(--cream);
}

.halftone-field {
  position: absolute;
  width: 28rem;
  height: 28rem;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(248,200,90,.75) 1.4px, transparent 2px);
  background-size: 17px 17px;
  filter: blur(.2px);
  opacity: .34;
}

.halftone-left { left: -5rem; top: 12vh; }
.contact-caption { margin: 2.2rem 0 0 54vw; transform: rotate(5deg); }

.name-panel {
  width: min(43rem, 78vw);
  margin-left: 12vw;
  padding: 2.2rem 2.4rem;
  background: rgba(244,214,179,.1);
  border-left: 6px solid var(--gold);
  border-top: 1px solid rgba(244,214,179,.35);
  box-shadow: -16px 18px 0 rgba(70,244,255,.09), 20px -14px 0 rgba(217,138,155,.12);
  transform: rotate(4deg);
}

.chapter-title {
  margin: 0;
  font-size: clamp(3.4rem, 9vw, 8.6rem);
  line-height: .8;
  letter-spacing: -.07em;
  color: var(--cream);
  text-shadow: 8px 7px 0 rgba(217,138,155,.46), -6px -3px 0 rgba(70,244,255,.32);
}

.poem-line {
  max-width: 34rem;
  font-size: clamp(1.35rem, 2.4vw, 2.15rem);
  line-height: 1.12;
  color: rgba(244,214,179,.88);
}

.instrument-cluster {
  width: min(57rem, 80vw);
  margin-left: auto;
  margin-right: 9vw;
  min-height: 58vh;
  position: relative;
  border: 1px solid rgba(70,244,255,.28);
  background: radial-gradient(circle at 48% 44%, rgba(70,244,255,.09), transparent 38%), rgba(9,3,10,.42);
  box-shadow: inset 0 0 80px rgba(42,6,18,.85), 18px 20px 0 rgba(217,138,155,.12);
  transform: rotate(-3deg);
}

.dial {
  position: absolute;
  border-radius: 50%;
  display: grid;
  place-items: center;
  font-family: var(--hud);
  font-size: .7rem;
  font-weight: 800;
  letter-spacing: .2em;
  color: var(--cyan);
  background: repeating-conic-gradient(rgba(244,214,179,.65) 0 2deg, transparent 2deg 8deg);
  mask: radial-gradient(circle, transparent 48%, #000 49% 52%, transparent 53%, transparent 66%, #000 67% 69%, transparent 70%);
  animation: slowSpin 36s linear infinite;
}

.dial-large { width: 28rem; height: 28rem; left: 7%; top: 9%; max-width: 55vmin; max-height: 55vmin; }
.dial-small { width: 12rem; height: 12rem; right: 10%; bottom: 12%; animation-direction: reverse; }

.readout-grid {
  position: absolute;
  right: 6%;
  top: 13%;
  width: min(23rem, 38vw);
  display: grid;
  gap: .7rem;
  font-family: var(--hud);
  font-size: .72rem;
  letter-spacing: .16em;
  color: var(--cream);
}

.readout-grid p { margin: 0; padding: .8rem; border: 1px solid rgba(244,214,179,.2); background: rgba(90,16,38,.36); }
.hud-caption { position: absolute; left: 12vw; bottom: 14vh; transform: rotate(-6deg); }

.closing-transmission {
  width: min(42rem, 76vw);
  margin-left: 14vw;
  padding: 2.6rem;
  background: linear-gradient(135deg, rgba(42,6,18,.7), rgba(9,3,10,.35));
  border: 1px solid rgba(244,214,179,.24);
  box-shadow: 0 0 120px rgba(217,138,155,.12);
  transform: rotate(2deg);
}

.small-domain {
  display: inline-block;
  margin-top: 1.4rem;
  font-family: var(--hud);
  letter-spacing: .28em;
  font-size: .72rem;
  color: var(--cyan);
  border-bottom: 1px solid var(--gold);
}

.reveal-print {
  opacity: 0;
  filter: blur(24px) contrast(.55);
  clip-path: inset(0 100% 0 0);
  transition: opacity 1.1s ease, filter 1.1s ease, clip-path 1.35s cubic-bezier(.19,1,.22,1);
}

.reveal-print.visible {
  opacity: 1;
  filter: blur(0) contrast(1.08);
  clip-path: inset(0 0 0 0);
}

@keyframes slowSpin { to { rotate: 360deg; } }
@keyframes drift { to { transform: translate3d(var(--dx), var(--dy), 0) rotate(28deg); } }
@keyframes pulse { 50% { opacity: .95; filter: blur(.8px); } }

@media (max-width: 820px) {
  .signal-nav { display: none; }
  .edge-left, .edge-right { display: none; }
  .edge-top { left: 1rem; top: .45rem; }
  .edge-bottom { right: 1rem; bottom: .45rem; }
  .scene { padding: 7rem 1.2rem; }
  .opening-panel, .name-panel, .closing-transmission, .instrument-cluster, .contact-strip { width: 100%; margin-left: 0; margin-right: 0; }
  .photo-negative { position: relative; width: 72vw; right: auto; top: auto; bottom: auto; margin: 2rem auto 0; }
  .contact-strip { grid-template-columns: repeat(2, 1fr); transform: rotate(-3deg); }
  .photo-cell { min-height: 28vh; }
  .contact-caption, .hud-caption { position: relative; left: auto; bottom: auto; margin: 2rem 0 0 auto; }
  .readout-grid { position: relative; right: auto; top: auto; width: auto; padding: 2rem; }
  .dial-large { opacity: .55; }
}
