:root {
  --ink-black: #090807;
  --newsprint: #F2E8D0;
  --tabloid-red: #E11229;
  --photocopy-blue: #234DFF;
  --rumor-yellow: #FFD400;
  --correction-white: #FFF9EA;
  --bruise-purple: #4C1D7A;
  --oxidized-green: #2DBA73;
  --mono: 'IBM Plex Mono', monospace;
  --headline: 'Bebas Neue', sans-serif;
  --serif: 'Fraunces', serif;
}

* { box-sizing: border-box; }

html { scroll-behavior: smooth; }

body {
  margin: 0;
  color: var(--ink-black);
  background: var(--ink-black);
  font-family: var(--serif);
  overflow-x: hidden;
}

body::before {
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: 40;
  opacity: .19;
  background-image:
    repeating-linear-gradient(0deg, rgba(9,8,7,.08) 0 1px, transparent 1px 5px),
    radial-gradient(circle at 18% 22%, rgba(255,249,234,.25), transparent 18%),
    radial-gradient(circle at 78% 60%, rgba(225,18,41,.12), transparent 20%);
  mix-blend-mode: multiply;
}

.svg-lab { position: absolute; }

.ticker-rail {
  position: fixed;
  left: -8vw;
  right: -8vw;
  top: 0;
  z-index: 20;
  height: 32px;
  display: flex;
  align-items: center;
  gap: 2rem;
  padding: 0 2rem;
  transform: rotate(-1.7deg);
  background: var(--rumor-yellow);
  border-bottom: 4px solid var(--ink-black);
  font: 700 .78rem var(--mono);
  letter-spacing: .18em;
  white-space: nowrap;
  animation: railShiver 1.2s steps(2) infinite;
}

.ticker-rail span { animation: tickerDrift 9s linear infinite; }

.room {
  position: relative;
  min-height: 100vh;
  overflow: hidden;
  isolation: isolate;
  padding: clamp(5rem, 8vw, 8rem) clamp(1.3rem, 4vw, 5rem);
  background-color: var(--newsprint);
  filter: url('#photocopyNoise');
}

.room::before {
  content: attr(data-room);
  position: absolute;
  top: 3.4rem;
  left: 1.3rem;
  z-index: 6;
  font: 700 .76rem var(--mono);
  letter-spacing: .22em;
  color: var(--photocopy-blue);
  transform: rotate(-2deg);
}

.mono-tag {
  margin: 0 0 .7rem;
  font: 700 .74rem var(--mono);
  letter-spacing: .18em;
  text-transform: uppercase;
}

.fraunces-copy {
  font: 650 clamp(1.05rem, 2vw, 1.55rem)/1.32 var(--serif);
}

.editor-note {
  font: 650 clamp(1rem, 1.5vw, 1.3rem)/1.28 var(--serif);
  background: var(--correction-white);
  border: 3px solid var(--ink-black);
  box-shadow: 8px 8px 0 var(--tabloid-red), -5px -5px 0 var(--photocopy-blue);
  clip-path: polygon(0 4%, 98% 0, 100% 91%, 93% 100%, 7% 96%, 0 100%);
}

.foundry {
  min-height: 112vh;
  background:
    linear-gradient(118deg, transparent 0 54%, rgba(76,29,122,.18) 54% 61%, transparent 61%),
    var(--newsprint);
}

.torn-masthead {
  position: relative;
  z-index: 4;
  width: min(1120px, 94vw);
  margin: 1.5rem auto 0;
  padding: .4rem 1.2rem .2rem;
  transform: rotate(-3.4deg);
  background: var(--correction-white);
  border: 5px solid var(--ink-black);
  box-shadow: 18px 20px 0 var(--rumor-yellow), -10px -8px 0 var(--tabloid-red);
  clip-path: polygon(0 8%, 4% 0, 12% 7%, 23% 1%, 32% 8%, 43% 0, 55% 7%, 68% 1%, 81% 9%, 93% 0, 100% 6%, 98% 84%, 91% 100%, 79% 91%, 69% 100%, 56% 92%, 41% 100%, 28% 91%, 14% 100%, 0 90%);
  transform-origin: 25% 70%;
  transition: transform .25s ease, clip-path .25s ease;
}

