:root {
  --bg: #000000;
  --magenta: #ff0080;
  --magenta-soft: #ff48a3;
  --cyan: #00f0ff;
  --cyan-soft: #6ef7ff;
  --yellow: #fff200;
  --ink: #f5f5f5;
  --ink-dim: #8a8a8a;
}

* { box-sizing: border-box; margin: 0; padding: 0; }

html, body {
  height: 100%;
  background: var(--bg);
  color: var(--ink);
  font-family: "JetBrains Mono", ui-monospace, SFMono-Regular, Menlo, monospace;
  overflow: hidden;
}

body {
  position: relative;
  display: grid;
  grid-template-rows: auto 1fr auto;
  min-height: 100vh;
  isolation: isolate;
}

/* ---------- the floor (signature wireframe grid) ---------- */
.floor {
  position: fixed;
  inset: 50% 0 0 0;
  perspective: 600px;
  perspective-origin: 50% 0%;
  z-index: 0;
  pointer-events: none;
}
.floor-inner {
  position: absolute;
  inset: 0;
  transform: rotateX(60deg);
  transform-origin: 50% 0%;
  background-image:
    linear-gradient(to right, var(--magenta) 1px, transparent 1px),
    linear-gradient(to bottom, var(--magenta) 1px, transparent 1px);
  background-size: 60px 60px;
  background-position: 0 0;
  animation: floor-scroll 1.6s linear infinite;
  filter: drop-shadow(0 0 6px var(--magenta));
  opacity: 0.85;
  mask-image: linear-gradient(to bottom, transparent 0%, #000 12%, #000 80%, transparent 100%);
}
@keyframes floor-scroll {
  from { background-position: 0 0; }
  to   { background-position: 0 60px; }
}

/* ---------- the sky (a glowy horizon line + soft gradient) ---------- */
.sky {
  position: fixed;
  inset: 0 0 50% 0;
  z-index: 0;
  pointer-events: none;
  background:
    radial-gradient(ellipse at 50% 100%, rgba(255, 0, 128, 0.35) 0%, rgba(255, 0, 128, 0.0) 55%),
    radial-gradient(ellipse at 50% 110%, rgba(0, 240, 255, 0.18) 0%, rgba(0, 240, 255, 0) 50%);
}
.sky::after {
  content: "";
  position: absolute;
  left: 0; right: 0;
  bottom: 0;
  height: 2px;
  background: var(--cyan);
  box-shadow:
    0 0 6px var(--cyan),
    0 0 18px var(--cyan),
    0 0 36px var(--cyan);
}

/* ---------- CRT chrome ---------- */
.scanlines {
  position: fixed;
  inset: 0;
  z-index: 5;
  pointer-events: none;
  background: repeating-linear-gradient(
    to bottom,
    rgba(0,0,0,0) 0px,
    rgba(0,0,0,0) 2px,
    rgba(0,0,0,0.18) 3px,
    rgba(0,0,0,0.18) 3px
  );
  mix-blend-mode: multiply;
}
.vignette {
  position: fixed;
  inset: 0;
  z-index: 4;
  pointer-events: none;
  background: radial-gradient(ellipse at center, transparent 50%, rgba(0,0,0,0.85) 100%);
}
.noise {
  position: fixed;
  inset: 0;
  z-index: 6;
  pointer-events: none;
  opacity: 0.06;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 1  0 0 0 0 1  0 0 0 0 1  0 0 0 0.6 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
  animation: noise-shift 0.6s steps(4) infinite;
}
@keyframes noise-shift {
  0%   { transform: translate(0, 0); }
  25%  { transform: translate(-2%, 1%); }
  50%  { transform: translate(1%, -2%); }
  75%  { transform: translate(-1%, 2%); }
  100% { transform: translate(0, 0); }
}

/* ---------- HUD ---------- */
.hud {
  position: relative;
  z-index: 10;
  display: flex;
  justify-content: space-between;
  padding: 1.25rem 1.75rem;
  font-size: 0.72rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--cyan);
  text-shadow: 0 0 6px rgba(0, 240, 255, 0.6);
}
@keyframes blink { 50% { opacity: 0.05; } }

