/* =========================================================
   $GCA — GRAND CUP AUTO VI
   Premium GTA-VI cover-art aesthetic
   Pricedown + heavy black outline · chrome VI · sunset · palms
   ========================================================= */

:root {
  /* Background — Miami night, lifted toward warm violet so the page reads
     as deep-twilight rather than near-black. Previous --bg-0 was #08030f
     (almost pure black); we're shifting up into the same range the GTA VI
     keyart actually sits at — saturated violet with pink ambient. */
  --bg-0: #1a0a3a;
  --bg-1: #2a0f55;
  --bg-2: #3a1670;
  --bg-3: #4a1d8a;

  /* GTA VI hero palette (matched to the cover art) */
  --vc-pink:   #ff3aa3;   /* hot vice pink */
  --vc-pink-2: #ff7ac8;   /* soft pink */
  --vc-magenta:#c12fff;
  --vc-violet: #6a2bff;
  --vc-cyan:   #46e5e5;   /* the iconic VI chrome cyan */
  --vc-cyan-2: #b5f6f6;
  --vc-orange: #ff8a3a;
  --vc-coral:  #ff6b6b;
  --vc-peach:  #ffc7a0;
  --vc-yellow: #ffd23a;

  /* HUD holdovers */
  --gold: #f0c040;
  --alert: #ff2d55;
  --go:    #2bd76b;

  /* Ink */
  --ink-0: #fff5fb;
  --ink-1: #d8c6e0;
  --ink-2: #8c7aa3;
  --ink-3: #5a4870;

  --hair: rgba(255,245,251,0.08);
  --hair-strong: rgba(255,245,251,0.18);

  /* Master sunset — matches the GTA VI keyart (bright Miami sunset, not night) */
  --sky-cinema: linear-gradient(180deg,
      #7a4cc4 0%,
      #a85dc4 12%,
      #c46eb8 24%,
      #e188ad 36%,
      #f59ca0 50%,
      #ffb088 64%,
      #ffc78a 78%,
      #ffd9a0 92%,
      #ffe8b8 100%);

  --gradient-hero: linear-gradient(90deg, var(--vc-cyan) 0%, #ffffff 35%, var(--vc-pink) 70%, var(--vc-pink) 100%);
  --gradient-chrome: linear-gradient(180deg,
      var(--vc-cyan) 0%,
      var(--vc-cyan) 28%,
      #ffffff 46%,
      var(--vc-pink-2) 60%,
      var(--vc-pink) 100%);

  --grain-opacity: 0.07;

  /* Hero title stroke — used by .gta-stroke */
  --stroke-w: 6px;
}

/* ----------- reset / base ----------- */
* { box-sizing: border-box; margin: 0; padding: 0; }
html {
  min-height: 100%;
  overflow-x: hidden;
}
body {
  min-height: 100dvh;
  background: var(--bg-0);
  color: var(--ink-0);
  font-family: 'Inter', system-ui, sans-serif;
  font-weight: 500;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
}
a { color: inherit; text-decoration: none; }
button { font: inherit; color: inherit; background: none; border: none; cursor: pointer; }
img, svg { display: block; max-width: 100%; }

::selection { background: var(--vc-pink); color: #08030f; }

/* film grain */
body::after {
  content: "";
  position: fixed; inset: 0;
  pointer-events: none;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='180' height='180'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.92' 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.35 0'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>");
  opacity: var(--grain-opacity);
  z-index: 9999;
  mix-blend-mode: overlay;
}

/* ----------- typography utility ----------- */
.display {
  font-family: 'Pricedown Bl', 'Pricedown', 'Bowlby One SC', 'Anton', Impact, sans-serif;
  letter-spacing: 0.005em;
  line-height: 0.88;
  text-transform: lowercase;
}
.gta-stroke {
  /* White fill, heavy black stroke painted behind the fill — the GTA hallmark */
  color: #ffffff;
  -webkit-text-stroke: var(--stroke-w) #0a0014;
          text-stroke: var(--stroke-w) #0a0014;
  paint-order: stroke fill;
  text-shadow:
    0 6px 0 rgba(0,0,0,0.45),
    0 18px 32px rgba(0,0,0,0.55);
}
.mono { font-family: 'JetBrains Mono', 'Courier New', monospace; font-weight: 500; letter-spacing: 0.01em; }
.label {
  font-family: 'Inter', sans-serif;
  font-weight: 700; font-size: 11px;
  letter-spacing: 0.28em; text-transform: uppercase;
  color: var(--ink-2);
}

/* =========================================================
   LOADING SCREEN — GTA-meme boot sequence
   ========================================================= */
.loader {
  position: fixed; inset: 0;
  z-index: 1000;
  display: grid; grid-template-rows: auto 1fr auto;
  background: #050010;
  overflow: hidden;
  transition: opacity 0.5s ease, visibility 0.5s ease;
}
.loader.exiting { opacity: 0; visibility: hidden; }
.loader.flash::after {
  content: ""; position: absolute; inset: 0; background: #fff;
  animation: flash 0.4s ease-out forwards;
  z-index: 50;
}
@keyframes flash { 0% { opacity: 0 } 18% { opacity: 1 } 100% { opacity: 0 } }
@keyframes pulse { 0%,100% { opacity: 1; transform: scale(1) } 50% { opacity: 0.4; transform: scale(0.7) } }
.loader.siren { animation: loaderSiren 0.6s steps(2) 6; }
@keyframes loaderSiren {
  0%, 100% { box-shadow: inset 0 0 0 0 transparent; }
  50% { box-shadow: inset 0 0 120px rgba(255, 45, 85, 0.55); }
}

/* MP4 background — heat surge */
.loader-video {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  object-fit: cover;
  z-index: 0;
  opacity: 0.55;
  filter: saturate(1.15) contrast(1.05) brightness(0.7) hue-rotate(-8deg);
  mix-blend-mode: screen;
}

.loader-scene {
  position: absolute; inset: 0; z-index: 1;
  background-color: #1a0a3a;
  background-image:
    radial-gradient(ellipse 80% 50% at 50% 65%, rgba(8,3,15,0.35), rgba(8,3,15,0.85) 75%),
    url('assets/loading-frame.jpg');
  background-size: auto, cover;
  background-position: center, center;
}
.loader-scene::before {
  content: ""; position: absolute; left: 0; right: 0; bottom: 0; height: 70%;
  background:
    radial-gradient(ellipse 60% 35% at 50% 70%, rgba(255,184,120,0.55), transparent 60%),
    linear-gradient(180deg, transparent 0%, rgba(0,0,0,0.55) 100%);
}
.loader-scene::after {
  content: ""; position: absolute; inset: 0;
  background:
    repeating-linear-gradient(180deg, rgba(255,255,255,0.025) 0 2px, transparent 2px 4px),
    radial-gradient(ellipse 80% 60% at 50% 50%, transparent 30%, rgba(0,0,0,0.5));
  mix-blend-mode: overlay; opacity: 0.7;
}

/* Diagonal hazard stripes top + bottom — like police tape */
.loader-stripe {
  position: absolute; left: 0; right: 0;
  height: 36px;
  z-index: 12;
  background:
    repeating-linear-gradient(90deg,
      #ffd23a 0 28px,
      #0a0014 28px 32px,
      #ff3aa3 32px 60px,
      #0a0014 60px 64px);
  overflow: hidden;
  display: flex; align-items: center;
  box-shadow: 0 0 20px rgba(255,210,58,0.45);
}
.loader-stripe.top { top: 0; border-bottom: 2px solid #0a0014; }
.loader-stripe.bot { bottom: 0; border-top: 2px solid #0a0014; }
.loader-stripe-track {
  display: inline-flex; gap: 22px; white-space: nowrap;
  font-family: 'Pricedown Bl','Pricedown','Bowlby One SC',sans-serif;
  font-size: 18px; letter-spacing: 0.04em;
  color: #0a0014; text-transform: lowercase;
  animation: loaderStripeMove 45s linear infinite;
  padding-left: 22px;
  -webkit-text-stroke: 0.5px rgba(255,255,255,0.4);
}
.loader-stripe-track.rev { animation-direction: reverse; }
.loader-stripe-track > span { padding: 0 12px; }
@keyframes loaderStripeMove {
  from { transform: translateX(0); }
  to { transform: translateX(-50%); }
}

/* Character posse — peek in from edges */
.loader-posse {
  position: absolute; inset: 0; z-index: 4;
  pointer-events: none;
}
.loader-char {
  position: absolute;
  height: 58vh;
  max-height: 720px;
  width: auto;
  opacity: 0;
  transform: translateY(80px) scale(0.92) rotate(var(--r, 0deg));
  filter:
    drop-shadow(0 0 28px rgba(255,58,163,0.4))
    drop-shadow(0 22px 36px rgba(0,0,0,0.7));
  animation: loaderCharIn 0.9s cubic-bezier(0.16,1,0.3,1) var(--d, 0s) forwards,
             loaderCharFloat 6s ease-in-out calc(1s + var(--d, 0s)) infinite;
}
.loader-char-ll { left: -3vw;  bottom: 38px; height: 62vh; }
.loader-char-l  { left: 14vw;  bottom: 38px; height: 50vh; opacity: 0.92; z-index: -1; }
.loader-char-r  { right: 14vw; bottom: 38px; height: 52vh; opacity: 0.95; z-index: -1; }
.loader-char-rr { right: -2vw; bottom: 38px; height: 64vh; }
@keyframes loaderCharIn {
  from { opacity: 0; transform: translateY(80px) scale(0.92) rotate(var(--r, 0deg)); filter: drop-shadow(0 22px 36px rgba(0,0,0,0.7)) blur(8px); }
  to   { opacity: 1; transform: translateY(0)    scale(1)    rotate(var(--r, 0deg)); filter: drop-shadow(0 0 28px rgba(255,58,163,0.4)) drop-shadow(0 22px 36px rgba(0,0,0,0.7)) blur(0); }
}
@keyframes loaderCharFloat {
  0%,100% { transform: translateY(0) scale(1) rotate(var(--r, 0deg)); }
  50%     { transform: translateY(-12px) scale(1.005) rotate(calc(var(--r, 0deg) + 0.4deg)); }
}

/* GTA stencil stamps — chunky angled labels */
.loader-stamp {
  position: absolute;
  z-index: 8;
  font-family: 'Pricedown Bl','Pricedown','Bowlby One SC',sans-serif;
  text-transform: lowercase;
  letter-spacing: 0.04em;
  transform: rotate(var(--rot, 0deg));
  opacity: 0;
  animation: loaderStampIn 0.6s cubic-bezier(0.34, 1.56, 0.64, 1) var(--d, 0.4s) forwards;
  pointer-events: none;
  white-space: nowrap;
}
@keyframes loaderStampIn {
  from { opacity: 0; transform: rotate(var(--rot, 0deg)) scale(2.2); }
  to   { opacity: 1; transform: rotate(var(--rot, 0deg)) scale(1); }
}
.stamp-wanted {
  font-size: clamp(48px, 6vw, 96px);
  color: #ff3aa3;
  -webkit-text-stroke: 4px #0a0014; paint-order: stroke fill;
  text-shadow: 0 6px 0 #0a0014, 0 14px 30px rgba(0,0,0,0.55);
}
.stamp-heat {
  font-size: clamp(20px, 1.6vw, 28px);
  color: #ffd23a;
  padding: 10px 18px;
  border: 3px solid #0a0014;
  background: #ffd23a;
  color: #0a0014;
  box-shadow: 4px 4px 0 #0a0014, 0 0 24px rgba(255,210,58,0.5);
}
.stamp-class {
  font-size: clamp(18px, 1.4vw, 24px);
  color: #46e5e5;
  padding: 8px 16px;
  border: 2px solid #46e5e5;
  background: rgba(8,3,15,0.85);
  box-shadow: 3px 3px 0 rgba(70,229,229,0.4);
  letter-spacing: 0.14em;
}
.stamp-norules {
  font-size: clamp(28px, 3vw, 48px);
  color: #fff;
  -webkit-text-stroke: 3px #ff3aa3; paint-order: stroke fill;
  text-shadow: 4px 4px 0 #0a0014;
}

/* Top chrome */
.loader-top {
  position: relative; z-index: 14;
  display: flex; align-items: center; justify-content: space-between;
  padding: 50px 36px 14px;
}
.loader-badge {
  display: inline-flex; align-items: center; gap: 10px;
  padding: 9px 14px;
  background: rgba(0,0,0,0.65);
  border: 1px solid rgba(255,255,255,0.25);
  backdrop-filter: blur(8px);
}
.loader-badge .txt {
  font-size: 11px; letter-spacing: 0.24em; text-transform: uppercase;
  color: #fff; font-weight: 600;
}
.loader-meta {
  font-size: 11px; letter-spacing: 0.22em; text-transform: uppercase;
  color: rgba(255,255,255,0.9);
  display: flex; gap: 16px; font-weight: 700;
}
.loader-meta-now {
  display: inline-flex; align-items: center; gap: 8px;
  color: var(--alert);
}
.loader-meta-now .d {
  width: 8px; height: 8px; border-radius: 50%;
  background: var(--alert);
  box-shadow: 0 0 10px var(--alert);
  animation: pulse 1.1s infinite;
}

/* Center */
.loader-center {
  position: relative; z-index: 10;
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  text-align: center;
  padding: 0 24px;
  gap: 14px;
}
.loader-eyebrow {
  font-size: 12px; letter-spacing: 0.5em;
  color: #fff;
  font-weight: 600;
  text-shadow: 0 2px 8px rgba(0,0,0,0.6);
  padding: 6px 14px;
  border-top: 1px solid rgba(255,255,255,0.25);
  border-bottom: 1px solid rgba(255,255,255,0.25);
}
.loader-title-wrap { position: relative; }
.loader-title, .loader-title-shadow {
  font-family: 'Pricedown Bl','Pricedown','Bowlby One SC','Anton',Impact,sans-serif;
  font-size: clamp(74px, 10.5vw, 178px);
  line-height: 0.86;
  text-transform: lowercase;
  letter-spacing: 0.005em;
}
.loader-title {
  position: relative;
  color: #fff;
  -webkit-text-stroke: 10px #0a0014; paint-order: stroke fill;
  text-shadow:
    0 8px 0 rgba(0,0,0,0.45),
    0 28px 60px rgba(0,0,0,0.7);
  animation: loaderTitleGlow 4s ease-in-out infinite;
}
@keyframes loaderTitleGlow {
  0%,100% { filter: drop-shadow(0 0 0 transparent); }
  50%     { filter: drop-shadow(0 0 22px rgba(255,58,163,0.45)) drop-shadow(0 0 38px rgba(70,229,229,0.25)); }
}
.loader-title-shadow {
  position: absolute; inset: 0;
  color: transparent;
  -webkit-text-stroke: 10px #ff3aa3; paint-order: stroke fill;
  opacity: 0.55;
  transform: translate(6px, 6px);
  filter: blur(0.5px);
  z-index: -1;
}

.loader-subtitle {
  display: inline-flex; align-items: baseline; gap: 14px;
  font-size: clamp(20px, 2.2vw, 36px);
  font-weight: 800;
  letter-spacing: 0.3em;
  color: #fff;
  text-shadow: 0 4px 14px rgba(0,0,0,0.6);
  text-transform: uppercase;
}
.loader-subtitle .loader-ss { color: #fff; }
.loader-subtitle .vi {
  font-family: 'Bowlby One SC','Anton',Impact,sans-serif;
  font-size: clamp(88px, 12vw, 190px);
  line-height: 0.86;
  font-style: italic;
  letter-spacing: -0.04em;
  padding: 0.02em 0.18em 0.04em;
  color: transparent;
  background:
    repeating-linear-gradient(180deg, rgba(0,0,0,0.42) 0 3px, transparent 3px 10px),
    linear-gradient(180deg, var(--vc-cyan) 0%, #fff 45%, var(--vc-pink) 100%);
  background-clip: text;
  -webkit-background-clip: text;
  -webkit-text-stroke: 5px #0a0014; paint-order: stroke fill;
  transform: skewX(-8deg) translateY(2px);
}

/* Quick facts strip */
.loader-facts {
  margin-top: 16px;
  display: inline-flex; gap: 0;
  background: rgba(0,0,0,0.65);
  border: 1px solid rgba(255,255,255,0.18);
  backdrop-filter: blur(6px);
  padding: 4px;
}
.loader-facts .lf {
  display: flex; flex-direction: column;
  align-items: center;
  padding: 10px 18px;
  border-right: 1px solid rgba(255,255,255,0.08);
  min-width: 76px;
}
.loader-facts .lf:last-child { border-right: 0; }
.loader-facts .lf .k {
  font-size: 9px; letter-spacing: 0.26em;
  color: var(--ink-2); text-transform: uppercase; font-weight: 700;
}
.loader-facts .lf .v {
  font-family: 'Pricedown Bl','Pricedown',sans-serif;
  font-size: 22px; color: var(--vc-cyan);
  text-transform: lowercase;
  -webkit-text-stroke: 1px #0a0014; paint-order: stroke fill;
  margin-top: 2px;
}

.loader-tag {
  font-size: 13px; letter-spacing: 0.22em;
  color: #fff;
  text-transform: uppercase; font-weight: 600;
  display: inline-flex; align-items: center; gap: 12px;
  padding: 8px 16px;
  background: rgba(0,0,0,0.55);
  border: 1px solid rgba(255,58,163,0.45);
  min-width: 360px; justify-content: center;
}
.loader-tag .dot {
  width: 9px; height: 9px; border-radius: 50%;
  background: var(--vc-pink);
  box-shadow: 0 0 16px var(--vc-pink);
  animation: pulse 1.2s infinite;
  flex: none;
}

/* Bottom — progress + skip */
.loader-bottom { position: relative; z-index: 14; padding: 18px 36px 60px; }
.loader-progress-row {
  display: flex; align-items: flex-end; justify-content: space-between;
  margin-bottom: 10px;
}
.loader-progress-label {
  font-family: 'Pricedown Bl','Pricedown',sans-serif;
  font-size: 24px; letter-spacing: 0.04em;
  color: #fff; text-transform: lowercase;
  -webkit-text-stroke: 1.5px #0a0014; paint-order: stroke fill;
}
.loader-progress-pct {
  font-family: 'Pricedown Bl','Pricedown',sans-serif;
  font-size: 44px;
  color: var(--vc-cyan);
  letter-spacing: -0.01em;
  -webkit-text-stroke: 2px #0a0014; paint-order: stroke fill;
  text-transform: lowercase;
  line-height: 0.9;
}
.loader-progress-pct i { font-style: normal; font-size: 0.6em; color: var(--ink-2); margin-left: 4px; }

.loader-bar {
  position: relative;
  height: 14px; width: 100%;
  background: rgba(0,0,0,0.55);
  border: 2px solid #0a0014;
  outline: 1px solid rgba(255,255,255,0.12);
  outline-offset: 1px;
  overflow: hidden;
}
.loader-bar-fill {
  height: 100%; position: relative;
  background:
    repeating-linear-gradient(45deg, rgba(255,255,255,0.18) 0 6px, transparent 6px 12px),
    linear-gradient(90deg, var(--vc-cyan), #ffffff 50%, var(--vc-pink) 100%);
  box-shadow: 0 0 22px rgba(255,255,255,0.6);
  transition: width 60ms linear;
}
.loader-bar-head {
  position: absolute; right: 0; top: -2px; bottom: -2px; width: 4px;
  background: #fff;
  box-shadow: 0 0 14px #fff, 0 0 28px var(--vc-pink);
}
.loader-bar-tick {
  position: absolute; top: -3px; bottom: -3px; width: 2px;
  background: rgba(255,255,255,0.25);
}
.loader-bar-tick.on { background: var(--gold); box-shadow: 0 0 8px var(--gold); }

.loader-bottom-row {
  margin-top: 14px;
  display: flex; align-items: center; justify-content: space-between;
}
.loader-skip {
  font-size: 10px; letter-spacing: 0.32em;
  color: rgba(255,255,255,0.7);
  text-transform: uppercase; font-weight: 600;
  animation: blink 1.6s infinite;
}
.loader-pump {
  display: inline-flex; align-items: center; gap: 8px;
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px; letter-spacing: 0.2em;
  color: var(--ink-1); text-transform: uppercase;
}
.loader-pump .d {
  width: 8px; height: 8px; border-radius: 50%;
  background: var(--go);
  box-shadow: 0 0 10px var(--go);
  animation: pulse 1.4s infinite;
}
.loader-pump .t { color: var(--gold); font-weight: 700; }
@keyframes blink { 0%,100% { opacity: 1 } 50% { opacity: 0.35 } }

@media (max-width: 760px) {
  .loader-char-l, .loader-char-r { display: none; }
  .loader-char-ll { height: 48vh; left: -8vw; opacity: 0.6; }
  .loader-char-rr { height: 50vh; right: -8vw; opacity: 0.65; }
  .loader-stamp { font-size: 28px !important; padding: 4px 10px; }
  .stamp-wanted { font-size: 44px !important; }
  .loader-facts { flex-wrap: wrap; }
  .loader-top { padding-top: 56px; }
  .loader-stripe { height: 28px; }
  .loader-stripe-track { font-size: 14px; }
}

/* =========================================================
   MISSION BRIEF
   ========================================================= */
.brief-scrim {
  position: fixed; inset: 0;
  background: rgba(8,3,15,0.6);
  backdrop-filter: blur(10px);
  z-index: 900;
  opacity: 0; pointer-events: none;
  transition: opacity 0.3s ease;
}
.brief-scrim.open { opacity: 1; pointer-events: auto; }

.brief {
  position: fixed;
  top: 50%; right: 36px;
  transform: translate(120%, -50%);
  width: 560px; max-width: calc(100vw - 24px);
  background: var(--bg-1);
  border: 1px solid rgba(255,255,255,0.16);
  z-index: 950;
  transition: transform 0.45s cubic-bezier(0.16, 1, 0.3, 1);
  box-shadow:
    0 30px 80px -20px rgba(0,0,0,0.8),
    0 0 0 1px rgba(255,58,163,0.35),
    0 0 60px rgba(255,58,163,0.25);
}
.brief.open { transform: translate(0, -50%); }
.brief-top {
  display: flex; align-items: center; justify-content: space-between;
  padding: 12px 16px;
  background: linear-gradient(90deg, var(--vc-cyan), #ffffff 45%, var(--vc-pink));
  color: #08030f;
  font-family: 'Pricedown Bl', 'Pricedown', 'Bowlby One SC', sans-serif;
  text-transform: lowercase;
  letter-spacing: 0.02em;
  font-size: 26px;
}
.brief-top .crosshair { width: 22px; height: 22px; }
.brief-body {
  padding: 22px 24px 24px;
  max-height: calc(100vh - 120px);
  overflow-y: auto;
}
.brief-title {
  font-family: 'Inter', sans-serif;
  font-weight: 800;
  font-size: 22px; line-height: 1.15;
  letter-spacing: 0;
  margin-bottom: 8px;
}
.brief-sub { color: var(--ink-2); font-size: 13px; line-height: 1.55; margin-bottom: 18px; }
.brief-divider { height: 1px; background: var(--hair-strong); margin: 14px 0; }
.brief-objs { display: flex; flex-direction: column; gap: 10px; margin-bottom: 18px; }
.brief-obj {
  display: flex; align-items: flex-start; gap: 12px;
  font-size: 14px; color: var(--ink-1);
  line-height: 1.35;
}
.brief-obj .checkbox {
  width: 16px; height: 16px; flex: none;
  border: 1.5px solid var(--ink-2);
  background: transparent;
  position: relative;
  margin-top: 2px;
}
.brief-obj.done .checkbox { background: var(--go); border-color: var(--go); }
.brief-obj.done .checkbox::after {
  content: "✓"; position: absolute; inset: 0;
  display: flex; align-items: center; justify-content: center;
  font-size: 12px; color: #08030f; font-weight: 800;
}
.brief-obj.done {
  color: var(--ink-2);
  text-decoration: line-through;
  text-decoration-color: rgba(255,255,255,0.3);
}

.brief-flow {
  display: grid;
  gap: 10px;
  margin-bottom: 16px;
}
.flow-node,
.flow-require {
  position: relative;
  padding: 12px 14px;
  border: 1px solid rgba(255,255,255,0.14);
  background:
    linear-gradient(135deg, rgba(255,255,255,0.055), rgba(255,255,255,0.018)),
    rgba(0,0,0,0.24);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.08);
}
.flow-main {
  text-align: center;
  border-color: rgba(70,229,229,0.45);
  background:
    linear-gradient(90deg, rgba(70,229,229,0.18), rgba(255,58,163,0.12)),
    rgba(0,0,0,0.26);
}
.flow-node span,
.flow-require span {
  display: block;
  color: var(--ink-2);
  font-size: 11px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}
.flow-node b,
.flow-require b {
  display: block;
  margin-top: 4px;
  color: #fff;
  font-family: 'JetBrains Mono', monospace;
  font-size: 13px;
  letter-spacing: 0.04em;
}
.flow-line {
  width: 2px;
  height: 18px;
  margin: -2px auto;
  background: linear-gradient(180deg, var(--vc-cyan), var(--vc-pink));
  box-shadow: 0 0 14px rgba(70,229,229,0.45);
}
.flow-fees {
  width: fit-content;
  margin: 0 auto;
  color: var(--vc-cyan);
  font-family: 'Pricedown Bl', 'Pricedown', 'Bowlby One SC', sans-serif;
  font-size: 22px;
  text-transform: lowercase;
}
.flow-split {
  position: relative;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
  padding-top: 18px;
}
.flow-split::before {
  content: "";
  position: absolute;
  left: 25%;
  right: 25%;
  top: 0;
  height: 18px;
  border-top: 1px solid rgba(255,255,255,0.22);
  border-left: 1px solid rgba(255,255,255,0.22);
  border-right: 1px solid rgba(255,255,255,0.22);
}
.flow-branch {
  display: grid;
  gap: 8px;
}
.flow-branch .pct {
  justify-self: center;
  padding: 3px 10px;
  color: #08030f;
  background: linear-gradient(90deg, var(--vc-cyan), var(--vc-pink));
  font-family: 'JetBrains Mono', monospace;
  font-size: 12px;
  font-weight: 900;
  letter-spacing: 0.08em;
}
.flow-node.burn {
  border-color: rgba(255,58,163,0.45);
}
.flow-node.bounty {
  border-color: rgba(255,210,58,0.46);
}
.flow-require {
  text-align: center;
  border-color: rgba(70,229,229,0.38);
  background:
    radial-gradient(circle at 50% 0%, rgba(70,229,229,0.14), transparent 58%),
    rgba(0,0,0,0.32);
}
.flow-require em {
  display: inline-block;
  margin-top: 8px;
  color: var(--vc-pink);
  font-family: 'Pricedown Bl', 'Pricedown', 'Bowlby One SC', sans-serif;
  font-size: 24px;
  font-style: normal;
  text-transform: lowercase;
}

.brief-stats {
  display: grid; grid-template-columns: repeat(3, 1fr);
  gap: 8px; margin-bottom: 18px;
  padding: 12px 14px;
  background: rgba(0,0,0,0.45);
  border: 1px solid var(--hair);
}
.brief-stats .cell { display: flex; flex-direction: column; gap: 4px; }
.brief-stats .k { font-size: 9px; letter-spacing: 0.22em; color: var(--ink-2); text-transform: uppercase; font-weight: 700; }
.brief-stats .v { font-family: 'JetBrains Mono', monospace; color: var(--vc-cyan); font-size: 14px; font-weight: 600; }

/* =========================================================
   App ready state
   ========================================================= */
.app { opacity: 0; pointer-events: none; transition: opacity 0.6s ease 0.2s; }
.app.ready { opacity: 1; pointer-events: auto; }

/* =========================================================
   HUD top bar — premium glass strip
   ========================================================= */
.hud {
  position: sticky; top: 0; z-index: 100;
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 24px;
  padding: 14px 28px;
  background: linear-gradient(180deg, rgba(8,3,15,0.95) 0%, rgba(8,3,15,0.7) 100%);
  border-bottom: 1px solid var(--hair);
  backdrop-filter: blur(14px);
}
.hud-brand {
  display: flex; align-items: center; gap: 10px;
}
.hud-brand .mark {
  width: 76px; height: 54px;
  display: block;
  object-fit: contain;
  filter: drop-shadow(0 4px 12px rgba(255,58,163,0.42));
}
.hud-brand .word {
  display: flex; flex-direction: column; line-height: 1;
}
.hud-brand .word .t {
  font-family: 'Pricedown Bl', 'Pricedown', 'Bowlby One SC', sans-serif;
  font-size: 24px;
  letter-spacing: 0.02em;
  color: #fff;
  -webkit-text-stroke: 1.5px #0a0014;
  paint-order: stroke fill;
  text-transform: lowercase;
}
.hud-brand .word .s {
  font-size: 9px; letter-spacing: 0.32em;
  color: var(--ink-2); font-weight: 700;
  margin-top: 3px;
}

.hud-center {
  display: flex; align-items: center; justify-content: center;
  gap: 28px;
}
.hud-stat { display: flex; flex-direction: column; gap: 0; line-height: 1; }
.hud-stat .num {
  font-family: 'JetBrains Mono', monospace;
  font-weight: 600;
  font-size: 18px;
  color: var(--vc-cyan);
  letter-spacing: -0.01em;
  text-shadow: 0 0 12px rgba(70,229,229,0.35);
}
.hud-stat .num.pink { color: var(--vc-pink); text-shadow: 0 0 12px rgba(255,58,163,0.45); }
.hud-stat .num.gold { color: var(--gold); text-shadow: 0 0 12px rgba(240,192,64,0.45); }
.hud-stat .lbl { margin-top: 4px; font-size: 9px; letter-spacing: 0.28em; color: var(--ink-2); text-transform: uppercase; font-weight: 700; }
.hud-stat .delta { font-size: 12px; margin-left: 6px; font-family: 'JetBrains Mono', monospace; }
.hud-stat .delta.up { color: var(--go); }
.hud-stat .delta.dn { color: var(--alert); }
.hud-divider { width: 1px; height: 30px; background: var(--hair-strong); }

.hud-right { display: flex; align-items: center; gap: 12px; }
.hud-stars { display: flex; align-items: center; gap: 6px; }
.hud-placeholder-heat {
  min-width: 92px;
  text-align: right;
}
.stars { display: flex; gap: 2px; }
.star { width: 22px; height: 22px; color: var(--gold); filter: drop-shadow(0 0 4px rgba(240,192,64,0.5)); }
.star.off { color: rgba(240,192,64,0.16); filter: none; }
.star.pulse { animation: starpulse 1.2s ease-in-out infinite; }
@keyframes starpulse {
  0%,100% { transform: scale(1); filter: drop-shadow(0 0 4px rgba(240,192,64,0.5)); }
  50%     { transform: scale(1.12); filter: drop-shadow(0 0 12px rgba(255,193,58,0.95)); }
}

.btn-wanted-cta {
  display: inline-flex; align-items: center; gap: 10px;
  padding: 12px 20px;
  background: linear-gradient(90deg, var(--vc-cyan), #ffffff 50%, var(--vc-pink));
  color: #08030f;
  font-family: 'Pricedown Bl', 'Pricedown', 'Bowlby One SC', sans-serif;
  font-size: 18px; letter-spacing: 0.04em;
  text-transform: lowercase;
  position: relative;
  transition: filter 0.15s ease, transform 0.15s ease;
}
.btn-wanted-cta:hover { transform: translateY(-1px); filter: brightness(1.08); }
.btn-wanted-cta::before {
  content: ""; position: absolute; inset: -2px;
  border: 1px solid rgba(255,58,163,0.4);
  pointer-events: none;
}

/* =========================================================
   Buttons / Cards
   ========================================================= */
.btn-sunset {
  display: inline-flex; align-items: center; justify-content: center; gap: 10px;
  padding: 14px 24px;
  background: linear-gradient(90deg, var(--vc-cyan), #ffffff 45%, var(--vc-pink));
  color: #08030f;
  font-family: 'Pricedown Bl', 'Pricedown', 'Bowlby One SC', sans-serif;
  font-size: 24px; letter-spacing: 0.04em;
  text-transform: lowercase;
  border: none; position: relative; overflow: hidden;
  transition: filter 0.15s ease, transform 0.15s ease;
}
.btn-sunset:hover { filter: brightness(1.08); transform: translateY(-1px); }
.btn-sunset.lg { padding: 18px 32px; font-size: 30px; }
.btn-sunset::after {
  content: ""; position: absolute; left: -120%; top: 0; bottom: 0; width: 60%;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,0.5), transparent);
  transform: skewX(-20deg);
  animation: sheen 4s ease-in-out infinite;
}
@keyframes sheen { 0%, 60% { left: -120% } 80% { left: 120% } 100% { left: 120% } }

.btn-ghost {
  display: inline-flex; align-items: center; justify-content: center; gap: 8px;
  padding: 12px 20px;
  background: rgba(0,0,0,0.35);
  border: 1px solid var(--hair-strong);
  color: var(--ink-0);
  font-family: 'Pricedown Bl', 'Pricedown', 'Bowlby One SC', sans-serif;
  font-size: 20px; letter-spacing: 0.04em; text-transform: lowercase;
  backdrop-filter: blur(6px);
  transition: all 0.15s ease;
}
.btn-ghost:hover { border-color: var(--vc-pink); color: var(--vc-pink); }

.card {
  background: var(--bg-1);
  border: 1px solid var(--hair);
  position: relative;
}
.card-pink-edge {
  border-color: rgba(255,58,163,0.45);
  box-shadow: 0 0 0 1px rgba(255,58,163,0.12), 0 20px 50px -20px rgba(0,0,0,0.7);
}
.card-cyan-edge {
  border-color: rgba(70,229,229,0.4);
  box-shadow: 0 0 0 1px rgba(70,229,229,0.1), 0 20px 50px -20px rgba(0,0,0,0.7);
}

/* =========================================================
   HERO — cinematic cover scene
   ========================================================= */
.hero {
  position: relative;
  min-height: calc(100vh - 64px);
  overflow: hidden;
  isolation: isolate;
}

/* SCENE — Real cover-art photo background */
.hero-scene {
  position: absolute; inset: 0;
  background-color: #0f0726;
  background-image: url('assets/hero-desktop.jpg');
  background-size: cover;
  background-position: center center;
}
.hero-scene::before {
  /* subtle warm glow boost */
  content: "";
  position: absolute; left: 0; right: 0; bottom: 0; top: 0;
  background:
    radial-gradient(ellipse 80% 40% at 50% 80%, rgba(255, 100, 60, 0.18), transparent 60%);
  pointer-events: none;
}
.hero-scene::after {
  /* readability gradient — darker around the title area for text legibility */
  content: "";
  position: absolute; inset: 0;
  background:
    radial-gradient(ellipse 70% 55% at 50% 45%, rgba(8,3,15,0.55), transparent 70%),
    linear-gradient(180deg, rgba(8,3,15,0.25) 0%, transparent 22%, transparent 76%, rgba(8,3,15,0.65) 100%);
  pointer-events: none;
}

@media (max-width: 760px) {
  .hero-scene { background-image: url('assets/hero-mobile.jpg'); }
}

/* Stars/dust */
.hero-stars {
  position: absolute; top: 0; left: 0; right: 0; height: 35%;
  background-image:
    radial-gradient(1px 1px at 12% 18%, #fff 100%, transparent),
    radial-gradient(1px 1px at 25% 36%, #fff 100%, transparent),
    radial-gradient(1.5px 1.5px at 36% 12%, rgba(255,255,255,0.8) 100%, transparent),
    radial-gradient(1px 1px at 58% 24%, #fff 100%, transparent),
    radial-gradient(1px 1px at 72% 8%, rgba(255,255,255,0.6) 100%, transparent),
    radial-gradient(1px 1px at 86% 22%, #fff 100%, transparent),
    radial-gradient(2px 2px at 92% 5%, rgba(255,255,255,0.7) 100%, transparent);
  opacity: 0.7;
  pointer-events: none;
}

/* The SVG scene now sits as a TOP layer that ALPHA-OVERLAYS onto the photo,
   blended in for extra dimensionality. We hide it by default and only use it
   as a fallback if the image doesn't load. */
.hero-art { display: none; }

/* Cinema bars (top/bottom) — thin, premium */
.hero-bars { position: absolute; left: 0; right: 0; pointer-events: none; z-index: 8; height: 24px; background: #000; }
.hero-bars.top { top: 0; }
.hero-bars.bot { bottom: 0; }

/* HUD-style ticker bar that floats over the bottom of the hero */
.hero-ticker {
  position: absolute;
  left: 0; right: 0; bottom: 24px;
  z-index: 7;
  padding: 10px 28px;
  background: linear-gradient(180deg, transparent, rgba(0,0,0,0.7));
  display: flex; gap: 22px; align-items: center;
  font-size: 11px; letter-spacing: 0.22em;
  color: #fff;
  text-transform: uppercase; font-weight: 600;
  pointer-events: none;
  overflow: hidden;
  text-shadow: 0 1px 4px rgba(0,0,0,0.6);
}
.hero-ticker .pip { display: inline-flex; align-items: center; gap: 8px; white-space: nowrap; }
.hero-ticker .pip .d {
  width: 7px; height: 7px; border-radius: 50%; background: var(--vc-pink);
  box-shadow: 0 0 10px var(--vc-pink);
}
.hero-ticker .pip.cyan .d { background: var(--vc-cyan); box-shadow: 0 0 10px var(--vc-cyan); }
.hero-ticker .pip.gold .d { background: var(--gold); box-shadow: 0 0 10px var(--gold); }
.hero-ticker-track {
  display: inline-flex; gap: 22px; align-items: center;
  animation: tickerMove 60s linear infinite;
  padding-right: 22px;
}
@keyframes tickerMove {
  0%   { transform: translateX(0); }
  100% { transform: translateX(-50%); }
}

.hero-content {
  position: relative; z-index: 5;
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  text-align: center;
  padding: 100px 32px 280px;
  min-height: calc(100vh - 64px);
  gap: 16px;
}

/* Pill eyebrow at top of hero */
.hero-eyebrow {
  display: inline-flex; align-items: center; gap: 14px;
  font-size: 11px; letter-spacing: 0.4em;
  color: #fff;
  text-transform: uppercase; font-weight: 600;
  padding: 9px 18px;
  border: 1px solid rgba(255,255,255,0.3);
  background: rgba(0,0,0,0.45);
  backdrop-filter: blur(8px);
}
.hero-eyebrow .dot {
  width: 8px; height: 8px; border-radius: 50%;
  background: var(--vc-pink); box-shadow: 0 0 12px var(--vc-pink);
  animation: pulse 1.2s infinite;
}

/* THE HERO LOGO — Grand Cup Auto VI cover */
.hero-logo {
  display: flex; flex-direction: column; align-items: center; gap: 0;
  position: relative;
}
.hero-line {
  font-family: 'Pricedown Bl', 'Pricedown', 'Bowlby One SC', 'Anton', Impact, sans-serif;
  font-size: clamp(86px, 13vw, 240px);
  line-height: 0.86;
  text-transform: lowercase;
  color: #fff;
  -webkit-text-stroke: 10px #0a0014;
          text-stroke: 10px #0a0014;
  paint-order: stroke fill;
  letter-spacing: 0.005em;
  text-shadow:
    0 8px 0 rgba(0,0,0,0.45),
    0 28px 50px rgba(0,0,0,0.55);
  margin: 0;
}
.hero-line-main {
  font-size: clamp(64px, 9.4vw, 168px);
  max-width: min(1180px, 92vw);
  line-height: 0.88;
}
.hero-line .cap {
  font-size: 1em;
  text-transform: lowercase; /* Pricedown styles handled by font */
  display: inline-block;
}
.hero-line.l2 { margin-top: -0.06em; }
.hero-line.l3 {
  display: flex; align-items: center; justify-content: center; gap: 0.08em;
  margin-top: -0.04em;
  position: relative;
}
/* "world cup" line — smaller */
.hero-line.cup {
  font-size: clamp(56px, 8.6vw, 156px);
  -webkit-text-stroke: 8px #0a0014;
          text-stroke: 8px #0a0014;
}

/* The chrome "VI" — chunky callout with stripes (GTA VI signature) */
.hero-vi {
  position: relative;
  display: inline-flex; align-items: center; justify-content: center;
  font-family: 'Bowlby One SC', 'Anton', Impact, sans-serif;
  font-size: clamp(96px, 12vw, 210px);
  line-height: 0.85;
  letter-spacing: -0.04em;
  padding: 0.04em 0.18em 0.06em;
  margin-top: -0.03em;
  color: transparent;
  background:
    repeating-linear-gradient(180deg,
      rgba(0,0,0,0.42) 0 3px,
      transparent 3px 10px),
    var(--gradient-chrome);
  background-clip: text;
  -webkit-background-clip: text;
  -webkit-text-stroke: 9px #0a0014;
          text-stroke: 9px #0a0014;
  paint-order: stroke fill;
  text-shadow: 0 8px 0 rgba(0,0,0,0.5), 0 22px 36px rgba(0,0,0,0.55);
  font-style: italic;
  font-weight: 400;
  transform: translateY(-0.02em) skewX(-8deg);
}

.hero-tag-row {
  margin-top: 22px;
  display: inline-flex; align-items: center; gap: 18px;
  font-family: 'Inter', sans-serif;
  font-size: clamp(13px, 1.3vw, 18px);
  letter-spacing: 0.32em;
  color: #fff;
  text-transform: uppercase;
  font-weight: 700;
  text-shadow: 0 2px 8px rgba(0,0,0,0.5);
}

/* Real $GCA wordmark badge image — slots beneath title */
.hero-wordmark {
  display: block;
  margin: 18px auto 0;
  width: clamp(220px, 28vw, 360px);
  height: auto;
  filter:
    drop-shadow(0 0 24px rgba(255,58,163,0.45))
    drop-shadow(0 14px 30px rgba(0,0,0,0.5));
  animation: floatY 6s ease-in-out infinite;
}
@keyframes floatY {
  0%,100% { transform: translateY(0); }
  50%     { transform: translateY(-6px); }
}

/* Character cutout — large transparent PNG, left side of hero (right side has stadium in photo) */
.hero-character {
  position: absolute;
  left: max(1vw, 8px);
  bottom: 80px;
  width: clamp(240px, 24vw, 380px);
  z-index: 4;
  pointer-events: none;
  filter:
    drop-shadow(0 0 30px rgba(255,58,163,0.35))
    drop-shadow(0 30px 50px rgba(0,0,0,0.6));
  animation: floatYsmall 7s ease-in-out infinite;
}
@media (max-width: 1280px) {
  .hero-character { display: none; }
}
@keyframes floatYsmall {
  0%,100% { transform: translateY(0); }
  50%     { transform: translateY(-10px); }
}
.hero-tag-row .sep {
  width: 8px; height: 8px;
  background: var(--vc-pink);
  transform: rotate(45deg);
  box-shadow: 0 0 12px var(--vc-pink);
}

.hero-subtag {
  font-size: clamp(13px, 1.1vw, 15px);
  color: rgba(255,255,255,0.8);
  letter-spacing: 0.06em;
  text-shadow: 0 2px 8px rgba(0,0,0,0.6);
  max-width: 600px;
  line-height: 1.5;
}

.hero-cta-row {
  margin-top: 28px;
  display: flex; gap: 14px; justify-content: center; flex-wrap: wrap;
}

/* Floating side decorations */
.hero-side-l, .hero-side-r {
  position: absolute; top: 90px; bottom: 240px;
  width: 12%;
  z-index: 4;
  pointer-events: none;
}
.hero-side-l { left: 0; }
.hero-side-r { right: 0; }

/* Floating live-match HUD on bottom-right */
.hero-match-hud {
  position: absolute;
  right: 28px; bottom: 64px;
  z-index: 7;
  width: 360px;
  max-width: calc(100vw - 56px);
}

/* Minimap — hidden on hero (mission log section has the proper Grand Cup Auto map). 
   Kept in code for replay-intro toggle but display: none. */
.minimap {
  display: none;
}
.minimap-circle svg { width: 100%; height: 100%; }
.minimap-label {
  margin-top: 8px;
  text-align: center;
  font-size: 9px; letter-spacing: 0.3em;
  color: #fff; text-transform: uppercase; font-weight: 700;
  text-shadow: 0 2px 6px rgba(0,0,0,0.7);
}
.minimap-dot {
  position: absolute;
  left: 50%; top: 50%;
  transform: translate(-50%, -50%);
  width: 12px; height: 12px;
  border-radius: 50%;
  background: var(--alert);
  box-shadow: 0 0 0 6px rgba(255,45,85,0.2), 0 0 18px var(--alert);
  animation: blip 1.3s ease-in-out infinite;
}
@keyframes blip {
  0%,100% { box-shadow: 0 0 0 4px rgba(255,45,85,0.35), 0 0 18px var(--alert); }
  50%     { box-shadow: 0 0 0 12px rgba(255,45,85,0.05), 0 0 26px var(--alert); }
}

/* =========================================================
   Match Card (used in HUD)
   ========================================================= */
.match-card { padding: 18px 22px 20px; backdrop-filter: blur(10px); background: rgba(17,6,38,0.85); }
.match-head { display: flex; align-items: center; justify-content: space-between; margin-bottom: 14px; }
.match-live { display: inline-flex; align-items: center; gap: 8px; font-size: 10px; letter-spacing: 0.28em; color: var(--alert); text-transform: uppercase; font-weight: 700; }
.match-live .dot { width: 8px; height: 8px; border-radius: 50%; background: var(--alert); box-shadow: 0 0 12px var(--alert); animation: pulse 1.1s infinite; }
.match-min { font-family: 'JetBrains Mono', monospace; font-size: 11px; color: var(--ink-2); }

.match-teams { display: grid; grid-template-columns: 1fr auto 1fr; align-items: center; gap: 12px; padding: 6px 0; }
.match-team { display: flex; flex-direction: column; align-items: center; gap: 8px; }
.match-team .flag { width: 56px; height: 38px; border-radius: 2px; overflow: hidden; border: 1px solid var(--hair); box-shadow: 0 4px 14px rgba(0,0,0,0.4); }
.match-team .name {
  font-family: 'Pricedown Bl', 'Pricedown', 'Bowlby One SC', sans-serif;
  font-size: 24px; letter-spacing: 0.02em; text-transform: lowercase;
  color: #fff;
  -webkit-text-stroke: 2.5px #0a0014;
          text-stroke: 2.5px #0a0014;
  paint-order: stroke fill;
}
.match-score {
  font-family: 'JetBrains Mono', monospace; font-weight: 600;
  font-size: 36px; color: var(--vc-cyan);
  text-shadow: 0 0 18px rgba(70,229,229,0.45);
  letter-spacing: -0.02em;
}
.match-mission {
  text-align: center;
  font-family: 'Pricedown Bl', 'Pricedown', 'Bowlby One SC', sans-serif;
  font-size: 20px; letter-spacing: 0.06em; text-transform: lowercase;
  background: linear-gradient(90deg, var(--vc-cyan), #ffffff 50%, var(--vc-pink));
  -webkit-background-clip: text; background-clip: text; color: transparent;
  margin: 6px 0 4px;
}
.match-objs { margin-top: 14px; border-top: 1px solid var(--hair); padding-top: 12px; display: flex; flex-direction: column; gap: 6px; }
.match-obj { display: flex; align-items: center; gap: 10px; font-size: 12px; color: var(--ink-1); letter-spacing: 0.02em; font-weight: 500; }
.match-obj .box { width: 13px; height: 13px; border: 1.5px solid var(--ink-2); flex: none; position: relative; }
.match-obj.done .box { background: var(--go); border-color: var(--go); }
.match-obj.done .box::after { content: "✓"; position: absolute; inset: 0; display: flex; align-items: center; justify-content: center; font-size: 10px; font-weight: 800; color: #08030f; }
.match-obj.done { color: var(--go); }

/* Countdown variant */
.countdown { text-align: center; padding: 18px 22px 20px; backdrop-filter: blur(10px); background: rgba(17,6,38,0.85); }
.countdown .lbl { font-size: 10px; letter-spacing: 0.32em; color: var(--ink-2); text-transform: uppercase; font-weight: 700; }
.countdown .time { font-family: 'JetBrains Mono', monospace; font-weight: 600; font-size: 44px; color: var(--gold); letter-spacing: -0.02em; margin: 8px 0; text-shadow: 0 0 22px rgba(240,192,64,0.4); }

/* =========================================================
   Section scaffold
   ========================================================= */
.section { position: relative; padding: 110px 32px 96px; overflow: hidden; }

/* =========================================================
   INTEL DECK - current GTA VI / World Cup meme operations
   ========================================================= */
.intel-section {
  position: relative;
  padding: 92px 32px 88px;
  background:
    radial-gradient(ellipse 80% 70% at 12% 0%, rgba(70,229,229,0.16), transparent 60%),
    radial-gradient(ellipse 70% 65% at 90% 10%, rgba(255,58,163,0.18), transparent 62%),
    linear-gradient(180deg, #16052f 0%, #070114 100%);
  overflow: hidden;
  isolation: isolate;
}
.intel-section::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(rgba(255,255,255,0.045) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.04) 1px, transparent 1px);
  background-size: 44px 44px;
  mask-image: linear-gradient(180deg, transparent 0%, #000 18%, #000 82%, transparent 100%);
  pointer-events: none;
  z-index: 0;
}
.intel-bg-grid {
  position: absolute;
  inset: 16px;
  border: 1px solid rgba(70,229,229,0.16);
  clip-path: polygon(2% 0, 100% 0, 98% 100%, 0 100%);
  pointer-events: none;
  z-index: 0;
}
.intel-shell {
  position: relative;
  z-index: 1;
  max-width: 1360px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: minmax(300px, 0.8fr) minmax(520px, 1.2fr);
  gap: 34px;
  align-items: stretch;
}
.intel-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 8px 12px;
  border: 1px solid rgba(255,255,255,0.16);
  background: rgba(0,0,0,0.34);
  color: var(--vc-cyan);
  font-size: 10px;
  font-weight: 800;
  letter-spacing: 0.28em;
  text-transform: uppercase;
}
.intel-eyebrow .dot,
.intel-screen-top .scan-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--vc-pink);
  box-shadow: 0 0 12px var(--vc-pink);
}
.intel-title {
  margin-top: 22px;
  max-width: 620px;
  font-family: 'Pricedown Bl','Pricedown','Bowlby One SC',Impact,sans-serif;
  font-size: clamp(54px, 7.4vw, 118px);
  line-height: 0.86;
  letter-spacing: 0;
  text-transform: lowercase;
  color: #fff;
  -webkit-text-stroke: 5px #0a0014;
  paint-order: stroke fill;
  text-shadow: 0 8px 0 rgba(0,0,0,0.42), 0 24px 46px rgba(0,0,0,0.5);
}
.intel-sub {
  margin-top: 22px;
  max-width: 560px;
  color: rgba(255,245,251,0.82);
  font-size: 15px;
  line-height: 1.65;
}
.intel-console {
  display: grid;
  grid-template-columns: 230px 1fr;
  min-height: 430px;
  border: 1px solid rgba(255,255,255,0.15);
  background: rgba(8,3,15,0.72);
  box-shadow: 0 34px 90px -44px rgba(0,0,0,0.95), 0 0 50px rgba(255,58,163,0.12);
  backdrop-filter: blur(12px);
}
.intel-tabs {
  display: grid;
  gap: 1px;
  background: rgba(255,255,255,0.08);
  border-right: 1px solid rgba(255,255,255,0.12);
}
.intel-tab {
  min-height: 104px;
  display: grid;
  grid-template-columns: 54px 1fr;
  align-items: center;
  gap: 12px;
  padding: 16px;
  text-align: left;
  background: rgba(14,4,34,0.92);
  transition: background 0.18s ease, color 0.18s ease, transform 0.18s ease;
}
.intel-tab:hover,
.intel-tab.on {
  background: linear-gradient(90deg, rgba(70,229,229,0.18), rgba(255,58,163,0.18));
}
.intel-tab.on { color: #fff; }
.intel-tab .code {
  display: grid;
  place-items: center;
  min-width: 54px;
  min-height: 54px;
  border: 1px solid rgba(70,229,229,0.42);
  color: var(--vc-cyan);
  font-family: 'JetBrains Mono', monospace;
  font-size: 15px;
  font-weight: 800;
  letter-spacing: 0.04em;
  box-shadow: inset 0 0 18px rgba(70,229,229,0.08);
}
.intel-tab .label {
  color: rgba(255,245,251,0.8);
  font-size: 11px;
  line-height: 1.35;
  letter-spacing: 0.18em;
  text-transform: uppercase;
}
.intel-screen {
  display: flex;
  flex-direction: column;
  min-width: 0;
  padding: 24px;
  position: relative;
  overflow: hidden;
  view-transition-name: gca-intel-screen;
}
.intel-screen::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, transparent 0 48%, rgba(70,229,229,0.08) 50%, transparent 52% 100%);
  background-size: 100% 8px;
  opacity: 0.45;
  pointer-events: none;
}
.intel-screen-top {
  display: flex;
  align-items: center;
  gap: 10px;
  color: rgba(255,245,251,0.72);
  font-size: 10px;
  font-weight: 800;
  letter-spacing: 0.24em;
  text-transform: uppercase;
}
.intel-screen-top .live {
  margin-left: auto;
  color: var(--go);
}
.intel-screen-main {
  flex: 1;
  display: grid;
  grid-template-columns: 1fr 160px;
  gap: 22px;
  align-items: center;
  position: relative;
  z-index: 1;
}
.intel-screen h3 {
  font-family: 'Pricedown Bl','Pricedown','Bowlby One SC',Impact,sans-serif;
  font-size: clamp(38px, 4.6vw, 72px);
  line-height: 0.9;
  letter-spacing: 0;
  text-transform: lowercase;
  color: #fff;
  -webkit-text-stroke: 3px #0a0014;
  paint-order: stroke fill;
}
.intel-screen p {
  margin-top: 18px;
  color: rgba(255,245,251,0.78);
  font-size: 14px;
  line-height: 1.65;
}
.intel-reward {
  align-self: center;
  display: grid;
  place-content: center;
  gap: 8px;
  width: 160px;
  min-height: 160px;
  aspect-ratio: 1;
  padding: 18px;
  border: 1px solid rgba(255,210,58,0.35);
  background:
    radial-gradient(circle at 50% 0%, rgba(255,210,58,0.22), transparent 62%),
    rgba(0,0,0,0.28);
  text-align: center;
}
.intel-reward .k {
  color: var(--ink-2);
  font-size: 9px;
  letter-spacing: 0.26em;
  text-transform: uppercase;
}
.intel-reward .v {
  color: var(--gold);
  font-family: 'JetBrains Mono', monospace;
  font-weight: 800;
  font-size: 16px;
  text-transform: uppercase;
}
.intel-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  position: relative;
  z-index: 1;
}
.intel-tags span {
  padding: 8px 10px;
  border: 1px solid rgba(70,229,229,0.25);
  color: var(--vc-cyan);
  background: rgba(70,229,229,0.08);
  font-size: 10px;
  font-weight: 800;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}
.intel-progress {
  margin-top: 18px;
  height: 5px;
  background: rgba(255,255,255,0.1);
  overflow: hidden;
  position: relative;
  z-index: 1;
}
.intel-progress span {
  display: block;
  height: 100%;
  background: linear-gradient(90deg, var(--vc-cyan), #fff, var(--vc-pink));
  box-shadow: 0 0 18px rgba(255,58,163,0.45);
  transition: width 0.28s ease;
}
.intel-marquee {
  grid-column: 1 / -1;
  overflow: hidden;
  border-block: 1px solid rgba(255,255,255,0.12);
  background: linear-gradient(90deg, var(--vc-cyan), #fff, var(--vc-pink));
  color: #070114;
  font-family: 'Pricedown Bl','Pricedown','Bowlby One SC',Impact,sans-serif;
  font-size: 22px;
  letter-spacing: 0.06em;
  text-transform: lowercase;
}
.intel-marquee-track {
  display: inline-flex;
  gap: 34px;
  white-space: nowrap;
  padding: 10px 18px;
  animation: intelMarquee 34s linear infinite;
}
@keyframes intelMarquee {
  from { transform: translateX(0); }
  to { transform: translateX(-50%); }
}
::view-transition-old(gca-intel-screen),
::view-transition-new(gca-intel-screen) {
  animation-duration: 260ms;
  animation-timing-function: cubic-bezier(0.2, 0.8, 0.2, 1);
}

/* ---- shared decorative section accents -------------------- */
/* halftone dot triangle (top-right) baked as repeating-radial-gradient
   masked into a diagonal — the GTA-VI staple */
.section.dark::after,
.section.darker::after,
.section.midnight::after {
  content: "";
  position: absolute;
  top: 0; right: 0;
  width: 38%;
  height: 360px;
  background-image: radial-gradient(circle, rgba(255,58,163,0.55) 22%, transparent 26%);
  background-size: 14px 14px;
  -webkit-mask-image: linear-gradient(225deg, #000 0%, #000 32%, transparent 70%);
          mask-image: linear-gradient(225deg, #000 0%, #000 32%, transparent 70%);
  opacity: 0.22;
  pointer-events: none;
  z-index: 0;
}

/* ---- Sectional backgrounds: Grand Cup Auto keyart with light scrim ----
   Each .section.dark / .darker / .midnight gets a fixed parallax
   Grand Cup Auto scene as its bg. A soft horizon-tinted scrim on top
   keeps text readable while letting the sunset/neon colors come
   through — replaces the old flat purple wash. */
.section.dark,
.section.darker,
.section.midnight {
  background-color: #1a0a3a;
  background-repeat: no-repeat;
  background-position: center center;
  background-size: cover;
  background-attachment: fixed;
}

/* §02 — dark: trophy / skyline keyart */
.section.dark {
  background-image:
    /* top sunset cap */
    linear-gradient(180deg,
      rgba(255,138,90,0.16) 0%,
      rgba(255,58,163,0.08) 12%,
      transparent 28%),
    /* readability scrim — vignette darker at edges, lighter mid */
    radial-gradient(ellipse 90% 70% at 50% 50%,
      rgba(20,8,48,0.40) 0%,
      rgba(20,8,48,0.62) 55%,
      rgba(14,5,36,0.82) 100%),
    /* keyart */
    url("assets/bg-section-trophy.png");
}

/* §03/§04 — darker: map keyart (cooler aqua read) */
.section.darker {
  background-image:
    linear-gradient(180deg,
      rgba(255,58,163,0.10) 0%,
      transparent 28%),
    radial-gradient(ellipse 90% 70% at 50% 50%,
      rgba(18,8,46,0.42) 0%,
      rgba(18,8,46,0.66) 58%,
      rgba(12,5,34,0.86) 100%),
    url("assets/bg-section-map.png");
}

/* §07/§08 — midnight: trophy keyart, different crop + cyan tint */
.section.midnight {
  background-image:
    linear-gradient(180deg,
      rgba(70,229,229,0.10) 0%,
      transparent 32%),
    radial-gradient(ellipse 90% 70% at 50% 50%,
      rgba(12,8,46,0.46) 0%,
      rgba(12,8,46,0.70) 58%,
      rgba(8,4,30,0.88) 100%),
    url("assets/bg-section-trophy.png");
  background-position: center right;
}

/* Mobile / iOS Safari: drop fixed attachment (causes jank + iOS doesn't
   honor it). Switch to scroll so the bg simply scrolls with content. */
@media (max-width: 900px), (hover: none) and (pointer: coarse) {
  .section.dark,
  .section.darker,
  .section.midnight {
    background-attachment: scroll;
  }
}

/* Palm silhouettes at the left and right edges of each section.
   SVG inline as data URL, very low opacity so they read as ambient
   decoration only — matches the keyart's framing palms. */
.section.dark::before,
.section.darker::before,
.section.midnight::before {
  content: "";
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 1px;
  background: linear-gradient(90deg, transparent 0%, rgba(255,255,255,0.18) 30%, rgba(70,229,229,0.6) 50%, rgba(255,58,163,0.6) 70%, transparent 100%);
  z-index: 1;
}
/* decorative top-edge stripe — every section */
.section::before {
  content: "";
  position: absolute; top: 0; left: 0; right: 0; height: 1px;
  background: linear-gradient(90deg, transparent, rgba(70,229,229,0.5) 25%, rgba(255,255,255,0.65) 50%, rgba(255,58,163,0.5) 75%, transparent);
}
/* glow blob upper-left for cinematic mood */
.section::after {
  content: "";
  position: absolute;
  width: 600px; height: 600px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(255,58,163,0.08), transparent 70%);
  top: -240px; left: -180px;
  pointer-events: none;
  filter: blur(20px);
}

.section-head {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 36px;
  align-items: end;
  max-width: 1360px; margin: 0 auto 48px;
  position: relative; z-index: 2;
}
.section > .gen-wrap,
.section > .leader,
.section > .mlog-wrap,
.section > .dossier-wrap { position: relative; z-index: 2; }
.section-eyebrow {
  display: inline-flex; align-items: center; gap: 12px;
  font-size: 11px; letter-spacing: 0.32em;
  color: var(--ink-2); text-transform: uppercase; font-weight: 700;
  margin-bottom: 14px;
}
.section-eyebrow .bar {
  width: 36px; height: 2px;
  background: linear-gradient(90deg, var(--vc-cyan), var(--vc-pink));
}
.section-title {
  font-family: 'Pricedown Bl', 'Pricedown', 'Bowlby One SC', sans-serif;
  font-size: clamp(54px, 7vw, 110px);
  line-height: 0.92;
  letter-spacing: 0.01em;
  text-transform: lowercase;
  color: #fff;
  -webkit-text-stroke: 4px #0a0014;
          text-stroke: 4px #0a0014;
  paint-order: stroke fill;
  text-shadow: 0 4px 0 rgba(0,0,0,0.35);
}
.section-title .accent {
  -webkit-text-stroke: 4px #0a0014;
  background: linear-gradient(90deg, var(--vc-cyan), #ffffff 50%, var(--vc-pink));
  -webkit-background-clip: text; background-clip: text;
  color: transparent;
  paint-order: stroke fill;
}
.section-sub {
  margin-top: 16px;
  font-size: 16px; color: var(--ink-1);
  max-width: 580px; line-height: 1.55;
}

/* =========================================================
   THE WORLD IS OURS: ecosystem flywheel explainer
   ========================================================= */
.world-wrap {
  position: relative;
  z-index: 2;
  width: min(1360px, calc(100vw - 64px));
  margin: 0 auto;
  overflow: hidden;
  border: 1px solid rgba(255,255,255,0.14);
  border-radius: 26px;
  background:
    radial-gradient(circle at 8% 12%, rgba(70,229,229,0.18), transparent 34%),
    radial-gradient(circle at 90% 8%, rgba(255,58,163,0.22), transparent 32%),
    linear-gradient(145deg, rgba(18,7,38,0.96), rgba(4,2,13,0.98));
  box-shadow:
    0 36px 100px rgba(0,0,0,0.58),
    inset 0 1px 0 rgba(255,255,255,0.14);
}
.world-wrap::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(90deg, rgba(255,58,163,0.07) 1px, transparent 1px),
    linear-gradient(0deg, rgba(70,229,229,0.055) 1px, transparent 1px);
  background-size: 52px 52px;
  mask-image: linear-gradient(180deg, transparent, #000 14%, #000 88%, transparent);
  pointer-events: none;
}
.world-characters { position: absolute; inset: 0; pointer-events: none; z-index: 1; }
.world-char {
  position: absolute;
  bottom: -24px;
  max-height: 520px;
  width: auto;
  opacity: 0.2;
  filter: drop-shadow(0 24px 32px rgba(0,0,0,0.75));
}
.world-char-left { left: -58px; transform: rotate(-3deg); }
.world-char-right { right: -42px; transform: rotate(3deg); }
.world-head,
.world-grid { position: relative; z-index: 2; }
.world-head {
  display: flex;
  justify-content: space-between;
  gap: 28px;
  padding: 34px 36px 24px;
}
.world-kicker {
  color: var(--vc-cyan);
  font-family: 'JetBrains Mono', monospace;
  font-size: 12px;
  font-weight: 800;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}
.world-head h3 {
  margin: 10px 0 10px;
  color: #fff;
  font-family: 'Pricedown Bl', 'Pricedown', 'Bowlby One SC', sans-serif;
  font-size: clamp(56px, 6.5vw, 108px);
  line-height: 0.86;
  text-transform: lowercase;
  text-shadow: 6px 6px 0 rgba(0,0,0,0.78), 0 0 28px rgba(255,58,163,0.32);
}
.world-head p {
  max-width: 800px;
  margin: 0;
  color: rgba(255,255,255,0.72);
  font-size: 15px;
  line-height: 1.65;
}
.world-count {
  flex: 0 0 190px;
  align-self: start;
  padding: 18px;
  border: 1px solid rgba(70,229,229,0.34);
  background: rgba(0,0,0,0.28);
  text-align: center;
}
.world-count span {
  display: block;
  color: var(--vc-cyan);
  font-family: 'Pricedown Bl', 'Pricedown', 'Bowlby One SC', sans-serif;
  font-size: 74px;
  line-height: 0.8;
  text-shadow: 0 0 18px rgba(70,229,229,0.5);
}
.world-count b {
  display: block;
  margin-top: 8px;
  color: #fff;
  font-family: 'JetBrains Mono', monospace;
  font-size: 10px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}
.world-grid {
  display: grid;
  grid-template-columns: minmax(440px, 1fr) minmax(420px, 0.95fr);
  gap: 24px;
  padding: 0 36px 36px;
}
.world-diagram,
.world-panel {
  min-height: 560px;
  border: 1px solid rgba(255,255,255,0.13);
  border-radius: 22px;
  background: rgba(3,1,12,0.74);
  box-shadow: inset 0 0 52px rgba(0,0,0,0.66);
}
.world-diagram {
  position: relative;
  display: grid;
  grid-template-rows: repeat(8, auto);
  align-content: center;
  gap: 9px;
  padding: 32px;
  overflow: hidden;
  font-family: 'JetBrains Mono', monospace;
}
.world-diagram::before {
  content: "";
  position: absolute;
  inset: 22px;
  border: 1px dashed rgba(255,255,255,0.42);
  border-left: 0;
  border-bottom: 0;
  opacity: 0.7;
}
.world-diagram::after {
  content: "";
  position: absolute;
  right: 22px;
  bottom: 66px;
  width: 34%;
  height: 1px;
  background: linear-gradient(90deg, rgba(255,255,255,0.5), transparent);
}
.diagram-node {
  position: relative;
  z-index: 1;
  width: fit-content;
  max-width: 100%;
  margin: 0 auto;
  padding: 9px 13px;
  color: #fff;
  border: 1px solid rgba(255,255,255,0.16);
  background: rgba(0,0,0,0.34);
  text-align: center;
  font-size: 13px;
  font-weight: 800;
  letter-spacing: 0.02em;
  text-transform: uppercase;
}
.diagram-node span {
  display: block;
  margin-top: 3px;
  color: rgba(255,255,255,0.64);
  font-size: 11px;
  text-transform: none;
}
.diagram-node.attention { color: var(--vc-cyan); }
.diagram-node.trade { border-color: rgba(70,229,229,0.38); }
.diagram-node.fees { color: var(--vc-pink); border-color: rgba(255,58,163,0.38); }
.diagram-arrow.down {
  position: relative;
  z-index: 1;
  width: 2px;
  height: 18px;
  margin: 0 auto;
  background: linear-gradient(180deg, var(--vc-cyan), var(--vc-pink));
}
.diagram-split {
  position: relative;
  z-index: 1;
  margin: 0 auto;
  color: #fff;
  font-family: 'Pricedown Bl', 'Pricedown', 'Bowlby One SC', sans-serif;
  font-size: 24px;
  text-transform: lowercase;
}
.diagram-branches {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
  margin: 0 auto;
  width: min(100%, 520px);
}
.diagram-branches::before {
  content: "";
  position: absolute;
  left: 25%;
  right: 25%;
  top: -8px;
  height: 8px;
  border-top: 1px solid rgba(255,255,255,0.35);
  border-left: 1px solid rgba(255,255,255,0.35);
  border-right: 1px solid rgba(255,255,255,0.35);
}
.diagram-node.burn { border-color: rgba(255,58,163,0.45); }
.diagram-node.pots { border-color: rgba(255,210,58,0.45); }
.diagram-node.hunters { color: var(--vc-cyan); }
.diagram-node.gate { border-color: rgba(70,229,229,0.45); max-width: 520px; }
.diagram-return {
  position: relative;
  z-index: 1;
  justify-self: end;
  margin-right: 44px;
  color: rgba(255,255,255,0.72);
  font-family: 'JetBrains Mono', monospace;
  font-size: 12px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}
.world-panel {
  display: grid;
  grid-template-rows: auto 1fr auto;
  gap: 16px;
  padding: 22px;
}
.world-tabs {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
}
.world-tab {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 12px 10px;
  border: 1px solid rgba(255,255,255,0.13);
  background: rgba(0,0,0,0.28);
  color: rgba(255,255,255,0.72);
  font-family: 'Pricedown Bl', 'Pricedown', 'Bowlby One SC', sans-serif;
  font-size: 18px;
  text-transform: lowercase;
  cursor: pointer;
}
.world-tab.on {
  color: #08030f;
  border-color: transparent;
  background: linear-gradient(90deg, var(--vc-cyan), #fff 48%, var(--vc-pink));
}
.world-card {
  display: grid;
  grid-template-columns: 80px 1fr;
  gap: 18px;
  align-items: start;
  padding: 24px;
  border: 1px solid rgba(255,255,255,0.13);
  background:
    radial-gradient(circle at 0% 0%, rgba(255,58,163,0.16), transparent 42%),
    rgba(0,0,0,0.28);
}
.world-card-icon {
  display: grid;
  place-items: center;
  width: 72px;
  height: 72px;
  border-radius: 18px;
  background: linear-gradient(135deg, rgba(70,229,229,0.22), rgba(255,58,163,0.22));
  border: 1px solid rgba(255,255,255,0.16);
  font-size: 34px;
}
.world-card h4 {
  margin: 0 0 14px;
  color: #fff;
  font-family: 'Pricedown Bl', 'Pricedown', 'Bowlby One SC', sans-serif;
  font-size: clamp(32px, 4vw, 54px);
  line-height: 0.9;
  text-transform: lowercase;
}
.world-card ul {
  display: grid;
  gap: 12px;
  margin: 0;
  padding: 0;
  list-style: none;
}
.world-card li {
  position: relative;
  padding-left: 18px;
  color: rgba(255,255,255,0.76);
  font-size: 14px;
  line-height: 1.52;
}
.world-card li::before {
  content: ">";
  position: absolute;
  left: 0;
  color: var(--vc-cyan);
  font-family: 'JetBrains Mono', monospace;
  font-weight: 900;
}
.world-mini-stats {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
}
.world-mini-stats div {
  padding: 14px;
  border: 1px solid rgba(255,255,255,0.1);
  background: rgba(0,0,0,0.28);
}
.world-mini-stats span {
  display: block;
  color: rgba(255,255,255,0.45);
  font-family: 'JetBrains Mono', monospace;
  font-size: 10px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}
.world-mini-stats b {
  display: block;
  margin-top: 8px;
  color: var(--vc-cyan);
  font-family: 'JetBrains Mono', monospace;
  font-size: 18px;
}

/* =========================================================
   Wanted Poster Generator
   ========================================================= */
.gen-wrap {
  max-width: 1360px; margin: 0 auto;
  display: grid; grid-template-columns: 460px 1fr; gap: 40px; align-items: start;
}
.gen-controls {
  background: linear-gradient(180deg, var(--bg-1), var(--bg-2));
  border: 1px solid var(--hair-strong);
  padding: 28px;
  position: relative;
}
.gen-controls::before {
  content: ""; position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--vc-cyan), #ffffff 50%, var(--vc-pink));
}
.gen-step { margin-bottom: 22px; }
.gen-step .step-no {
  font-family: 'Pricedown Bl', 'Pricedown', 'Bowlby One SC', sans-serif;
  font-size: 18px; letter-spacing: 0.06em;
  background: linear-gradient(90deg, var(--vc-cyan), var(--vc-pink));
  -webkit-background-clip: text; background-clip: text;
  color: transparent;
  text-transform: lowercase;
}
.gen-step .step-ttl {
  font-size: 17px; font-weight: 800;
  color: var(--ink-0); margin: 4px 0 12px;
}
.input-wrap {
  display: flex; height: 52px;
  border: 1px solid var(--hair-strong);
  background: #07020e; align-items: stretch;
  transition: border-color 0.15s ease;
}
.input-wrap:focus-within { border-color: var(--vc-pink); }
.input-wrap .pref {
  display: flex; align-items: center; justify-content: center;
  padding: 0 14px;
  background: var(--bg-2);
  color: var(--vc-cyan);
  font-family: 'JetBrains Mono', monospace;
  border-right: 1px solid var(--hair);
  font-size: 14px;
}
.input-wrap input {
  flex: 1; background: transparent; border: none; outline: none;
  font-family: 'JetBrains Mono', monospace; font-size: 13px;
  color: var(--ink-0); padding: 0 14px;
}
.input-wrap input::placeholder { color: var(--ink-3); }

.slider-wrap { display: flex; flex-direction: column; gap: 6px; }
.slider-wrap .top { display: flex; align-items: center; justify-content: space-between; font-size: 11px; letter-spacing: 0.18em; color: var(--ink-2); text-transform: uppercase; font-weight: 700; }
.slider-wrap .top .val { font-family: 'JetBrains Mono', monospace; color: var(--vc-cyan); font-weight: 600; letter-spacing: 0; }
.slider-wrap input[type=range] {
  -webkit-appearance: none; appearance: none;
  width: 100%; height: 4px;
  background: linear-gradient(90deg, var(--vc-cyan), var(--vc-pink));
  outline: none;
}
.slider-wrap input[type=range]::-webkit-slider-thumb {
  -webkit-appearance: none; appearance: none;
  width: 18px; height: 18px; border-radius: 50%;
  background: #fff; border: 2px solid var(--vc-pink);
  box-shadow: 0 0 12px var(--vc-pink);
  cursor: pointer;
}
.slider-wrap input[type=range]::-moz-range-thumb {
  width: 18px; height: 18px; border-radius: 50%;
  background: #fff; border: 2px solid var(--vc-pink);
  box-shadow: 0 0 12px var(--vc-pink);
}

.gen-toggle-row { display: flex; flex-wrap: wrap; gap: 6px; margin-top: 8px; }
.gen-toggle {
  padding: 7px 14px;
  min-height: 44px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-family: 'Pricedown Bl', 'Pricedown', 'Bowlby One SC', sans-serif;
  font-size: 14px; letter-spacing: 0.04em; text-transform: lowercase;
  border: 1px solid var(--hair-strong);
  color: var(--ink-2); background: rgba(0,0,0,0.3);
  cursor: pointer; transition: all 0.15s ease;
}
.gen-toggle.on {
  background: linear-gradient(90deg, var(--vc-cyan), var(--vc-pink));
  border-color: transparent; color: #08030f;
}
.gen-toggle:hover:not(.on) { color: var(--vc-pink); border-color: var(--vc-pink); }

.processing {
  display: flex; align-items: center; gap: 10px;
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px; color: var(--vc-cyan);
  letter-spacing: 0.18em; text-transform: uppercase;
  margin: 14px 0 12px;
  min-height: 18px;
}
.processing.ready { color: var(--go); }
.processing .dots::after { content: ""; animation: ellipsis 1.2s infinite steps(4); }
@keyframes ellipsis { 0% { content: "" } 25% { content: "." } 50% { content: ".." } 75% { content: "..." } 100% { content: "" } }

.gen-share-row { display: flex; gap: 10px; margin-top: 16px; }

/* The Poster artwork */
.poster-frame {
  position: relative;
  width: 100%;
  aspect-ratio: 3 / 4;
  background-color: #f6e1b3;
  background-image: url('assets/poster-frame-sm.png');
  background-size: 100% 100%;
  background-repeat: no-repeat;
  background-position: center;
  color: #1c0a2c; font-family: 'Inter', sans-serif;
  display: flex; flex-direction: column;
  overflow: visible;
  transform: rotate(-1deg);
  transition: transform 0.4s ease;
  filter:
    drop-shadow(0 30px 60px rgba(0,0,0,0.55))
    drop-shadow(0 0 24px rgba(255,58,163,0.18));
}
.poster-frame:hover { transform: rotate(0) scale(1.01); }
.poster-frame::before,
.poster-frame::after { display: none; }

/* =========================================================
   Advanced Meme Generator
   ========================================================= */
.meme-section {
  background:
    radial-gradient(ellipse 80% 50% at 78% 12%, rgba(255,58,163,0.18), transparent 58%),
    radial-gradient(ellipse 60% 45% at 16% 72%, rgba(70,229,229,0.12), transparent 60%),
    linear-gradient(180deg, #21083d, #10051f 52%, #1a0a3a);
}
.meme-section > .ss,
.meme-section > .meme-gen {
  position: relative;
  z-index: 2;
}
.meme-gen {
  max-width: 1480px;
  margin: 54px auto 0;
  display: grid;
  grid-template-columns: minmax(260px, 0.88fr) minmax(420px, 1.32fr) minmax(300px, 0.92fr);
  gap: 18px;
  align-items: start;
}
.meme-panel,
.meme-preview-panel {
  background: linear-gradient(180deg, rgba(17,6,38,0.92), rgba(8,3,15,0.96));
  border: 1px solid var(--hair-strong);
  box-shadow: 0 26px 80px rgba(0,0,0,0.36);
}
.meme-panel {
  padding: 18px;
}
.meme-panel-head {
  display: grid;
  grid-template-columns: 48px 1fr;
  gap: 12px;
  align-items: start;
  margin-bottom: 14px;
}
.meme-panel-head.small { margin-top: 22px; }
.meme-panel-head .k {
  display: grid;
  place-items: center;
  height: 48px;
  border: 1px solid rgba(70,229,229,0.48);
  color: var(--vc-cyan);
  font-family: 'JetBrains Mono', monospace;
  font-weight: 800;
  background: rgba(70,229,229,0.08);
}
.meme-panel-head h3 {
  font-family: 'Pricedown Bl','Pricedown','Bowlby One SC',sans-serif;
  font-size: 26px;
  line-height: 0.9;
  letter-spacing: 0.04em;
  text-transform: lowercase;
  color: #fff;
  -webkit-text-stroke: 1px #0a0014;
  paint-order: stroke fill;
}
.meme-panel-head p {
  margin-top: 6px;
  color: var(--ink-2);
  font-size: 12px;
  line-height: 1.45;
}
.meme-template-grid {
  display: grid;
  gap: 8px;
  max-height: 420px;
  overflow: auto;
  padding-right: 4px;
}
.meme-template-card {
  min-height: 74px;
  text-align: left;
  padding: 12px 13px;
  background: rgba(0,0,0,0.28);
  border: 1px solid var(--hair-strong);
  transition: transform 0.16s ease, border-color 0.16s ease, background 0.16s ease;
}
.meme-template-card:hover {
  transform: translateY(-1px);
  border-color: rgba(255,58,163,0.6);
}
.meme-template-card.on {
  background: linear-gradient(90deg, rgba(70,229,229,0.18), rgba(255,58,163,0.2));
  border-color: var(--vc-cyan);
}
.meme-template-name {
  display: block;
  font-family: 'Pricedown Bl','Pricedown','Bowlby One SC',sans-serif;
  font-size: 19px;
  letter-spacing: 0.04em;
  text-transform: lowercase;
}
.meme-template-angle {
  display: block;
  margin-top: 4px;
  color: var(--ink-2);
  font-size: 11px;
  line-height: 1.35;
}
.meme-character-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
  max-height: 470px;
  overflow: auto;
  padding-right: 4px;
}
.meme-character-card {
  min-height: 112px;
  display: grid;
  grid-template-rows: 72px auto;
  gap: 6px;
  justify-items: center;
  align-items: center;
  padding: 8px 6px;
  background: rgba(0,0,0,0.32);
  border: 1px solid var(--hair-strong);
  color: var(--ink-1);
  transition: transform 0.16s ease, border-color 0.16s ease, box-shadow 0.16s ease;
}
.meme-character-card:hover {
  transform: translateY(-1px);
  border-color: rgba(255,58,163,0.54);
}
.meme-character-card.on {
  border-color: var(--vc-pink);
  box-shadow: inset 0 0 0 1px rgba(255,58,163,0.24), 0 0 18px rgba(255,58,163,0.18);
}
.meme-character-card img {
  width: 76px;
  height: 72px;
  object-fit: contain;
  filter: drop-shadow(0 10px 14px rgba(0,0,0,0.65));
}
.meme-character-card span {
  font-size: 10px;
  line-height: 1.1;
  text-align: center;
  color: var(--ink-1);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  font-weight: 800;
}
.meme-preview-panel {
  padding: 16px;
  position: sticky;
  top: 78px;
}
.meme-preview-top {
  min-height: 48px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  color: var(--ink-2);
  font-size: 11px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}
.meme-preview-top div {
  display: inline-flex;
  align-items: center;
  gap: 10px;
}
.meme-live-dot {
  width: 12px;
  height: 12px;
  border-radius: 50%;
  background: var(--vc-pink);
  box-shadow: 0 0 18px var(--vc-pink);
}
.meme-canvas-shell {
  background:
    linear-gradient(135deg, rgba(255,255,255,0.08), transparent 40%),
    #05000d;
  border: 1px solid rgba(255,255,255,0.18);
  padding: 8px;
  overflow: hidden;
}
.meme-canvas-shell canvas {
  width: 100%;
  height: auto;
  display: block;
  background: #07020e;
  box-shadow: 0 24px 60px rgba(0,0,0,0.5);
}
.meme-actions {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
  margin-top: 14px;
}
.meme-actions .btn-sunset,
.meme-actions .btn-ghost {
  min-height: 52px;
  padding: 10px 12px;
  font-size: 18px;
  line-height: 1;
}
.meme-actions.mini {
  grid-template-columns: 1fr;
}
.meme-actions.mini .btn-ghost.on {
  border-color: var(--vc-cyan);
  color: var(--vc-cyan);
}
.meme-status {
  margin-top: 10px;
  color: var(--vc-cyan);
  font-size: 10px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}
.meme-field,
.meme-select-field {
  display: grid;
  gap: 7px;
  margin-bottom: 12px;
}
.meme-field span,
.meme-select-field span,
.meme-sliders span {
  color: var(--ink-2);
  font-size: 10px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  font-weight: 800;
}
.meme-field textarea,
.meme-field input,
.meme-select-field select {
  width: 100%;
  min-height: 48px;
  background: #07020e;
  border: 1px solid var(--hair-strong);
  color: var(--ink-0);
  padding: 11px 12px;
  outline: none;
  font-family: 'JetBrains Mono', monospace;
  font-size: 12px;
}
.meme-field textarea {
  min-height: 82px;
  resize: vertical;
}
.meme-field textarea:focus,
.meme-field input:focus,
.meme-select-field select:focus {
  border-color: var(--vc-pink);
}
.meme-chip-group {
  display: flex;
  gap: 7px;
  flex-wrap: wrap;
  margin: 12px 0;
}
.meme-chip-group button {
  min-height: 44px;
  padding: 8px 12px;
  border: 1px solid var(--hair-strong);
  background: rgba(0,0,0,0.34);
  color: var(--ink-2);
  font-family: 'Pricedown Bl','Pricedown','Bowlby One SC',sans-serif;
  font-size: 15px;
  text-transform: lowercase;
  letter-spacing: 0.04em;
}
.meme-chip-group button.on {
  background: linear-gradient(90deg, var(--vc-cyan), var(--vc-pink));
  color: #08030f;
  border-color: transparent;
}
.meme-sliders {
  display: grid;
  gap: 10px;
  margin-top: 14px;
}
.meme-sliders label {
  display: grid;
  grid-template-columns: 48px 1fr;
  gap: 10px;
  align-items: center;
}
.meme-sliders input[type=range] {
  -webkit-appearance: none;
  appearance: none;
  height: 4px;
  background: linear-gradient(90deg, var(--vc-cyan), var(--vc-pink));
}
.meme-sliders input[type=range]::-webkit-slider-thumb {
  -webkit-appearance: none;
  width: 18px;
  height: 18px;
  border-radius: 50%;
  background: #fff;
  border: 2px solid var(--vc-pink);
  box-shadow: 0 0 12px var(--vc-pink);
}
.meme-sliders input[type=range]::-moz-range-thumb {
  width: 18px;
  height: 18px;
  border-radius: 50%;
  background: #fff;
  border: 2px solid var(--vc-pink);
  box-shadow: 0 0 12px var(--vc-pink);
}
.meme-file {
  display: none;
}

/* All the inner poster content lives inside the frame's transparent center.
   The transparent area sits roughly at x:12%-88%, y:18%-82%. */
.poster-inner {
  position: absolute;
  left: 12%; right: 12%;
  top: 18%; bottom: 18%;
  display: flex; flex-direction: column;
  padding: 8px 0;
  z-index: 2;
}
.poster-stars {
  display: flex; align-items: center; justify-content: center; gap: 4px;
  margin-bottom: 2px;
}
.poster-stars .ps { color: #1c0a2c; filter: drop-shadow(0 1px 1px rgba(0,0,0,0.18)); }
.poster-stars .ps.off { color: rgba(28,10,44,0.2); filter: none; }
.poster-wanted {
  text-align: center;
  font-family: 'Pricedown Bl', 'Pricedown', 'Bowlby One SC', sans-serif;
  font-size: clamp(32px, 5.4vw, 64px);
  letter-spacing: 0.04em; line-height: 0.9;
  color: #1c0a2c;
  text-transform: lowercase;
  margin-top: 2px;
  -webkit-text-stroke: 2px #1c0a2c;
  paint-order: stroke fill;
}
.poster-dora {
  text-align: center; font-size: 11px;
  letter-spacing: 0.42em; text-transform: uppercase;
  color: #6a1d2e; margin-top: -2px; font-weight: 700;
}
.poster-avatar-wrap {
  display: flex; justify-content: center;
  margin: 6px 0 4px;
  position: relative;
  flex: 1 1 auto;
  min-height: 180px;
  align-items: stretch;
}
.poster-avatar {
  width: 100%;
  background: rgba(28, 10, 44, 0.04);
  border: 2px dashed rgba(28,10,44,0.35);
  position: relative; image-rendering: pixelated;
  display: flex; align-items: flex-end; justify-content: center;
  overflow: hidden;
  min-height: 180px;
}
.poster-avatar.has-photo {
  border: none;
  background:
    radial-gradient(ellipse 70% 50% at 50% 100%, rgba(255, 58, 163, 0.25), transparent 65%),
    linear-gradient(180deg, rgba(28,10,44,0) 60%, rgba(28,10,44,0.18) 100%);
}
.poster-avatar img.character {
  width: 100%; height: 100%;
  object-fit: contain;
  object-position: bottom center;
}
.poster-alias {
  text-align: center;
  font-family: 'Pricedown Bl', 'Pricedown', 'Bowlby One SC', sans-serif;
  font-size: clamp(16px, 2vw, 24px);
  letter-spacing: 0.06em; color: #1c0a2c;
  margin-top: 4px;
  text-transform: lowercase;
}
.poster-addr {
  text-align: center; font-family: 'JetBrains Mono', monospace;
  font-size: 9px; color: #5a2c1e; margin-top: -2px;
  letter-spacing: 0.04em;
}
.poster-crimes {
  margin: 6px 0 0; padding: 5px 8px;
  border-top: 1.5px dashed rgba(28,10,44,0.35);
  border-bottom: 1.5px dashed rgba(28,10,44,0.35);
}
.poster-crimes .ttl { font-size: 8.5px; letter-spacing: 0.32em; font-weight: 800; color: #6a1d2e; margin-bottom: 2px; text-align: center; }
.poster-crimes ul { list-style: none; font-size: 10px; color: #1c0a2c; line-height: 1.3; }
.poster-crimes li::before { content: "▸ "; color: #c33f3f; font-weight: 800; }
.poster-crimes li { white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.poster-bounty {
  margin-top: 6px;
  background: #1c0a2c; color: #f0c040;
  padding: 5px 12px 4px; text-align: center;
}
.poster-bounty .lbl { font-size: 8px; letter-spacing: 0.35em; color: #9d8138; font-weight: 700; }
.poster-bounty .val {
  font-family: 'Pricedown Bl', 'Pricedown', 'Bowlby One SC', sans-serif;
  font-size: clamp(22px, 3.4vw, 34px);
  letter-spacing: 0.04em; color: #f0c040;
  line-height: 1; margin-top: 1px;
  text-transform: lowercase;
}
.poster-foot {
  margin-top: 4px;
  color: #1c0a2c;
  font-family: 'JetBrains Mono', monospace;
  font-size: 8px; letter-spacing: 0.06em;
  text-align: center;
  opacity: 0.7;
}
.poster-foot .ca {
  display: block;
  font-size: 7.5px;
  margin-bottom: 1px;
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}

.poster-match-overlay {
  position: absolute; right: 4%; top: 14%;
  background: rgba(28,10,44,0.92); color: #ffc23a;
  border: 1px solid #f0c040;
  padding: 4px 8px;
  font-family: 'Pricedown Bl', 'Pricedown', 'Bowlby One SC', sans-serif;
  font-size: 11px; letter-spacing: 0.06em; text-transform: lowercase;
  z-index: 3; text-align: center;
  transform: rotate(8deg);
}
.poster-match-overlay .sc { font-family: 'JetBrains Mono', monospace; color: var(--alert); font-size: 13px; }

.pixel-grid { display: grid; grid-template-columns: repeat(8, 1fr); grid-template-rows: repeat(8, 1fr); width: 86%; height: 86%; }
.pixel-grid .px { width: 100%; height: 100%; }

/* =========================================================
   Leaderboard
   ========================================================= */
.leader { max-width: 1360px; margin: 0 auto; background: var(--bg-1); border: 1px solid var(--hair); position: relative; }
.leader::before { content: ""; position: absolute; top: 0; left: 0; right: 0; height: 2px; background: linear-gradient(90deg, var(--vc-cyan), var(--vc-pink)); }
.leader-row {
  display: grid;
  grid-template-columns: 56px 110px 1fr 1fr 1fr 1fr 90px;
  align-items: center; gap: 16px;
  padding: 14px 22px;
  border-bottom: 1px solid var(--hair);
  font-size: 13px;
  transition: background 0.15s ease;
}
.leader-row.head {
  font-size: 10px; letter-spacing: 0.28em;
  color: var(--ink-2); text-transform: uppercase; font-weight: 700;
  background: rgba(0,0,0,0.4);
  border-bottom: 1px solid var(--hair-strong);
}
.leader-row:last-child { border-bottom: none; }
.leader-row:not(.head) { cursor: pointer; }
.leader-row:not(.head):hover { background: rgba(255,58,163,0.08); }
.leader-row.first {
  background: linear-gradient(90deg, rgba(70,229,229,0.16), rgba(255,58,163,0.08) 50%, transparent 80%);
  border-left: 3px solid var(--vc-cyan);
  padding-left: 19px;
}
.leader-rank {
  font-family: 'Pricedown Bl', 'Pricedown', 'Bowlby One SC', sans-serif;
  font-size: 28px; color: var(--vc-pink);
  letter-spacing: 0.02em; text-transform: lowercase;
}
.leader-rank.gold {
  background: linear-gradient(180deg, var(--vc-cyan), var(--vc-pink));
  -webkit-background-clip: text; background-clip: text;
  color: transparent;
}
.leader-stars { display: flex; gap: 2px; }
.leader-stars svg { width: 16px; height: 16px; color: var(--gold); }
.leader-stars svg.off { color: rgba(240,192,64,0.18); }
.leader-alias { font-family: 'Inter', sans-serif; font-weight: 800; color: var(--ink-0); font-size: 16px; }
.leader-aka { font-size: 11px; color: var(--ink-2); font-family: 'JetBrains Mono', monospace; margin-top: 2px; }
.leader-num { font-family: 'JetBrains Mono', monospace; color: var(--vc-cyan); font-size: 14px; font-weight: 600; }
.leader-thumb {
  width: 70px; height: 88px;
  background: #f6e1b3;
  border: 2px solid #fff;
  outline: 1px solid #0a0014;
  outline-offset: -3px;
  position: relative;
  display: flex; flex-direction: column;
  align-items: center; justify-content: flex-start;
  padding: 4px 2px;
}
.leader-thumb .lt-wanted { font-family: 'Pricedown Bl', 'Pricedown', sans-serif; font-size: 8px; color: #1c0a2c; letter-spacing: 0.12em; text-transform: lowercase; }
.leader-thumb .lt-pix { width: 32px; height: 32px; background: #1c0a2c; margin-top: 2px; }
.leader-thumb .lt-name { font-family: 'Pricedown Bl', 'Pricedown', sans-serif; color: #1c0a2c; font-size: 8px; margin-top: 3px; letter-spacing: 0.06em; text-transform: lowercase; }

/* =========================================================
   Mission Log
   ========================================================= */
.mlog-wrap { max-width: 1360px; margin: 0 auto; display: grid; grid-template-columns: 1.05fr 1fr; gap: 36px; align-items: start; }
.mlog-map {
  position: sticky; top: 88px;
  background-color: #0d0428;
  background-image: url('assets/loading-frame.jpg');
  background-size: cover;
  background-position: center;
  border: 1px solid var(--hair-strong);
  padding: 22px;
  aspect-ratio: 16 / 11;
  position: relative; overflow: hidden;
  box-shadow: inset 0 0 80px rgba(0,0,0,0.6);
}
.mlog-map::after {
  /* sunset glow + readability tint */
  content: "";
  position: absolute; inset: 0;
  background:
    radial-gradient(ellipse 70% 50% at 50% 100%, rgba(255,58,163,0.12), transparent 60%),
    linear-gradient(180deg, rgba(8,3,15,0.25) 0%, transparent 30%, transparent 70%, rgba(8,3,15,0.6) 100%);
  pointer-events: none;
}
.mlog-map .title {
  position: absolute; top: 16px; left: 22px;
  font-family: 'Pricedown Bl', 'Pricedown', 'Bowlby One SC', sans-serif;
  color: #fff;
  letter-spacing: 0.04em;
  font-size: 22px;
  z-index: 4;
  text-transform: lowercase;
  -webkit-text-stroke: 2px #0a0014; paint-order: stroke fill;
}
.heist-map-copy {
  position: absolute;
  left: 22px;
  right: 22px;
  top: 58px;
  z-index: 4;
  max-width: 520px;
  padding: 14px 16px;
  border: 1px solid rgba(70,229,229,0.32);
  background: rgba(5,1,16,0.72);
  box-shadow: 0 0 24px rgba(70,229,229,0.12);
}
.heist-map-copy b {
  display: block;
  color: #fff;
  font-family: 'Pricedown Bl', 'Pricedown', 'Bowlby One SC', sans-serif;
  font-size: 30px;
  line-height: 0.9;
  text-transform: lowercase;
  text-shadow: 3px 3px 0 rgba(0,0,0,0.78);
}
.heist-map-copy span {
  display: block;
  margin-top: 8px;
  color: rgba(255,255,255,0.72);
  font-size: 13px;
  line-height: 1.45;
}
.mlog-map .legend { position: absolute; bottom: 18px; left: 22px; display: flex; gap: 18px; font-size: 10px; letter-spacing: 0.18em; color: var(--ink-2); text-transform: uppercase; z-index: 4; font-weight: 700; }
.mlog-map .legend .pip { display: inline-flex; align-items: center; gap: 6px; }
.mlog-map .legend .dot { width: 8px; height: 8px; border-radius: 50%; }
.legend .dot.live { background: var(--alert); box-shadow: 0 0 10px var(--alert); }
.legend .dot.up   { background: var(--gold); }
.legend .dot.done { background: var(--ink-3); }
.mlog-map svg { width: 100%; height: 100%; }

/* Pulsing pin markers laid over the loading-frame map image */
.map-pin {
  position: absolute; z-index: 5;
  display: flex; flex-direction: column; align-items: center;
  transform: translate(-50%, -50%);
}
.map-pin .dot {
  width: 12px; height: 12px; border-radius: 50%;
  background: var(--gold);
  box-shadow: 0 0 0 2px rgba(0,0,0,0.5), 0 0 16px var(--gold);
}
.map-pin.live .dot {
  background: var(--alert);
  box-shadow: 0 0 0 2px rgba(0,0,0,0.5), 0 0 18px var(--alert);
}
.map-pin.next .dot {
  background: var(--vc-cyan);
  box-shadow: 0 0 0 2px rgba(0,0,0,0.5), 0 0 18px var(--vc-cyan);
}
.map-pin .ring {
  position: absolute; left: 50%; top: 6px;
  width: 12px; height: 12px; border-radius: 50%;
  background: var(--alert);
  transform: translate(-50%, -50%);
  animation: pinRing 1.5s ease-out infinite;
  z-index: -1;
}
@keyframes pinRing {
  0%   { transform: translate(-50%, -50%) scale(1);   opacity: 0.5; }
  100% { transform: translate(-50%, -50%) scale(4.5); opacity: 0; }
}
.map-pin .lbl {
  margin-top: 6px;
  padding: 3px 8px;
  background: rgba(8,3,15,0.92);
  border: 1px solid rgba(255,255,255,0.18);
  font-family: 'Pricedown Bl', 'Pricedown', sans-serif;
  font-size: 11px; letter-spacing: 0.06em;
  color: #fff; text-transform: lowercase;
  white-space: nowrap;
  box-shadow: 0 4px 12px rgba(0,0,0,0.6);
}
.map-pin.live .lbl { color: var(--alert); border-color: var(--alert); }
.map-pin.next .lbl { color: var(--vc-cyan); border-color: var(--vc-cyan); }

/* =========================================================
   TURF MAP — premium 3D edition · neon beams over tilted world
   ========================================================= */
.turf-section {
  padding: 120px 32px 100px;
  background:
    radial-gradient(ellipse 60% 40% at 50% 0%, rgba(70,229,229,0.1), transparent 60%),
    radial-gradient(ellipse 80% 50% at 50% 100%, rgba(255,58,163,0.12), transparent 60%),
    var(--bg-0);
  position: relative;
  overflow: hidden;
  isolation: isolate;
}

/* === Section head meta column === */
.turf-meta {
  display: flex; flex-direction: column; gap: 14px; align-items: flex-end;
}
.turf-filter { display: flex; gap: 6px; flex-wrap: wrap; justify-content: flex-end; }
.turf-chip {
  padding: 8px 14px;
  min-height: 44px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-family: 'Pricedown Bl', 'Pricedown', sans-serif;
  font-size: 14px; letter-spacing: 0.04em; text-transform: lowercase;
  border: 1px solid var(--hair-strong);
  color: var(--ink-2); background: rgba(0,0,0,0.4);
  cursor: pointer;
  transition: all 0.15s ease;
}
.turf-chip.on {
  background: linear-gradient(90deg, var(--vc-cyan), var(--vc-pink));
  border-color: transparent; color: #08030f;
}
.turf-chip:hover:not(.on) { color: var(--vc-pink); border-color: var(--vc-pink); }
.turf-counter {
  text-align: right;
  padding: 8px 14px;
  border: 1px solid var(--hair-strong);
  background: rgba(0,0,0,0.5);
  backdrop-filter: blur(6px);
}
.turf-counter .num {
  font-family: 'JetBrains Mono', monospace;
  font-size: 28px; font-weight: 700;
  color: var(--gold);
  line-height: 1;
  text-shadow: 0 0 12px rgba(240,192,64,0.4);
}
.turf-counter .num .den { color: var(--ink-2); font-size: 18px; }
.turf-counter .lbl {
  font-size: 9px; letter-spacing: 0.32em;
  color: var(--ink-2); text-transform: uppercase; font-weight: 700;
  margin-top: 4px;
}

/* Legend strip — badge shape decoder */
.turf-legend {
  max-width: 1480px;
  margin: 0 auto 22px;
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 10px;
  position: relative; z-index: 2;
}
.turf-legend .legend-chip {
  display: flex; align-items: center; gap: 12px;
  padding: 10px 14px;
  background: linear-gradient(180deg, rgba(17,6,38,0.85), rgba(8,3,15,0.92));
  border: 1px solid var(--hair-strong);
  position: relative;
  overflow: hidden;
}
.turf-legend .legend-chip::before {
  content: "";
  position: absolute; left: 0; top: 0; bottom: 0; width: 3px;
  background: linear-gradient(180deg, var(--vc-cyan), var(--vc-pink));
}
.turf-legend .legend-chip svg {
  flex: none;
  filter: drop-shadow(0 4px 10px rgba(0,0,0,0.6));
}
.turf-legend .legend-meta .lbl {
  font-family: 'Pricedown Bl','Pricedown','Bowlby One SC',sans-serif;
  font-size: 18px; letter-spacing: 0.04em;
  color: #fff; text-transform: lowercase; line-height: 1;
  -webkit-text-stroke: 1px #0a0014; paint-order: stroke fill;
}
.turf-legend .legend-meta .sub {
  font-family: 'JetBrains Mono', monospace;
  font-size: 9.5px; letter-spacing: 0.16em;
  color: var(--ink-2); margin-top: 4px;
  text-transform: uppercase; font-weight: 600;
}

/* === The 3D stage === */
.turf-stage {
  position: relative;
  max-width: 1480px; margin: 0 auto;
  aspect-ratio: 16 / 9;
  border: 1px solid var(--hair-strong);
  background:
    radial-gradient(ellipse 100% 50% at 50% 100%, #1a0a3a 0%, #050111 70%);
  overflow: hidden;
  perspective: 2200px;
  perspective-origin: 50% 30%;
  box-shadow:
    0 80px 160px -40px rgba(255,58,163,0.4),
    inset 0 0 160px rgba(70,229,229,0.07),
    inset 0 0 0 1px rgba(255,255,255,0.04);
}

/* Sky backdrop above the horizon — Miami sunset gradient */
.turf-sky {
  position: absolute; left: 0; right: 0; top: 0; height: 38%;
  z-index: 0;
  background:
    radial-gradient(ellipse 80% 100% at 50% 100%, rgba(255,138,58,0.35), transparent 70%),
    radial-gradient(ellipse 60% 100% at 30% 100%, rgba(255,58,163,0.25), transparent 70%),
    linear-gradient(180deg, #0a0322 0%, #2a0a4a 60%, #4a1582 90%, #6e2cb0 100%);
  pointer-events: none;
}
.turf-sky::before {
  /* stars */
  content: "";
  position: absolute; inset: 0;
  background-image:
    radial-gradient(1px 1px at 8% 20%, #fff 100%, transparent),
    radial-gradient(1px 1px at 22% 38%, #fff 100%, transparent),
    radial-gradient(1.5px 1.5px at 38% 15%, rgba(255,255,255,0.9) 100%, transparent),
    radial-gradient(1px 1px at 56% 28%, #fff 100%, transparent),
    radial-gradient(1px 1px at 72% 10%, rgba(255,255,255,0.7) 100%, transparent),
    radial-gradient(1px 1px at 86% 24%, #fff 100%, transparent),
    radial-gradient(2px 2px at 92% 8%, rgba(255,255,255,0.8) 100%, transparent),
    radial-gradient(1px 1px at 48% 6%, #fff 100%, transparent),
    radial-gradient(1px 1px at 66% 34%, #fff 100%, transparent);
  opacity: 0.8;
}
.turf-sky::after {
  /* horizon sun bloom */
  content: "";
  position: absolute; left: 50%; bottom: 0; width: 70%; height: 100%;
  transform: translateX(-50%);
  background: radial-gradient(ellipse 60% 80% at 50% 100%, rgba(255,200,120,0.5), transparent 60%);
  filter: blur(8px);
  pointer-events: none;
}
.turf-horizon {
  position: absolute; left: 0; right: 0; top: 36%; height: 4%;
  z-index: 1;
  background: linear-gradient(180deg, transparent 0%, rgba(70,229,229,0.55) 40%, rgba(70,229,229,0.85) 50%, rgba(70,229,229,0.55) 60%, transparent 100%);
  filter: blur(1.5px);
  pointer-events: none;
  opacity: 0.6;
}
/* Inner vignette */
.turf-vignette {
  position: absolute; inset: 0;
  z-index: 7;
  pointer-events: none;
  background:
    radial-gradient(ellipse 100% 80% at 50% 60%, transparent 50%, rgba(0,0,0,0.65) 100%);
}

/* the 3D world container (rotated) */
.turf-world {
  position: absolute;
  inset: 0;
  transform-style: preserve-3d;
  transition: transform 0.5s cubic-bezier(0.16,1,0.3,1);
  transform-origin: 50% 50%;
}

/* The flat plane — visually flat after world rotation. */
.turf-plane {
  position: absolute;
  inset: -2% -2% -2% -2%;
  transform-style: preserve-3d;
}
.turf-plane-svg {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
}
.turf-floor-glow {
  position: absolute; inset: 0;
  background:
    radial-gradient(ellipse 50% 30% at 50% 50%, rgba(70,229,229,0.18), transparent 70%),
    radial-gradient(ellipse 40% 25% at 25% 60%, rgba(255,58,163,0.18), transparent 70%);
  mix-blend-mode: screen;
  pointer-events: none;
}

/* Beam containers in 3D */
.turf-beams {
  position: absolute; inset: 0;
  transform-style: preserve-3d;
  z-index: 3;
}

/* === BEAM === */
.beam-3d {
  position: absolute;
  width: 0; height: 0;
  background: none; border: none; padding: 0;
  cursor: pointer;
  transform-style: preserve-3d;
  /* the beam's anchor point sits on the plane */
  transform: translate(-50%, -50%);
}

/* Floor pad — sits flush on the plane */
.beam-3d .b3-pad {
  position: absolute;
  left: -22px; top: -7px;
  width: 44px; height: 14px;
  background: radial-gradient(ellipse 50% 50% at 50% 50%, var(--bc) 0%, transparent 65%);
  filter: blur(2.5px);
  opacity: 0.85;
}
/* Pulse ring on the plane */
.beam-3d .b3-ring {
  position: absolute;
  left: -28px; top: -10px;
  width: 56px; height: 20px;
  border-radius: 50%;
  border: 1.5px solid var(--bc);
  opacity: 0;
  animation: ringPulse 2.8s ease-out infinite;
}
@keyframes ringPulse {
  0%   { opacity: 0;    transform: scale(0.3); }
  20%  { opacity: 0.5; }
  100% { opacity: 0;    transform: scale(2.2); }
}

/* Vertical shaft wrap — counter-rotated to stand UPRIGHT */
.beam-3d .b3-shaft-wrap {
  position: absolute;
  left: 0; top: 0;
  width: 0; height: 0;
  transform-style: preserve-3d;
  /* counter the world's rotateX(52deg) so this stands vertical */
  transform: rotateX(-52deg);
  transform-origin: center bottom;
}
/* Core shaft */
.beam-3d .b3-shaft {
  position: absolute;
  left: -1.5px; bottom: 0;
  width: 3px; height: 180px;
  background: linear-gradient(180deg, var(--bc) 0%, color-mix(in oklab, var(--bc) 40%, transparent) 60%, transparent 100%);
  box-shadow:
    0 0 4px var(--bc),
    0 0 14px var(--bc),
    0 0 32px color-mix(in oklab, var(--bc) 70%, transparent);
  border-radius: 3px;
  transform-origin: bottom center;
  transition: height 0.3s ease, box-shadow 0.2s ease;
}
.beam-3d .b3-shaft.inner {
  left: -0.5px;
  width: 1px;
  background: linear-gradient(180deg, #fff 0%, var(--bc) 30%, transparent 100%);
  box-shadow: 0 0 6px #fff, 0 0 12px var(--bc);
  opacity: 0.9;
}
/* Outer cone of light — wider soft glow */
.beam-3d .b3-cone {
  position: absolute;
  left: -18px; bottom: 0;
  width: 36px; height: 210px;
  background: linear-gradient(180deg,
    color-mix(in oklab, var(--bc) 55%, transparent) 0%,
    color-mix(in oklab, var(--bc) 20%, transparent) 50%,
    transparent 90%);
  filter: blur(11px);
  border-radius: 50% 50% 30% 30% / 80% 80% 20% 20%;
  pointer-events: none;
  animation: coneFlicker 3.4s ease-in-out infinite;
}
@keyframes coneFlicker {
  0%, 100% { opacity: 0.7; }
  50%      { opacity: 1; }
}
/* Particles rising up the beam */
.beam-3d .b3-particles {
  position: absolute;
  left: -2px; bottom: 0;
  width: 4px; height: 180px;
  pointer-events: none;
}
.beam-3d .b3-particles span {
  position: absolute;
  left: 0;
  width: 4px; height: 4px;
  border-radius: 50%;
  background: var(--bc);
  box-shadow: 0 0 8px var(--bc);
  animation: rise 2.8s linear infinite;
  opacity: 0;
}
.beam-3d .b3-particles span:nth-child(1) { animation-delay: 0s;   }
.beam-3d .b3-particles span:nth-child(2) { animation-delay: 0.7s; }
.beam-3d .b3-particles span:nth-child(3) { animation-delay: 1.4s; }
.beam-3d .b3-particles span:nth-child(4) { animation-delay: 2.1s; left: 1px; }
@keyframes rise {
  0%   { bottom: 0;     opacity: 0;   transform: scale(0.4); }
  15%  { opacity: 1; }
  100% { bottom: 180px; opacity: 0;   transform: scale(0.2); }
}

/* Second pulse ring on the plane */
.beam-3d .b3-ring.r2 {
  animation-delay: 1.4s;
}

/* === BADGE — SVG container === */
.beam-3d .b3-badge {
  position: absolute;
  left: 0; bottom: 0;
  width: 0; height: 0;
  /* same counter-rotation as shaft to stand vertical */
  transform: rotateX(-54deg) translateY(-180px);
  transform-origin: center bottom;
  transform-style: preserve-3d;
  z-index: 4;
}
.beam-3d .b3-svg {
  position: absolute;
  left: -26px;
  top: -26px;
  filter: drop-shadow(0 6px 16px rgba(0,0,0,0.7)) drop-shadow(0 0 12px var(--bc));
  transition: transform 0.2s ease;
}
.beam-3d.host .b3-svg {
  filter: drop-shadow(0 6px 16px rgba(0,0,0,0.7)) drop-shadow(0 0 18px var(--gold));
}

/* hover + active states */
.beam-3d:hover .b3-svg,
.beam-3d.active .b3-svg {
  transform: scale(1.3);
}
.beam-3d:hover .b3-shaft,
.beam-3d.active .b3-shaft {
  height: 220px;
  box-shadow:
    0 0 8px var(--bc),
    0 0 26px var(--bc),
    0 0 56px var(--bc);
}
.beam-3d:hover .b3-cone,
.beam-3d.active .b3-cone {
  height: 250px;
  opacity: 1;
}
.beam-3d.active::after {
  content: "";
  position: absolute;
  left: -32px; top: -12px;
  width: 64px; height: 24px;
  border-radius: 50%;
  border: 2px solid var(--bc);
  animation: claimPulse 0.7s ease-out;
}
@keyframes claimPulse {
  0%   { opacity: 1; transform: scale(0.5); }
  100% { opacity: 0; transform: scale(3); }
}
.beam-3d.claimed .b3-shaft {
  background: linear-gradient(180deg, var(--gold) 0%, color-mix(in oklab, var(--gold) 40%, transparent) 60%, transparent 100%);
  box-shadow:
    0 0 4px var(--gold),
    0 0 14px var(--gold),
    0 0 36px color-mix(in oklab, var(--gold) 70%, transparent);
}

/* Tooltip — screen-space (not rotated) */
.turf-tip {
  position: absolute;
  transform: translate(-50%, -100%);
  z-index: 10;
  min-width: 200px;
  padding: 10px 14px;
  background: rgba(8,3,15,0.94);
  border: 1px solid var(--bc);
  pointer-events: none;
  box-shadow:
    0 0 0 1px rgba(0,0,0,0.5),
    0 12px 30px rgba(0,0,0,0.7),
    0 0 28px color-mix(in oklab, var(--bc) 30%, transparent);
}
.turf-tip .tt-row {
  display: flex; justify-content: space-between; align-items: center;
  margin-bottom: 4px;
}
.turf-tip .tt-code {
  font-family: 'JetBrains Mono', monospace;
  font-size: 10px; letter-spacing: 0.22em; color: var(--ink-2); text-transform: uppercase;
}
.turf-tip .tt-heat .s { color: rgba(240,192,64,0.18); font-size: 10px; }
.turf-tip .tt-heat .s.on { color: var(--gold); }
.turf-tip .tt-name {
  font-family: 'Pricedown Bl', 'Pricedown', sans-serif;
  font-size: 22px; line-height: 1; letter-spacing: 0.02em; color: #fff;
  text-transform: lowercase;
}
.turf-tip .tt-crew {
  font-size: 12px; color: var(--bc); margin-top: 4px;
  letter-spacing: 0.04em; font-weight: 600;
}
.turf-tip .tt-host {
  font-size: 9px; letter-spacing: 0.32em;
  color: var(--gold); margin-top: 5px;
  font-weight: 700;
}

/* HUD corner labels — IFR HUD style */
.turf-hud-corner {
  position: absolute;
  z-index: 5;
  font-family: 'JetBrains Mono', monospace;
  font-size: 9.5px;
  letter-spacing: 0.16em;
  color: var(--ink-2);
  text-transform: uppercase;
  padding: 6px 10px;
  background: rgba(8,3,15,0.55);
  border: 1px solid var(--hair);
  backdrop-filter: blur(6px);
  pointer-events: none;
}
.turf-hud-corner .k { color: var(--ink-2); }
.turf-hud-corner .v { color: var(--vc-cyan); margin-top: 2px; font-weight: 600; }
.turf-hud-corner.tl { top: 16px; left: 16px; }
.turf-hud-corner.tr { top: 16px; right: 16px; text-align: right; }
.turf-hud-corner.bl { bottom: 16px; left: 16px; }
.turf-hud-corner.br { bottom: 16px; right: 16px; text-align: right; }

/* Scanline overlay */
.turf-scan {
  position: absolute; inset: 0;
  pointer-events: none;
  z-index: 6;
  background: repeating-linear-gradient(0deg, rgba(255,255,255,0) 0 2px, rgba(255,255,255,0.025) 2px 3px);
  mix-blend-mode: overlay;
  opacity: 0.6;
}

/* === Detail panel === */
.turf-detail {
  margin: 28px auto 0;
  max-width: 1480px;
  display: grid;
  grid-template-columns: auto 1fr auto auto;
  align-items: center;
  gap: 28px;
  padding: 18px 22px;
  background: linear-gradient(180deg, var(--bg-1), var(--bg-2));
  border: 1px solid var(--hair-strong);
  border-left: 4px solid var(--vc-pink);
  position: relative;
  overflow: hidden;
  animation: detailIn 0.35s cubic-bezier(0.16,1,0.3,1);
}
.turf-detail::before {
  content: ""; position: absolute; top: 0; left: 0; right: 0; height: 2px;
  background: linear-gradient(90deg, var(--vc-cyan), var(--vc-pink));
}
@keyframes detailIn {
  from { opacity: 0; transform: translateY(14px); }
  to   { opacity: 1; transform: translateY(0); }
}
.d-flag {
  position: relative;
  width: 88px; height: 60px;
  border: 2px solid #fff;
  outline: 1px solid #0a0014;
  outline-offset: -3px;
  overflow: hidden;
  display: flex; align-items: center; justify-content: center;
  box-shadow: 0 8px 24px rgba(0,0,0,0.55);
}
.d-flag .d-flag-code {
  font-family: 'Pricedown Bl', 'Pricedown', sans-serif;
  font-size: 22px;
  color: #fff;
  letter-spacing: 0.04em;
  -webkit-text-stroke: 2px #0a0014;
  paint-order: stroke fill;
}
.d-flag .d-flag-shine {
  position: absolute; top: 0; left: -100%;
  width: 60%; height: 100%;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,0.6), transparent);
  transform: skewX(-20deg);
  animation: dShine 3s ease-in-out infinite;
}
@keyframes dShine {
  0%, 70% { left: -100%; }
  85%      { left: 120%; }
  100%     { left: 120%; }
}
.d-eyebrow {
  font-size: 10px; letter-spacing: 0.32em; color: var(--ink-2);
  text-transform: uppercase; font-weight: 700;
}
.d-title {
  font-family: 'Pricedown Bl', 'Pricedown', sans-serif;
  font-size: 40px; line-height: 1;
  color: #fff;
  -webkit-text-stroke: 2px #0a0014; paint-order: stroke fill;
  text-transform: lowercase;
  margin-top: 4px;
}
.d-crew { font-size: 13px; color: var(--vc-cyan); margin-top: 6px; letter-spacing: 0.06em; font-weight: 600; }
.d-stats { display: flex; gap: 22px; }
.d-stats > div { text-align: center; }
.d-stats .lbl { font-size: 9px; letter-spacing: 0.3em; color: var(--ink-2); text-transform: uppercase; font-weight: 700; }
.d-stats .v {
  font-family: 'JetBrains Mono', monospace;
  font-size: 20px; color: var(--vc-cyan); font-weight: 600;
  margin-top: 2px;
}
.btn-sunset.claimed {
  background: linear-gradient(90deg, var(--gold), #fff5d1);
  color: #08030f;
}

@media (max-width: 1100px) {
  .turf-stage { aspect-ratio: 4 / 3; }
  .turf-legend { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 760px) {
  .turf-stage { aspect-ratio: 1 / 1; }
  .beam-3d .b3-shaft, .beam-3d .b3-shaft.inner { height: 110px; }
  .beam-3d .b3-cone { height: 140px; }
  .beam-3d .b3-particles { height: 110px; }
  .beam-3d .b3-particles span:nth-child(3),
  .beam-3d .b3-particles span:nth-child(4) { display: none; }
  .beam-3d .b3-badge { transform: rotateX(-54deg) translateY(-110px); }
  .beam-3d .b3-svg { width: 38px; height: 38px; left: -19px; top: -19px; }
  .turf-legend { grid-template-columns: 1fr; }
  .turf-detail { grid-template-columns: 1fr; text-align: left; }
}

.mlog-list { display: flex; flex-direction: column; gap: 12px; }
.mlog-card {
  display: grid; grid-template-columns: 92px 1fr auto; gap: 18px; align-items: center;
  padding: 18px 20px;
  background:
    linear-gradient(90deg, rgba(255,58,163,0.08), transparent 42%),
    linear-gradient(180deg, rgba(45,9,88,0.94), rgba(22,4,48,0.96));
  border: 1px solid rgba(255,255,255,0.12);
  border-left: 4px solid var(--ink-3);
  box-shadow: 0 14px 28px rgba(0,0,0,0.26), inset 0 1px 0 rgba(255,255,255,0.08);
  transition: border-color 0.15s ease, transform 0.15s ease, box-shadow 0.15s ease;
  cursor: pointer;
}
.mlog-card:hover { transform: translateX(3px); border-left-color: var(--vc-pink); box-shadow: 0 18px 34px rgba(0,0,0,0.34), 0 0 22px rgba(255,58,163,0.12); }
.mlog-card.live {
  border-left-color: var(--alert);
  background:
    linear-gradient(90deg, rgba(255,58,91,0.2), transparent 44%),
    linear-gradient(180deg, rgba(65,7,68,0.96), rgba(29,4,50,0.98));
  box-shadow: 0 18px 36px rgba(0,0,0,0.35), 0 0 26px rgba(255,58,91,0.18);
}
.mlog-card.next {
  border-left-color: var(--vc-cyan);
  background:
    linear-gradient(90deg, rgba(70,229,229,0.16), transparent 42%),
    linear-gradient(180deg, rgba(16,22,72,0.96), rgba(19,4,48,0.98));
}
.mlog-card.up {
  border-left-color: var(--gold);
}
.mlog-card.done { opacity: 0.68; border-left-color: rgba(255,255,255,0.28); filter: grayscale(0.18); }
.mlog-when { font-family: 'JetBrains Mono', monospace; font-size: 11px; color: var(--ink-2); line-height: 1.4; }
.mlog-when .date { color: var(--vc-cyan); font-weight: 600; }
.contract-id {
  margin-top: 8px;
  color: var(--gold);
  font-weight: 800;
  letter-spacing: 0.16em;
}
.mlog-mid .pair {
  font-family: 'Pricedown Bl', 'Pricedown', 'Bowlby One SC', sans-serif;
  font-size: 24px; letter-spacing: 0.02em; text-transform: lowercase;
  display: flex; align-items: center; gap: 10px;
  color: #fff;
}
.mlog-mid .mname { font-size: 11px; letter-spacing: 0.22em; text-transform: uppercase; color: var(--vc-pink); margin-top: 2px; font-weight: 700; }
.contract-objective,
.mlog-mid .venue { font-size: 11px; color: var(--ink-2); letter-spacing: 0.04em; margin-top: 5px; }
.contract-objective {
  color: rgba(255,255,255,0.74);
}
.heist-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 10px;
}
.heist-meta span {
  padding: 4px 8px;
  border: 1px solid rgba(255,255,255,0.12);
  background: rgba(0,0,0,0.22);
  color: var(--ink-1);
  font-family: 'JetBrains Mono', monospace;
  font-size: 10px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}
.mlog-badge {
  font-family: 'Pricedown Bl', 'Pricedown', 'Bowlby One SC', sans-serif;
  font-size: 13px; letter-spacing: 0.06em; text-transform: lowercase;
  padding: 8px 14px;
  border: 1px solid var(--ink-3);
  color: var(--ink-2);
  min-width: 112px;
  text-align: center;
}
.mlog-badge.live { color: #fff; border-color: var(--alert); background: var(--alert); }
.mlog-badge.next { color: #08030f; border-color: var(--vc-cyan); background: var(--vc-cyan); }
.mlog-badge.up { color: var(--gold); border-color: rgba(255,210,58,0.42); background: rgba(255,210,58,0.08); }
.mlog-badge.done { color: var(--ink-2); }

/* =========================================================
   Operation Dossier
   ========================================================= */
.dossier-wrap { max-width: 1360px; margin: 0 auto; display: grid; grid-template-columns: 1fr 1.1fr; gap: 36px; align-items: stretch; }
.dossier-stats { display: grid; grid-template-columns: 1fr 1fr; gap: 1px; background: var(--hair-strong); border: 1px solid var(--hair-strong); }
.dossier-stat { background: var(--bg-1); padding: 22px 24px; position: relative; }
.dossier-stat .k { font-size: 10px; letter-spacing: 0.32em; color: var(--ink-2); text-transform: uppercase; font-weight: 700; }
.dossier-stat .v {
  font-family: 'Pricedown Bl', 'Pricedown', 'Bowlby One SC', sans-serif;
  font-size: 28px; text-transform: lowercase;
  margin-top: 8px;
  color: #fff;
  -webkit-text-stroke: 2px #0a0014; paint-order: stroke fill;
}
.dossier-stat .v.mono { font-family: 'JetBrains Mono', monospace; font-size: 20px; color: var(--vc-cyan); -webkit-text-stroke: 0; text-transform: none; }
.dossier-stat .v.gold { color: var(--gold); }
.dossier-stat .v.live-pink { color: var(--alert); }
.dossier-stat.live::after {
  content: "● LIVE";
  position: absolute; top: 14px; right: 16px;
  font-size: 9px; letter-spacing: 0.22em; color: var(--alert);
  font-family: 'Inter', sans-serif; font-weight: 800;
}

.dossier-side {
  background: linear-gradient(180deg, var(--bg-1), var(--bg-2));
  border: 1px solid var(--hair-strong);
  padding: 28px;
  display: flex; flex-direction: column; gap: 16px;
  position: relative;
}
.dossier-side::before { content: ""; position: absolute; top: 0; left: 0; right: 0; height: 2px; background: linear-gradient(90deg, var(--vc-cyan), var(--vc-pink)); }
.dossier-side .ca-row {
  display: flex; align-items: center; gap: 10px;
  padding: 14px 16px;
  background: #07020e;
  border: 1px solid var(--hair);
}
.dossier-side .ca-row .lbl { font-size: 10px; letter-spacing: 0.28em; color: var(--ink-2); text-transform: uppercase; font-weight: 700; }
.dossier-side .ca-row .val { flex: 1; font-family: 'JetBrains Mono', monospace; color: var(--vc-cyan); font-size: 12px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; font-weight: 600; }
.dossier-side .copy-btn {
  padding: 7px 12px;
  background: linear-gradient(90deg, var(--vc-cyan), var(--vc-pink));
  color: #08030f;
  font-family: 'Pricedown Bl', 'Pricedown', 'Bowlby One SC', sans-serif;
  font-size: 12px; letter-spacing: 0.04em; text-transform: lowercase;
}
.dossier-side .social-row { display: flex; gap: 10px; }
.dossier-side .social-row a {
  flex: 1; display: flex; align-items: center; justify-content: center; gap: 8px;
  padding: 12px;
  background: var(--bg-2); border: 1px solid var(--hair);
  font-family: 'Pricedown Bl', 'Pricedown', 'Bowlby One SC', sans-serif;
  font-size: 16px; letter-spacing: 0.02em; color: var(--ink-0);
  text-transform: lowercase;
  transition: all 0.15s ease;
}
.dossier-side .social-row a:hover { border-color: var(--vc-pink); color: var(--vc-pink); }
.dossier-side .buy-cta { margin-top: auto; text-align: center; }

/* =========================================================
   Final CTA section — "join the crew" cinematic close
   ========================================================= */
.cta-section {
  position: relative;
  padding: 140px 32px 160px;
  overflow: hidden;
  background-color: #1a0a3a;
  background-image: url('assets/tg-banner.jpg');
  background-size: cover;
  background-position: center;
  text-align: center;
  isolation: isolate;
}
.cta-section::before {
  /* darker readability overlay */
  content: "";
  position: absolute; inset: 0;
  background:
    radial-gradient(ellipse 60% 40% at 50% 50%, rgba(0,0,0,0.35), transparent 70%),
    linear-gradient(180deg, rgba(8,3,15,0.55) 0%, transparent 25%, transparent 75%, rgba(8,3,15,0.7) 100%);
  pointer-events: none;
  z-index: 1;
}
.cta-section .palm-art {
  position: absolute; inset: 0; z-index: 2; pointer-events: none;
}
.cta-section .palm-art svg { width: 100%; height: 100%; display: block; }
.cta-inner { position: relative; z-index: 3; max-width: 1100px; margin: 0 auto; }
.cta-coin {
  display: block;
  width: clamp(180px, 18vw, 260px);
  height: auto;
  margin: 0 auto 28px;
  filter:
    drop-shadow(0 0 32px rgba(255,200,80,0.55))
    drop-shadow(0 20px 40px rgba(0,0,0,0.55));
}
@keyframes coinSpin {
  0%   { transform: rotateY(0deg); }
  100% { transform: rotateY(360deg); }
}
.cta-eyebrow {
  display: inline-flex; align-items: center; gap: 12px;
  font-size: 12px; letter-spacing: 0.42em;
  color: #fff; font-weight: 700; text-transform: uppercase;
  padding: 9px 18px;
  background: rgba(0,0,0,0.5);
  border: 1px solid rgba(255,255,255,0.3);
  backdrop-filter: blur(6px);
}
.cta-eyebrow .dot {
  width: 8px; height: 8px; border-radius: 50%;
  background: var(--vc-pink); box-shadow: 0 0 14px var(--vc-pink);
  animation: pulse 1.2s infinite;
}
.cta-title {
  margin-top: 28px;
  font-family: 'Pricedown Bl', 'Pricedown', 'Bowlby One SC', sans-serif;
  font-size: clamp(64px, 9vw, 168px);
  line-height: 0.9;
  text-transform: lowercase;
  color: #fff;
  -webkit-text-stroke: 8px #0a0014;
  paint-order: stroke fill;
  text-shadow: 0 8px 0 rgba(0,0,0,0.5), 0 24px 50px rgba(0,0,0,0.5);
}
.cta-title .accent {
  background: linear-gradient(90deg, var(--vc-cyan), #ffffff 45%, var(--vc-pink));
  -webkit-background-clip: text; background-clip: text;
  color: transparent;
  -webkit-text-stroke: 8px #0a0014;
  paint-order: stroke fill;
}
.cta-tag {
  margin-top: 24px;
  font-size: clamp(15px, 1.4vw, 20px);
  letter-spacing: 0.22em;
  color: #fff; font-weight: 700;
  text-transform: uppercase;
  text-shadow: 0 2px 8px rgba(0,0,0,0.6);
}
.cta-cta-row {
  margin-top: 40px;
  display: flex; gap: 14px; justify-content: center; flex-wrap: wrap;
}
/* crew chooser pills */
.cta-crews {
  margin-top: 64px;
  display: flex; gap: 10px; flex-wrap: wrap; justify-content: center;
}
.crew-pill {
  display: inline-flex; align-items: center; gap: 8px;
  min-height: 44px;
  padding: 10px 16px;
  background: rgba(0,0,0,0.5);
  border: 1px solid rgba(255,255,255,0.3);
  font-family: 'Pricedown Bl', 'Pricedown', sans-serif;
  font-size: 16px; letter-spacing: 0.04em; text-transform: lowercase;
  color: #fff;
  backdrop-filter: blur(6px);
  cursor: pointer;
  transition: all 0.15s ease;
}
.crew-pill:hover, .crew-pill.on {
  background: linear-gradient(90deg, var(--vc-cyan), var(--vc-pink));
  border-color: transparent; color: #08030f;
  transform: translateY(-1px);
}
.crew-pill .fl { width: 22px; height: 14px; overflow: hidden; border-radius: 1px; }

.btn-social {
  min-height: 52px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  padding: 14px 22px;
  border: 1px solid rgba(255,255,255,0.22);
  color: #fff;
  background:
    repeating-linear-gradient(135deg, rgba(255,255,255,0.055) 0 4px, transparent 4px 11px),
    rgba(8,1,18,0.62);
  font-family: 'Pricedown Bl', 'Pricedown', 'Bowlby One SC', sans-serif;
  font-size: 20px;
  line-height: 0.95;
  text-transform: lowercase;
  box-shadow: inset 0 -3px 0 rgba(0,0,0,0.24);
}
.btn-social.x {
  border-color: rgba(70,229,229,0.68);
  box-shadow: inset 0 -3px 0 rgba(0,0,0,0.24), 0 0 22px rgba(70,229,229,0.16);
}
.btn-social.tg {
  border-color: rgba(255,58,163,0.68);
  box-shadow: inset 0 -3px 0 rgba(0,0,0,0.24), 0 0 22px rgba(255,58,163,0.16);
}
.btn-social:hover {
  color: #08030f;
  background: linear-gradient(90deg, var(--vc-cyan), #fff 50%, var(--vc-pink));
}

/* =========================================================
   Footer
   ========================================================= */
.foot { border-top: 1px solid var(--hair); padding: 64px 32px 70px; background: var(--bg-0); position: relative; }
.foot::before { content: ""; position: absolute; top: 0; left: 0; right: 0; height: 1px; background: linear-gradient(90deg, transparent, var(--vc-pink) 30%, var(--vc-cyan) 70%, transparent); }
.foot-faq {
  position: relative;
  z-index: 1;
  max-width: 1360px;
  margin: 0 auto 36px;
  display: grid;
  grid-template-columns: minmax(220px, 0.34fr) 1fr;
  gap: 24px;
  align-items: start;
  padding-bottom: 34px;
  border-bottom: 1px solid rgba(255,255,255,0.08);
}
.foot-faq::before {
  content: "";
  position: absolute;
  inset: -18px -18px auto;
  height: 150px;
  pointer-events: none;
  background:
    linear-gradient(90deg, rgba(70,229,229,0.12), rgba(255,58,163,0.14), transparent 74%),
    repeating-linear-gradient(90deg, rgba(255,255,255,0.04) 0 1px, transparent 1px 54px);
  opacity: 0.75;
  mask-image: linear-gradient(180deg, #000 0%, transparent 100%);
}
.foot-faq-head {
  position: sticky;
  top: 86px;
  min-height: 160px;
  padding: 18px;
  border: 1px solid rgba(255,255,255,0.14);
  background:
    linear-gradient(135deg, rgba(70,229,229,0.12), rgba(255,58,163,0.14)),
    rgba(8,0,20,0.74);
  box-shadow: inset 0 0 0 1px rgba(0,0,0,0.65), 0 22px 70px rgba(0,0,0,0.35);
  overflow: hidden;
}
.foot-faq-head::after {
  content: "";
  position: absolute;
  right: -38px;
  bottom: -42px;
  width: 132px;
  height: 132px;
  border: 1px solid rgba(70,229,229,0.28);
  border-radius: 50%;
  box-shadow: 0 0 34px rgba(255,58,163,0.18), inset 0 0 34px rgba(70,229,229,0.16);
}
.foot-faq-head span {
  position: relative;
  z-index: 1;
  display: inline-flex;
  color: var(--vc-cyan);
  font-size: 10px;
  letter-spacing: 0.28em;
  text-transform: uppercase;
}
.foot-faq-head h3 {
  position: relative;
  z-index: 1;
  margin: 8px 0 8px;
  font-family: 'Pricedown Bl', 'Pricedown', 'Bowlby One SC', sans-serif;
  font-size: clamp(46px, 6vw, 78px);
  line-height: 0.82;
  color: #fff;
  -webkit-text-stroke: 3px #0a0014;
  paint-order: stroke fill;
  text-transform: lowercase;
}
.foot-faq-head p {
  position: relative;
  z-index: 1;
  max-width: 250px;
  margin: 0;
  color: var(--ink-1);
  font-size: 13px;
  line-height: 1.45;
}
.foot-faq-list {
  display: grid;
  gap: 10px;
}
.foot-faq-item {
  position: relative;
  border: 1px solid rgba(255,255,255,0.13);
  background: linear-gradient(90deg, rgba(14,0,34,0.92), rgba(35,8,72,0.66));
  box-shadow: inset 3px 0 0 rgba(255,58,163,0.8);
  overflow: hidden;
}
.foot-faq-item:nth-child(even) {
  box-shadow: inset 3px 0 0 rgba(70,229,229,0.85);
}
.foot-faq-item[open] {
  border-color: rgba(255,58,163,0.42);
  background:
    linear-gradient(90deg, rgba(255,58,163,0.13), rgba(70,229,229,0.08)),
    rgba(14,0,34,0.95);
}
.foot-faq-item summary {
  min-height: 58px;
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: 14px;
  align-items: center;
  padding: 16px 18px;
  cursor: pointer;
  list-style: none;
}
.foot-faq-item summary::-webkit-details-marker { display: none; }
.foot-faq-item summary::after {
  content: "+";
  width: 28px;
  height: 28px;
  display: grid;
  place-items: center;
  border: 1px solid rgba(255,255,255,0.16);
  color: var(--vc-cyan);
  font-family: 'JetBrains Mono', monospace;
  font-size: 17px;
  line-height: 1;
  background: rgba(0,0,0,0.24);
}
.foot-faq-item[open] summary::after {
  content: "-";
  color: var(--vc-pink);
}
.foot-faq-item summary span {
  color: var(--gold);
  font-size: 10px;
  letter-spacing: 0.16em;
}
.foot-faq-item summary strong {
  min-width: 0;
  color: #fff;
  font-family: 'Bebas Neue', 'Anton', sans-serif;
  font-size: clamp(18px, 2vw, 26px);
  line-height: 0.96;
  letter-spacing: 0.05em;
  text-transform: uppercase;
}
.foot-faq-item p {
  margin: 0;
  padding: 0 64px 18px 68px;
  color: var(--ink-1);
  font-size: 14px;
  line-height: 1.62;
}
.foot-inner { max-width: 1360px; margin: 0 auto; display: grid; gap: 24px; grid-template-columns: 1fr auto; align-items: end; }
.foot-left .ttl {
  font-family: 'Pricedown Bl', 'Pricedown', 'Bowlby One SC', sans-serif;
  font-size: 44px;
  color: #fff;
  -webkit-text-stroke: 3px #0a0014; paint-order: stroke fill;
  text-transform: lowercase; line-height: 0.95;
}
.foot-left .disclaimer { font-size: 11px; color: var(--ink-2); letter-spacing: 0.04em; max-width: 780px; margin-top: 12px; line-height: 1.6; }
.foot-right {
  display: flex; gap: 14px;
  font-family: 'Pricedown Bl', 'Pricedown', 'Bowlby One SC', sans-serif;
  font-size: 18px; text-transform: lowercase;
}
.foot-right a { color: var(--ink-2); }
.foot-right a:hover { color: var(--vc-pink); }

/* =========================================================
   PWA install hint
   ========================================================= */
.install-hint {
  position: fixed;
  bottom: 24px; left: 24px;
  z-index: 200;
  display: none;
  align-items: center; gap: 12px;
  padding: 12px 16px;
  background: linear-gradient(180deg, var(--bg-1), var(--bg-2));
  border: 1px solid var(--vc-pink);
  box-shadow: 0 0 24px rgba(255,58,163,0.3);
  max-width: 320px;
}
.install-hint.show { display: flex; }
.install-hint .ic {
  width: 36px; height: 36px;
  display: grid; place-items: center;
  background: linear-gradient(135deg, var(--vc-cyan), var(--vc-pink));
  color: #08030f;
  font-family: 'Pricedown Bl', 'Pricedown', 'Bowlby One SC', sans-serif;
  font-size: 22px;
}
.install-hint .tx { flex: 1; font-size: 12px; color: var(--ink-0); line-height: 1.3; }
.install-hint .tx b { display: block; font-weight: 700; }
.install-hint .x { color: var(--ink-2); padding: 4px 8px; font-size: 16px; cursor: pointer; }
.install-hint button.go {
  padding: 7px 12px;
  background: linear-gradient(90deg, var(--vc-cyan), var(--vc-pink));
  color: #08030f;
  font-family: 'Pricedown Bl', 'Pricedown', 'Bowlby One SC', sans-serif;
  font-size: 13px; letter-spacing: 0.04em; text-transform: lowercase;
}

/* =========================================================
   Responsive
   ========================================================= */
/* =========================================================
   GTA BANNER — diagonal-stripe section header
   (Style ref: 02-group-stage-turf-war / 04-pumpfun-getaway)
   ========================================================= */
.gta-banner {
  position: relative;
  width: 100%;
  max-width: 1480px;
  margin: 0 auto 36px;
  overflow: hidden;
  isolation: isolate;
  border: 1px solid #0a0014;
  box-shadow:
    0 30px 80px -20px rgba(0,0,0,0.8),
    0 0 0 1px rgba(255,58,163,0.2);
}
.gb-image {
  position: absolute; inset: 0;
  background-size: cover;
  background-position: center;
  z-index: 1;
}
/* Diagonal accent stripe — colored translucent panel on the left,
   ending in a slanted edge similar to the reference banners. */
.gb-stripe {
  position: absolute;
  left: 0; top: 0; bottom: 0;
  width: 42%;
  background: var(--accent);
  opacity: 0.55;
  z-index: 2;
  clip-path: polygon(0 0, 100% 0, 78% 100%, 0 100%);
  mix-blend-mode: multiply;
}
.gb-vignette {
  position: absolute; inset: 0; z-index: 3; pointer-events: none;
  background:
    radial-gradient(ellipse 50% 60% at 50% 50%, transparent 30%, rgba(0,0,0,0.6) 100%),
    linear-gradient(180deg, rgba(0,0,0,0.2), transparent 30%, transparent 70%, rgba(0,0,0,0.5));
}
.gb-scan {
  position: absolute; inset: 0; z-index: 4; pointer-events: none;
  background: repeating-linear-gradient(0deg, rgba(255,255,255,0) 0 3px, rgba(255,255,255,0.025) 3px 4px);
  mix-blend-mode: overlay;
  opacity: 0.5;
}

/* Character cutout — sits over the image */
.gb-character {
  position: absolute;
  bottom: -2%;
  height: 110%;
  z-index: 5;
  pointer-events: none;
  filter: drop-shadow(0 10px 24px rgba(0,0,0,0.6));
}
.gb-character.right { right: 4%; }
.gb-character.left  { left: 4%; }

/* Stars top-right */
.gb-stars {
  position: absolute;
  top: 22px; right: 28px;
  display: flex; gap: 4px;
  z-index: 6;
  font-size: 22px;
}
.gb-star.on  { color: #ffd23a; text-shadow: 0 2px 0 #0a0014, 0 0 12px rgba(255,210,58,0.8); -webkit-text-stroke: 1.5px #0a0014; paint-order: stroke fill; }
.gb-star.off { color: rgba(0,0,0,0.45); -webkit-text-stroke: 1.5px #0a0014; paint-order: stroke fill; }

/* Title block — anchored upper-left */
.gb-title-block {
  position: absolute;
  top: 28px; left: 28px;
  max-width: 70%;
  z-index: 6;
  display: flex; flex-direction: column; gap: 16px;
}
.gb-title {
  font-family: 'Pricedown Bl','Pricedown','Bowlby One SC',sans-serif;
  font-size: clamp(38px, 5.4vw, 78px);
  line-height: 0.92;
  letter-spacing: 0.005em;
  text-transform: lowercase;
  color: #fff5eb;
  -webkit-text-stroke: 5px #0a0014; paint-order: stroke fill;
  text-shadow:
    4px 4px 0 var(--accent),
    6px 6px 0 #0a0014,
    0 14px 30px rgba(0,0,0,0.5);
  margin: 0;
}

/* Tagline pill */
.gb-tagline { display: inline-flex; }
.gb-tagline-frame {
  display: inline-flex;
  padding: 10px 22px;
  background: #0a0014;
  border: 2.5px solid var(--pill-col);
  border-radius: 4px;
  box-shadow: 0 4px 0 #0a0014, 0 0 20px rgba(255,210,58,0.18);
}
.gb-tagline-frame span {
  font-family: 'Pricedown Bl','Pricedown','Bowlby One SC',sans-serif;
  font-size: clamp(14px, 1.5vw, 22px);
  letter-spacing: 0.06em;
  text-transform: lowercase;
  color: var(--pill-col);
  -webkit-text-stroke: 1px #0a0014; paint-order: stroke fill;
}

/* Bottom-left badge stack */
.gb-badges {
  position: absolute;
  bottom: 24px; left: 28px;
  display: flex; flex-direction: column; gap: 10px;
  z-index: 6;
  max-width: 50%;
}

/* Bottom-right $GCA lockup */
.gb-lockup {
  position: absolute;
  bottom: 24px; right: 28px;
  display: flex; align-items: center; gap: 12px;
  z-index: 6;
  padding: 10px 16px 10px 12px;
  background: rgba(0,0,0,0.75);
  border: 1.5px solid rgba(255,255,255,0.18);
  backdrop-filter: blur(6px);
}
.gb-lockup-text {
  display: flex; flex-direction: column; line-height: 1;
}
.gb-lockup-text .t {
  font-family: 'Pricedown Bl','Pricedown','Bowlby One SC',sans-serif;
  font-size: 26px;
  color: #fff;
  -webkit-text-stroke: 1.5px #0a0014; paint-order: stroke fill;
  letter-spacing: 0.02em; text-transform: lowercase;
}
.gb-lockup-text .s {
  font-size: 9px; letter-spacing: 0.28em; font-weight: 700;
  color: var(--accent);
  margin-top: 5px;
}

.gb-chip {
  position: absolute;
  bottom: 24px; left: 28px;
  z-index: 5;
  padding: 12px 24px;
  background: rgba(0,0,0,0.85);
  border: 1.5px solid rgba(255,255,255,0.25);
  font-family: 'Pricedown Bl','Pricedown','Bowlby One SC',sans-serif;
  font-size: 18px; letter-spacing: 0.06em;
  color: #fff5eb;
  text-transform: lowercase;
  -webkit-text-stroke: 0.5px #0a0014; paint-order: stroke fill;
}
.gb-badges + .gb-chip { display: none; }
/* If both gb-badges and gb-chip exist, gb-badges takes the corner.
   The .gb-chip class is also placed on the visible chip when no badges are passed. */

/* =========================================================
   BADGE PILL — slanted GTA pill, ref turf-record-stamp etc.
   ========================================================= */
.gta-pill {
  --pill-h: 56px;
  position: relative;
  width: 280px;
  height: var(--pill-h);
  filter: drop-shadow(0 0 14px color-mix(in oklab, var(--outline) 40%, transparent));
}
.gta-pill-frame {
  position: absolute; inset: 0;
  background: #15131e;
  border: 2.5px solid var(--outline);
  border-radius: 8px;
  display: grid;
  grid-template-columns: 1fr auto;
  align-items: center;
  padding: 0 8px 0 14px;
  overflow: hidden;
}
.gta-pill-frame::before {
  /* dark inner shadow stroke */
  content: "";
  position: absolute; inset: 1px;
  border: 1.5px solid #0a0014;
  border-radius: 6px;
  pointer-events: none;
}
/* The slanted accent slash that fills the right portion */
.gta-pill-slash {
  position: absolute;
  top: 2px; bottom: 2px; right: 52px; width: 80px;
  background: var(--slash);
  clip-path: polygon(60% 0, 100% 0, 100% 100%, 30% 100%);
  z-index: 1;
}
.gta-pill-stars {
  position: absolute;
  top: 4px; left: 12px;
  display: flex; gap: 1px;
  font-size: 11px;
  z-index: 3;
}
.gta-pill-stars span.on  { color: #ffd23a; text-shadow: 0 0 4px rgba(255,210,58,0.6); }
.gta-pill-stars span.off { color: rgba(255,255,255,0.18); }
.gta-pill-label {
  font-family: 'Pricedown Bl','Pricedown','Bowlby One SC',sans-serif;
  font-size: 22px;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: #fff5eb;
  -webkit-text-stroke: 1.5px #0a0014; paint-order: stroke fill;
  line-height: 1;
  z-index: 2;
  position: relative;
}
.gta-pill-sub {
  position: absolute;
  bottom: 4px; left: 12px;
  font-family: 'Pricedown Bl','Pricedown','Bowlby One SC',sans-serif;
  font-size: 12px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--sub-col);
  -webkit-text-stroke: 0.6px #0a0014; paint-order: stroke fill;
  z-index: 3;
}
.gta-pill-emblem {
  position: relative;
  z-index: 4;
  filter: drop-shadow(0 0 8px var(--outline));
  width: 42px; height: 42px;
}
.gta-pill-emblem svg {
  display: block;
}

@media (max-width: 760px) {
  .gta-pill { width: 240px; --pill-h: 48px; }
  .gta-pill-label { font-size: 18px; }
  .gta-pill-emblem { width: 36px; height: 36px; }
  .gta-pill-emblem svg { width: 36px; height: 36px; }
  .gb-title-block { max-width: 90%; }
  .gb-character { height: 80%; bottom: 0; opacity: 0.7; }
  .gb-badges { position: relative; max-width: 100%; padding: 0; bottom: auto; left: auto; margin-top: 12px; }
  .gb-lockup { display: none; }
}

/* =========================================================
   RANK LADDER — Crew tier section
   ========================================================= */
.ranks-section {
  padding: 110px 32px 96px;
  background:
    radial-gradient(ellipse 50% 40% at 20% 10%, rgba(70,229,229,0.08), transparent 60%),
    radial-gradient(ellipse 60% 50% at 90% 90%, rgba(255,58,163,0.1), transparent 60%),
    var(--bg-0);
}
.ranks-grid {
  max-width: 1480px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 16px;
}
.rank-card {
  position: relative;
  display: flex; flex-direction: column;
  border: 1.5px solid var(--hair-strong);
  background: linear-gradient(180deg, rgba(17,6,38,0.95), rgba(8,3,15,0.95));
  overflow: hidden;
  isolation: isolate;
  transition: transform 0.2s ease, border-color 0.2s ease;
  min-height: 540px;
}
.rank-card:hover {
  transform: translateY(-6px);
  border-color: var(--vc-pink);
}
.rc-char {
  position: relative;
  height: 320px;
  background:
    radial-gradient(ellipse 80% 60% at 50% 100%, rgba(255,58,163,0.45), transparent 70%),
    linear-gradient(180deg, #2a0a4a 0%, #0a0322 100%);
  overflow: hidden;
  display: flex; align-items: flex-end; justify-content: center;
}
.rc-char::before {
  /* halftone */
  content: "";
  position: absolute; inset: 0;
  background-image: radial-gradient(circle, rgba(255,122,200,0.18) 0.5px, transparent 1px);
  background-size: 6px 6px;
  z-index: 1;
}
.rc-char::after {
  /* city silhouette */
  content: "";
  position: absolute; left: 0; right: 0; bottom: 0; height: 36%;
  background:
    linear-gradient(180deg, transparent 0%, rgba(8,3,15,0.95) 100%);
  z-index: 2;
  pointer-events: none;
}
.rc-char img {
  position: relative; z-index: 3;
  height: 105%;
  object-fit: contain;
  object-position: bottom center;
  filter: drop-shadow(0 10px 16px rgba(0,0,0,0.6));
}
.rc-glow {
  position: absolute; left: 0; right: 0; top: 280px;
  height: 80px;
  background: radial-gradient(ellipse 50% 70% at 50% 30%, var(--vc-pink), transparent 70%);
  opacity: 0.5;
  filter: blur(20px);
  z-index: 0;
  pointer-events: none;
}
.rc-badge {
  position: relative;
  z-index: 4;
  margin: -34px 14px 0;
  filter: drop-shadow(0 8px 16px rgba(0,0,0,0.7));
}
.rc-badge img {
  width: 100%; height: auto;
  display: block;
}
.rc-meta {
  position: relative;
  z-index: 3;
  padding: 14px 16px 18px;
  flex: 1;
  display: flex; flex-direction: column;
}
.rc-tier {
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--ink-2);
  font-weight: 600;
}
.rc-name {
  font-family: 'Pricedown Bl','Pricedown','Bowlby One SC',sans-serif;
  font-size: 26px;
  line-height: 0.96;
  text-transform: lowercase;
  color: #fff;
  -webkit-text-stroke: 2.5px #0a0014; paint-order: stroke fill;
  margin: 4px 0 6px;
}
.rc-bag {
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px;
  letter-spacing: 0.16em;
  color: var(--gold);
  font-weight: 700;
}
.rc-perks {
  margin-top: 14px;
  list-style: none;
  display: flex; flex-direction: column; gap: 6px;
}
.rc-perks li {
  font-size: 12px;
  color: var(--ink-1);
  line-height: 1.35;
  letter-spacing: 0.02em;
}
.rank-card.tier-untouchable { border-color: rgba(255,87,112,0.6); }
.rank-card.tier-untouchable:hover { border-color: #ff5570; }
.rank-card.tier-cartel { border-color: rgba(160,43,255,0.6); }
.rank-card.tier-cartel:hover { border-color: #a02bff; }

@media (max-width: 1280px) {
  .ranks-grid { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 760px) {
  .ranks-grid { grid-template-columns: 1fr 1fr; gap: 12px; }
  .rank-card { min-height: 0; }
  .rc-char { height: 220px; }
  .rc-name { font-size: 20px; }
}

/* =========================================================
   CINEMATIC FLOW — scroll-reveal, mission rail,
   section dividers, micro-interactions
   ========================================================= */

/* ----- Generic reveal targets (data-reveal attribute) ----- */
[data-reveal] {
  opacity: 0;
  transform: translateY(28px);
  transition:
    opacity 0.7s cubic-bezier(0.16, 1, 0.3, 1),
    transform 0.7s cubic-bezier(0.16, 1, 0.3, 1);
  will-change: opacity, transform;
}
[data-reveal].revealed {
  opacity: 1;
  transform: translateY(0);
}

/* ----- GTA BANNER — staged choreography on reveal ----- */
.gta-banner { opacity: 0; transform: translateY(40px) scale(0.985); transition: opacity 0.7s cubic-bezier(0.16,1,0.3,1), transform 0.7s cubic-bezier(0.16,1,0.3,1); }
.gta-banner.revealed { opacity: 1; transform: translateY(0) scale(1); }
.gb-stripe        { transform: translateX(-30%); opacity: 0; transition: transform 0.9s cubic-bezier(0.16,1,0.3,1) 0.1s, opacity 0.5s ease 0.1s; }
.gb-title         { opacity: 0; transform: translateY(-10px) scale(0.94); filter: blur(8px); transition: opacity 0.6s ease 0.35s, transform 0.6s cubic-bezier(0.16,1,0.3,1) 0.35s, filter 0.6s ease 0.35s; }
.gb-tagline       { opacity: 0; transform: translateX(-18px); transition: opacity 0.5s ease 0.6s, transform 0.5s cubic-bezier(0.16,1,0.3,1) 0.6s; }
.gb-stars .gb-star { opacity: 0; transform: scale(0.4) rotate(-90deg); transition: opacity 0.4s ease calc(0.5s + var(--i, 0) * 0.08s), transform 0.5s cubic-bezier(0.34,1.56,0.64,1) calc(0.5s + var(--i, 0) * 0.08s); }
.gb-character     { opacity: 0; transform: translateX(60px) scale(0.96); filter: blur(8px); transition: opacity 0.7s ease 0.4s, transform 0.9s cubic-bezier(0.16,1,0.3,1) 0.4s, filter 0.7s ease 0.4s; }
.gb-character.left { transform: translateX(-60px) scale(0.96); }
.gb-badge-row     { opacity: 0; transform: translateY(20px); transition: opacity 0.5s ease calc(0.8s + var(--i, 0) * 0.12s), transform 0.5s cubic-bezier(0.16,1,0.3,1) calc(0.8s + var(--i, 0) * 0.12s); }
.gb-lockup        { opacity: 0; transform: translateY(20px); transition: opacity 0.5s ease 1.1s, transform 0.5s ease 1.1s; }
.gb-chip          { opacity: 0; transform: translateY(10px); transition: opacity 0.5s ease 1.2s, transform 0.5s ease 1.2s; }

.gta-banner.revealed .gb-stripe      { opacity: 0.55; transform: translateX(0); }
.gta-banner.revealed .gb-title       { opacity: 1; transform: translateY(0) scale(1); filter: blur(0); }
.gta-banner.revealed .gb-tagline     { opacity: 1; transform: translateX(0); }
.gta-banner.revealed .gb-stars .gb-star { opacity: 1; transform: scale(1) rotate(0); }
.gta-banner.revealed .gb-character   { opacity: 1; transform: translateX(0) scale(1); filter: blur(0); }
.gta-banner.revealed .gb-character.left { opacity: 1; transform: translateX(0) scale(1); }
.gta-banner.revealed .gb-badge-row   { opacity: 1; transform: translateY(0); }
.gta-banner.revealed .gb-lockup      { opacity: 1; transform: translateY(0); }
.gta-banner.revealed .gb-chip        { opacity: 1; transform: translateY(0); }

/* sweep light that slides across the banner after reveal */
.gb-sweep {
  position: absolute;
  top: 0; bottom: 0;
  left: -40%; width: 30%;
  background: linear-gradient(110deg, transparent, rgba(255,255,255,0.18) 50%, transparent);
  transform: skewX(-12deg);
  z-index: 4;
  pointer-events: none;
  opacity: 0;
}
.gta-banner.revealed .gb-sweep { animation: gb-sweep 1.4s cubic-bezier(0.16,1,0.3,1) 0.6s 1 forwards; }
@keyframes gb-sweep {
  0%   { left: -40%; opacity: 0; }
  10%  { opacity: 1; }
  90%  { opacity: 1; }
  100% { left: 130%; opacity: 0; }
}

/* Title ambient flicker after settled */
.gta-banner.revealed .gb-title {
  animation: gbTitleFlick 6s ease-in-out 1.6s infinite,
             gbTitleSettle 0.6s cubic-bezier(0.16,1,0.3,1) 0.35s backwards;
}
@keyframes gbTitleFlick {
  0%, 96%, 100% { text-shadow: 4px 4px 0 var(--accent), 6px 6px 0 #0a0014, 0 14px 30px rgba(0,0,0,0.5); }
  97%, 99%      { text-shadow: 3px 3px 0 var(--accent), 5px 5px 0 #0a0014, 0 14px 30px rgba(0,0,0,0.5), 0 0 24px var(--accent); }
}
@keyframes gbTitleSettle {
  from { opacity: 0; transform: translateY(-10px) scale(0.94); filter: blur(8px); }
  to   { opacity: 1; transform: translateY(0) scale(1); filter: blur(0); }
}

/* ----- Rank cards stagger ----- */
.rank-card {
  opacity: 0;
  transform: translateY(36px) scale(0.96);
  transition:
    opacity 0.7s cubic-bezier(0.16,1,0.3,1) calc(var(--i, 0) * 0.12s),
    transform 0.7s cubic-bezier(0.16,1,0.3,1) calc(var(--i, 0) * 0.12s),
    border-color 0.2s ease;
}
.rank-card.revealed { opacity: 1; transform: translateY(0) scale(1); }
.rank-card .rc-char img { transition: transform 0.5s cubic-bezier(0.16,1,0.3,1), filter 0.5s ease; }
.rank-card:hover .rc-char img {
  transform: translateY(-4%) scale(1.04);
  filter: drop-shadow(0 18px 28px rgba(0,0,0,0.7)) drop-shadow(0 0 22px var(--vc-pink));
}
.rank-card .rc-badge { transition: transform 0.4s cubic-bezier(0.16,1,0.3,1); }
.rank-card:hover .rc-badge { transform: translateY(-6px) scale(1.03); }
.rank-card .rc-corner {
  position: absolute;
  top: 12px; right: 12px;
  width: 28px; height: 28px;
  z-index: 5;
  pointer-events: none;
  border-top: 2px solid var(--vc-cyan);
  border-right: 2px solid var(--vc-cyan);
  opacity: 0.7;
  transition: width 0.3s ease, height 0.3s ease, opacity 0.3s ease, border-color 0.3s ease;
}
.rank-card:hover .rc-corner {
  width: 44px; height: 44px;
  opacity: 1;
  border-color: var(--vc-pink);
}

/* ----- Leaderboard row stagger ----- */
.leader-row[data-reveal] {
  transform: translateY(20px);
  transition-delay: calc(var(--i, 0) * 0.06s);
}
.leader-row[data-reveal].revealed { transform: translateY(0); }

/* ----- Mission log card stagger + hover stripe ----- */
.mlog-card[data-reveal] {
  transform: translateX(-30px);
  transition-delay: calc(var(--i, 0) * 0.08s);
}
.mlog-card[data-reveal].revealed { transform: translateX(0); }
.mlog-card { position: relative; overflow: hidden; }
.mlog-card::after {
  content: ""; position: absolute; right: 0; top: 0; bottom: 0; width: 3px;
  background: linear-gradient(180deg, var(--vc-cyan), var(--vc-pink));
  transform: scaleY(0);
  transform-origin: top;
  transition: transform 0.3s cubic-bezier(0.16,1,0.3,1);
  pointer-events: none;
  box-shadow: 0 0 12px var(--vc-pink);
}
.mlog-card:hover::after { transform: scaleY(1); }

/* =========================================================
   MISSION RAIL — vertical right-side scroll progress
   ========================================================= */
.mission-rail {
  position: fixed;
  top: 50%;
  right: 14px;
  transform: translateY(-50%);
  z-index: 80;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 12px;
  padding: 18px 12px;
  background: linear-gradient(180deg, rgba(17,6,38,0.55), rgba(8,3,15,0.78));
  border: 1px solid rgba(255,255,255,0.08);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  font-family: 'JetBrains Mono', monospace;
  transition: width 0.3s cubic-bezier(0.16,1,0.3,1), background 0.3s ease;
  pointer-events: auto;
  width: 40px;
  box-shadow: 0 30px 80px -20px rgba(0,0,0,0.7);
}
.mission-rail:hover, .mission-rail.open {
  width: 220px;
  background: linear-gradient(180deg, rgba(17,6,38,0.92), rgba(8,3,15,0.96));
  border-color: rgba(70,229,229,0.4);
}
.mr-head {
  display: flex; flex-direction: column; align-items: center;
  width: 100%;
  text-align: center;
  font-size: 9px;
  letter-spacing: 0.22em;
  font-weight: 700;
  color: var(--ink-2);
  text-transform: uppercase;
  gap: 2px;
}
.mr-num {
  display: flex; align-items: baseline; gap: 2px;
  font-family: 'Pricedown Bl','Pricedown',sans-serif;
  text-transform: lowercase;
}
.mr-num .cur {
  font-size: 26px;
  color: var(--vc-cyan);
  -webkit-text-stroke: 1.2px #0a0014; paint-order: stroke fill;
  line-height: 1;
  text-shadow: 0 0 14px rgba(70,229,229,0.5);
}
.mr-num .den { font-size: 13px; color: var(--ink-3); margin-left: 2px; }
.mr-lbl {
  font-size: 8px;
  letter-spacing: 0.22em;
  opacity: 0.7;
  display: none;
  margin-top: 2px;
}
.mr-pct {
  font-size: 11px;
  color: var(--vc-pink);
  font-weight: 700;
  letter-spacing: 0.04em;
  margin-top: 4px;
}
.mission-rail.open .mr-lbl,
.mission-rail:hover .mr-lbl { display: block; }

/* Vertical track */
.mr-track {
  position: relative;
  width: 2px;
  height: 300px;
  background: rgba(255,255,255,0.08);
  margin: 6px 0;
}
.mr-fill {
  position: absolute;
  left: 0; right: 0; top: 0;
  background: linear-gradient(180deg, var(--vc-cyan), var(--vc-pink));
  box-shadow: 0 0 12px var(--vc-pink);
  transition: height 0.2s ease-out;
}
.mr-fill-glow {
  position: absolute;
  bottom: -6px; left: -5px;
  width: 12px; height: 12px;
  border-radius: 50%;
  background: #fff;
  box-shadow:
    0 0 4px var(--vc-cyan),
    0 0 12px var(--vc-pink),
    0 0 22px var(--vc-pink);
  animation: pulse 1.4s ease-in-out infinite;
}
.mr-mark {
  position: absolute;
  left: 1px;
  transform: translate(-12px, -50%);
  display: flex; align-items: center; gap: 10px;
  padding: 4px;
  background: none;
  border: none;
  cursor: pointer;
  color: var(--ink-2);
  transition: color 0.2s ease;
  white-space: nowrap;
}
.mr-mark .dot {
  flex: none;
  width: 10px; height: 10px;
  border-radius: 50%;
  background: rgba(255,255,255,0.14);
  border: 1.5px solid rgba(255,255,255,0.35);
  transition: all 0.25s ease;
}
.mr-mark.passed .dot {
  background: var(--vc-pink);
  border-color: var(--vc-cyan);
}
.mr-mark.on .dot {
  background: var(--vc-cyan);
  border-color: #fff;
  box-shadow: 0 0 0 3px rgba(70,229,229,0.25), 0 0 16px var(--vc-cyan);
  animation: pulse 1.2s ease-in-out infinite;
}
.mr-mark-label {
  display: flex; flex-direction: column; gap: 1px; line-height: 1;
  opacity: 0;
  transform: translateX(-6px);
  transition: opacity 0.2s ease, transform 0.2s ease;
  pointer-events: none;
}
.mr-mark-label .n {
  font-size: 8px; letter-spacing: 0.22em; color: var(--ink-3);
  font-weight: 700;
}
.mr-mark-label .l {
  font-family: 'Pricedown Bl','Pricedown',sans-serif;
  font-size: 13px; color: #fff;
  letter-spacing: 0.04em;
  text-transform: lowercase;
  -webkit-text-stroke: 0.5px #0a0014; paint-order: stroke fill;
}
.mr-mark.on .mr-mark-label .l { color: var(--vc-cyan); }
.mission-rail:hover .mr-mark-label,
.mission-rail.open .mr-mark-label {
  opacity: 1;
  transform: translateX(0);
}
.mr-mark:hover { color: var(--vc-pink); }
.mr-mark:hover .dot { transform: scale(1.3); box-shadow: 0 0 12px var(--vc-pink); }

.mr-foot {
  width: 100%;
  text-align: center;
  font-size: 8px;
  letter-spacing: 0.22em;
  font-weight: 700;
  color: var(--ink-3);
  text-transform: uppercase;
  display: flex; flex-direction: column; gap: 4px; align-items: center;
}
.mr-vc { color: var(--vc-pink); }
.mr-now {
  display: inline-flex; align-items: center; gap: 5px;
  color: var(--alert);
}
.mr-now .dot {
  width: 6px; height: 6px; border-radius: 50%;
  background: var(--alert);
  box-shadow: 0 0 8px var(--alert);
  animation: pulse 1.2s infinite;
}

@media (max-width: 760px) {
  .mission-rail { display: none; }
}

/* =========================================================
   ENHANCED TURF BEAMS — sequential ignition + idle drift
   ========================================================= */
.beam-3d .b3-shaft, .beam-3d .b3-shaft.inner, .beam-3d .b3-cone, .beam-3d .b3-particles,
.beam-3d .b3-ring, .beam-3d .b3-pad {
  opacity: 0;
  transition: opacity 0.6s ease;
}
.beam-3d .b3-badge {
  opacity: 0;
  transform: rotateX(-54deg) translateY(-180px) scale(0.3);
  transition: opacity 0.5s ease, transform 0.7s cubic-bezier(0.34,1.56,0.64,1);
}
.beam-3d.ignited .b3-shaft,
.beam-3d.ignited .b3-shaft.inner,
.beam-3d.ignited .b3-cone,
.beam-3d.ignited .b3-particles,
.beam-3d.ignited .b3-ring,
.beam-3d.ignited .b3-pad {
  opacity: 1;
  transition-delay: calc(var(--i, 0) * 0.045s + 0.2s);
}
.beam-3d.ignited .b3-badge {
  opacity: 1;
  transform: rotateX(-54deg) translateY(-180px) scale(1);
  transition-delay: calc(var(--i, 0) * 0.045s + 0.4s);
}
/* extra ignition flare on each badge */
.beam-3d.ignited .b3-svg {
  animation: badgeFlare 0.65s cubic-bezier(0.34,1.56,0.64,1) calc(var(--i, 0) * 0.045s + 0.45s) backwards;
}
@keyframes badgeFlare {
  0%   { filter: drop-shadow(0 6px 16px rgba(0,0,0,0.7)) drop-shadow(0 0 30px #fff) brightness(2); }
  100% { filter: drop-shadow(0 6px 16px rgba(0,0,0,0.7)) drop-shadow(0 0 12px var(--bc)); }
}

/* =========================================================
   BUTTON polish — magnet hover & subtle shadow rise
   ========================================================= */
.btn-sunset, .btn-ghost {
  transition: transform 0.18s cubic-bezier(0.16,1,0.3,1), filter 0.18s ease, box-shadow 0.18s ease;
}
.btn-sunset:hover {
  transform: translateY(-2px) scale(1.02);
  box-shadow: 0 16px 36px -8px rgba(255,58,163,0.55), 0 0 28px rgba(70,229,229,0.4);
}
.btn-ghost:hover {
  transform: translateY(-1px);
  box-shadow: 0 6px 18px rgba(255,58,163,0.25);
}

/* Section title shimmer */
[data-reveal] .section-title .accent,
.section-title .accent {
  background-size: 200% 100%;
  animation: shimmerAcc 6s ease-in-out infinite;
}
@keyframes shimmerAcc {
  0%, 100% { background-position: 0% 50%; }
  50%      { background-position: 100% 50%; }
}

/* Ambient hero gradient drift */
.hero-scene {
  animation: heroAmbient 18s ease-in-out infinite;
}
@keyframes heroAmbient {
  0%, 100% { filter: hue-rotate(0deg) saturate(1); }
  50%      { filter: hue-rotate(-8deg) saturate(1.08); }
}

/* GTA banner background slow-drift */
.gta-banner .gb-image {
  transition: transform 0.6s ease-out;
}
.gta-banner.revealed .gb-image {
  animation: gbBgFloat 18s ease-in-out infinite;
}
@keyframes gbBgFloat {
  0%, 100% { transform: scale(1.04) translateY(0); }
  50%      { transform: scale(1.07) translateY(-1.5%); }
}

@media (max-width: 1100px) {
  .hero-match-hud { width: 300px; right: 24px; bottom: 80px; }
  .minimap { display: none; }
}
@media (max-width: 900px) {
  .gen-wrap { grid-template-columns: 1fr; }
  .world-wrap {
    width: min(100% - 28px, 760px);
    border-radius: 22px;
  }
  .world-head {
    display: block;
    padding: 26px 22px 20px;
  }
  .world-count {
    display: inline-block;
    margin-top: 18px;
    width: 160px;
  }
  .world-grid {
    grid-template-columns: 1fr;
    padding: 0 14px 18px;
  }
  .world-diagram,
  .world-panel {
    min-height: 0;
  }
  .world-char {
    opacity: 0.1;
  }
  .meme-gen {
    grid-template-columns: 1fr;
    max-width: 760px;
    margin-top: 34px;
  }
  .meme-preview-panel {
    position: relative;
    top: 0;
    order: -1;
  }
  .meme-template-grid,
  .meme-character-grid {
    max-height: none;
  }
  .meme-character-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }
  .mlog-wrap { grid-template-columns: 1fr; }
  .mlog-map { position: relative; top: 0; }
  .mlog-card {
    grid-template-columns: 74px 1fr;
    align-items: start;
  }
  .mlog-badge {
    grid-column: 2;
    justify-self: start;
    margin-top: 2px;
  }
  .dossier-wrap { grid-template-columns: 1fr; }
  .leader-row { grid-template-columns: 40px 80px 1fr 1fr; }
  .leader-row .hide-mob { display: none; }
  .hud { grid-template-columns: auto 1fr auto; gap: 12px; padding: 12px 16px; }
  .hud-center .hud-stat:not(:first-child) { display: none; }
  .hud-divider { display: none; }
  .hero-match-hud { position: static; width: 100%; margin: 24px auto 0; }
  .section { padding: 64px 20px 56px; }
  .hero-content { padding: 56px 20px 340px; }
  .hero-side-l, .hero-side-r { display: none; }
  .foot-faq {
    grid-template-columns: 1fr;
  }
  .foot-faq-head {
    position: relative;
    top: auto;
    min-height: 0;
  }
  .foot-faq-head p {
    max-width: none;
  }
  .foot-inner { grid-template-columns: 1fr; }
}

@media (max-width: 640px) {
  .brief {
    right: 12px;
    width: calc(100vw - 24px);
  }
  .brief-body {
    padding: 18px;
  }
  .flow-split {
    grid-template-columns: 1fr;
  }
  .flow-split::before {
    left: 50%;
    right: auto;
    width: 1px;
    height: 100%;
    border: 0;
    background: linear-gradient(180deg, rgba(70,229,229,0.45), rgba(255,58,163,0.35));
    opacity: 0.45;
  }
  .foot {
    padding: 46px 14px 54px;
  }
  .foot-faq {
    gap: 14px;
    margin-bottom: 28px;
    padding-bottom: 26px;
  }
  .foot-faq-head {
    padding: 16px;
  }
  .foot-faq-item summary {
    min-height: 54px;
    grid-template-columns: auto 1fr auto;
    gap: 10px;
    padding: 14px 12px;
  }
  .foot-faq-item summary strong {
    font-size: 18px;
    line-height: 1.02;
  }
  .foot-faq-item summary::after {
    width: 24px;
    height: 24px;
  }
  .foot-faq-item p {
    padding: 0 14px 16px 42px;
    font-size: 13px;
  }
  .flow-branch {
    position: relative;
  }
  .brief-stats {
    grid-template-columns: 1fr;
  }
  .world-head h3 {
    font-size: 58px;
  }
  .world-tabs,
  .world-mini-stats,
  .diagram-branches {
    grid-template-columns: 1fr;
  }
  .world-card {
    grid-template-columns: 1fr;
  }
  .world-card-icon {
    width: 58px;
    height: 58px;
  }
  .world-diagram {
    padding: 22px 14px;
  }
  .diagram-node {
    width: 100%;
    font-size: 11px;
  }
  .diagram-branches::before {
    display: none;
  }
  .diagram-return {
    justify-self: center;
    margin-right: 0;
  }
}

@media (max-width: 900px) {
  .intel-section { padding: 66px 20px 62px; }
  .intel-shell { grid-template-columns: 1fr; gap: 24px; }
  .intel-console { grid-template-columns: 1fr; min-height: 0; }
  .intel-tabs { grid-template-columns: repeat(2, minmax(0, 1fr)); border-right: 0; border-bottom: 1px solid rgba(255,255,255,0.12); }
  .intel-tab { min-height: 92px; grid-template-columns: 46px 1fr; padding: 12px; }
  .intel-tab .code { min-width: 46px; min-height: 46px; font-size: 13px; }
  .intel-tab .label { font-size: 9px; letter-spacing: 0.12em; }
  .intel-screen-main { grid-template-columns: 1fr; padding: 24px 0; }
  .intel-reward { width: 100%; min-height: 96px; aspect-ratio: auto; }
}

@media (max-width: 760px) {
  .hud {
    grid-template-columns: 1fr auto;
    align-items: center;
    padding: 10px 14px;
  }
  .hud-brand .mark { width: 58px; height: 42px; }
  .hud-brand .word .t {
    font-size: 20px;
    max-width: 112px;
    line-height: 0.85;
  }
  .hud-brand .word .s {
    font-size: 9px;
    letter-spacing: 0.2em;
    max-width: 106px;
    overflow-wrap: anywhere;
  }
  .hud-center { justify-content: flex-start; }
  .hud-stat .num { font-size: 18px; }
  .hud-stat .lbl { font-size: 8px; letter-spacing: 0.2em; }
  .hud-right { justify-content: flex-end; }
  .btn-wanted-cta {
    width: 136px;
    min-height: 72px;
    padding: 10px 12px;
    font-size: 24px;
    line-height: 0.95;
    text-align: center;
  }
  .hero-content {
    min-height: calc(100svh - 116px);
    padding: 64px 20px 116px;
    justify-content: flex-start;
    gap: 13px;
  }
  .hero-eyebrow {
    width: 100%;
    justify-content: center;
    padding: 9px 12px;
    font-size: 10px;
    line-height: 1.4;
    letter-spacing: 0.26em;
    text-align: center;
  }
  .hero-line {
    font-size: clamp(72px, 22vw, 92px);
    -webkit-text-stroke-width: 5px;
    line-height: 0.82;
  }
  .hero-line-main {
    font-size: clamp(46px, 15vw, 68px);
    max-width: 94vw;
  }
  .hero-line.cup {
    font-size: clamp(48px, 16vw, 64px);
    -webkit-text-stroke-width: 4px;
  }
  .hero-vi {
    font-size: clamp(82px, 22vw, 112px);
    -webkit-text-stroke-width: 5px;
  }
  .hero-wordmark { width: min(270px, 76vw); margin-top: 10px; }
  .hero-tag-row {
    margin-top: 8px;
    gap: 12px;
    justify-content: center;
    font-size: 12px;
    letter-spacing: 0.22em;
  }
  .hero-subtag { font-size: 14px; }
  .hero-cta-row {
    width: 100%;
    margin-top: 12px;
    gap: 10px;
  }
  .hero-cta-row .btn-sunset.lg,
  .hero-cta-row .btn-ghost {
    width: 100%;
    min-height: 58px;
    padding: 12px 16px;
    font-size: 28px;
    line-height: 0.95;
  }
  .hero-match-hud { margin-top: 14px; }
  .hero-ticker { bottom: 18px; padding: 8px 16px; font-size: 10px; }
  .hero-bars { height: 18px; }
  .meme-section { padding-left: 14px; padding-right: 14px; }
  .meme-panel,
  .meme-preview-panel { padding: 12px; }
  .meme-panel-head { grid-template-columns: 42px 1fr; }
  .meme-panel-head .k { height: 42px; }
  .meme-panel-head h3 { font-size: 23px; }
  .meme-character-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
  .meme-character-card { min-height: 104px; }
  .meme-actions { grid-template-columns: 1fr; }
  .meme-chip-group button { flex: 1 1 calc(50% - 7px); }
  .meme-preview-top { align-items: flex-start; flex-direction: column; }
  .gx-mute {
    left: auto;
    right: 14px;
    top: 132px;
    bottom: auto;
    width: 48px;
    height: 48px;
    padding: 0;
    justify-content: center;
  }
  .gx-mute span { display: none; }
  .intel-title { -webkit-text-stroke-width: 3px; }
  .intel-sub { font-size: 14px; }
  .intel-screen { padding: 18px; }
  .intel-screen-top { letter-spacing: 0.16em; }
  .intel-screen h3 { -webkit-text-stroke-width: 2px; }
}

.cta-tag-current + .cta-tag { display: none; }


/* =========================================================
   BOUNTY BOARD — total leaderboard revamp
   ========================================================= */

/* Registered property — animatable conic-gradient angle for fugitive aura */
@property --bb-aura-angle {
  syntax: '<angle>';
  inherits: false;
  initial-value: 0deg;
}

.bb-wrap {
  max-width: 1360px;
  margin: 0 auto;
  background:
    radial-gradient(ellipse 70% 60% at 50% 0%, rgba(70,229,229,0.06), transparent 60%),
    linear-gradient(180deg, #100422 0%, #0a0218 100%);
  border: 1px solid var(--hair-strong);
  position: relative;
  overflow: hidden;
}
.bb-wrap::before {
  content: ""; position: absolute; inset: 0 0 auto 0; height: 2px;
  background: linear-gradient(90deg,
    transparent, var(--vc-cyan) 20%, var(--vc-pink) 50%, var(--gold) 80%, transparent);
  box-shadow: 0 0 16px rgba(255,58,163,0.5);
  z-index: 3;
}

/* ---------- HEAD ---------- */
.bb-head {
  padding: 18px 22px 14px;
  border-bottom: 1px solid var(--hair-strong);
  display: grid;
  gap: 16px;
  position: relative;
}

/* BOLO ticker */
.bb-bolo {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 18px;
  align-items: center;
  padding: 10px 14px;
  background: linear-gradient(90deg, rgba(255,45,85,0.18), rgba(255,45,85,0) 38%),
              rgba(0,0,0,0.55);
  border: 1px solid rgba(255,45,85,0.45);
  position: relative;
  overflow: hidden;
}
.bb-bolo-label {
  display: flex; align-items: center; gap: 10px;
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px; letter-spacing: 0.22em; font-weight: 700;
  color: var(--alert);
  white-space: nowrap;
}
.bb-bolo-label .dot {
  width: 8px; height: 8px; border-radius: 50%;
  background: var(--alert);
  box-shadow: 0 0 12px var(--alert);
  animation: pulse 1.1s infinite;
}
.bb-bolo-track {
  display: inline-flex; gap: 32px; align-items: center;
  white-space: nowrap;
  animation: bb-bolo-scroll 60s linear infinite;
  font-family: 'JetBrains Mono', monospace;
  font-size: 12px;
  color: var(--ink-1);
  min-width: 200%;
}
@keyframes bb-bolo-scroll {
  from { transform: translateX(0); }
  to   { transform: translateX(-50%); }
}
.bb-bolo-pip { display: inline-flex; gap: 8px; align-items: center; }
.bb-bolo-pip b {
  color: var(--vc-cyan);
  font-weight: 700;
  letter-spacing: 0.1em;
  font-family: 'JetBrains Mono', monospace;
}
.bb-bolo-sep { color: var(--ink-3); }
.bb-bolo-crime { color: var(--ink-2); }
.bb-bolo-time { color: var(--alert); }

/* Meta stats row */
.bb-meta {
  display: grid;
  grid-template-columns: repeat(3, 1fr) 120px;
  gap: 14px;
  align-items: center;
}
.bb-meta-cell {
  padding: 10px 14px;
  background: rgba(0,0,0,0.4);
  border: 1px solid var(--hair);
  position: relative;
}
.bb-meta-cell .k {
  font-size: 9px; letter-spacing: 0.24em; font-weight: 700;
  color: var(--ink-2); text-transform: uppercase;
  font-family: 'JetBrains Mono', monospace;
}
.bb-meta-cell .v {
  margin-top: 4px;
  font-family: 'JetBrains Mono', monospace;
  font-weight: 700;
  font-size: 22px;
  color: var(--ink-0);
  letter-spacing: -0.01em;
}
.bb-meta-cell .v.gold { color: var(--gold); text-shadow: 0 0 14px rgba(240,192,64,0.4); }
.bb-meta-cell .v.cyan { color: var(--vc-cyan); text-shadow: 0 0 14px rgba(70,229,229,0.4); }
.bb-meta-cell .v.pink { color: var(--vc-pink); text-shadow: 0 0 14px rgba(255,58,163,0.4); }
.bb-meta-cell .v i {
  font-style: normal;
  font-size: 12px;
  color: var(--ink-3);
  font-weight: 500;
}

/* Heat dial — conic gradient */
.bb-dial {
  width: 116px; height: 116px;
  border-radius: 50%;
  position: relative;
  background: conic-gradient(
    var(--vc-cyan) 0%,
    var(--vc-pink) calc(var(--p, 0.5) * 50%),
    var(--alert) calc(var(--p, 0.5) * 100%),
    rgba(255,255,255,0.04) calc(var(--p, 0.5) * 100%),
    rgba(255,255,255,0.04) 100%
  );
  display: flex; align-items: center; justify-content: center;
  filter: drop-shadow(0 0 12px rgba(255,58,163,0.35));
}
.bb-dial-ring {
  position: absolute; inset: 0; border-radius: 50%;
  border: 1px solid rgba(255,255,255,0.18);
}
.bb-dial-mask {
  position: absolute; inset: 8px; border-radius: 50%;
  background: radial-gradient(circle at 30% 30%, #1a0535, #050010 70%);
  border: 1px solid rgba(255,255,255,0.06);
}
.bb-dial-text {
  position: relative; z-index: 2; text-align: center;
}
.bb-dial-num {
  font-family: 'Pricedown Bl', 'Pricedown', 'Bowlby One SC', sans-serif;
  font-size: 30px; letter-spacing: 0.02em;
  color: var(--gold);
  text-shadow: 0 0 14px rgba(240,192,64,0.5);
  text-transform: lowercase;
}
.bb-dial-num i { font-style: normal; font-size: 16px; color: var(--ink-2); margin-left: 1px; }
.bb-dial-lbl {
  font-family: 'JetBrains Mono', monospace;
  font-size: 8px; letter-spacing: 0.28em;
  color: var(--ink-2); text-transform: uppercase; font-weight: 700;
  margin-top: -3px;
}

/* ---------- CONTROLS ---------- */
.bb-controls {
  display: flex; align-items: center; justify-content: space-between;
  gap: 14px; flex-wrap: wrap;
  padding: 12px 22px;
  border-bottom: 1px solid var(--hair);
  background: rgba(0,0,0,0.25);
}
.bb-cap {
  font-family: 'JetBrains Mono', monospace;
  font-size: 9px; letter-spacing: 0.28em; font-weight: 700;
  color: var(--ink-3); text-transform: uppercase;
  margin-right: 6px;
}
.bb-sort, .bb-filter {
  display: inline-flex; align-items: center; gap: 6px;
  flex-wrap: wrap;
}
.bb-chip {
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px; font-weight: 700;
  letter-spacing: 0.06em; text-transform: lowercase;
  padding: 6px 10px;
  background: transparent;
  border: 1px solid var(--hair-strong);
  color: var(--ink-1);
  cursor: pointer;
  transition: all 0.15s ease;
}
.bb-chip:hover { border-color: var(--vc-pink); color: var(--vc-pink); }
.bb-chip.on {
  background: linear-gradient(180deg, var(--vc-pink), #d12a8a);
  color: #fff;
  border-color: var(--vc-pink);
  box-shadow: 0 0 0 1px rgba(255,255,255,0.18), 0 0 14px rgba(255,58,163,0.45);
}
.bb-chip-crew { font-size: 13px; padding: 4px 8px; }

/* ---------- column header ---------- */
.bb-colhead {
  display: grid;
  grid-template-columns: 100px 1.4fr 1.2fr 1.4fr 110px 1.1fr;
  gap: 14px; align-items: center;
  padding: 10px 22px;
  font-family: 'JetBrains Mono', monospace;
  font-size: 9px; letter-spacing: 0.26em; font-weight: 700;
  color: var(--ink-3); text-transform: uppercase;
  background: rgba(0,0,0,0.55);
  border-bottom: 1px solid var(--hair-strong);
}

/* ---------- ROWS ---------- */
.bb-rows { position: relative; }
.bb-row {
  display: grid;
  grid-template-columns: 100px 1.4fr 1.2fr 1.4fr 110px 1.1fr;
  gap: 14px; align-items: center;
  padding: 14px 22px;
  border-bottom: 1px solid var(--hair);
  cursor: pointer;
  position: relative;
  transition: background 0.18s ease;
  overflow: hidden;
}
.bb-row::after {
  content: ""; position: absolute; inset: 0;
  background: linear-gradient(90deg, transparent, rgba(255,58,163,0.06) 60%, transparent);
  opacity: 0;
  transition: opacity 0.2s ease;
  pointer-events: none;
}
.bb-row:hover { background: rgba(255,58,163,0.05); }
.bb-row:hover::after { opacity: 1; }
.bb-row.open { background: linear-gradient(180deg, rgba(70,229,229,0.04), rgba(255,58,163,0.04)); }
.bb-row.open::before {
  content: ""; position: absolute; left: 0; top: 0; bottom: 0; width: 2px;
  background: var(--vc-cyan);
  box-shadow: 0 0 14px var(--vc-cyan);
}

/* Fugitive aura — registered property + conic-gradient sweep */
.bb-row.fugitive {
  background:
    linear-gradient(90deg, rgba(70,229,229,0.14), rgba(255,58,163,0.08) 60%, transparent 92%),
    rgba(0,0,0,0.4);
  border-left: 3px solid var(--vc-cyan);
  border-bottom-color: var(--hair-strong);
}
.bb-row.fugitive::before {
  content: ""; position: absolute; inset: -1px;
  background: conic-gradient(from var(--bb-aura-angle, 0deg),
    transparent 0%,
    rgba(70,229,229,0.22) 10%,
    transparent 25%,
    rgba(255,58,163,0.18) 50%,
    transparent 70%);
  animation: bb-aura-spin 6s linear infinite;
  pointer-events: none;
  mix-blend-mode: screen;
}
@keyframes bb-aura-spin {
  to { --bb-aura-angle: 360deg; }
}

/* rank cell */
.bb-rank-cell {
  display: flex; flex-direction: column; align-items: flex-start; gap: 4px;
  position: relative; z-index: 2;
}
.bb-rank {
  font-family: 'Pricedown Bl', 'Pricedown', 'Bowlby One SC', sans-serif;
  font-size: 32px; line-height: 0.9;
  color: var(--vc-pink);
  letter-spacing: 0.02em; text-transform: lowercase;
  text-shadow: 0 0 12px rgba(255,58,163,0.35);
}
.bb-rank.gold {
  background: linear-gradient(180deg, var(--vc-cyan), var(--vc-pink));
  -webkit-background-clip: text; background-clip: text;
  color: transparent;
  filter: drop-shadow(0 0 14px rgba(70,229,229,0.45));
}
.bb-delta {
  display: inline-flex; align-items: center; gap: 2px;
  font-family: 'JetBrains Mono', monospace;
  font-size: 10px; font-weight: 700; letter-spacing: 0.06em;
  padding: 2px 4px;
}
.bb-delta i { font-style: normal; }
.bb-delta.up   { color: var(--go);    text-shadow: 0 0 8px rgba(43,215,107,0.5); }
.bb-delta.dn   { color: var(--alert); text-shadow: 0 0 8px rgba(255,45,85,0.5); }
.bb-delta.same { color: var(--ink-3); }
.bb-fugitive-tag {
  font-family: 'JetBrains Mono', monospace;
  font-size: 8px; font-weight: 700; letter-spacing: 0.24em;
  color: var(--gold);
  padding: 1px 4px;
  border: 1px solid var(--gold);
  background: rgba(240,192,64,0.06);
  margin-top: 2px;
}

/* suspect cell */
.bb-suspect {
  display: flex; align-items: center; gap: 12px;
  position: relative; z-index: 2;
}
.bb-mug-wrap {
  position: relative;
  padding: 4px;
  background: #f6e1b3;
  border: 1.5px solid #fff;
  outline: 1px solid #0a0014;
  outline-offset: -2.5px;
  box-shadow: 0 4px 16px rgba(0,0,0,0.45);
}
.bb-mug-stamp {
  position: absolute; bottom: -8px; right: -8px;
  background: var(--bg-0);
  border: 1px solid rgba(255,255,255,0.18);
  padding: 1px 3px;
  font-size: 12px;
  border-radius: 2px;
}
.bb-mug {
  position: relative;
  background: #1c0a2c;
  overflow: hidden;
}
.bb-mug span { position: absolute; display: block; }
.bb-alias {
  font-family: 'Pricedown Bl', 'Pricedown', 'Bowlby One SC', sans-serif;
  font-size: 20px; letter-spacing: 0.02em;
  color: var(--ink-0);
  text-transform: lowercase;
  line-height: 1.05;
}
.bb-aka {
  font-size: 10px; color: var(--ink-2);
  margin-top: 4px;
  letter-spacing: 0.08em;
}
.mono { font-family: 'JetBrains Mono', monospace; }

/* holdings + sparkline */
.bb-holdings {
  display: flex; flex-direction: column; gap: 4px;
  position: relative; z-index: 2;
}
.bb-h-val {
  font-size: 16px; font-weight: 700;
  color: var(--vc-cyan);
  letter-spacing: 0.02em;
  text-shadow: 0 0 10px rgba(70,229,229,0.3);
}
.bb-h-unit {
  margin-left: 6px; font-size: 9px; color: var(--ink-3);
  letter-spacing: 0.22em; text-transform: uppercase;
}
.bb-spark { display: block; }

/* bounty bar */
.bb-bounty {
  display: flex; flex-direction: column; gap: 6px;
  position: relative; z-index: 2;
}
.bb-bar-track {
  width: 100%;
  height: 14px;
  background: rgba(0,0,0,0.55);
  border: 1px solid var(--hair-strong);
  position: relative; overflow: hidden;
}
.bb-bar-fill {
  position: absolute; left: 0; top: 0; bottom: 0;
  width: var(--bar, 0%);
  background:
    linear-gradient(90deg,
      var(--accent, var(--vc-pink)) 0%,
      color-mix(in oklab, var(--accent, var(--vc-pink)) 60%, white) 50%,
      var(--gold) 100%);
  box-shadow: 0 0 12px rgba(255,58,163,0.55);
  transition: width 0.7s cubic-bezier(.2,.7,.1,1);
}
.bb-bar-fill::after {
  content: ""; position: absolute; inset: 0;
  background:
    repeating-linear-gradient(45deg,
      rgba(255,255,255,0.18) 0 2px,
      transparent 2px 6px);
  mix-blend-mode: overlay;
  opacity: 0.7;
}
.bb-bar-glint {
  position: absolute; top: 0; bottom: 0; width: 12px;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,0.6), transparent);
  animation: bb-glint 2.4s linear infinite;
  mix-blend-mode: screen;
}
@keyframes bb-glint {
  from { left: -16px; opacity: 0.0; }
  20%  { opacity: 0.9; }
  80%  { opacity: 0.9; }
  to   { left: 100%; opacity: 0.0; }
}
.bb-bounty-num {
  font-family: 'JetBrains Mono', monospace;
  font-size: 13px; font-weight: 700;
  color: var(--gold);
  text-shadow: 0 0 10px rgba(240,192,64,0.4);
}

/* heat stars */
.bb-heat {
  display: flex; gap: 3px; position: relative; z-index: 2;
}
.bb-star {
  font-size: 18px;
  color: rgba(240,192,64,0.18);
  text-shadow: none;
  transition: transform 0.15s ease;
}
.bb-star.on {
  color: var(--gold);
  text-shadow: 0 0 8px rgba(240,192,64,0.55);
}
.bb-row:hover .bb-star.on { animation: bb-star-wobble 0.6s ease infinite alternate; }
@keyframes bb-star-wobble {
  from { transform: translateY(0); }
  to   { transform: translateY(-2px); }
}

/* last seen */
.bb-last {
  font-size: 11px; color: var(--ink-2);
  display: flex; align-items: center; gap: 6px;
  position: relative; z-index: 2;
}
.bb-pin {
  width: 6px; height: 6px; border-radius: 50%;
  background: var(--vc-cyan);
  box-shadow: 0 0 10px var(--vc-cyan);
  flex: none;
}
.bb-row.fugitive .bb-pin { background: var(--gold); box-shadow: 0 0 10px var(--gold); }

/* ---------- DOSSIER (expanded) ---------- */
.bb-dossier {
  grid-column: 1 / -1;
  display: grid;
  grid-template-columns: 220px 1fr;
  gap: 28px;
  padding: 22px 4px 6px;
  border-top: 1px dashed var(--hair-strong);
  margin-top: 14px;
  position: relative;
  z-index: 4;
  animation: bb-dossier-in 0.4s cubic-bezier(.2,.8,.2,1) both;
}
@keyframes bb-dossier-in {
  from { opacity: 0; transform: translateY(-10px); }
  to   { opacity: 1; transform: translateY(0); }
}
.bb-dossier-poster {
  background: #f6e1b3;
  border: 3px solid #fff;
  outline: 1px solid #0a0014;
  outline-offset: -4px;
  padding: 16px 12px;
  display: flex; flex-direction: column; align-items: center; gap: 10px;
  color: var(--vc-pink);
  position: relative;
  box-shadow: 0 14px 36px rgba(0,0,0,0.55), 0 0 0 1px rgba(255,255,255,0.1) inset;
}
.bb-poster-stamp {
  font-family: 'Pricedown Bl', 'Pricedown', sans-serif;
  font-size: 11px; color: #1c0a2c;
  letter-spacing: 0.18em; text-transform: lowercase;
}
.bb-poster-name {
  font-family: 'Pricedown Bl', 'Pricedown', sans-serif;
  font-size: 22px; color: #1c0a2c;
  letter-spacing: 0.04em; text-transform: lowercase;
  text-align: center; line-height: 1;
}
.bb-poster-bounty {
  font-family: 'Pricedown Bl', 'Pricedown', sans-serif;
  font-size: 18px; color: #c1272d;
  letter-spacing: 0.06em; text-transform: lowercase;
}

.bb-dossier-eyebrow {
  font-family: 'JetBrains Mono', monospace;
  font-size: 10px; letter-spacing: 0.24em; font-weight: 700;
  color: var(--vc-cyan); text-transform: uppercase;
}
.bb-dossier-title {
  font-family: 'Pricedown Bl', 'Pricedown', 'Bowlby One SC', sans-serif;
  font-size: 38px; line-height: 1; letter-spacing: 0.02em;
  text-transform: lowercase;
  margin: 4px 0 6px;
  background: linear-gradient(180deg, var(--vc-cyan), var(--vc-pink));
  -webkit-background-clip: text; background-clip: text; color: transparent;
}
.bb-dossier-aka {
  font-size: 11px; color: var(--ink-2);
  letter-spacing: 0.08em;
  margin-bottom: 14px;
}
.bb-dossier-stats {
  display: grid; grid-template-columns: repeat(6, 1fr); gap: 8px;
  margin-bottom: 18px;
}
.dd-stat {
  background: rgba(0,0,0,0.45);
  border: 1px solid var(--hair);
  padding: 8px 10px;
}
.dd-k {
  font-family: 'JetBrains Mono', monospace;
  font-size: 8px; letter-spacing: 0.24em; font-weight: 700;
  color: var(--ink-3); text-transform: uppercase;
}
.dd-v {
  margin-top: 4px;
  font-family: 'JetBrains Mono', monospace;
  font-weight: 700;
  font-size: 14px;
  color: var(--ink-0);
}
.dd-v.gold { color: var(--gold); }
.dd-v.pink { color: var(--gold); }
.dd-v.alert { color: var(--alert); }
.dd-v.go { color: var(--go); }

.bb-dossier-spark { margin-bottom: 18px; }
.dd-spark-lbl {
  font-family: 'JetBrains Mono', monospace;
  font-size: 9px; letter-spacing: 0.24em; font-weight: 700;
  color: var(--ink-3); text-transform: uppercase;
  margin-bottom: 6px;
}
.bb-dossier-cta {
  display: flex; gap: 10px; flex-wrap: wrap;
}
.bb-close { font-size: 12px !important; padding: 8px 14px !important; }

/* ---------- FOOTER ---------- */
.bb-foot {
  display: flex; justify-content: space-between; align-items: center;
  padding: 10px 22px;
  background: rgba(0,0,0,0.55);
  border-top: 1px solid var(--hair-strong);
  font-size: 10px; letter-spacing: 0.18em;
  color: var(--ink-3); text-transform: uppercase;
}
.bb-foot-dot {
  display: inline-block; width: 7px; height: 7px; border-radius: 50%;
  background: var(--go);
  box-shadow: 0 0 10px var(--go);
  margin-right: 8px;
  animation: pulse 1.4s infinite;
  vertical-align: middle;
}

/* Compositor-thread scroll-driven reveals.
   Each row slides in from the left, lightly staggered by sibling-index(). */
@supports (animation-timeline: view()) {
  .bb-row {
    animation: bb-row-in linear both;
    animation-timeline: view();
    animation-range: entry 4% cover 22%;
  }
  @keyframes bb-row-in {
    0%   { opacity: 0; transform: translateX(-36px); filter: blur(4px); }
    100% { opacity: 1; transform: translateX(0);     filter: blur(0); }
  }
}
@supports (sibling-index()) {
  .bb-row {
    animation-delay: calc(sibling-index() * 0.04s);
  }
}

/* responsive */
@media (max-width: 1100px) {
  .bb-meta { grid-template-columns: 1fr 1fr; }
  .bb-meta .bb-dial { display: none; }
  .bb-colhead, .bb-row { grid-template-columns: 80px 1.5fr 1.2fr 1.4fr; gap: 12px; padding: 12px 16px; }
  .bb-colhead > div:nth-child(5),
  .bb-colhead > div:nth-child(6) { display: none; }
  .bb-dossier-stats { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 680px) {
  .bb-meta { grid-template-columns: 1fr; }
  .bb-colhead, .bb-row { grid-template-columns: 60px 1.2fr 1.5fr; gap: 10px; padding: 12px; }
  .bb-colhead > div:nth-child(4) { display: none; }
  .bb-row > .bb-bounty { display: none; }
  .bb-alias { font-size: 16px; }
  .bb-rank { font-size: 24px; }
  .bb-dossier { grid-template-columns: 1fr; }
}

/* =========================================================
   TURF — MODE SWITCH + GLOBE + ARC ROUTES + DAY/NIGHT
   ========================================================= */

.turf-mode-switch {
  display: inline-flex; align-items: center; gap: 6px;
  padding-right: 12px; margin-right: 4px;
  border-right: 1px solid var(--hair-strong);
}
.turf-mode-btn {
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px; font-weight: 700;
  letter-spacing: 0.06em; text-transform: lowercase;
  padding: 6px 10px;
  background: transparent;
  border: 1px solid var(--hair-strong);
  color: var(--ink-1);
  cursor: pointer;
  transition: all 0.15s ease;
}
.turf-mode-btn:hover { border-color: var(--vc-cyan); color: var(--vc-cyan); }
.turf-mode-btn.on {
  background: linear-gradient(180deg, var(--vc-cyan), #2eb4b4);
  color: #08030f;
  border-color: var(--vc-cyan);
  box-shadow: 0 0 14px rgba(70,229,229,0.45);
}

/* ---------- GLOBE ---------- */
.turf-stage.mode-globe { aspect-ratio: 16 / 10; }
.turf-globe-wrap {
  position: absolute; inset: 0;
  display: flex; align-items: center; justify-content: center;
  gap: 36px;
  padding: 28px;
}
.turf-globe {
  cursor: grab;
  user-select: none;
  filter: drop-shadow(0 30px 60px rgba(0,0,0,0.7));
  flex: none;
}
.turf-globe.drag { cursor: grabbing; }
.turf-globe svg { display: block; }
.turf-globe-hud {
  position: absolute;
  bottom: 14px; left: 50%; transform: translateX(-50%);
  text-align: center;
  font-family: 'JetBrains Mono', monospace;
  pointer-events: none;
}
.turf-globe-hud .k {
  font-size: 9px; letter-spacing: 0.28em; font-weight: 700;
  color: var(--ink-3); text-transform: uppercase;
}
.turf-globe-hud .v {
  font-size: 13px; color: var(--vc-cyan);
  letter-spacing: 0.12em; font-weight: 700;
  margin-top: 2px;
  text-shadow: 0 0 10px rgba(70,229,229,0.5);
}
.turf-globe-hud .k2 {
  font-size: 8px; letter-spacing: 0.28em; font-weight: 700;
  color: var(--ink-3); text-transform: uppercase;
  margin-top: 6px;
}

.turf-globe-side {
  flex: 1; max-width: 260px;
  display: flex; flex-direction: column; gap: 12px;
  padding: 18px;
  background: rgba(0,0,0,0.55);
  border: 1px solid var(--hair-strong);
  align-self: stretch; justify-content: flex-start;
  margin-top: 20%;
}
.turf-globe-side .tg-stat .k {
  font-family: 'JetBrains Mono', monospace;
  font-size: 9px; letter-spacing: 0.24em; font-weight: 700;
  color: var(--ink-2); text-transform: uppercase;
}
.turf-globe-side .tg-stat .v {
  font-family: 'JetBrains Mono', monospace;
  font-weight: 700; font-size: 15px;
  color: var(--ink-0); margin-top: 3px;
}
.turf-globe-side .tg-stat .v.gold { color: var(--gold); }
.turf-globe-side .tg-stat .v.alert { color: var(--alert); }
.turf-globe-side .tg-hint {
  margin-top: 6px;
  font-family: 'JetBrains Mono', monospace;
  font-size: 10px; letter-spacing: 0.16em;
  color: var(--ink-3);
}

/* ---------- ARCS overlay ---------- */
.turf-arcs {
  position: absolute; inset: 0;
  pointer-events: none;
  z-index: 4;
}
.turf-arcs canvas {
  width: 100%; height: 100%;
  display: block;
}

/* ---------- DAY/NIGHT terminator ---------- */
.turf-daynight {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  pointer-events: none;
  mix-blend-mode: multiply;
  z-index: 2;
}

/* ---------- Sat-feed mode mods ---------- */
.turf-stage.mode-satfeed .turf-world {
  transform: rotateX(0deg) rotateZ(0deg) !important;
}
.turf-stage.mode-satfeed .b3-shaft,
.turf-stage.mode-satfeed .b3-shaft.inner,
.turf-stage.mode-satfeed .b3-cone {
  height: 0 !important;
  opacity: 0 !important;
}
.turf-stage.mode-satfeed .b3-particles { display: none; }
.turf-stage.mode-satfeed .turf-arcs canvas { filter: brightness(1.15) contrast(1.1); }

@media (max-width: 900px) {
  .turf-globe-wrap { flex-direction: column; padding: 18px; gap: 16px; }
  .turf-globe-side { max-width: 100%; margin-top: 0; }
}


/* =========================================================
   TIER B — engine + particles + claude alias forge styles
   ========================================================= */

/* ---------- Neon rain in hero ---------- */
.gx-rain {
  position: absolute; inset: 0;
  pointer-events: none;
  z-index: 2;
  mix-blend-mode: screen;
}
.gx-rain canvas {
  width: 100%; height: 100%;
  display: block;
  opacity: 0.85;
}

/* ---------- Coin confetti canvas — page-level overlay ---------- */
.gx-coinburst {
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: 99;
  mix-blend-mode: screen;
}

/* ---------- Claim-banner flash ---------- */
.gx-claim-banner {
  position: fixed;
  top: 14%; left: 50%; transform: translateX(-50%) translateY(0);
  z-index: 100;
  font-family: 'Pricedown Bl', 'Pricedown', sans-serif;
  font-size: 44px; letter-spacing: 0.06em;
  text-transform: lowercase;
  background: linear-gradient(180deg, #fff7c2, #f0c040 60%, #b87a18);
  -webkit-background-clip: text; background-clip: text;
  color: transparent;
  filter: drop-shadow(0 8px 26px rgba(240,192,64,0.6)) drop-shadow(0 0 12px rgba(255,58,163,0.5));
  opacity: 0; pointer-events: none;
  animation: gx-claim-in 0.45s cubic-bezier(.2,.8,.2,1) forwards;
}
.gx-claim-banner.out {
  animation: gx-claim-out 0.7s ease forwards;
}
.gx-claim-banner .gx-claim-star { margin-right: 12px; }
@keyframes gx-claim-in {
  from { opacity: 0; transform: translateX(-50%) translateY(-18px) scale(0.9); }
  to   { opacity: 1; transform: translateX(-50%) translateY(0) scale(1); }
}
@keyframes gx-claim-out {
  from { opacity: 1; transform: translateX(-50%) translateY(0) scale(1); }
  to   { opacity: 0; transform: translateX(-50%) translateY(-20px) scale(0.94); }
}

/* ---------- Mute button (floating) ---------- */
.gx-mute {
  position: fixed;
  bottom: 22px; left: 22px;
  z-index: 95;
  display: inline-flex; align-items: center; gap: 8px;
  padding: 10px 14px;
  background: rgba(8,3,15,0.7);
  backdrop-filter: blur(8px);
  border: 1px solid var(--hair-strong);
  color: var(--ink-1);
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px; font-weight: 700;
  letter-spacing: 0.18em; text-transform: uppercase;
  cursor: pointer;
  transition: all 0.15s ease;
}
.gx-mute:hover {
  border-color: var(--vc-pink);
  color: var(--vc-pink);
  box-shadow: 0 0 22px rgba(255,58,163,0.25);
}
.gx-mute.on {
  color: var(--vc-cyan);
  border-color: var(--vc-cyan);
  box-shadow: 0 0 22px rgba(70,229,229,0.3);
  animation: gx-mute-pulse 2s infinite;
}
.gx-mute.on svg { color: var(--vc-cyan); }
@keyframes gx-mute-pulse {
  0%, 100% { box-shadow: 0 0 16px rgba(70,229,229,0.25); }
  50%      { box-shadow: 0 0 28px rgba(70,229,229,0.55); }
}

/* ---------- Tilt-gate button ---------- */
.gx-tilt-ask {
  position: fixed;
  bottom: 22px; left: 50%; transform: translateX(-50%);
  z-index: 95;
  padding: 8px 14px;
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px; letter-spacing: 0.2em; font-weight: 700;
  text-transform: uppercase;
  background: rgba(0,0,0,0.55);
  color: var(--gold);
  border: 1px solid var(--gold);
  cursor: pointer;
}
@media (min-width: 900px) { .gx-tilt-ask { display: none; } }

/* ---------- Tilt parallax — applied where useful via CSS vars ---------- */
:root { --tilt-x: 0; --tilt-y: 0; }
.hero-character {
  transform: translate3d(calc(var(--tilt-x) * -22px), calc(var(--tilt-y) * -10px), 0) !important;
}
.hero-art svg { transform: translate3d(calc(var(--tilt-x) * 8px), calc(var(--tilt-y) * 4px), 0); }

/* ---------- Sat radar overlay (in turf stage) ---------- */
.gx-radar {
  position: absolute; inset: 0;
  pointer-events: none;
  z-index: 6;
  mix-blend-mode: screen;
  overflow: hidden;
  opacity: 0.6;
}
.gx-radar-sweep {
  position: absolute;
  width: 200%; height: 200%;
  left: -50%; top: -50%;
  background: conic-gradient(
    from 0deg at 50% 50%,
    rgba(70,229,229,0.0) 0deg,
    rgba(70,229,229,0.45) 6deg,
    rgba(70,229,229,0.0) 40deg,
    rgba(70,229,229,0.0) 360deg
  );
  animation: gx-radar-spin 7s linear infinite;
  transform-origin: 50% 50%;
  filter: blur(8px);
}
@keyframes gx-radar-spin {
  to { transform: rotate(360deg); }
}
.gx-radar-rings {
  position: absolute; inset: 0;
  display: grid; place-items: center;
}
.gx-radar-rings span {
  position: absolute;
  width: calc(min(70vw, 720px) * var(--r));
  height: calc(min(70vw, 720px) * var(--r));
  border: 1px solid rgba(70,229,229,0.16);
  border-radius: 50%;
}
.gx-radar-cross {
  position: absolute; inset: 0;
}
.gx-radar-cross .vx, .gx-radar-cross .hx {
  position: absolute; background: rgba(70,229,229,0.16);
}
.gx-radar-cross .vx { left: 50%; top: 0; bottom: 0; width: 1px; transform: translateX(-0.5px); }
.gx-radar-cross .hx { top: 50%; left: 0; right: 0; height: 1px; transform: translateY(-0.5px); }

/* ---------- Live BOLO claim pip styling ---------- */
.bb-bolo-pip.claim b { color: var(--gold); text-shadow: 0 0 10px rgba(240,192,64,0.5); }
.bb-bolo-pip.claim .bb-bolo-crime { color: var(--gold); }

/* ---------- Alias forge inside dossier ---------- */
.bb-dossier-forge {
  margin-top: 20px;
  padding-top: 16px;
  border-top: 1px dashed var(--hair);
}
.af-wrap { display: flex; flex-direction: column; gap: 12px; }
.af-row { display: flex; gap: 8px; }
.af-input {
  flex: 1;
  background: rgba(0,0,0,0.5);
  border: 1px solid var(--hair-strong);
  color: var(--ink-0);
  font-family: 'JetBrains Mono', monospace;
  font-size: 13px;
  padding: 10px 12px;
  letter-spacing: 0.04em;
  outline: none;
  transition: border-color 0.15s ease, box-shadow 0.15s ease;
}
.af-input:focus {
  border-color: var(--vc-cyan);
  box-shadow: 0 0 0 1px rgba(70,229,229,0.3);
}
.af-btn { white-space: nowrap; }
.af-err {
  font-size: 10px; color: var(--ink-3);
  letter-spacing: 0.18em; text-transform: uppercase;
}
.af-poster {
  display: grid;
  grid-template-columns: 1fr;
  gap: 8px;
  padding: 18px 20px;
  background: linear-gradient(180deg, #f6e1b3 0%, #ecca8b 100%);
  color: #1c0a2c;
  border: 3px solid #fff;
  outline: 1px solid #0a0014;
  outline-offset: -4px;
  position: relative;
  box-shadow: 0 14px 36px rgba(0,0,0,0.45);
}
.af-stamp {
  font-family: 'Pricedown Bl', 'Pricedown', sans-serif;
  font-size: 11px; letter-spacing: 0.22em; text-transform: lowercase;
}
.af-alias {
  font-family: 'Pricedown Bl', 'Pricedown', sans-serif;
  font-size: 36px; line-height: 1; letter-spacing: 0.04em;
  text-transform: lowercase;
  color: #c1272d;
  margin-top: -2px;
}
.af-aka { font-size: 11px; letter-spacing: 0.1em; opacity: 0.8; }
.af-meta {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
  margin-top: 10px;
  padding: 10px 0;
  border-top: 1px dashed rgba(28,10,44,0.3);
  border-bottom: 1px dashed rgba(28,10,44,0.3);
}
.af-stat .k {
  font-family: 'JetBrains Mono', monospace;
  font-size: 8px; letter-spacing: 0.24em;
  font-weight: 700; text-transform: uppercase;
  color: #6a3a8a;
}
.af-stat .v {
  font-family: 'JetBrains Mono', monospace;
  font-weight: 700; font-size: 14px;
  margin-top: 3px;
}
.af-stat .v.gold { color: #b87a18; }
.af-crime {
  font-size: 11px;
  letter-spacing: 0.06em;
  color: #1c0a2c;
  margin-top: 4px;
}

/* ---------- View transitions ---------- */
@supports (view-transition-name: a) {
  /* Each animated section */
  .turf-stage, .bb-rows { view-transition-name: auto; }

  /* Map mode swap */
  ::view-transition-old(root),
  ::view-transition-new(root) {
    animation-duration: 0.45s;
    animation-timing-function: cubic-bezier(.2,.8,.2,1);
  }
  html[data-vt="turf-mode"]::view-transition-old(root) {
    animation: gx-vt-fade-out 0.4s both;
  }
  html[data-vt="turf-mode"]::view-transition-new(root) {
    animation: gx-vt-fade-in 0.5s both;
  }
  html[data-vt="bb-dossier"]::view-transition-old(root) {
    animation: gx-vt-fade-out 0.3s both;
  }
  html[data-vt="bb-dossier"]::view-transition-new(root) {
    animation: gx-vt-slide-in 0.45s both;
  }

  @keyframes gx-vt-fade-out {
    from { opacity: 1; filter: blur(0); }
    to   { opacity: 0; filter: blur(8px); }
  }
  @keyframes gx-vt-fade-in {
    from { opacity: 0; filter: blur(10px) saturate(0.4); }
    to   { opacity: 1; filter: blur(0) saturate(1); }
  }
  @keyframes gx-vt-slide-in {
    from { opacity: 0; transform: translateY(8px); }
    to   { opacity: 1; transform: translateY(0); }
  }
}

/* ---------- Reduced motion considerations ---------- */
@media (prefers-reduced-motion: reduce) {
  .gx-rain, .gx-coinburst, .gx-radar { display: none !important; }
  .bb-bolo-track { animation: none; }
  .bb-bar-glint { animation: none; }
  .bb-row.fugitive::before { animation: none; }
  .intel-marquee-track { animation: none; }
  .intel-progress span { transition: none; }
  .intel-screen { view-transition-name: none; }
}

/* =========================================================
   SECTION HEAD — replaces the heavy <GtaBanner>.
   Goal: low-density, elegant, varied. Each section gets a
   confident typographic header instead of a re-skinned banner.
   ========================================================= */

.sh {
  position: relative;
  z-index: 2;
  max-width: 1360px;
  margin: 0 auto 56px;
  padding: 0 4px;
  --sh-accent: var(--vc-cyan);
}

/* ---- shared title ---- */
.sh-title {
  font-family: 'Pricedown Bl','Pricedown','Bowlby One SC',sans-serif;
  font-size: clamp(56px, 9vw, 132px);
  line-height: 0.88;
  letter-spacing: 0.005em;
  text-transform: lowercase;
  color: #fff;
  -webkit-text-stroke: 4px #0a0014;
          text-stroke: 4px #0a0014;
  paint-order: stroke fill;
  text-shadow:
    0 6px 0 rgba(0,0,0,0.45),
    0 22px 40px rgba(0,0,0,0.55);
  text-wrap: balance;
}
.sh-title .ac {
  background: linear-gradient(180deg,
    var(--sh-accent) 0%,
    var(--sh-accent) 32%,
    #ffffff 50%,
    #ffb9dc 70%,
    var(--vc-pink) 100%);
  -webkit-background-clip: text; background-clip: text;
  color: transparent;
  -webkit-text-stroke: 4px #0a0014;
  paint-order: stroke fill;
  text-shadow: none;
}

/* ---- shared eyebrow + num ---- */
.sh-num {
  font-family: 'JetBrains Mono', monospace;
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.28em;
  color: var(--sh-accent);
  text-transform: uppercase;
}
.sh-eyebrow {
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.34em;
  color: var(--ink-1);
  text-transform: uppercase;
}
.sh-sub {
  margin-top: 18px;
  max-width: 620px;
  color: var(--ink-1);
  font-size: 15px;
  line-height: 1.55;
  letter-spacing: 0.005em;
}

/* ============================================================
   Variant A: MARQUEE
   left-anchored: thin rule → §NN · EYEBROW → big title → sub
   ============================================================ */
.sh-marquee .sh-rule {
  width: 56px;
  height: 2px;
  margin-bottom: 18px;
  background: linear-gradient(90deg, var(--sh-accent), transparent);
}
.sh-marquee .sh-marquee-head {
  display: inline-flex;
  align-items: center;
  gap: 18px;
  margin-bottom: 14px;
}
.sh-marquee .sh-tick {
  width: 6px; height: 6px; border-radius: 50%;
  background: var(--sh-accent);
  box-shadow: 0 0 12px var(--sh-accent);
  animation: shTickPulse 1.6s ease-in-out infinite;
}
@keyframes shTickPulse {
  0%, 100% { opacity: 0.4; transform: scale(0.85); }
  50%      { opacity: 1;   transform: scale(1.15); }
}
.sh-marquee .sh-title-marquee {
  margin: 0;
  text-align: left;
}
.sh-align-center .sh-rule { margin-left: auto; margin-right: auto; }
.sh-align-center .sh-marquee-head { width: 100%; justify-content: center; }
.sh-align-center .sh-title-marquee { text-align: center; }
.sh-align-center .sh-sub { margin-left: auto; margin-right: auto; text-align: center; }

/* ============================================================
   Variant B: BLADE
   right-anchored title, thin diagonal neon blade cutting across,
   mono meta tucked to the upper-left.
   ============================================================ */
.sh-blade {
  display: grid;
  grid-template-columns: 1fr;
  position: relative;
  padding-top: 12px;
  min-height: 140px;
}
.sh-blade .sh-blade-line {
  position: absolute;
  left: 0; right: 0;
  top: 50%;
  height: 1px;
  background: linear-gradient(90deg,
    transparent 0%,
    rgba(255,255,255,0.06) 12%,
    var(--sh-accent) 50%,
    rgba(255,255,255,0.06) 88%,
    transparent 100%);
  transform: translateY(-50%) skewY(-1.6deg);
  filter: drop-shadow(0 0 12px color-mix(in oklch, var(--sh-accent) 60%, transparent));
  opacity: 0.85;
}
.sh-blade .sh-blade-line::before,
.sh-blade .sh-blade-line::after {
  content: "";
  position: absolute;
  top: 50%; transform: translateY(-50%);
  width: 8px; height: 8px;
  background: var(--sh-accent);
  box-shadow: 0 0 14px var(--sh-accent);
}
.sh-blade .sh-blade-line::before { left: 0; }
.sh-blade .sh-blade-line::after  { right: 0; }
.sh-blade .sh-blade-meta {
  position: relative;
  z-index: 2;
  display: inline-flex;
  align-items: center;
  gap: 14px;
  padding: 4px 12px;
  background: var(--bg-0);
  width: max-content;
  margin-bottom: 18px;
}
.sh-blade .sh-title-blade {
  position: relative;
  z-index: 2;
  margin: 0;
  text-align: right;
  background: var(--bg-0);
  padding: 6px 14px 6px 0;
  width: max-content;
  margin-left: auto;
}
.sh-blade .sh-sub-blade {
  margin-top: 14px;
  margin-left: auto;
  text-align: right;
  max-width: 520px;
}

/* ============================================================
   Reveal choreography (uses existing .revealed pattern)
   ============================================================ */
.sh { opacity: 0; transform: translateY(24px); transition: opacity 0.6s cubic-bezier(0.16,1,0.3,1), transform 0.6s cubic-bezier(0.16,1,0.3,1); }
.sh.revealed { opacity: 1; transform: translateY(0); }
.sh-title { opacity: 0; transform: translateY(-6px); filter: blur(6px); transition: opacity 0.55s ease 0.22s, transform 0.6s cubic-bezier(0.16,1,0.3,1) 0.22s, filter 0.55s ease 0.22s; }
.sh.revealed .sh-title { opacity: 1; transform: translateY(0); filter: blur(0); }
.sh-blade-line { transform-origin: left center; transform: translateY(-50%) skewY(-1.6deg) scaleX(0); transition: transform 0.9s cubic-bezier(0.16,1,0.3,1) 0.1s; }
.sh.revealed .sh-blade-line { transform: translateY(-50%) skewY(-1.6deg) scaleX(1); }
.sh-rule { transform-origin: left center; transform: scaleX(0); transition: transform 0.6s cubic-bezier(0.16,1,0.3,1) 0.1s; }
.sh.revealed .sh-rule { transform: scaleX(1); }
.sh-align-center .sh-rule { transform-origin: center; }

/* ============================================================
   Mobile
   ============================================================ */
@media (max-width: 720px) {
  .sh { margin: 0 auto 36px; }
  .sh-title { font-size: clamp(44px, 13vw, 80px); -webkit-text-stroke-width: 3px; text-stroke-width: 3px; }
  .sh-title .ac { -webkit-text-stroke-width: 3px; }
  .sh-blade .sh-title-blade { text-align: left; margin-left: 0; }
  .sh-blade .sh-sub-blade { text-align: left; margin-left: 0; }
  .sh-blade .sh-blade-line { display: none; }
}

/* ============================================================
   Reduce hero density a touch (single source of crowding):
   hide the secondary tag-row on small screens & lighten its
   weight on desktop so the hero subtag does the talking.
   ============================================================ */
.hero-tag-row {
  opacity: 0.78;
}

/* tighten the section vertical rhythm globally — the old banners
   left huge gaps above content. The new headers sit closer. */
.section { padding-top: 88px; padding-bottom: 88px; }
@media (max-width: 720px) {
  .section { padding-top: 56px; padding-bottom: 56px; }
}

/* =========================================================
   SECTION STAGE — flagship theatrical section panel.
   New structure (see sectionstage.jsx):
   .ss = sizing wrapper (overflow visible)
     .ss-frame      = chamfered/slanted rim shape (the colored bg)
       .ss-frame-bg = clipped — holds backdrop + scrim + scan
     .ss-char-layer = NOT clipped — heads pop above the frame
     .ss-content    = NOT clipped — text + CTA
     .ss-bracket    = corner brackets
   ========================================================= */
.ss {
  --ss-accent: var(--vc-pink);
  --ss-corner: 30px;
  --ss-rim: 2.5px;
  --ss-pop: 14%;

  position: relative;
  max-width: 1360px;
  height: var(--ss-h, 460px);
  margin: var(--ss-pop, 14%) auto 64px;   /* top margin so popping head has room */
  /* convert percent pop to fixed pixels for top margin */
  margin-top: calc(var(--ss-h, 460px) * var(--ss-pop) / 100);
  overflow: visible;
  filter: drop-shadow(0 24px 48px rgba(0,0,0,0.55))
          drop-shadow(0 0 24px color-mix(in oklch, var(--ss-accent) 35%, transparent));
}

/* ----- FRAME — colored chamfered rim -------------------------- */
.ss-frame {
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg,
    var(--ss-accent) 0%,
    var(--ss-accent) 30%,
    var(--vc-cyan)   50%,
    var(--ss-accent) 70%,
    var(--ss-accent) 100%);
}

/* default: chamfer all four corners */
.ss-shape-chamfer .ss-frame {
  clip-path: polygon(
    var(--ss-corner) 0%, calc(100% - var(--ss-corner)) 0%,
    100% var(--ss-corner), 100% calc(100% - var(--ss-corner)),
    calc(100% - var(--ss-corner)) 100%, var(--ss-corner) 100%,
    0 calc(100% - var(--ss-corner)), 0 var(--ss-corner)
  );
}
/* slant-r: top edge slopes up from left to right; bottom mirrored */
.ss-shape-slant-r .ss-frame {
  clip-path: polygon(
    0% 12%, 100% 0%,
    100% 88%, 0% 100%
  );
}
/* slant-l: top edge slopes down from left to right (mirror of slant-r) */
.ss-shape-slant-l .ss-frame {
  clip-path: polygon(
    0% 0%, 100% 12%,
    100% 100%, 0% 88%
  );
}
/* wedge: top-left and bottom-right corners diagonally cut large */
.ss-shape-wedge .ss-frame {
  clip-path: polygon(
    14% 0%, 100% 0%,
    100% 86%, 86% 100%,
    0% 100%, 0% 14%
  );
}
/* strip: horizontal cinema strip, only corners faintly notched */
.ss-shape-strip .ss-frame {
  clip-path: polygon(
    18px 0%, calc(100% - 18px) 0%,
    100% 18px, 100% calc(100% - 18px),
    calc(100% - 18px) 100%, 18px 100%,
    0 calc(100% - 18px), 0 18px
  );
}

/* the inner-bg layer — clipped to same shape but inset by --ss-rim */
.ss-frame-bg {
  position: absolute;
  inset: var(--ss-rim);
  background: #14072a;
  overflow: hidden;
  isolation: isolate;
}
.ss-shape-chamfer .ss-frame-bg {
  clip-path: polygon(
    calc(var(--ss-corner) - var(--ss-rim)) 0%,
    calc(100% - var(--ss-corner) + var(--ss-rim)) 0%,
    100% calc(var(--ss-corner) - var(--ss-rim)),
    100% calc(100% - var(--ss-corner) + var(--ss-rim)),
    calc(100% - var(--ss-corner) + var(--ss-rim)) 100%,
    calc(var(--ss-corner) - var(--ss-rim)) 100%,
    0 calc(100% - var(--ss-corner) + var(--ss-rim)),
    0 calc(var(--ss-corner) - var(--ss-rim))
  );
}
.ss-shape-slant-r .ss-frame-bg { clip-path: polygon(0% 12%, 100% 0%, 100% 88%, 0% 100%); }
.ss-shape-slant-l .ss-frame-bg { clip-path: polygon(0% 0%, 100% 12%, 100% 100%, 0% 88%); }
.ss-shape-wedge   .ss-frame-bg { clip-path: polygon(14% 0%, 100% 0%, 100% 86%, 86% 100%, 0% 100%, 0% 14%); }
.ss-shape-strip   .ss-frame-bg {
  clip-path: polygon(
    16px 0%, calc(100% - 16px) 0%,
    100% 16px, 100% calc(100% - 16px),
    calc(100% - 16px) 100%, 16px 100%,
    0 calc(100% - 16px), 0 16px
  );
}

/* image bg fallback */
.ss-bg {
  position: absolute;
  inset: -4%;
  background-size: cover;
  background-position: center;
  filter: saturate(1.15) contrast(1.05);
}
/* SVG backdrop fills the frame */
.ss-backdrop {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  display: block;
}
/* scrim — lifted to keep scene images vibrant. Dark vignette only at
   corners + bottom for text legibility, NOT a flat darkening pass. */
.ss-scrim {
  position: absolute; inset: 0;
  background:
    radial-gradient(ellipse 90% 60% at 50% 100%,
      rgba(8,3,15,0.55) 0%,
      transparent 70%),
    linear-gradient(180deg,
      rgba(8,3,15,0.18) 0%,
      transparent 30%,
      transparent 60%,
      rgba(8,3,15,0.45) 100%);
}
/* wash — soft cyan→pink screen overlay that re-saturates the backdrop
   into the brand palette. Lighter now since the SVG backdrops are
   already vibrant on their own. */
.ss-wash {
  position: absolute; inset: 0;
  background:
    linear-gradient(115deg,
      color-mix(in oklch, var(--vc-cyan) 18%, transparent) 0%,
      transparent 35%,
      transparent 55%,
      color-mix(in oklch, var(--ss-accent) 20%, transparent) 100%);
  mix-blend-mode: screen;
  opacity: 0.6;
}
.ss-scan {
  position: absolute; inset: 0;
  background: repeating-linear-gradient(
    0deg,
    rgba(255,255,255,0) 0 3px,
    rgba(255,255,255,0.025) 3px 4px);
  pointer-events: none;
}
/* accent piece — a single diagonal "puzzle piece" stripe that slides
   in LAST to lock the composition. Lives over the frame, under the
   characters. */
.ss-frame::after {
  content: "";
  position: absolute;
  top: -8%;
  right: -6%;
  width: 26%;
  height: 116%;
  background: linear-gradient(
    115deg,
    transparent 0%,
    transparent 28%,
    var(--ss-accent) 28%,
    var(--ss-accent) 32%,
    transparent 32%,
    transparent 40%,
    var(--ss-accent) 40%,
    var(--ss-accent) 41%,
    transparent 41%);
  clip-path: polygon(20% 0%, 100% 0%, 80% 100%, 0% 100%);
  filter: drop-shadow(0 0 12px color-mix(in oklch, var(--ss-accent) 60%, transparent));
  opacity: 0.85;
  pointer-events: none;
  z-index: 2;
}
.ss-solo-left .ss-frame::after,
.ss-shape-slant-l .ss-frame::after {
  right: auto;
  left: -6%;
  clip-path: polygon(0% 0%, 80% 0%, 100% 100%, 20% 100%);
  background: linear-gradient(
    -115deg,
    transparent 0%,
    transparent 28%,
    var(--ss-accent) 28%,
    var(--ss-accent) 32%,
    transparent 32%,
    transparent 40%,
    var(--ss-accent) 40%,
    var(--ss-accent) 41%,
    transparent 41%);
}

/* ----- CHARACTERS — pop OUT of the top of the frame ----------- */
.ss-char-layer {
  position: absolute;
  inset: 0;
  pointer-events: none;
  z-index: 3;
}
.ss-char {
  position: absolute;
  bottom: 0;
  /* heads extend above the panel top by --ss-pop * h */
  height: calc(100% + var(--ss-pop));
  width: auto;
  filter: drop-shadow(0 20px 30px rgba(0,0,0,0.7));
}
.ss-char-left  { left: 0%;  transform: translateX(-8%); }
.ss-char-right { right: 0%; transform: translateX(8%); }
.ss-solo-right .ss-char-right { right: 2%; transform: translateX(2%); }
.ss-solo-left  .ss-char-left  { left: 2%;  transform: translateX(-2%); }

/* corner brackets — small neon L-shapes on each corner of the frame */
.ss-bracket {
  position: absolute;
  width: 22px; height: 22px;
  border: 2px solid var(--ss-accent);
  pointer-events: none;
  filter: drop-shadow(0 0 8px var(--ss-accent));
  z-index: 4;
}
.ss-bracket.tl { top: 14px;    left: 14px;    border-right: 0;  border-bottom: 0; }
.ss-bracket.tr { top: 14px;    right: 14px;   border-left: 0;   border-bottom: 0; }
.ss-bracket.bl { bottom: 14px; left: 14px;    border-right: 0;  border-top: 0; }
.ss-bracket.br { bottom: 14px; right: 14px;   border-left: 0;   border-top: 0; }
/* hide brackets for slanted shapes — they don't fit the diagonal cut */
.ss-shape-slant-r .ss-bracket,
.ss-shape-slant-l .ss-bracket,
.ss-shape-wedge   .ss-bracket { display: none; }

/* ----- CONTENT COLUMN ----------------------------------------- */
.ss-content {
  position: absolute;
  inset: 0;
  padding: 56px 64px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 22px;
  z-index: 5;
  pointer-events: none;
}
.ss-content > * { pointer-events: auto; }
.ss-align-center .ss-content { align-items: center;   text-align: center; }
.ss-align-left   .ss-content { align-items: flex-start; text-align: left; }
.ss-align-right  .ss-content { align-items: flex-end;   text-align: right; }

.ss-meta {
  display: inline-flex;
  align-items: center;
  gap: 14px;
  padding: 5px 14px;
  border: 1px solid color-mix(in oklch, var(--ss-accent) 55%, transparent);
  background: rgba(8,3,15,0.55);
  backdrop-filter: blur(6px);
  border-radius: 999px;
}
.ss-num {
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.28em;
  color: var(--ss-accent);
}
.ss-eyebrow {
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.32em;
  color: #fff;
  text-transform: uppercase;
}

.ss-title {
  margin: 0;
  font-family: 'Pricedown Bl','Pricedown','Bowlby One SC',sans-serif;
  font-size: clamp(64px, 10vw, 152px);
  line-height: 0.86;
  letter-spacing: 0.005em;
  text-transform: lowercase;
  color: #ffffff;
  -webkit-text-stroke: 5px #0a0014;
          text-stroke: 5px #0a0014;
  paint-order: stroke fill;
  text-shadow:
    0 6px 0 rgba(0,0,0,0.55),
    0 24px 50px rgba(0,0,0,0.65),
    0 0 38px color-mix(in oklch, var(--ss-accent) 50%, transparent);
  max-width: 14ch;
  text-wrap: balance;
}
.ss-title .ac {
  background: linear-gradient(180deg,
    var(--ss-accent) 0%,
    var(--ss-accent) 30%,
    #ffffff 50%,
    #ffd6ea 68%,
    var(--vc-pink) 100%);
  -webkit-background-clip: text; background-clip: text;
  color: transparent;
  -webkit-text-stroke: 5px #0a0014;
  paint-order: stroke fill;
  text-shadow: none;
}
.ss-title .ac-cyan {
  background: linear-gradient(180deg,
    var(--vc-cyan) 0%,
    var(--vc-cyan) 30%,
    #ffffff 50%,
    #ffd6ea 68%,
    var(--vc-pink) 100%);
  -webkit-background-clip: text; background-clip: text;
  color: transparent;
  -webkit-text-stroke: 5px #0a0014;
  paint-order: stroke fill;
  text-shadow: none;
}
.ss-title .ac-gold {
  background: linear-gradient(180deg,
    var(--vc-yellow) 0%,
    var(--vc-yellow) 30%,
    #ffffff 50%,
    var(--vc-yellow) 68%,
    var(--vc-orange) 100%);
  -webkit-background-clip: text; background-clip: text;
  color: transparent;
  -webkit-text-stroke: 5px #0a0014;
  paint-order: stroke fill;
  text-shadow: none;
}

.ss-sub {
  font-size: 16px;
  color: #f0e3f3;
  letter-spacing: 0.01em;
  max-width: 560px;
  line-height: 1.5;
  text-shadow: 0 2px 12px rgba(0,0,0,0.7);
}

.ss-cta {
  font-family: 'Pricedown Bl','Pricedown','Bowlby One SC',sans-serif;
  font-size: 22px;
  letter-spacing: 0.04em;
  text-transform: lowercase;
  padding: 16px 38px;
  color: #fff;
  background: linear-gradient(180deg,
    rgba(255,58,163,0.18) 0%,
    rgba(160,43,255,0.18) 100%);
  border: 2px solid var(--ss-accent);
  clip-path: polygon(
    14px 0, calc(100% - 14px) 0,
    100% 14px, 100% calc(100% - 14px),
    calc(100% - 14px) 100%, 14px 100%,
    0 calc(100% - 14px), 0 14px
  );
  cursor: pointer;
  text-shadow: 0 0 12px color-mix(in oklch, var(--ss-accent) 60%, transparent);
  box-shadow: 0 0 24px color-mix(in oklch, var(--ss-accent) 40%, transparent);
  transition: transform 0.2s ease, box-shadow 0.2s ease, background 0.2s ease;
  position: relative;
}
.ss-cta:hover {
  transform: translateY(-2px);
  background: linear-gradient(180deg,
    rgba(255,58,163,0.35) 0%,
    rgba(160,43,255,0.35) 100%);
  box-shadow: 0 0 38px color-mix(in oklch, var(--ss-accent) 70%, transparent);
}

/* ----- variant padding so text doesn't crash into characters ----- */
.ss-duo .ss-content       { padding-left: 22%; padding-right: 22%; }
.ss-solo-right .ss-content { padding-right: 36%; }
.ss-solo-left  .ss-content { padding-left: 36%; }

/* ============================================================
   Reveal choreography — "puzzle snap":
     frame slides in from one side with overshoot
     character slides in from the OPPOSITE side
     accent stripe locks in last
     content (text + CTA) fades up after everything locks
   ============================================================ */
.ss {
  opacity: 0;
  transform: translateY(40px) scale(0.985);
  transition:
    opacity 0.7s cubic-bezier(0.16,1,0.3,1),
    transform 0.7s cubic-bezier(0.16,1,0.3,1);
}
.ss.revealed { opacity: 1; transform: translateY(0) scale(1); }

/* frame slides in from LEFT for solo-right / duo */
.ss-frame {
  transform: translateX(-12%) rotate(-1.2deg);
  opacity: 0;
  transition:
    transform 0.85s cubic-bezier(0.34,1.4,0.4,1) 0.05s,
    opacity  0.55s ease 0.05s;
}
/* …and from RIGHT for solo-left */
.ss-solo-left .ss-frame {
  transform: translateX(12%) rotate(1.2deg);
}
.ss.revealed .ss-frame {
  transform: translateX(0) rotate(0);
  opacity: 1;
}

/* accent piece slides in last from the same side as the frame's
   pre-state, locking the composition together */
.ss-frame::after {
  transform: translateX(60%) scaleX(0.4);
  opacity: 0;
  transition:
    transform 0.75s cubic-bezier(0.34,1.5,0.6,1) 0.55s,
    opacity  0.4s ease 0.55s;
}
.ss-solo-left .ss-frame::after,
.ss-shape-slant-l .ss-frame::after {
  transform: translateX(-60%) scaleX(0.4);
}
.ss.revealed .ss-frame::after {
  transform: translateX(0) scaleX(1);
  opacity: 0.85;
}

/* title — de-blur as the frame locks */
.ss-title {
  opacity: 0;
  transform: translateY(-10px);
  filter: blur(8px);
  transition:
    opacity 0.6s ease 0.42s,
    transform 0.6s cubic-bezier(0.16,1,0.3,1) 0.42s,
    filter 0.6s ease 0.42s;
}
.ss.revealed .ss-title { opacity: 1; transform: translateY(0); filter: blur(0); }

/* characters — slide in from THEIR side (left from left edge,
   right from right edge), opposite to the frame, with overshoot */
.ss-char {
  opacity: 0;
  transition:
    opacity 0.7s ease 0.3s,
    transform 1.0s cubic-bezier(0.34,1.5,0.5,1) 0.25s;
}
.ss-char-left  { transform: translateX(-60%) translateY(20px); }
.ss-char-right { transform: translateX(60%)  translateY(20px); }
.ss.revealed .ss-char { opacity: 1; }
.ss.revealed .ss-char-left  { transform: translateX(-8%) translateY(0); }
.ss.revealed .ss-char-right { transform: translateX(8%)  translateY(0); }
.ss.revealed.ss-solo-right .ss-char-right { transform: translateX(2%); }
.ss.revealed.ss-solo-left  .ss-char-left  { transform: translateX(-2%); }

/* brackets snap in last */
.ss-bracket {
  opacity: 0;
  transform: scale(0.4);
  transition:
    opacity 0.4s ease 0.7s,
    transform 0.5s cubic-bezier(0.34,1.7,0.6,1) 0.7s;
}
.ss.revealed .ss-bracket { opacity: 1; transform: scale(1); }
.ss-bracket.tr { transition-delay: 0.78s; }
.ss-bracket.bl { transition-delay: 0.78s; }
.ss-bracket.br { transition-delay: 0.86s; }

/* meta / sub / CTA — fade up after the lock */
.ss-meta, .ss-sub, .ss-cta {
  opacity: 0;
  transform: translateY(10px);
  transition: opacity 0.5s ease, transform 0.5s ease;
}
.ss-meta { transition-delay: 0.78s; }
.ss-sub  { transition-delay: 0.88s; }
.ss-cta  { transition-delay: 1.0s; }
.ss.revealed .ss-meta, .ss.revealed .ss-sub, .ss.revealed .ss-cta {
  opacity: 1; transform: translateY(0);
}

/* respect reduced motion */
@media (prefers-reduced-motion: reduce) {
  .ss, .ss-frame, .ss-frame::after, .ss-char, .ss-title, .ss-bracket,
  .ss-meta, .ss-sub, .ss-cta {
    transition: opacity 0.3s ease !important;
    transform: none !important;
    filter: none !important;
  }
}

/* ============================================================
   Responsive
   ============================================================ */
@media (max-width: 980px) {
  .ss { --ss-h: 420px !important; height: 420px !important; }
  .ss-content { padding: 36px 32px !important; }
  .ss-duo       .ss-content { padding-left: 32px !important; padding-right: 32px !important; }
  .ss-solo-right .ss-content { padding-right: 50% !important; }
  .ss-solo-left  .ss-content { padding-left: 50% !important; }
  .ss-title { font-size: clamp(44px, 8vw, 88px); -webkit-text-stroke-width: 4px; }
  .ss-title .ac, .ss-title .ac-cyan, .ss-title .ac-gold { -webkit-text-stroke-width: 4px; }
}
@media (max-width: 720px) {
  .ss { --ss-h: 480px !important; height: 480px !important; --ss-pop: 10%; }
  .ss-char-left  { left: -10%; height: calc(80% + var(--ss-pop)); opacity: 0.45; }
  .ss-char-right { right: -10%; height: calc(80% + var(--ss-pop)); opacity: 0.45; }
  .ss-solo-right .ss-content,
  .ss-solo-left  .ss-content,
  .ss-duo .ss-content { padding: 28px 24px !important; align-items: flex-start; text-align: left; }
  .ss-title { font-size: clamp(40px, 12vw, 64px); -webkit-text-stroke-width: 3px; }
  .ss-title .ac, .ss-title .ac-cyan, .ss-title .ac-gold { -webkit-text-stroke-width: 3px; }
  .ss-bracket { width: 16px; height: 16px; }
}

/* =========================================================
   REAL 3D GLOBE — MapLibre + GTA chrome
   The map canvas is the bottom layer; everything else
   (pins, HUD, recticle, controls) sits on top via z-index.
   ========================================================= */
.gta-map-wrap {
  position: absolute;
  inset: 0;
  overflow: hidden;
  background:
    radial-gradient(circle at 48% 46%, rgba(255,58,163,0.16), transparent 34%),
    radial-gradient(circle at 55% 52%, rgba(70,229,229,0.12), transparent 46%),
    #06011a;
  isolation: isolate;
  z-index: 2;
}
.gta-map-wrap::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 3;
  pointer-events: none;
  background:
    linear-gradient(90deg, transparent 0 49.85%, rgba(70,229,229,0.18) 50%, transparent 50.15% 100%),
    linear-gradient(180deg, transparent 0 49.85%, rgba(255,58,163,0.16) 50%, transparent 50.15% 100%),
    repeating-linear-gradient(180deg, rgba(255,255,255,0.025) 0 1px, transparent 1px 5px);
  mix-blend-mode: screen;
  opacity: 0.68;
}
.gta-map-wrap::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 3;
  pointer-events: none;
  background:
    radial-gradient(circle at 50% 48%, transparent 0 40%, rgba(5,0,18,0.18) 58%, rgba(5,0,18,0.82) 100%),
    linear-gradient(135deg, rgba(255,58,163,0.14), transparent 24%, transparent 70%, rgba(70,229,229,0.12));
}
.gta-map {
  position: absolute;
  inset: 0;
  /* push the MapLibre canvas slightly toward the GTA palette
     (the per-layer recolor in JS does the heavy lifting; this
     is just a final wash so it matches the page tone). */
  filter: brightness(1.18) contrast(1.2) saturate(1.48) hue-rotate(-5deg);
}
.gta-map .maplibregl-canvas { outline: none; }
.gta-map .maplibregl-canvas-container { outline: none; }
.gta-map .maplibregl-ctrl-attrib { display: none !important; }

/* Pin — neon diamond + label below.
   The whole pin is a <button>, so anchor "center" positions
   its midpoint on the lon/lat; we visually compensate with
   translateY so the dot sits ON the country, not the label. */
.gta-pin {
  position: relative;
  width: 36px;
  height: 50px;
  background: none;
  border: 0;
  padding: 0;
  cursor: pointer;
  transform: translateY(-12px);
  z-index: 2;
  -webkit-tap-highlight-color: transparent;
}
.gta-pin-ring {
  position: absolute;
  top: 6px; left: 50%;
  width: 36px; height: 36px;
  border-radius: 50%;
  border: 1.5px solid rgba(43,215,107,0.55);
  transform: translate(-50%, 0);
  opacity: 0.0;
  pointer-events: none;
  animation: pinRing 2.4s ease-out infinite;
}
.gta-pin-dot {
  position: absolute;
  top: 9px; left: 50%;
  width: 20px; height: 20px;
  transform: translate(-50%, 0) rotate(45deg);
  background: linear-gradient(135deg, #b6ff8a 0%, #2bd76b 60%, #178f3f 100%);
  border: 1.5px solid #0a1604;
  box-shadow:
    0 0 8px rgba(43,215,107,0.85),
    0 0 22px rgba(43,215,107,0.45),
    inset 0 2px 0 rgba(255,255,255,0.35),
    inset 0 -2px 0 rgba(0,0,0,0.45);
  pointer-events: none;
}
.gta-pin-dot::after {
  /* inner highlight */
  content: "";
  position: absolute;
  inset: 3px;
  background: linear-gradient(135deg, rgba(255,255,255,0.4), transparent 55%);
  pointer-events: none;
}
.gta-pin-lbl {
  position: absolute;
  bottom: 0; left: 50%;
  transform: translateX(-50%);
  font-family: 'JetBrains Mono', monospace;
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 0.16em;
  color: #c9ffae;
  text-shadow:
    0 0 2px #0a1604,
    0 0 4px #0a1604,
    0 0 8px rgba(43,215,107,0.7);
  white-space: nowrap;
  pointer-events: none;
}
.gta-pin:hover {
  z-index: 5;
}
.gta-pin:hover .gta-pin-dot {
  filter: brightness(1.25);
  box-shadow:
    0 0 14px rgba(43,215,107,1),
    0 0 28px rgba(43,215,107,0.7),
    inset 0 2px 0 rgba(255,255,255,0.5),
    inset 0 -2px 0 rgba(0,0,0,0.45);
}
.gta-pin:hover .gta-pin-lbl {
  color: #fff;
}

/* Heat-tier sizing — bigger dots for higher heat */
.gta-pin.heat-5 .gta-pin-dot { width: 24px; height: 24px; top: 7px; }
.gta-pin.heat-4 .gta-pin-dot { width: 22px; height: 22px; top: 8px; }
.gta-pin.heat-2 .gta-pin-dot { width: 18px; height: 18px; top: 10px; }

/* Claimed → gold */
.gta-pin.claimed .gta-pin-dot {
  background: linear-gradient(135deg, #fff3a0 0%, #ffd23a 60%, #a06b10 100%);
  box-shadow:
    0 0 10px rgba(255,210,58,0.9),
    0 0 26px rgba(255,210,58,0.55),
    inset 0 2px 0 rgba(255,255,255,0.45),
    inset 0 -2px 0 rgba(0,0,0,0.5);
}
.gta-pin.claimed .gta-pin-ring { border-color: rgba(255,210,58,0.65); }
.gta-pin.claimed .gta-pin-lbl {
  color: #ffe9a0;
  text-shadow: 0 0 2px #2a1700, 0 0 4px #2a1700, 0 0 10px rgba(255,210,58,0.75);
}

/* Host → pink */
.gta-pin.host .gta-pin-dot {
  width: 26px; height: 26px; top: 6px;
  background: linear-gradient(135deg, #ffd0e8 0%, #ff3aa3 55%, #8a0e54 100%);
  box-shadow:
    0 0 14px rgba(255,58,163,1),
    0 0 32px rgba(255,58,163,0.55),
    inset 0 2px 0 rgba(255,255,255,0.5),
    inset 0 -2px 0 rgba(0,0,0,0.55);
}
.gta-pin.host .gta-pin-ring { border-color: rgba(255,58,163,0.7); }
.gta-pin.host .gta-pin-lbl {
  color: #ffb5db;
  text-shadow: 0 0 2px #2a0014, 0 0 4px #2a0014, 0 0 10px rgba(255,58,163,0.85);
}

/* Live match → pulsing red */
.gta-pin.live .gta-pin-dot {
  background: linear-gradient(135deg, #ffd0d8 0%, #ff2d55 55%, #7a0a18 100%);
  box-shadow:
    0 0 14px rgba(255,45,85,1),
    0 0 32px rgba(255,45,85,0.6),
    inset 0 2px 0 rgba(255,255,255,0.45);
  animation: pinLivePulse 0.85s ease-in-out infinite;
}
.gta-pin.live .gta-pin-ring {
  border-color: rgba(255,45,85,0.85);
  animation-duration: 1.1s;
}
.gta-pin.live .gta-pin-lbl {
  color: #ffb5c0;
  text-shadow: 0 0 2px #200004, 0 0 4px #200004, 0 0 10px rgba(255,45,85,0.85);
}

@keyframes pinRing {
  0%   { transform: translate(-50%, 0) scale(0.5); opacity: 0.85; }
  100% { transform: translate(-50%, 0) scale(2.4); opacity: 0; }
}
@keyframes pinLivePulse {
  0%, 100% { transform: translate(-50%, 0) rotate(45deg) scale(1); }
  50%      { transform: translate(-50%, 0) rotate(45deg) scale(1.18); }
}

/* HUD corner blocks — mil-spec readouts */
.gta-map-hud {
  position: absolute;
  z-index: 4;
  padding: 10px 14px;
  background: rgba(8,3,15,0.62);
  border: 1px solid rgba(70,229,229,0.28);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  font-family: 'JetBrains Mono', monospace;
  font-size: 9px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  pointer-events: none;
  min-width: 170px;
  display: grid;
  gap: 2px;
}
.gta-map-hud .k { color: rgba(255,255,255,0.4); }
.gta-map-hud .v {
  color: #46e5e5;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.08em;
  margin-bottom: 6px;
}
.gta-map-hud .v:last-child { margin-bottom: 0; }
.gta-map-hud .v.gold  { color: #ffd23a; text-shadow: 0 0 8px rgba(255,210,58,0.55); }
.gta-map-hud .v.pink  { color: #ff3aa3; text-shadow: 0 0 8px rgba(255,58,163,0.55); }
.gta-map-hud .v.alert { color: #ff2d55; text-shadow: 0 0 8px rgba(255,45,85,0.55); }
.gta-map-hud .v.mono  { font-family: 'JetBrains Mono', monospace; font-size: 11.5px; }
.gta-map-hud .hoverlink { pointer-events: auto; cursor: pointer; }
.gta-map-hud .hoverlink:hover { filter: brightness(1.3); }
.gta-map-hud.tl { top: 14px; left: 14px; }
.gta-map-hud.tr { top: 14px; right: 14px; text-align: right; }
.gta-map-hud.bl { bottom: 14px; left: 14px; }
.gta-map-hud.br { bottom: 14px; right: 14px; text-align: right; }

/* Decorative crosshair recticle (center of viewport) */
.gta-map-recticle {
  position: absolute;
  inset: 0;
  pointer-events: none;
  z-index: 3;
}
.gta-rec.h, .gta-rec.v {
  position: absolute;
  background: linear-gradient(90deg, transparent, rgba(70,229,229,0.18), transparent);
}
.gta-rec.h { left: 0; right: 0; top: 50%; height: 1px; }
.gta-rec.v {
  top: 0; bottom: 0; left: 50%; width: 1px;
  background: linear-gradient(180deg, transparent, rgba(70,229,229,0.18), transparent);
}
.gta-rec.cn {
  position: absolute;
  width: 16px; height: 16px;
  border: 1px solid rgba(70,229,229,0.55);
  pointer-events: none;
}
.gta-rec.cn.tl { top: 16px; left: 16px; border-right: 0; border-bottom: 0; }
.gta-rec.cn.tr { top: 16px; right: 16px; border-left: 0; border-bottom: 0; }
.gta-rec.cn.bl { bottom: 16px; left: 16px; border-right: 0; border-top: 0; }
.gta-rec.cn.br { bottom: 16px; right: 16px; border-left: 0; border-top: 0; }

/* Zoom / spin controls cluster */
.gta-map-ctrl {
  position: absolute;
  right: 14px;
  top: 50%;
  transform: translateY(-50%);
  z-index: 4;
  display: flex;
  flex-direction: column;
  gap: 4px;
  pointer-events: auto;
}
.gta-map-ctrl button {
  width: 44px; height: 44px;
  background: rgba(8,3,15,0.78);
  color: #46e5e5;
  border: 1px solid rgba(70,229,229,0.45);
  font-family: 'Pricedown Bl', 'Pricedown', 'Bowlby One SC', sans-serif;
  font-size: 18px;
  cursor: pointer;
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  transition: all 0.12s ease;
}
.gta-map-ctrl button:hover {
  background: rgba(70,229,229,0.18);
  color: #fff;
  border-color: #46e5e5;
  box-shadow: 0 0 12px rgba(70,229,229,0.45);
}
.gta-map-ctrl button.on {
  background: linear-gradient(180deg, #46e5e5, #2eb4b4);
  color: #08030f;
  border-color: transparent;
}

/* Title strip — bottom-left ($GCA mark like screenshot 1) */
.gta-map-title {
  position: absolute;
  left: -2px;
  bottom: 56px;
  z-index: 4;
  display: flex;
  flex-direction: column;
  padding: 8px 16px 8px 14px;
  background: linear-gradient(90deg, rgba(255,58,163,0.95), rgba(255,58,163,0.0));
  pointer-events: none;
}
.gta-map-title .t {
  font-family: 'Pricedown Bl', 'Pricedown', 'Bowlby One SC', sans-serif;
  font-size: 22px;
  letter-spacing: 0.04em;
  color: #fff;
  -webkit-text-stroke: 1px #0a0014;
  paint-order: stroke fill;
  line-height: 1;
}
.gta-map-title .s {
  font-family: 'JetBrains Mono', monospace;
  font-size: 8.5px;
  letter-spacing: 0.32em;
  color: rgba(255,255,255,0.75);
  margin-top: 2px;
}

/* Boot / loader state */
.gta-map-boot {
  position: absolute;
  inset: 0;
  z-index: 5;
  display: flex; flex-direction: column;
  align-items: center; justify-content: center;
  gap: 14px;
  background: rgba(6,1,26,0.92);
  pointer-events: none;
}
.gta-boot-bar {
  position: relative;
  width: 220px; height: 4px;
  background: rgba(70,229,229,0.12);
  overflow: hidden;
}
.gta-boot-bar span {
  position: absolute; inset: 0;
  background: linear-gradient(90deg, transparent, #46e5e5, transparent);
  width: 60%;
  animation: bootScan 1.6s linear infinite;
}
.gta-boot-lbl {
  font-family: 'JetBrains Mono', monospace;
  font-size: 10px;
  color: #46e5e5;
  letter-spacing: 0.22em;
  text-transform: uppercase;
}
@keyframes bootScan {
  from { transform: translateX(-100%); }
  to   { transform: translateX(220%); }
}

.gta-map-fail {
  position: absolute;
  inset: 0;
  z-index: 6;
  display: flex; flex-direction: column;
  align-items: center; justify-content: center;
  gap: 8px; padding: 24px;
  background: rgba(6,1,26,0.85);
  color: #ff2d55;
  font-family: 'JetBrains Mono', monospace;
  letter-spacing: 0.2em;
  text-align: center;
}
.gta-map-fail .ttl {
  font-family: 'Pricedown Bl','Pricedown','Bowlby One SC',sans-serif;
  font-size: 28px; color: #fff; letter-spacing: 0.04em;
  -webkit-text-stroke: 1px #0a0014; paint-order: stroke fill;
}
.gta-map-fail .sub { font-size: 11px; color: #ff7a96; line-height: 1.5; }

/* Mobile compaction — keep HUD readable on phones */
@media (max-width: 760px) {
  .turf-section {
    padding-left: 10px;
    padding-right: 10px;
  }
  .turf-stage {
    width: 100%;
    max-width: calc(100vw - 20px);
    margin-left: auto;
    margin-right: auto;
  }
  .turf-stage.mode-globe {
    aspect-ratio: 1 / 1.12;
    min-height: 430px;
  }
  .gta-map-hud {
    min-width: 0;
    font-size: 8px;
    padding: 8px 10px;
    max-width: 42vw;
    letter-spacing: 0.12em;
    background: rgba(8,3,15,0.72);
  }
  .gta-map-hud .k { font-size: 7px; }
  .gta-map-hud .v { font-size: 10px; }
  .gta-map-hud.tl, .gta-map-hud.tr, .gta-map-hud.bl, .gta-map-hud.br {
    max-width: 42vw;
  }
  .gta-map-hud.tr,
  .gta-map-hud.bl { display: none; }
  .gta-map-hud.br {
    left: 8px;
    right: auto;
    bottom: 8px;
    text-align: left;
    max-width: calc(100% - 74px);
  }
  .gta-map-title .t { font-size: 18px; }
  .gta-map-title {
    display: none;
  }
  .gta-map-title .s { letter-spacing: 0.18em; }
  .gta-map-ctrl {
    right: 8px;
    top: auto;
    bottom: 8px;
    transform: none;
  }
  .gta-map-ctrl button { width: 44px; height: 44px; font-size: 16px; }
  .gta-pin-lbl { font-size: 8px; }
}

@media (max-width: 760px) {
  .gx-mute {
    left: auto;
    right: 14px;
    top: 132px;
    bottom: auto;
    width: 48px;
    height: 48px;
    padding: 0;
    justify-content: center;
  }
  .gx-mute span { display: none; }
}

/* ------------------------------------------------------------------
   Grand Cup Auto X Pump.fun Bounties
   Clean retro TV replacement for the old Turf Map section.
------------------------------------------------------------------ */
.bounties-tv-section {
  isolation: isolate;
  padding-top: 92px;
  background:
    radial-gradient(circle at 82% 24%, rgba(70,229,229,0.18), transparent 34%),
    radial-gradient(circle at 18% 24%, rgba(255,58,163,0.22), transparent 32%),
    linear-gradient(180deg, rgba(8,3,28,0.96), rgba(3,2,14,0.98));
}

.bounties-tv-section::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  background:
    linear-gradient(90deg, rgba(255,58,163,0.09) 1px, transparent 1px),
    linear-gradient(0deg, rgba(70,229,229,0.06) 1px, transparent 1px);
  background-size: 72px 72px, 72px 72px;
  mask-image: linear-gradient(180deg, transparent, #000 16%, #000 84%, transparent);
}

.btv-shell {
  position: relative;
  z-index: 2;
  width: min(1360px, calc(100vw - 64px));
  margin: 0 auto;
}

.btv-head {
  align-items: end;
  margin-bottom: 34px;
}

.btv-section-kicker {
  color: var(--vc-cyan);
  font-family: "JetBrains Mono", monospace;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}

.btv-section-title {
  max-width: 960px;
  margin: 10px 0 0;
  color: white;
  font-family: "Pricedown Bl", "Pricedown", "Bowlby One SC", Impact, sans-serif;
  font-size: clamp(44px, 6vw, 86px);
  line-height: 0.9;
  text-transform: lowercase;
  text-shadow: 5px 5px 0 rgba(0,0,0,0.78), 0 0 24px rgba(255,58,163,0.28);
}

.btv-section-title span {
  color: var(--vc-cyan);
  text-shadow: 5px 5px 0 rgba(0,0,0,0.78), 0 0 24px rgba(70,229,229,0.3);
}

.btv-head-copy {
  max-width: 420px;
  color: rgba(255,255,255,0.66);
  font-family: "JetBrains Mono", monospace;
  font-size: 12px;
  line-height: 1.7;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  text-align: right;
}

.btv-console {
  position: relative;
  display: grid;
  grid-template-columns: minmax(0, 1fr) 250px;
  gap: 22px;
  align-items: stretch;
}

.btv-tv {
  position: relative;
  min-width: 0;
  padding: 34px 34px 30px;
  border-radius: 34px;
  background:
    linear-gradient(135deg, rgba(255,255,255,0.18), transparent 18%),
    linear-gradient(145deg, #27124a 0%, #12071f 44%, #05020c 100%);
  border: 1px solid rgba(255,255,255,0.18);
  box-shadow:
    0 34px 90px rgba(0,0,0,0.58),
    inset 0 1px 0 rgba(255,255,255,0.22),
    inset 0 -18px 38px rgba(0,0,0,0.5);
}

.btv-tv::before {
  content: "";
  position: absolute;
  inset: 14px;
  border-radius: 25px;
  border: 1px solid rgba(255,58,163,0.28);
  pointer-events: none;
}

.btv-antenna {
  position: absolute;
  top: -42px;
  left: 48%;
  width: 3px;
  height: 70px;
  border-radius: 99px;
  background: linear-gradient(#ffe8b8, #ff3aa3);
  transform-origin: bottom;
  opacity: 0.78;
}
.btv-antenna.a1 { transform: rotate(-32deg); }
.btv-antenna.a2 { transform: translateX(34px) rotate(34deg); }

.btv-bezel {
  position: relative;
  overflow: hidden;
  border-radius: 24px;
  padding: 16px;
  background:
    linear-gradient(145deg, rgba(255,210,58,0.28), rgba(70,229,229,0.16) 34%, rgba(255,58,163,0.22) 70%, rgba(0,0,0,0.4)),
    #090313;
  box-shadow:
    inset 0 0 0 2px rgba(255,255,255,0.09),
    inset 0 0 36px rgba(0,0,0,0.9);
}

.btv-screen {
  position: relative;
  overflow: hidden;
  min-height: 520px;
  border-radius: 18px;
  background:
    radial-gradient(circle at 50% 35%, rgba(255,122,200,0.22), transparent 34%),
    linear-gradient(135deg, rgba(255,58,163,0.24), rgba(70,229,229,0.12) 42%, rgba(4,2,14,0.92)),
    #05020c;
  border: 1px solid rgba(255,255,255,0.12);
  box-shadow:
    inset 0 0 46px rgba(0,0,0,0.72),
    0 0 42px rgba(70,229,229,0.18);
}

.btv-screen::before,
.btv-screen::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 8;
  pointer-events: none;
}

.btv-screen::before {
  background: linear-gradient(rgba(255,255,255,0.045) 50%, rgba(0,0,0,0.1) 50%);
  background-size: 100% 4px;
  mix-blend-mode: overlay;
}

.btv-screen::after {
  background:
    radial-gradient(ellipse at center, transparent 58%, rgba(0,0,0,0.42)),
    linear-gradient(100deg, rgba(255,255,255,0.16), transparent 24%, transparent 74%, rgba(255,255,255,0.08));
}

.btv-screen-glow {
  position: absolute;
  inset: -24%;
  background:
    radial-gradient(circle at 26% 24%, rgba(255,58,163,0.3), transparent 28%),
    radial-gradient(circle at 76% 18%, rgba(70,229,229,0.24), transparent 32%),
    radial-gradient(circle at 44% 100%, rgba(255,210,58,0.16), transparent 36%);
  pointer-events: none;
}

.btv-menu,
.btv-player {
  position: absolute;
  inset: 0;
  z-index: 2;
}

.btv-menu {
  display: flex;
  flex-direction: column;
  gap: 24px;
  padding: 34px;
}

.btv-menu-top {
  display: flex;
  justify-content: space-between;
  gap: 24px;
  align-items: start;
}

.btv-label,
.btv-tile-kicker,
.btv-live {
  font-family: "JetBrains Mono", monospace;
  font-size: 11px;
  line-height: 1;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}

.btv-label { color: var(--vc-cyan); }

.btv-menu-title {
  margin-top: 10px;
  max-width: 650px;
  color: white;
  font-family: "Pricedown Bl", "Pricedown", "Bowlby One SC", Impact, sans-serif;
  font-size: clamp(40px, 4.6vw, 68px);
  line-height: 0.9;
  text-transform: lowercase;
  text-shadow: 5px 5px 0 rgba(0,0,0,0.8), 0 0 20px rgba(255,58,163,0.35);
}

.btv-live {
  flex: 0 0 auto;
  padding: 11px 13px;
  color: #071016;
  border-radius: 999px;
  background: #46e5e5;
  box-shadow: 0 0 18px rgba(70,229,229,0.44);
}

.btv-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 14px;
  margin-top: auto;
}

.btv-tile {
  position: relative;
  overflow: hidden;
  min-height: 258px;
  padding: 0;
  color: white;
  border: 1px solid rgba(255,255,255,0.14);
  border-radius: 14px;
  background: rgba(5,2,13,0.72);
  cursor: pointer;
  text-align: left;
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.12);
  transition: transform 180ms ease, border-color 180ms ease, box-shadow 180ms ease;
}

.btv-tile:hover,
.btv-tile:focus-visible {
  transform: translateY(-4px);
  border-color: var(--tile-accent);
  box-shadow: 0 16px 34px rgba(0,0,0,0.35), 0 0 24px color-mix(in srgb, var(--tile-accent) 42%, transparent);
  outline: none;
}

.btv-tile-no {
  position: absolute;
  z-index: 3;
  top: 12px;
  left: 12px;
  color: #071016;
  font-family: "JetBrains Mono", monospace;
  font-size: 11px;
  font-weight: 800;
  letter-spacing: 0.14em;
  padding: 7px 8px;
  border-radius: 999px;
  background: var(--tile-accent);
}

.btv-tile-thumb {
  position: absolute;
  inset: 0;
}

.btv-tile-thumb video {
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: saturate(1.22) contrast(1.08) brightness(0.82);
}

.btv-tile-scan {
  position: absolute;
  inset: 0;
  background:
    linear-gradient(180deg, transparent 0%, rgba(0,0,0,0.46) 72%, rgba(0,0,0,0.82) 100%),
    linear-gradient(rgba(255,255,255,0.05) 50%, rgba(0,0,0,0.14) 50%);
  background-size: auto, 100% 5px;
}

.btv-tile-copy {
  position: absolute;
  z-index: 3;
  left: 14px;
  right: 14px;
  bottom: 14px;
}

.btv-tile-kicker {
  display: block;
  color: var(--tile-accent);
  margin-bottom: 8px;
}

.btv-tile-title {
  display: block;
  font-family: "Pricedown Bl", "Pricedown", "Bowlby One SC", Impact, sans-serif;
  font-size: 32px;
  line-height: 0.92;
  text-shadow: 3px 3px 0 rgba(0,0,0,0.8);
}

.btv-player video {
  width: 100%;
  height: 100%;
  object-fit: cover;
  background: #020009;
}

.btv-player-top {
  position: absolute;
  z-index: 10;
  top: 18px;
  left: 18px;
  right: 18px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 14px;
  pointer-events: none;
}

.btv-player-top span,
.btv-player-top button {
  font-family: "JetBrains Mono", monospace;
  font-size: 11px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}

.btv-player-top span {
  color: rgba(255,255,255,0.84);
  padding: 10px 12px;
  border-radius: 999px;
  background: rgba(0,0,0,0.44);
  border: 1px solid rgba(255,255,255,0.12);
}

.btv-player-top button {
  pointer-events: auto;
  color: #071016;
  border: 0;
  border-radius: 999px;
  padding: 10px 13px;
  background: var(--vc-cyan);
  cursor: pointer;
}

.btv-controls {
  display: grid;
  grid-template-columns: auto auto 1fr;
  align-items: center;
  gap: 16px;
  margin-top: 20px;
}

.btv-dial {
  width: 44px;
  height: 44px;
  border-radius: 50%;
  background:
    radial-gradient(circle at 35% 30%, rgba(255,255,255,0.9), transparent 18%),
    conic-gradient(from 20deg, rgba(255,255,255,0.25), transparent, rgba(255,255,255,0.18)),
    #13071f;
  border: 1px solid rgba(255,255,255,0.16);
}
.btv-dial.pink { box-shadow: 0 0 18px rgba(255,58,163,0.42); }
.btv-dial.cyan { box-shadow: 0 0 18px rgba(70,229,229,0.34); }

.btv-speaker {
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  gap: 7px;
  justify-self: end;
  width: min(360px, 100%);
}
.btv-speaker span {
  height: 4px;
  border-radius: 999px;
  background: rgba(255,255,255,0.16);
}

.btv-side-panel {
  position: relative;
  overflow: hidden;
  border-radius: 22px;
  padding: 24px;
  background:
    linear-gradient(180deg, rgba(255,58,163,0.12), rgba(70,229,229,0.08)),
    rgba(5,2,15,0.78);
  border: 1px solid rgba(255,255,255,0.12);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.12);
}

.btv-panel-title {
  color: white;
  font-family: "Pricedown Bl", "Pricedown", "Bowlby One SC", Impact, sans-serif;
  font-size: 44px;
  line-height: 0.92;
  text-transform: lowercase;
}

.btv-panel-rule {
  width: 100%;
  height: 3px;
  margin: 18px 0;
  background: linear-gradient(90deg, var(--vc-pink), var(--vc-cyan), transparent);
}

.btv-side-panel p {
  color: rgba(255,255,255,0.66);
  font-size: 14px;
  line-height: 1.7;
  margin: 0;
}

.btv-status {
  position: absolute;
  left: 24px;
  right: 24px;
  bottom: 24px;
  display: flex;
  align-items: center;
  gap: 10px;
  color: var(--vc-cyan);
  font-family: "JetBrains Mono", monospace;
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

.btv-status span {
  width: 9px;
  height: 9px;
  border-radius: 50%;
  background: var(--vc-cyan);
  box-shadow: 0 0 14px var(--vc-cyan);
}

@media (max-width: 1100px) {
  .btv-console {
    grid-template-columns: 1fr;
  }
  .btv-side-panel {
    display: none;
  }
  .btv-screen {
    min-height: 500px;
  }
}

@media (max-width: 760px) {
  .bounties-tv-section {
    padding-top: 64px;
  }
  .btv-shell {
    width: min(100% - 28px, 640px);
  }
  .btv-head {
    align-items: start;
  }
  .btv-section-title {
    font-size: 46px;
    max-width: 340px;
  }
  .btv-head-copy {
    display: none;
  }
  .btv-tv {
    padding: 18px 14px 16px;
    border-radius: 24px;
  }
  .btv-bezel {
    padding: 10px;
    border-radius: 18px;
  }
  .btv-screen {
    min-height: 600px;
    border-radius: 14px;
  }
  .btv-menu {
    padding: 22px;
  }
  .btv-menu-top {
    display: block;
  }
  .btv-menu-title {
    font-size: 40px;
  }
  .btv-live {
    display: inline-block;
    margin-top: 14px;
  }
  .btv-grid {
    grid-template-columns: 1fr;
    gap: 10px;
  }
  .btv-tile {
    min-height: 96px;
  }
  .btv-tile-title {
    font-size: 26px;
  }
  .btv-controls {
    display: none;
  }
  .btv-player video { object-fit: cover; }
}

/* ------------------------------------------------------------------
   Bounty Board Loading
   Replaces the old suspect leaderboard with a Pump.fun GO relay board.
------------------------------------------------------------------ */
.bb-load {
  position: relative;
  z-index: 2;
  width: min(1360px, calc(100vw - 64px));
  margin: 0 auto;
  overflow: hidden;
  border: 1px solid rgba(255,255,255,0.14);
  border-radius: 26px;
  background:
    radial-gradient(circle at 22% 18%, rgba(255,58,163,0.2), transparent 34%),
    radial-gradient(circle at 78% 22%, rgba(70,229,229,0.18), transparent 32%),
    linear-gradient(145deg, rgba(18,7,38,0.96), rgba(4,2,13,0.98));
  box-shadow:
    0 36px 100px rgba(0,0,0,0.58),
    inset 0 1px 0 rgba(255,255,255,0.14);
}

.bb-load::before,
.bb-load::after {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
}

.bb-load::before {
  background:
    linear-gradient(90deg, rgba(255,58,163,0.08) 1px, transparent 1px),
    linear-gradient(0deg, rgba(70,229,229,0.06) 1px, transparent 1px);
  background-size: 54px 54px;
  mask-image: linear-gradient(180deg, transparent, #000 16%, #000 88%, transparent);
}

.bb-load::after {
  background: linear-gradient(rgba(255,255,255,0.045) 50%, rgba(0,0,0,0.08) 50%);
  background-size: 100% 4px;
  mix-blend-mode: overlay;
}

.bb-load-top {
  position: relative;
  z-index: 2;
  display: flex;
  justify-content: space-between;
  gap: 28px;
  padding: 34px 36px 22px;
}

.bb-load-kicker,
.bb-load-status,
.bb-cartel-foot,
.bb-pipe-card span,
.bb-load-metric span {
  font-family: "JetBrains Mono", monospace;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

.bb-load-kicker {
  color: var(--vc-cyan);
  font-size: 12px;
  font-weight: 800;
}

.bb-load h3 {
  margin: 10px 0 10px;
  color: white;
  font-family: "Pricedown Bl", "Pricedown", "Bowlby One SC", Impact, sans-serif;
  font-size: clamp(58px, 7vw, 118px);
  line-height: 0.86;
  text-transform: lowercase;
  text-shadow: 6px 6px 0 rgba(0,0,0,0.78), 0 0 28px rgba(255,58,163,0.32);
}

.bb-load p {
  max-width: 760px;
  margin: 0;
  color: rgba(255,255,255,0.72);
  font-size: 15px;
  line-height: 1.65;
}

.bb-load-status {
  align-self: start;
  display: flex;
  align-items: center;
  gap: 10px;
  flex: 0 0 auto;
  padding: 12px 14px;
  border-radius: 999px;
  color: #061016;
  font-size: 11px;
  font-weight: 900;
  background: var(--vc-cyan);
  box-shadow: 0 0 22px rgba(70,229,229,0.42);
}

.bb-load-dot {
  width: 9px;
  height: 9px;
  border-radius: 50%;
  background: #ff3aa3;
  box-shadow: 0 0 16px #ff3aa3;
  animation: bbPulse 1.1s ease-in-out infinite;
}

.bb-load-screen {
  position: relative;
  z-index: 2;
  display: grid;
  grid-template-columns: 360px minmax(0, 1fr);
  grid-template-rows: auto auto;
  gap: 22px;
  margin: 0 36px 26px;
  padding: 26px;
  min-height: 520px;
  border-radius: 24px;
  border: 1px solid rgba(255,255,255,0.13);
  background:
    radial-gradient(circle at 30% 28%, rgba(255,58,163,0.2), transparent 34%),
    radial-gradient(circle at 74% 36%, rgba(70,229,229,0.16), transparent 34%),
    rgba(3,1,12,0.78);
  box-shadow: inset 0 0 52px rgba(0,0,0,0.7);
}

.bb-load-radar {
  position: relative;
  grid-row: span 2;
  min-height: 100%;
  border-radius: 22px;
  border: 1px solid rgba(255,255,255,0.12);
  background:
    radial-gradient(circle at center, rgba(70,229,229,0.12), transparent 42%),
    linear-gradient(180deg, rgba(255,255,255,0.04), rgba(255,255,255,0.01));
  overflow: hidden;
}

.bb-load-radar::before {
  content: "";
  position: absolute;
  inset: 26px;
  border-radius: 50%;
  border: 1px solid rgba(70,229,229,0.18);
  box-shadow:
    0 0 0 42px rgba(70,229,229,0.04),
    0 0 0 86px rgba(255,58,163,0.035),
    0 0 0 130px rgba(70,229,229,0.03);
}

.bb-load-radar-core {
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  width: min(84%, 330px);
  aspect-ratio: 1;
  display: grid;
  place-items: center;
  border-radius: 28px;
  isolation: isolate;
  background:
    radial-gradient(circle at 50% 45%, rgba(70,229,229,0.16), transparent 60%),
    radial-gradient(circle at 50% 58%, rgba(255,58,163,0.18), transparent 68%);
  box-shadow:
    0 0 34px rgba(70,229,229,0.24),
    0 0 80px rgba(255,58,163,0.22);
}

.bb-load-radar-core::before {
  content: "";
  position: absolute;
  inset: -10%;
  border-radius: 34px;
  border: 1px solid rgba(255,255,255,0.08);
  background: linear-gradient(135deg, rgba(255,58,163,0.14), rgba(70,229,229,0.12));
  filter: blur(18px);
  opacity: 0.72;
  z-index: -1;
}

.bb-load-radar-core img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  border-radius: 24px;
  filter:
    drop-shadow(0 14px 24px rgba(0,0,0,0.56))
    drop-shadow(0 0 18px rgba(255,58,163,0.28))
    saturate(1.06)
    contrast(1.04);
}

.bb-load-ring {
  position: absolute;
  left: 50%;
  top: 50%;
  width: 150px;
  height: 150px;
  border-radius: 50%;
  border: 1px solid rgba(255,255,255,0.32);
  transform: translate(-50%, -50%);
  animation: bbRadarRing 2.7s ease-out infinite;
}
.bb-load-ring.r2 { animation-delay: 1.15s; }

.bb-load-sweep {
  position: absolute;
  left: 50%;
  top: 50%;
  width: 45%;
  height: 2px;
  transform-origin: left center;
  background: linear-gradient(90deg, rgba(70,229,229,0.9), transparent);
  filter: drop-shadow(0 0 12px rgba(70,229,229,0.7));
  animation: bbRadarSweep 3.8s linear infinite;
}

.bb-load-cartels {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 12px;
}

.bb-load-cartel {
  position: relative;
  overflow: hidden;
  min-height: 170px;
  padding: 18px;
  border-radius: 18px;
  border: 1px solid color-mix(in srgb, var(--cartel-color) 38%, rgba(255,255,255,0.12));
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--cartel-color) 16%, transparent), rgba(0,0,0,0.18)),
    rgba(7,3,18,0.78);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.1);
}

.bb-cartel-mark {
  position: absolute;
  right: -18px;
  top: -18px;
  width: 118px;
  height: 118px;
  display: grid;
  place-items: center;
  border-radius: 50%;
  opacity: 0.32;
  filter:
    drop-shadow(0 0 22px color-mix(in srgb, var(--cartel-color) 45%, transparent))
    saturate(1.15)
    contrast(1.05);
  transform: rotate(-7deg);
  pointer-events: none;
}

.bb-cartel-mark::before {
  content: "";
  position: absolute;
  inset: 8px;
  border-radius: inherit;
  background: radial-gradient(circle, color-mix(in srgb, var(--cartel-color) 32%, transparent), transparent 68%);
}

.bb-cartel-mark img {
  position: relative;
  width: 100%;
  height: 100%;
  object-fit: contain;
}

.bb-load-cartel:hover .bb-cartel-mark {
  opacity: 0.5;
  transform: rotate(-4deg) scale(1.04);
}

.bb-load-cartel::after {
  content: "";
  position: absolute;
  inset: auto -20% 0 -20%;
  height: 54px;
  background: radial-gradient(ellipse at center, color-mix(in srgb, var(--cartel-color) 34%, transparent), transparent 70%);
  opacity: 0.85;
}

.bb-cartel-head {
  position: relative;
  z-index: 2;
  display: flex;
  flex-direction: column;
  gap: 7px;
  padding-right: 46px;
}

.bb-cartel-head span {
  color: white;
  font-family: "Pricedown Bl", "Pricedown", "Bowlby One SC", Impact, sans-serif;
  font-size: 29px;
  line-height: 0.9;
  text-transform: lowercase;
  text-shadow: 3px 3px 0 rgba(0,0,0,0.75);
}

.bb-cartel-head b {
  color: var(--cartel-color);
  font-family: "JetBrains Mono", monospace;
  font-size: 11px;
  letter-spacing: 0.14em;
}

.bb-cartel-bar {
  position: relative;
  z-index: 2;
  height: 8px;
  margin: 24px 0 18px;
  overflow: hidden;
  border-radius: 999px;
  background: rgba(255,255,255,0.08);
}

.bb-cartel-bar span {
  display: block;
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, var(--cartel-color), #fff2a8);
  box-shadow: 0 0 16px color-mix(in srgb, var(--cartel-color) 55%, transparent);
  animation: bbLoadBar 1.8s ease-in-out infinite alternate;
  animation-delay: calc(var(--i) * 120ms);
}

.bb-cartel-foot {
  position: relative;
  z-index: 2;
  display: grid;
  gap: 8px;
  color: rgba(255,255,255,0.6);
  font-size: 10px;
  line-height: 1.45;
}

.bb-cartel-foot span:first-child {
  color: #fff;
}

.bb-load-pipeline {
  display: grid;
  grid-template-columns: 1fr 60px 1fr 60px 1fr;
  gap: 10px;
  align-items: center;
}

.bb-pipe-card {
  min-height: 112px;
  padding: 18px;
  border-radius: 18px;
  color: #fff;
  font-family: "Pricedown Bl", "Pricedown", "Bowlby One SC", Impact, sans-serif;
  font-size: 34px;
  line-height: 0.95;
  text-transform: lowercase;
  background: rgba(255,255,255,0.055);
  border: 1px solid rgba(255,255,255,0.12);
}

.bb-pipe-card.hot {
  border-color: rgba(255,58,163,0.45);
  box-shadow: 0 0 28px rgba(255,58,163,0.18);
}

.bb-pipe-card span {
  display: block;
  margin-bottom: 12px;
  color: var(--vc-cyan);
  font-size: 11px;
  font-family: "JetBrains Mono", monospace;
}

.bb-pipe-arrow {
  height: 3px;
  border-radius: 999px;
  background: linear-gradient(90deg, var(--vc-pink), var(--vc-cyan));
  box-shadow: 0 0 16px rgba(70,229,229,0.35);
}

.bb-load-bottom {
  position: relative;
  z-index: 2;
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
  padding: 0 36px 36px;
}

.bb-load-metric {
  padding: 18px;
  border-radius: 16px;
  background: rgba(0,0,0,0.26);
  border: 1px solid rgba(255,255,255,0.1);
}

.bb-load-metric span {
  display: block;
  color: rgba(255,255,255,0.48);
  font-size: 10px;
}

.bb-load-metric b {
  display: block;
  margin-top: 8px;
  color: var(--vc-cyan);
  font-family: "JetBrains Mono", monospace;
  font-size: 24px;
}

@keyframes bbPulse {
  0%, 100% { transform: scale(1); opacity: 1; }
  50% { transform: scale(1.6); opacity: 0.55; }
}

@keyframes bbRadarSweep {
  to { transform: rotate(360deg); }
}

@keyframes bbRadarRing {
  0% { width: 120px; height: 120px; opacity: 0.55; }
  100% { width: 420px; height: 420px; opacity: 0; }
}

@keyframes bbLoadBar {
  from { filter: brightness(0.9); }
  to { filter: brightness(1.45); }
}

@media (max-width: 1060px) {
  .bb-load-screen {
    grid-template-columns: 1fr;
  }
  .bb-load-radar {
    min-height: 360px;
  }
  .bb-load-cartels {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .bb-load-pipeline {
    grid-template-columns: 1fr;
  }
  .bb-pipe-arrow {
    width: 3px;
    height: 28px;
    margin: 0 auto;
  }
}

@media (max-width: 760px) {
  .bb-load {
    width: min(100% - 28px, 640px);
    border-radius: 22px;
  }
  .bb-load-top {
    display: block;
    padding: 24px 22px 18px;
  }
  .bb-load h3 {
    font-size: 62px;
  }
  .bb-load-status {
    display: inline-flex;
    margin-top: 18px;
  }
  .bb-load-screen {
    margin: 0 14px 18px;
    padding: 16px;
    min-height: 0;
  }
  .bb-load-radar {
    min-height: 320px;
  }
  .bb-load-cartels,
  .bb-load-bottom {
    grid-template-columns: 1fr;
  }
  .bb-load-cartel {
    min-height: 220px;
    padding: 28px;
  }
  .bb-cartel-mark {
    right: 18px;
    top: 18px;
    width: 118px;
    height: 118px;
    opacity: 0.42;
  }
  .bb-cartel-head {
    padding-right: 118px;
  }
  .bb-load-bottom {
    padding: 0 14px 18px;
  }
}

/* ------------------------------------------------------------------
   Retro square restyle: Bounty Board + World Is Ours
------------------------------------------------------------------ */
.world-wrap,
.bb-load {
  border-radius: 0;
  border: 1px solid rgba(255,58,163,0.72);
  background:
    linear-gradient(180deg, rgba(255,58,163,0.13), rgba(16,3,31,0.96) 28%, rgba(5,1,13,0.98)),
    repeating-linear-gradient(135deg, rgba(255,255,255,0.045) 0 4px, transparent 4px 10px),
    linear-gradient(135deg, rgba(48,12,86,0.96), rgba(5,1,13,0.98));
  box-shadow:
    0 36px 90px rgba(0,0,0,0.62),
    inset 0 0 0 1px rgba(70,229,229,0.26),
    inset 0 0 48px rgba(255,58,163,0.14);
}

.world-wrap::before,
.bb-load::before {
  background:
    repeating-linear-gradient(135deg, rgba(255,58,163,0.08) 0 2px, transparent 2px 12px),
    linear-gradient(90deg, rgba(70,229,229,0.12), transparent 38%, rgba(255,58,163,0.12));
  background-size: auto;
  mask-image: none;
  opacity: 0.72;
}

.world-wrap::after,
.bb-load::after {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background:
    linear-gradient(90deg, rgba(70,229,229,0.7), transparent 16%, transparent 84%, rgba(255,58,163,0.7)),
    linear-gradient(rgba(255,255,255,0.055) 50%, rgba(0,0,0,0.1) 50%);
  background-size: 100% 2px, 100% 4px;
  mix-blend-mode: screen;
  opacity: 0.42;
}

.world-head,
.bb-load-top {
  border-bottom: 1px solid rgba(255,58,163,0.34);
  background:
    linear-gradient(90deg, rgba(255,58,163,0.15), rgba(70,229,229,0.06) 48%, transparent),
    repeating-linear-gradient(135deg, rgba(255,255,255,0.04) 0 4px, transparent 4px 12px);
}

.world-kicker,
.bb-load-kicker {
  color: var(--vc-cyan);
  text-shadow: 0 0 12px rgba(70,229,229,0.5);
}

.world-count,
.world-diagram,
.world-panel,
.world-tab,
.world-card,
.world-card-icon,
.world-mini-stats div,
.diagram-node,
.bb-load-status,
.bb-load-screen,
.bb-load-feature,
.bb-load-cartel,
.bb-load-metric,
.bb-pipe-card {
  border-radius: 0;
}

.world-count {
  border-color: rgba(255,210,58,0.6);
  background:
    repeating-linear-gradient(135deg, rgba(255,210,58,0.08) 0 4px, transparent 4px 10px),
    rgba(8,0,18,0.72);
  box-shadow: inset 4px 0 0 var(--gold);
}

.world-diagram,
.world-panel {
  border-color: rgba(255,255,255,0.18);
  background:
    linear-gradient(180deg, rgba(42,11,77,0.88), rgba(5,1,13,0.94)),
    repeating-linear-gradient(135deg, rgba(255,255,255,0.04) 0 4px, transparent 4px 12px);
  box-shadow:
    inset 4px 0 0 rgba(255,58,163,0.72),
    inset 0 0 40px rgba(0,0,0,0.72);
}

.world-panel {
  position: relative;
}

.world-panel::before {
  content: "family file";
  position: absolute;
  top: 14px;
  right: 14px;
  z-index: 1;
  padding: 5px 9px;
  border: 1px solid rgba(255,58,163,0.75);
  color: #fff;
  background: rgba(255,45,85,0.76);
  font-family: "JetBrains Mono", monospace;
  font-size: 10px;
  font-weight: 900;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  transform: rotate(2deg);
}

.world-tabs,
.world-card,
.world-mini-stats {
  position: relative;
  z-index: 2;
}

.world-tab {
  min-height: 48px;
  border-color: rgba(255,255,255,0.18);
  background: rgba(5,1,13,0.72);
  box-shadow: inset 0 -2px 0 rgba(255,255,255,0.06);
}

.world-tab.on {
  border-color: rgba(255,58,163,0.9);
  background: var(--vc-pink);
  color: #fff;
  text-shadow: 2px 2px 0 rgba(0,0,0,0.72);
  box-shadow: inset 0 -4px 0 rgba(0,0,0,0.26), 0 0 20px rgba(255,58,163,0.28);
}

.world-card {
  border-color: rgba(70,229,229,0.34);
  background:
    linear-gradient(160deg, rgba(255,58,163,0.12), transparent 34%),
    repeating-linear-gradient(135deg, rgba(255,255,255,0.045) 0 4px, transparent 4px 12px),
    rgba(5,1,13,0.76);
  box-shadow: inset 0 0 0 1px rgba(255,58,163,0.2);
}

.world-card-icon {
  border-color: rgba(255,58,163,0.72);
  background: rgba(255,58,163,0.16);
  box-shadow: inset 0 0 0 2px rgba(0,0,0,0.42);
}

.world-mini-stats div,
.diagram-node {
  background:
    repeating-linear-gradient(135deg, rgba(255,255,255,0.035) 0 3px, transparent 3px 10px),
    rgba(0,0,0,0.46);
}

.diagram-node {
  border-color: rgba(255,255,255,0.24);
}

.bb-load-top {
  align-items: flex-start;
}

.bb-load-status {
  color: #fff;
  border: 1px solid rgba(255,255,255,0.72);
  background: var(--vc-pink);
  box-shadow: 6px 6px 0 rgba(0,0,0,0.42), 0 0 20px rgba(255,58,163,0.32);
  transform: rotate(1.5deg);
}

.bb-load-screen {
  grid-template-columns: minmax(420px, 1.02fr) minmax(520px, 1.25fr);
  grid-template-rows: 1fr;
  align-items: stretch;
  gap: 14px;
  padding: 0;
  min-height: 640px;
  border-color: transparent;
  background: transparent;
  box-shadow: none;
}

.bb-load-feature,
.bb-load-cartel {
  position: relative;
  overflow: hidden;
  border: 1px solid rgba(255,58,163,0.7);
  background:
    linear-gradient(180deg, rgba(255,58,163,0.16), rgba(4,1,12,0.82) 44%, rgba(3,1,9,0.98)),
    repeating-linear-gradient(135deg, rgba(255,255,255,0.045) 0 4px, transparent 4px 10px);
  box-shadow:
    inset 0 0 0 1px rgba(70,229,229,0.24),
    0 20px 48px rgba(0,0,0,0.28);
}

.bb-load-feature {
  min-height: 640px;
  padding: 20px;
  display: grid;
  align-content: end;
}

.bb-load-feature::before,
.bb-load-cartel::before {
  content: "";
  position: absolute;
  left: -8%;
  right: -8%;
  top: 31%;
  height: 7px;
  background: var(--vc-pink);
  box-shadow: 0 0 18px rgba(255,58,163,0.8);
  transform: rotate(-10deg);
  z-index: 4;
}

.bb-card-rank,
.bb-card-heat,
.bb-card-stamp {
  position: absolute;
  z-index: 6;
  font-family: "JetBrains Mono", monospace;
  font-weight: 900;
  text-transform: uppercase;
}

.bb-card-rank {
  left: 18px;
  top: 16px;
  color: var(--vc-pink);
  font-family: "Pricedown Bl", "Pricedown", "Bowlby One SC", Impact, sans-serif;
  font-size: 32px;
  line-height: 1;
  text-shadow: 3px 3px 0 rgba(0,0,0,0.72);
}

.bb-card-heat {
  right: 16px;
  top: 18px;
  color: var(--gold);
  font-size: 10px;
  letter-spacing: 0.08em;
}

.bb-card-stamp {
  right: 14px;
  top: 48px;
  padding: 5px 9px;
  color: #fff;
  background: #ff2d55;
  border: 1px solid rgba(255,255,255,0.7);
  font-family: "Pricedown Bl", "Pricedown", "Bowlby One SC", Impact, sans-serif;
  font-size: 18px;
  line-height: 0.85;
  transform: rotate(6deg);
  box-shadow: 4px 4px 0 rgba(0,0,0,0.36);
}

.bb-feature-media {
  position: absolute;
  inset: 64px 18px 198px;
  border: 1px solid rgba(70,229,229,0.84);
  background:
    linear-gradient(90deg, rgba(255,58,163,0.25), transparent 48%, rgba(70,229,229,0.22)),
    repeating-linear-gradient(0deg, rgba(255,255,255,0.045) 0 1px, transparent 1px 8px),
    #120320;
  overflow: hidden;
}

.bb-feature-character {
  position: absolute;
  right: -38px;
  bottom: -20px;
  height: 108%;
  width: auto;
  filter: drop-shadow(0 18px 24px rgba(0,0,0,0.72)) saturate(1.1);
}

.bb-feature-logo {
  position: absolute;
  left: 26px;
  bottom: 24px;
  width: min(48%, 260px);
  max-height: 42%;
  object-fit: contain;
  filter: drop-shadow(0 0 18px rgba(70,229,229,0.32));
}

.bb-feature-copy {
  position: relative;
  z-index: 5;
}

.bb-feature-copy h4 {
  margin: 0 0 16px;
  color: #fff;
  font-family: "Pricedown Bl", "Pricedown", "Bowlby One SC", Impact, sans-serif;
  font-size: clamp(38px, 4.4vw, 74px);
  line-height: 0.86;
  text-transform: lowercase;
  text-shadow: 4px 4px 0 rgba(0,0,0,0.76);
}

.bb-feature-grid {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 8px 18px;
  max-width: 440px;
  padding: 14px;
  border-top: 1px solid rgba(255,255,255,0.14);
  border-bottom: 1px solid rgba(255,255,255,0.1);
  background: rgba(0,0,0,0.28);
}

.bb-feature-grid span,
.bb-feature-copy p {
  color: rgba(255,255,255,0.58);
  font-family: "JetBrains Mono", monospace;
  font-size: 10px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
}

.bb-feature-grid b {
  color: var(--vc-cyan);
  font-family: "JetBrains Mono", monospace;
  font-size: 12px;
  text-align: right;
  text-transform: uppercase;
}

.bb-feature-copy p {
  max-width: 520px;
  margin: 14px 0 0;
  color: rgba(255,255,255,0.72);
  line-height: 1.55;
  letter-spacing: 0.04em;
}

.bb-load-cartels {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
}

.bb-load-cartel {
  min-height: 312px;
  padding: 178px 16px 16px;
  border-color: color-mix(in srgb, var(--cartel-color) 72%, rgba(255,255,255,0.12));
}

.bb-load-cartel:nth-child(5) {
  grid-column: span 2;
  min-height: 230px;
  padding-top: 112px;
}

.bb-card-media {
  position: absolute;
  inset: 50px 14px auto;
  height: 120px;
  border: 1px solid rgba(70,229,229,0.7);
  background:
    linear-gradient(90deg, color-mix(in srgb, var(--cartel-color) 28%, transparent), rgba(0,0,0,0.14)),
    repeating-linear-gradient(0deg, rgba(255,255,255,0.045) 0 1px, transparent 1px 8px);
  overflow: hidden;
  z-index: 2;
}

.bb-load-cartel:nth-child(5) .bb-card-media {
  height: 92px;
}

.bb-card-character {
  position: absolute;
  right: -8px;
  bottom: -18px;
  height: 148%;
  width: auto;
  filter: drop-shadow(0 16px 18px rgba(0,0,0,0.72)) saturate(1.08);
}

.bb-cartel-mark {
  right: 12px;
  top: 82px;
  width: 74px;
  height: 74px;
  border-radius: 0;
  opacity: 0.78;
  z-index: 3;
  background: rgba(0,0,0,0.34);
  border: 1px solid rgba(255,255,255,0.26);
  transform: rotate(-4deg);
}

.bb-cartel-mark::before {
  border-radius: 0;
}

.bb-cartel-head {
  padding-right: 0;
}

.bb-cartel-head span {
  font-size: 31px;
}

.bb-cartel-bar {
  height: 5px;
  border-radius: 0;
  background: rgba(255,255,255,0.1);
}

.bb-cartel-bar span {
  border-radius: 0;
}

.bb-load-metric {
  border-color: rgba(255,255,255,0.14);
  background:
    repeating-linear-gradient(135deg, rgba(255,255,255,0.035) 0 3px, transparent 3px 10px),
    rgba(0,0,0,0.42);
  box-shadow: inset 3px 0 0 rgba(70,229,229,0.68);
}

@media (max-width: 1180px) {
  .bb-load-screen {
    grid-template-columns: 1fr;
  }
  .bb-load-feature {
    min-height: 520px;
  }
  .bb-feature-media {
    bottom: 174px;
  }
}

@media (max-width: 760px) {
  .world-wrap,
  .bb-load {
    border-radius: 0;
  }
  .bb-load-screen {
    grid-template-columns: 1fr;
  }
  .bb-load-feature {
    min-height: 500px;
    padding: 16px;
  }
  .bb-feature-media {
    inset: 58px 12px 188px;
  }
  .bb-feature-character {
    right: -72px;
  }
  .bb-load-cartels {
    grid-template-columns: 1fr;
  }
  .bb-load-cartel,
  .bb-load-cartel:nth-child(5) {
    grid-column: auto;
    min-height: 282px;
    padding: 166px 14px 14px;
  }
  .bb-load-cartel:nth-child(5) .bb-card-media,
  .bb-card-media {
    height: 104px;
  }
  .bb-cartel-head {
    padding-right: 78px;
  }
  .world-panel::before {
    display: none;
  }
}

/* ------------------------------------------------------------------
   Clean loading states: hero mission card + logo-first bounty board
------------------------------------------------------------------ */
.mission-loading-card {
  border-radius: 0;
  background:
    linear-gradient(180deg, rgba(32,7,61,0.92), rgba(8,1,18,0.94)),
    repeating-linear-gradient(135deg, rgba(255,255,255,0.04) 0 4px, transparent 4px 11px);
  box-shadow:
    inset 0 0 0 1px rgba(70,229,229,0.22),
    0 24px 56px rgba(0,0,0,0.46);
}

.mission-load-core {
  display: grid;
  grid-template-columns: 88px 1fr;
  gap: 14px;
  align-items: center;
  padding: 14px;
  border: 1px solid rgba(70,229,229,0.3);
  background:
    linear-gradient(90deg, rgba(70,229,229,0.12), rgba(255,58,163,0.1)),
    rgba(0,0,0,0.24);
}

.mission-load-icon {
  display: grid;
  place-items: center;
  width: 88px;
  aspect-ratio: 1;
  border: 1px solid rgba(255,58,163,0.48);
  background: rgba(0,0,0,0.28);
}

.mission-load-icon img {
  width: 82%;
  height: 82%;
  object-fit: contain;
  filter: drop-shadow(0 0 14px rgba(70,229,229,0.28));
}

.mission-load-title {
  color: #fff;
  font-family: "Pricedown Bl", "Pricedown", "Bowlby One SC", Impact, sans-serif;
  font-size: 30px;
  line-height: 0.9;
  text-transform: lowercase;
  text-shadow: 3px 3px 0 rgba(0,0,0,0.78);
}

.mission-load-sub {
  margin-top: 8px;
  color: rgba(255,255,255,0.68);
  font-size: 12px;
  line-height: 1.45;
}

.mission-loading-card .match-mission {
  margin-top: 14px;
}

.mission-loading-card .match-obj {
  color: rgba(255,255,255,0.72);
}

.bb-load-screen {
  grid-template-columns: minmax(360px, 0.82fr) minmax(560px, 1.18fr);
  min-height: 560px;
}

.bb-load-feature {
  min-height: 560px;
}

.bb-load-feature::before,
.bb-load-cartel::before {
  display: none;
}

.bb-feature-media {
  inset: 64px 18px 190px;
  display: grid;
  place-items: center;
}

.bb-feature-logo {
  position: relative;
  left: auto;
  bottom: auto;
  width: min(84%, 360px);
  max-height: 84%;
}

.bb-load-cartels {
  gap: 12px;
}

.bb-load-cartel,
.bb-load-cartel:nth-child(5) {
  min-height: 244px;
  padding: 132px 16px 16px;
}

.bb-load-cartel:nth-child(5) {
  grid-column: span 2;
}

.bb-card-media,
.bb-load-cartel:nth-child(5) .bb-card-media {
  inset: 48px 14px auto;
  height: 72px;
  display: grid;
  place-items: center;
  background:
    linear-gradient(90deg, color-mix(in srgb, var(--cartel-color) 18%, transparent), rgba(0,0,0,0.18)),
    rgba(0,0,0,0.26);
}

.bb-card-logo {
  width: 92%;
  height: 92%;
  object-fit: contain;
  filter:
    drop-shadow(0 0 16px color-mix(in srgb, var(--cartel-color) 36%, transparent))
    saturate(1.08)
    contrast(1.05);
}

.bb-card-stamp {
  font-size: 15px;
  background: rgba(255,58,163,0.92);
}

.bb-card-rank {
  font-size: 25px;
}

.bb-cartel-mark,
.bb-card-character {
  display: none;
}

.bb-cartel-head span {
  font-size: 27px;
}

.bb-cartel-bar {
  margin: 16px 0 14px;
}

.bb-cartel-bar span {
  width: 34%;
  background: linear-gradient(90deg, var(--cartel-color), rgba(255,255,255,0.34));
  animation: none;
}

.bb-load-bottom {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

@media (max-width: 1180px) {
  .bb-load-screen {
    grid-template-columns: 1fr;
  }
  .bb-load-feature {
    min-height: 480px;
  }
}

@media (max-width: 760px) {
  .mission-load-core {
    grid-template-columns: 72px 1fr;
  }
  .mission-load-icon {
    width: 72px;
  }
  .mission-load-title {
    font-size: 24px;
  }
  .bb-load-feature {
    min-height: 430px;
  }
  .bb-feature-media {
    inset: 58px 12px 176px;
  }
  .bb-load-cartel,
  .bb-load-cartel:nth-child(5) {
    grid-column: auto;
    min-height: 226px;
    padding-top: 124px;
  }
  .bb-load-bottom {
    grid-template-columns: 1fr;
  }
}

/* Final bounty board clarity pass: full crest logos, less clutter */
.bb-load-screen {
  grid-template-columns: minmax(340px, 0.72fr) minmax(620px, 1.28fr);
  min-height: 600px;
}

.bb-load-feature {
  min-height: 600px;
}

.bb-load-cartels {
  align-content: start;
}

.bb-load-cartel,
.bb-load-cartel:nth-child(5) {
  min-height: 208px;
  padding: 18px 18px 18px 170px;
}

.bb-card-media,
.bb-load-cartel:nth-child(5) .bb-card-media {
  left: 18px;
  top: 52px;
  right: auto;
  width: 132px;
  height: 132px;
  border-color: color-mix(in srgb, var(--cartel-color) 72%, rgba(255,255,255,0.18));
  background:
    radial-gradient(circle at 50% 50%, color-mix(in srgb, var(--cartel-color) 16%, transparent), transparent 62%),
    repeating-linear-gradient(135deg, rgba(255,255,255,0.035) 0 4px, transparent 4px 11px),
    rgba(3,1,10,0.72);
}

.bb-card-logo {
  width: 96%;
  height: 96%;
  object-fit: contain;
}

.bb-card-rank {
  top: 17px;
  left: 18px;
  font-size: 25px;
}

.bb-card-heat {
  top: 20px;
  right: 18px;
}

.bb-card-stamp {
  top: 52px;
  right: 18px;
  font-size: 14px;
}

.bb-cartel-head {
  padding-top: 46px;
  padding-right: 92px;
}

.bb-cartel-head span {
  font-size: clamp(24px, 2.4vw, 34px);
}

.bb-cartel-bar {
  margin: 20px 0 14px;
}

.bb-cartel-foot {
  gap: 7px;
}

@media (max-width: 1180px) {
  .bb-load-screen {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 760px) {
  .bb-load-cartel,
  .bb-load-cartel:nth-child(5) {
    min-height: 330px;
    padding: 18px;
  }
  .bb-card-media,
  .bb-load-cartel:nth-child(5) .bb-card-media {
    position: relative;
    left: auto;
    top: auto;
    width: min(100%, 220px);
    height: 220px;
    margin: 46px auto 12px;
  }
  .bb-card-rank {
    left: 18px;
  }
  .bb-card-stamp {
    top: 50px;
  }
  .bb-cartel-head {
    padding: 0 76px 0 0;
  }
  .bb-cartel-head span {
    font-size: 28px;
  }
}

/* Loader enter CTA + Heist Contract cards */
.loader-bottom-row {
  gap: 14px;
}
.loader-enter {
  appearance: none;
  border: 1px solid rgba(255,255,255,0.34);
  border-radius: 0;
  min-height: 42px;
  padding: 9px 24px 10px;
  background:
    repeating-linear-gradient(135deg, rgba(255,255,255,0.22) 0 6px, transparent 6px 12px),
    linear-gradient(90deg, var(--vc-cyan), #fff 52%, var(--vc-pink));
  color: #07020e;
  box-shadow: 0 0 0 1px rgba(70,229,229,0.24), 0 0 26px rgba(255,58,163,0.34);
  cursor: pointer;
  font-family: 'Pricedown Bl', 'Pricedown', 'Bowlby One SC', sans-serif;
  font-size: 22px;
  line-height: 1;
  text-transform: lowercase;
  letter-spacing: 0.02em;
  -webkit-text-stroke: 1px rgba(7,2,14,0.34);
  transition: transform 0.16s ease, filter 0.16s ease, box-shadow 0.16s ease;
}
.loader-enter:hover,
.loader-enter:focus-visible {
  transform: translateY(-1px);
  filter: saturate(1.2) brightness(1.04);
  box-shadow: 0 0 0 1px rgba(255,255,255,0.36), 0 0 34px rgba(255,58,163,0.48);
}
.loader-enter:focus-visible {
  outline: 2px solid var(--gold);
  outline-offset: 3px;
}

.mlog-contracts .mlog-map {
  border-radius: 0;
  position: sticky;
  top: 92px;
  min-height: 420px;
}
.mlog-contracts .mlog-map .title {
  color: var(--vc-cyan);
  letter-spacing: 0.24em;
}
.mlog-contracts .heist-map-copy {
  gap: 10px;
}
.mlog-contracts .heist-map-copy b {
  font-size: clamp(32px, 4vw, 54px);
  line-height: 0.9;
}
.mlog-contracts .heist-map-copy span {
  max-width: 470px;
}
.mlog-contracts .mlog-card {
  appearance: none;
  width: 100%;
  text-align: left;
  color: inherit;
  font: inherit;
  display: grid;
  grid-template-columns: 96px minmax(0, 1fr) 148px;
  gap: 18px;
  align-items: start;
  padding: 18px 20px;
  border-radius: 0;
  border: 1px solid rgba(255,255,255,0.16);
  border-left: 4px solid var(--ink-3);
  background:
    repeating-linear-gradient(135deg, rgba(255,255,255,0.035) 0 5px, transparent 5px 11px),
    linear-gradient(90deg, rgba(255,58,163,0.12), transparent 44%),
    linear-gradient(180deg, rgba(46,8,86,0.94), rgba(12,2,26,0.98));
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.08), 0 16px 30px rgba(0,0,0,0.32);
  overflow: hidden;
}
.mlog-contracts .mlog-card:hover,
.mlog-contracts .mlog-card:focus-visible,
.mlog-contracts .mlog-card.open {
  transform: translateX(3px);
  border-color: rgba(255,58,163,0.52);
  border-left-color: var(--vc-pink);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.12), 0 22px 42px rgba(0,0,0,0.42), 0 0 28px rgba(255,58,163,0.16);
}
.mlog-contracts .mlog-card:focus-visible {
  outline: 2px solid var(--vc-cyan);
  outline-offset: 2px;
}
.mlog-contracts .mlog-card.open::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background: linear-gradient(90deg, rgba(70,229,229,0.12), transparent 24%, rgba(255,58,163,0.1));
}
.mlog-contracts .mlog-card.live {
  border-left-color: var(--alert);
  background:
    repeating-linear-gradient(135deg, rgba(255,255,255,0.04) 0 5px, transparent 5px 11px),
    linear-gradient(90deg, rgba(255,58,91,0.28), transparent 46%),
    linear-gradient(180deg, rgba(84,8,78,0.96), rgba(20,2,38,0.99));
}
.mlog-contracts .mlog-card.next {
  border-left-color: var(--vc-cyan);
  background:
    repeating-linear-gradient(135deg, rgba(255,255,255,0.04) 0 5px, transparent 5px 11px),
    linear-gradient(90deg, rgba(70,229,229,0.22), transparent 43%),
    linear-gradient(180deg, rgba(10,30,80,0.96), rgba(14,3,42,0.99));
}
.mlog-contracts .mlog-card.up {
  border-left-color: var(--gold);
}
.mlog-contracts .mlog-card.done {
  opacity: 0.78;
}
.mlog-contracts .versus {
  color: var(--ink-3);
  font-family: 'JetBrains Mono', monospace;
  font-size: 12px;
  font-weight: 800;
  text-transform: uppercase;
}
.mlog-contracts .mname {
  margin-top: 4px;
}
.contract-job {
  margin-top: 9px;
  color: #fff;
  font-family: 'Pricedown Bl', 'Pricedown', 'Bowlby One SC', sans-serif;
  font-size: clamp(21px, 2.1vw, 30px);
  line-height: 0.95;
  text-transform: lowercase;
  -webkit-text-stroke: 1px rgba(8,3,15,0.7);
}
.mlog-side {
  display: grid;
  justify-items: end;
  gap: 10px;
}
.contract-action {
  color: var(--ink-2);
  font-family: 'JetBrains Mono', monospace;
  font-size: 9px;
  font-weight: 800;
  letter-spacing: 0.18em;
  text-transform: uppercase;
}
.contract-details {
  position: relative;
  z-index: 1;
  grid-column: 2 / 4;
  display: grid;
  grid-template-columns: minmax(0, 1.2fr) minmax(180px, 0.8fr) minmax(170px, 0.7fr);
  gap: 14px;
  align-items: stretch;
  margin-top: 2px;
  padding-top: 14px;
  border-top: 1px solid rgba(255,255,255,0.14);
}
.contract-label {
  color: var(--gold);
  font-family: 'JetBrains Mono', monospace;
  font-size: 9px;
  font-weight: 900;
  letter-spacing: 0.22em;
  text-transform: uppercase;
}
.contract-details p {
  margin: 6px 0 0;
  color: rgba(255,255,255,0.78);
  font-size: 13px;
  line-height: 1.45;
}
.contract-checklist {
  display: grid;
  gap: 6px;
}
.contract-checklist span,
.contract-proof {
  border: 1px solid rgba(255,255,255,0.13);
  background: rgba(0,0,0,0.28);
  padding: 7px 9px;
  color: rgba(255,255,255,0.78);
  font-family: 'JetBrains Mono', monospace;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}
.contract-proof {
  display: grid;
  align-content: center;
  gap: 5px;
  border-color: rgba(70,229,229,0.32);
}
.contract-proof b {
  color: var(--vc-cyan);
}
.contract-proof span {
  color: #fff;
}

@media (max-width: 900px) {
  .loader-bottom-row {
    flex-wrap: wrap;
    justify-content: center;
  }
  .loader-enter {
    order: -1;
  }
  .mlog-contracts .mlog-card {
    grid-template-columns: 82px minmax(0, 1fr);
  }
  .mlog-side {
    grid-column: 2;
    justify-items: start;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
  }
  .contract-details {
    grid-column: 1 / -1;
    grid-template-columns: 1fr;
  }
}

@media (max-width: 640px) {
  .loader-bottom-row {
    align-items: stretch;
  }
  .loader-enter {
    width: 100%;
    font-size: 20px;
  }
  .loader-skip,
  .loader-pump {
    width: 100%;
    justify-content: center;
    text-align: center;
  }
  .mlog-contracts .mlog-card {
    grid-template-columns: 1fr;
    padding: 16px;
  }
  .mlog-contracts .mlog-mid .pair {
    font-size: 22px;
    flex-wrap: wrap;
  }
  .mlog-side {
    grid-column: auto;
  }
  .contract-job {
    font-size: 24px;
  }
}