.torn-masthead.peeled {
  transform: rotate(-6deg) translateY(-12px) skewX(-2deg);
  clip-path: polygon(0 0, 6% 8%, 16% 0, 27% 12%, 38% 1%, 47% 9%, 60% 0, 73% 10%, 83% 1%, 100% 8%, 96% 75%, 89% 100%, 76% 84%, 61% 100%, 50% 86%, 35% 100%, 21% 84%, 5% 96%);
}

.torn-masthead h1,
.print-ghost {
  margin: 0;
  font-family: var(--headline);
  font-size: clamp(5.5rem, 18vw, 18rem);
  line-height: .82;
  letter-spacing: -.045em;
  text-transform: uppercase;
}

.print-ghost {
  position: absolute;
  inset: .4rem 1.2rem auto;
  mix-blend-mode: multiply;
  opacity: .82;
  pointer-events: none;
}

.print-ghost.red { color: var(--tabloid-red); transform: translate(-8px, 6px); }
.print-ghost.blue { color: var(--photocopy-blue); transform: translate(9px, -5px); }
.torn-masthead h1 { position: relative; z-index: 2; color: var(--ink-black); }

.masthead-rip {
  position: absolute;
  inset: auto -2% -9px -2%;
  height: 28px;
  background: var(--ink-black);
  clip-path: polygon(0 20%, 8% 80%, 13% 30%, 20% 100%, 29% 25%, 40% 85%, 51% 30%, 63% 95%, 75% 20%, 84% 78%, 91% 35%, 100% 88%, 100% 100%, 0 100%);
}

.breaking-stack {
  position: absolute;
  top: 18vh;
  right: clamp(1rem, 7vw, 7rem);
  z-index: 8;
  display: grid;
  gap: .75rem;
}

.stamp-verdict {
  display: inline-block;
  padding: .35rem .65rem .18rem;
  font: 700 clamp(1.4rem, 4vw, 3.4rem)/.9 var(--headline);
  letter-spacing: .05em;
  color: var(--tabloid-red);
  border: 5px solid currentColor;
  background: rgba(255,249,234,.82);
  transform: rotate(8deg);
  box-shadow: 5px 5px 0 var(--ink-black);
  animation: stampSlam 3s cubic-bezier(.2, 1.2, .2, 1) infinite;
}

.vague-sticker {
  color: var(--bruise-purple);
  font-size: clamp(1rem, 2.4vw, 1.8rem);
  transform: rotate(-5deg);
  animation-delay: 1.2s;
}

.source-labels {
  position: absolute;
  top: 40vh;
  left: clamp(1rem, 5vw, 6rem);
  z-index: 2;
  display: grid;
  gap: .5rem;
  opacity: .08;
  transform: translateY(30px) rotate(-2deg);
  transition: opacity .25s ease, transform .25s ease;
}

.source-labels.revealed { opacity: 1; transform: translateY(0) rotate(-2deg); }

.source-labels span {
  width: max-content;
  max-width: 88vw;
  padding: .35rem .5rem;
  color: var(--correction-white);
  background: var(--bruise-purple);
  font: 700 .76rem var(--mono);
  letter-spacing: .12em;
}

.headline-press {
  position: relative;
  z-index: 5;
  width: min(870px, 92vw);
  margin: clamp(3rem, 8vw, 8rem) 0 0 clamp(0rem, 7vw, 8rem);
  padding: clamp(1.2rem, 3vw, 2.2rem);
  background: var(--ink-black);
  color: var(--correction-white);
  border: 5px solid var(--ink-black);
  box-shadow: 14px 14px 0 var(--photocopy-blue);
  clip-path: polygon(0 7%, 96% 0, 100% 86%, 91% 100%, 2% 95%);
}

.headline-press h2,
.booth-folder h2,
.seed-strip h2,
.claim-slab h2,
.verified-card h2 {
  margin: 0;
  font-family: var(--headline);
  font-size: clamp(3rem, 8vw, 7rem);
  line-height: .86;
  letter-spacing: .01em;
  text-transform: uppercase;
}