.onair-dot {
  display: inline-block;
  margin-right: 0.5em;
}
.hud-left.live .onair-dot {
  color: #ff2a2a;
  text-shadow:
    0 0 6px #ff2a2a,
    0 0 14px #ff2a2a,
    0 0 28px rgba(255, 42, 42, 0.6);
  animation: onair-pulse 1.4s ease-in-out infinite;
}
.hud-left.offair .onair-dot {
  color: var(--ink-dim);
  text-shadow: none;
  opacity: 0.55;
}
.hud-left.live #onair-text {
  color: #ff5757;
  text-shadow: 0 0 6px rgba(255, 42, 42, 0.6);
}
.hud-left.offair #onair-text {
  color: var(--ink-dim);
}
@keyframes onair-pulse {
  0%, 100% {
    text-shadow:
      0 0 6px #ff2a2a,
      0 0 14px #ff2a2a,
      0 0 28px rgba(255, 42, 42, 0.6);
    transform: scale(1);
  }
  50% {
    text-shadow:
      0 0 10px #ff2a2a,
      0 0 24px #ff2a2a,
      0 0 48px rgba(255, 42, 42, 0.85);
    transform: scale(1.06);
  }
}

/* ---------- main ---------- */
main {
  position: relative;
  z-index: 10;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 2rem;
  padding: 2rem;
  text-align: center;
}

/* ---------- the logotype (glitch) ---------- */
.logo {
  font-family: "Major Mono Display", "JetBrains Mono", monospace;
  font-weight: 400;
  font-size: clamp(6rem, 22vw, 18rem);
  line-height: 0.85;
  letter-spacing: -0.04em;
  color: var(--ink);
  text-shadow:
    0 0 18px rgba(255, 255, 255, 0.25),
    0 0 60px rgba(255, 0, 128, 0.45);
}
.glitch {
  position: relative;
  display: inline-block;
}
.glitch::before,
.glitch::after {
  content: attr(data-text);
  position: absolute;
  inset: 0;
  pointer-events: none;
}
.glitch::before {
  color: var(--magenta);
  transform: translate(2px, 0);
  mix-blend-mode: screen;
  animation: glitch-anim-1 3.4s infinite steps(20);
}
.glitch::after {
  color: var(--cyan);
  transform: translate(-2px, 0);
  mix-blend-mode: screen;
  animation: glitch-anim-2 4.1s infinite steps(20);
}
@keyframes glitch-anim-1 {
  0%, 86%, 100% { clip-path: inset(0 0 0 0); transform: translate(2px, 0); }
  87% { clip-path: inset(15% 0 70% 0); transform: translate(6px, -2px); }
  89% { clip-path: inset(60% 0 10% 0); transform: translate(-4px, 1px); }
  91% { clip-path: inset(30% 0 50% 0); transform: translate(8px, 0); }
  93% { clip-path: inset(80% 0 5% 0); transform: translate(-2px, -1px); }
}
@keyframes glitch-anim-2 {
  0%, 92%, 100% { clip-path: inset(0 0 0 0); transform: translate(-2px, 0); }
  93% { clip-path: inset(40% 0 40% 0); transform: translate(-6px, 2px); }
  95% { clip-path: inset(10% 0 75% 0); transform: translate(4px, -1px); }
  97% { clip-path: inset(70% 0 15% 0); transform: translate(-8px, 0); }
}

/* the m-m-m stutter */
.logo.stutter .glitch {
  animation: stutter 0.35s steps(3);
}
@keyframes stutter {
  0%   { transform: translateX(0); }
  20%  { transform: translateX(-8px); }
  40%  { transform: translateX(6px); }
  60%  { transform: translateX(-4px); }
  80%  { transform: translateX(2px); }
  100% { transform: translateX(0); }
}

/* ---------- tagline ---------- */
.tagline {
  font-size: clamp(0.85rem, 1.4vw, 1.1rem);
  letter-spacing: 0.4em;
  text-transform: uppercase;
  color: var(--magenta);
  text-shadow: 0 0 10px rgba(255, 0, 128, 0.7);
}
.tagline .dot {
  color: var(--yellow);
  text-shadow: 0 0 10px var(--yellow);
}

.subtagline {
  margin-top: -0.75rem;
  font-size: clamp(0.7rem, 0.9vw, 0.85rem);
  letter-spacing: 0.12em;
  font-style: italic;
  color: var(--ink-dim);
  max-width: 38em;
}