#mutatingWord, .loud-word { color: var(--rumor-yellow); text-shadow: 4px 0 0 var(--tabloid-red), -3px 0 0 var(--photocopy-blue); }

.conveyor {
  display: flex;
  gap: 1rem;
  margin-top: 1.4rem;
  padding: .55rem;
  overflow: hidden;
  background: var(--rumor-yellow);
  color: var(--ink-black);
  font: 700 1rem var(--mono);
  white-space: nowrap;
  transform: rotate(-1deg);
}

.conveyor span { animation: conveyorMove 7s linear infinite; }

.press-wheel {
  position: absolute;
  right: -42px;
  top: -42px;
  width: 116px;
  height: 116px;
  border: 13px solid var(--tabloid-red);
  border-radius: 50%;
  background: repeating-conic-gradient(var(--correction-white) 0 10deg, var(--ink-black) 10deg 20deg);
  animation: crank 5s linear infinite;
}

.press-arm {
  position: absolute;
  right: 38px;
  top: 56px;
  width: 130px;
  height: 12px;
  background: var(--tabloid-red);
  transform: rotate(24deg);
  transform-origin: right center;
  animation: armPump 2.5s ease-in-out infinite;
}

.photocopy-band {
  position: absolute;
  z-index: 1;
  left: -10vw;
  right: -10vw;
  height: 9vh;
  background: rgba(35,77,255,.23);
  mix-blend-mode: multiply;
  animation: scanBand 5.8s linear infinite;
}
.band-a { top: 8%; }
.band-b { top: 68%; animation-delay: -2.6s; background: rgba(225,18,41,.16); }

.ink-smear {
  position: absolute;
  z-index: 1;
  width: 42vw;
  height: 16vh;
  border-radius: 50%;
  background: rgba(9,8,7,.28);
  filter: blur(11px);
  transform: rotate(-12deg);
}
.smear-one { right: -8vw; bottom: 13vh; }

.note-one {
  position: absolute;
  right: clamp(1rem, 6vw, 7rem);
  bottom: 9vh;
  z-index: 7;
  width: min(360px, 84vw);
  padding: 1rem;
  transform: rotate(3deg);
}

.paper-corner {
  position: absolute;
  z-index: 3;
  width: 120px;
  height: 120px;
  background: var(--correction-white);
  border: 4px solid var(--ink-black);
  transform: rotate(18deg);
}
.corner-left { left: -34px; bottom: 7vh; }
.corner-right { right: -44px; top: 48vh; background: var(--rumor-yellow); }

.source-booth {
  background:
    radial-gradient(circle at 50% 8%, rgba(255,212,0,.5), transparent 22%),
    linear-gradient(90deg, var(--bruise-purple) 0 21%, var(--newsprint) 21% 79%, var(--bruise-purple) 79% 100%);
}

.quote-curtain {
  position: absolute;
  top: 0;
  bottom: 0;
  z-index: 1;
  width: 25vw;
  display: flex;
  align-items: center;
  color: var(--correction-white);
  font: 8vw var(--serif);
  word-break: break-all;
  opacity: .9;
  transition: transform .6s cubic-bezier(.2, .8, .2, 1);
}
.left-curtain { left: 0; padding-left: 1vw; background: var(--bruise-purple); }
.right-curtain { right: 0; padding-right: 1vw; background: var(--bruise-purple); }
.source-booth.open .left-curtain { transform: translateX(-62%); }
.source-booth.open .right-curtain { transform: translateX(62%); }

.booth-light {
  position: absolute;
  top: 8vh;
  left: 50%;
  width: 34vw;
  height: 70vh;
  transform: translateX(-50%);
  background: radial-gradient(ellipse at top, rgba(255,249,234,.85), rgba(255,212,0,.22) 45%, transparent 70%);
  clip-path: polygon(45% 0, 55% 0, 100% 100%, 0 100%);
}