/* ---------- the terminal block / game ---------- */
.terminal {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: 0.4em;
  font-size: clamp(0.8rem, 1.05vw, 0.95rem);
  color: var(--ink);
  text-align: left;
  min-height: 18em;
  max-width: 40em;
  width: 100%;
}
#game-pane { display: flex; flex-direction: column; gap: 0.4em; }
#game-pane.hidden { display: none; }
#game-text {
  font-family: inherit;
  white-space: pre-wrap;
  word-break: break-word;
  margin: 0;
}
.caret {
  display: inline-block;
  width: 0.6em;
  color: var(--magenta);
  animation: blink 1.1s steps(2) infinite;
  text-shadow: 0 0 8px var(--magenta);
}
.caret.hidden { visibility: hidden; }

#game-choices {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 0.15em;
}
#game-choices li {
  cursor: pointer;
  padding: 0.35em 0.1em;
  color: var(--ink);
  transition: color 120ms ease, transform 120ms ease;
  outline: none;
  user-select: none;
}
#game-choices li .cnum {
  color: var(--magenta);
  text-shadow: 0 0 6px rgba(255, 0, 128, 0.55);
  margin-right: 0.4em;
}
#game-choices li:hover,
#game-choices li:focus {
  color: var(--cyan-soft);
  transform: translateX(2px);
}
#game-choices li:hover .cnum,
#game-choices li:focus .cnum {
  color: var(--yellow);
  text-shadow: 0 0 8px var(--yellow);
}
#game-choices li.flash {
  animation: choice-flash 280ms ease-out;
}
@keyframes choice-flash {
  0%   { color: var(--yellow); text-shadow: 0 0 12px var(--yellow); }
  100% { color: var(--ink); text-shadow: none; }
}

/* ---------- off-air "please stand by" card ---------- */
.offair-card {
  display: none;
  flex-direction: column;
  gap: 1.1em;
  text-align: left;
  padding: 0.5em 0;
}
.offair-card.visible { display: flex; }
.offair-card .standby {
  font-size: clamp(0.85rem, 1.1vw, 1rem);
  letter-spacing: 0.4em;
  color: var(--cyan);
  text-shadow: 0 0 8px rgba(0, 240, 255, 0.55);
  text-transform: uppercase;
  border: 1px solid var(--cyan);
  padding: 0.4em 0.6em;
  align-self: flex-start;
}
.offair-card .lede {
  color: var(--ink);
  line-height: 1.55;
}
.offair-card .lede em {
  color: var(--magenta-soft);
  font-style: normal;
  letter-spacing: 0.05em;
}
.offair-card .countdown {
  font-family: inherit;
  color: var(--ink);
}
.offair-card .countdown .label { color: var(--ink-dim); }
.offair-card .countdown .value {
  color: var(--magenta);
  text-shadow: 0 0 8px rgba(255, 0, 128, 0.6);
}
.offair-card .recs-header {
  color: var(--cyan);
  letter-spacing: 0.2em;
  font-size: 0.78em;
  text-transform: uppercase;
}
.offair-card .recs {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 0.3em;
}
.offair-card .recs li {
  display: grid;
  grid-template-columns: 4.5em 1fr;
  gap: 0.6em;
  align-items: baseline;
}
.offair-card .recs .rkind {
  color: var(--yellow);
  text-shadow: 0 0 6px rgba(255, 242, 0, 0.45);
  font-size: 0.78em;
  letter-spacing: 0.2em;
}
.offair-card .recs .rtitle { color: var(--ink); }
.offair-card .recs .rby { color: var(--ink-dim); }
.offair-card .crypt {
  color: var(--ink-dim);
  font-style: italic;
  letter-spacing: 0.04em;
}
.offair-card .refresh-hint {
  color: var(--ink-dim);
  font-size: 0.72em;
  letter-spacing: 0.15em;
  text-transform: uppercase;
}

/* ---------- footer ---------- */
footer {
  position: relative;
  z-index: 10;
  padding: 1.25rem 1.75rem;
  text-align: center;
  font-size: 0.72rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--ink-dim);
}
footer a {
  color: var(--cyan-soft);
  text-decoration: none;
  border-bottom: 1px dotted var(--cyan-soft);
}
footer a:hover { color: var(--magenta); border-color: var(--magenta); }

/* ---------- mobile ---------- */
@media (max-width: 600px) {
  .hud { font-size: 0.62rem; padding: 1rem; }
  main { gap: 1.5rem; padding: 1.5rem; }
  .terminal { font-size: 0.78rem; }
  footer { font-size: 0.62rem; }
}

@media (prefers-reduced-motion: reduce) {
  .glitch::before, .glitch::after,
  .floor-inner, .noise, .blink, .caret {
    animation: none !important;
  }
}