.empty-chair {
  position: absolute;
  bottom: 14vh;
  z-index: 2;
  width: 92px;
  height: 80px;
  border: 6px solid var(--ink-black);
  border-top: 22px solid var(--ink-black);
  background: transparent;
}
.empty-chair::before, .empty-chair::after { content: ""; position: absolute; bottom: -58px; width: 7px; height: 58px; background: var(--ink-black); }
.empty-chair::before { left: 14px; transform: rotate(6deg); }
.empty-chair::after { right: 14px; transform: rotate(-6deg); }
.chair-one { left: 41%; transform: rotate(-7deg); }
.chair-two { left: 55%; transform: rotate(6deg) scale(.86); }

.source-mask {
  position: absolute;
  z-index: 5;
  width: 118px;
  height: 150px;
  display: grid;
  place-items: center;
  background: var(--correction-white);
  border: 5px solid var(--ink-black);
  border-radius: 48% 52% 45% 55% / 42% 44% 56% 58%;
  box-shadow: 8px 8px 0 var(--tabloid-red);
  font: 5rem var(--headline);
  animation: maskSwing 3.5s ease-in-out infinite;
  transform-origin: top center;
}
.source-mask::before { content: ""; position: absolute; top: -42px; left: 50%; width: 2px; height: 42px; background: var(--ink-black); }
.mask-one { top: 17vh; left: 31vw; }
.mask-two { top: 23vh; right: 31vw; animation-delay: -.7s; background: var(--rumor-yellow); }
.mask-three { top: 42vh; left: 51vw; animation-delay: -1.4s; box-shadow: 8px 8px 0 var(--photocopy-blue); }

.booth-folder {
  position: relative;
  z-index: 4;
  width: min(690px, 84vw);
  margin: 28vh auto 0;
  padding: 1.4rem;
  background: var(--correction-white);
  border: 5px solid var(--ink-black);
  transform: rotate(-2deg);
  box-shadow: 12px 12px 0 var(--rumor-yellow);
}

.redaction-line { height: 18px; width: 72%; background: var(--ink-black); margin: 1rem 0 0; }
.redaction-line.short { width: 43%; }

.string-map span {
  position: absolute;
  z-index: 3;
  height: 3px;
  background: var(--tabloid-red);
  transform-origin: left center;
}
.string-map span:nth-child(1) { left: 22vw; top: 24vh; width: 36vw; transform: rotate(16deg); }
.string-map span:nth-child(2) { left: 37vw; top: 66vh; width: 30vw; transform: rotate(-23deg); }
.string-map span:nth-child(3) { left: 60vw; top: 22vh; width: 20vw; transform: rotate(61deg); }
.string-map span:nth-child(4) { left: 18vw; top: 73vh; width: 50vw; transform: rotate(-4deg); }

.amplification {
  background:
    repeating-linear-gradient(112deg, rgba(9,8,7,.08) 0 10px, transparent 10px 28px),
    var(--rumor-yellow);
}

.megaphone-field { position: absolute; inset: 0; z-index: 1; opacity: .88; }
.megaphone {
  position: absolute;
  width: 0;
  height: 0;
  border-top: 46px solid transparent;
  border-bottom: 46px solid transparent;
  border-left: 150px solid var(--tabloid-red);
  filter: drop-shadow(7px 7px 0 var(--ink-black));
  animation: megaphonePulse 2.1s ease-in-out infinite;
}
.megaphone::before { content: ""; position: absolute; left: -182px; top: -16px; width: 44px; height: 32px; background: var(--ink-black); }
.megaphone.one { top: 16vh; left: 6vw; transform: rotate(8deg); }
.megaphone.two { top: 54vh; right: 14vw; transform: rotate(188deg); animation-delay: -.7s; border-left-color: var(--photocopy-blue); }
.megaphone.three { bottom: 10vh; left: 24vw; transform: rotate(-14deg); animation-delay: -1.3s; border-left-color: var(--bruise-purple); }

.seed-strip {
  position: relative;
  z-index: 4;
  width: min(750px, 88vw);
  margin: 4vh 0 0 5vw;
  padding: 1.2rem;
  color: var(--correction-white);
  background: var(--ink-black);
  box-shadow: 14px 14px 0 var(--photocopy-blue);
  transform: rotate(-3deg);
  clip-path: polygon(0 7%, 100% 0, 96% 91%, 7% 100%);
}

.duplicate-cloud {
  position: relative;
  z-index: 5;
  min-height: 55vh;
  margin-top: 2rem;
}
.duplicate-cloud p {
  position: absolute;
  margin: 0;
  padding: .38rem .75rem .18rem;
  border: 4px solid var(--ink-black);
  background: var(--correction-white);
  font: clamp(1.7rem, 4.7vw, 5.6rem)/.9 var(--headline);
  box-shadow: 8px 8px 0 var(--tabloid-red);
  animation: duplicateDrift 4.2s ease-in-out infinite;
}
.duplicate-cloud p:nth-child(1) { left: 8vw; top: 4vh; transform: rotate(6deg); }
.duplicate-cloud p:nth-child(2) { left: 32vw; top: 13vh; transform: rotate(-5deg); animation-delay: -.5s; }
.duplicate-cloud p:nth-child(3) { left: 3vw; top: 26vh; transform: rotate(-9deg); animation-delay: -1s; box-shadow: 8px 8px 0 var(--photocopy-blue); }
.duplicate-cloud p:nth-child(4) { right: 5vw; top: 29vh; transform: rotate(8deg); animation-delay: -1.5s; }
.duplicate-cloud p:nth-child(5) { left: 25vw; top: 42vh; transform: rotate(3deg); animation-delay: -2s; background: var(--bruise-purple); color: var(--correction-white); }
.duplicate-cloud p:nth-child(6) { right: 13vw; top: 2vh; transform: rotate(-3deg); animation-delay: -2.6s; }

.rumor-canary {
  position: absolute;
  right: 7vw;
  bottom: 7vh;
  z-index: 6;
  width: 150px;
  height: 115px;
  background: var(--ink-black);
  color: var(--rumor-yellow);
  clip-path: polygon(8% 56%, 35% 21%, 70% 12%, 94% 39%, 74% 51%, 98% 73%, 58% 68%, 42% 97%, 31% 70%);
  display: flex;
  align-items: center;
  justify-content: center;
  gap: .1rem;
  font: 4rem var(--serif);
  animation: canaryTwitch 1.4s steps(2) infinite;
}

.alley-note {
  position: absolute;
  z-index: 7;
  left: 7vw;
  bottom: 7vh;
  width: min(430px, 82vw);
  padding: 1rem;
  transform: rotate(-2deg);
}

.morgue {
  background:
    linear-gradient(180deg, rgba(9,8,7,.88), rgba(9,8,7,.96)),
    var(--ink-black);
  color: var(--correction-white);
}

.morgue::before { color: var(--rumor-yellow); }

.morgue-drawer {
  position: absolute;
  right: -3vw;
  width: 46vw;
  min-width: 420px;
  height: 96px;
  border: 4px solid var(--correction-white);
  background: #090807;
  box-shadow: inset 0 0 0 10px rgba(255,249,234,.06), -8px 8px 0 var(--bruise-purple);
  transform: rotate(-2deg);
}
.morgue-drawer span { position: absolute; left: 1rem; top: 1rem; font: 700 .85rem var(--mono); color: var(--tabloid-red); letter-spacing: .18em; }
.drawer-one { top: 13vh; }
.drawer-two { top: 28vh; right: 3vw; }
.drawer-three { top: 43vh; right: -7vw; }

.claim-slab {
  position: relative;
  z-index: 4;
  width: min(850px, 90vw);
  margin: 9vh 0 0 3vw;
  padding: clamp(1.1rem, 3vw, 2.4rem);
  color: var(--ink-black);
  background: var(--newsprint);
  border: 5px solid var(--correction-white);
  box-shadow: 16px 16px 0 var(--tabloid-red);
  transform: rotate(2deg);
  clip-path: polygon(2% 0, 100% 6%, 97% 100%, 0 91%);
}

.correction-tape {
  position: absolute;
  left: 5%;
  right: 5%;
  height: 42px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--photocopy-blue);
  background: var(--correction-white);
  border: 2px solid var(--photocopy-blue);
  font: 700 .9rem var(--mono);
  letter-spacing: .28em;
  transform-origin: left center;
  animation: tapeWipe 4.5s ease-in-out infinite;
}
.tape-one { top: 41%; transform: rotate(-3deg); }
.tape-two { top: 58%; transform: rotate(2deg); animation-delay: -1.4s; }

.footnote-stack {
  position: relative;
  z-index: 5;
  display: grid;
  gap: .55rem;
  width: min(530px, 88vw);
  margin: 7vh 0 0 auto;
}
.footnote-stack span {
  padding: .5rem .7rem;
  color: var(--photocopy-blue);
  background: var(--correction-white);
  font: 700 .84rem var(--mono);
  transform: rotate(var(--r, -1deg));
}
.footnote-stack span:nth-child(2) { --r: 2deg; }
.footnote-stack span:nth-child(3) { --r: -3deg; }

.fact-room {
  display: grid;
  place-items: center;
  background: var(--newsprint);
  color: var(--ink-black);
}

.fact-room::before { color: var(--oxidized-green); }

.small-imprint {
  position: absolute;
  top: 12vh;
  left: 50%;
  transform: translateX(-50%) rotate(-1deg);
  font: clamp(1.6rem, 4vw, 3.2rem)/1 var(--headline);
  letter-spacing: .05em;
  color: var(--ink-black);
  border-bottom: 3px solid var(--ink-black);
}

.verified-card {
  width: min(760px, 86vw);
  padding: clamp(1.2rem, 4vw, 3rem);
  text-align: center;
  background: var(--correction-white);
  border: 1px solid rgba(9,8,7,.35);
  box-shadow: none;
}
.verified-card h2 {
  font-family: var(--serif);
  font-size: clamp(2rem, 5vw, 4.7rem);
  line-height: 1.05;
  text-transform: none;
  letter-spacing: -.035em;
}
.green-tag { color: var(--oxidized-green); }
.source-trail { margin: 1.4rem auto 0; max-width: 560px; font: 700 .86rem/1.7 var(--mono); color: var(--photocopy-blue); }
.quiet-line { position: absolute; bottom: 16vh; width: min(520px, 70vw); height: 2px; background: var(--ink-black); opacity: .3; }

@keyframes tickerDrift { to { transform: translateX(-120px); } }
@keyframes railShiver { 50% { transform: rotate(-1.1deg) translateY(1px); } }
@keyframes stampSlam { 0%, 78%, 100% { transform: rotate(8deg) scale(1); } 82% { transform: rotate(8deg) scale(1.32); } 88% { transform: rotate(8deg) scale(.94); } }
@keyframes conveyorMove { to { transform: translateX(-180px); } }
@keyframes crank { to { transform: rotate(360deg); } }
@keyframes armPump { 50% { transform: rotate(-8deg); } }
@keyframes scanBand { 0% { transform: translateY(-20vh); } 100% { transform: translateY(112vh); } }
@keyframes maskSwing { 0%, 100% { transform: rotate(-5deg); } 50% { transform: rotate(6deg); } }
@keyframes megaphonePulse { 50% { filter: drop-shadow(13px 13px 0 var(--ink-black)); } }
@keyframes duplicateDrift { 50% { translate: 12px -9px; filter: hue-rotate(12deg); } }
@keyframes canaryTwitch { 50% { transform: translate(5px, -4px) rotate(4deg); } }
@keyframes tapeWipe { 0%, 18% { clip-path: inset(0 100% 0 0); } 42%, 100% { clip-path: inset(0 0 0 0); } }

@media (max-width: 760px) {
  .room { padding-left: 1rem; padding-right: 1rem; }
  .breaking-stack { top: 33vh; right: 1rem; }
  .headline-press { margin-top: 8rem; }
  .note-one { position: relative; right: auto; bottom: auto; margin: 2rem 0 0 auto; }
  .quote-curtain { width: 32vw; }
  .source-mask { width: 84px; height: 108px; font-size: 3.4rem; }
  .mask-one { left: 25vw; }
  .mask-two { right: 23vw; }
  .booth-folder { margin-top: 34vh; }
  .duplicate-cloud { min-height: 72vh; }
  .duplicate-cloud p { max-width: 84vw; }
  .morgue-drawer { min-width: 300px; opacity: .55; }
  .claim-slab { margin-top: 18vh; }
  .correction-tape { font-size: .65rem; letter-spacing: .14em; }
}
