/* ═════════════════════════════════════════════════════════════════════════
   BUFO — Cinema Blocks v4.2.0
   Spectacular award-grade Gutenberg blocks for cinematic OSINT posts.
   All blocks respect prefers-reduced-motion via the :root overrides in
   inc/performance.php; this file focuses on layout, depth, and choreography.
   ═════════════════════════════════════════════════════════════════════════ */

/* ──────────────────────────────────────────────────────────────────────────
   1. CINEMA HERO — Full-bleed title card
   ────────────────────────────────────────────────────────────────────────── */
.bc-hero {
  position: relative;
  isolation: isolate;
  margin: clamp(2rem, 5vw, 3.5rem) calc(50% - 50vw);
  padding: clamp(4rem, 12vw, 9rem) clamp(1rem, 4vw, 3rem);
  min-height: clamp(380px, 65vh, 720px);
  display: grid;
  align-items: end;
  background: #050508;
  color: var(--bufo-text, #f5f7ff);
  overflow: hidden;
  border-block: 1px solid rgba(34, 197, 94, 0.18);
}
.bc-hero__bg {
  position: absolute; inset: 0; z-index: 0;
  background-size: cover; background-position: center;
  filter: saturate(1.05) contrast(1.05);
}
.bc-hero__bg::after {
  content: "";
  position: absolute; inset: 0;
  background:
    radial-gradient(ellipse at 20% 0%, rgba(34,197,94,0.18), transparent 60%),
    radial-gradient(ellipse at 80% 100%, rgba(168,85,247,0.14), transparent 65%),
    linear-gradient(180deg, rgba(5,7,9,0.55) 0%, rgba(5,7,9,0.88) 65%, rgba(5,7,9,0.98) 100%);
  mix-blend-mode: normal;
}
.bc-hero__grid {
  position: absolute; inset: 0; z-index: 1; pointer-events: none;
  background-image:
    linear-gradient(rgba(34,197,94,0.06) 1px, transparent 1px),
    linear-gradient(90deg, rgba(34,197,94,0.06) 1px, transparent 1px);
  background-size: 80px 80px;
  mask-image: radial-gradient(ellipse at 50% 60%, #000 30%, transparent 85%);
  -webkit-mask-image: radial-gradient(ellipse at 50% 60%, #000 30%, transparent 85%);
}
.bc-hero__noise {
  position: absolute; inset: -20%; z-index: 1; pointer-events: none;
  opacity: 0.08; mix-blend-mode: overlay;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/></filter><rect width='200' height='200' filter='url(%23n)' opacity='0.7'/></svg>");
}
.bc-hero__scan {
  position: absolute; left: 0; right: 0; top: 0; height: 2px; z-index: 2;
  background: linear-gradient(90deg, transparent, rgba(34,197,94,0.9), transparent);
  animation: bcScanDown 7s linear infinite;
}
.bc-hero__corner {
  position: absolute; width: 34px; height: 34px; z-index: 3; pointer-events: none;
  border: 1px solid rgba(34,197,94,0.45);
}
.bc-hero__corner--tl { top: 18px; left: 18px; border-right: 0; border-bottom: 0; }
.bc-hero__corner--tr { top: 18px; right: 18px; border-left: 0; border-bottom: 0; }
.bc-hero__corner--bl { bottom: 18px; left: 18px; border-right: 0; border-top: 0; }
.bc-hero__corner--br { bottom: 18px; right: 18px; border-left: 0; border-top: 0; }
.bc-hero__body {
  position: relative; z-index: 3;
  max-width: 960px;
  margin: 0 auto;
  width: 100%;
  padding-inline: clamp(0.5rem, 2vw, 1.5rem);
}
.bc-hero__kicker {
  display: inline-flex; align-items: center; gap: 10px;
  padding: 6px 12px;
  font-family: var(--bufo-mono, 'JetBrains Mono', monospace);
  font-size: 0.72rem;
  letter-spacing: 0.22em;
  color: var(--bufo-green-bright, #4ade80);
  background: rgba(34,197,94,0.08);
  border: 1px solid rgba(34,197,94,0.22);
  border-radius: 999px;
  text-transform: uppercase;
}
.bc-hero__kicker::before {
  content: "";
  width: 8px; height: 8px; border-radius: 50%;
  background: var(--bufo-green-bright, #4ade80);
  box-shadow: 0 0 10px currentColor;
  animation: bcBlink 1.6s ease-in-out infinite;
}
.bc-hero__title {
  margin: clamp(1rem, 3vw, 1.4rem) 0 0.6rem !important;
  font-family: var(--bufo-display, 'Zen Dots', system-ui), serif;
  font-size: clamp(2.2rem, 7vw, 5.2rem);
  line-height: 0.98;
  letter-spacing: -0.015em;
  text-wrap: balance;
  color: #fff;
  text-shadow: 0 2px 24px rgba(0,0,0,0.55);
}
.bc-hero__sub {
  max-width: 62ch;
  margin: 0 !important;
  font-size: clamp(1rem, 2vw, 1.28rem);
  line-height: 1.55;
  color: rgba(245,247,255,0.82);
}
.bc-hero__meta {
  margin-top: clamp(1.4rem, 3vw, 2rem);
  display: flex; flex-wrap: wrap; gap: 10px 18px;
  font-family: var(--bufo-mono, 'JetBrains Mono', monospace);
  font-size: 0.75rem;
  color: rgba(245,247,255,0.62);
  letter-spacing: 0.08em;
  text-transform: uppercase;
}
.bc-hero__meta > span { display: inline-flex; align-items: center; gap: 6px; }
.bc-hero__meta > span::before {
  content: ""; width: 6px; height: 6px; border-radius: 50%;
  background: var(--bufo-green, #22c55e); opacity: 0.7;
}
.bc-hero__stamp {
  position: absolute; top: clamp(1.2rem, 3vw, 2rem); right: clamp(1.2rem, 3vw, 2rem);
  z-index: 4;
  padding: 10px 14px;
  border: 2px solid currentColor;
  color: #ff3a8c;
  font-family: var(--bufo-mono, 'JetBrains Mono', monospace);
  font-size: 0.72rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  transform: rotate(4deg);
  opacity: 0.85;
  pointer-events: none;
}
.bc-hero--classified .bc-hero__stamp { color: #ff3a8c; }
.bc-hero--restricted .bc-hero__stamp { color: #fbbf24; }
.bc-hero--public     .bc-hero__stamp { color: #4ade80; }

/* ──────────────────────────────────────────────────────────────────────────
   2. STAT BOMBSHELL — Animated huge number
   ────────────────────────────────────────────────────────────────────────── */
.bc-stats {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: clamp(0.8rem, 2vw, 1.25rem);
  margin: clamp(1.6rem, 4vw, 2.4rem) 0;
}
.bc-stat {
  position: relative; overflow: hidden;
  padding: clamp(1.4rem, 3vw, 2rem) clamp(1.2rem, 2.5vw, 1.75rem);
  background:
    linear-gradient(140deg, rgba(34,197,94,0.06), transparent 55%),
    rgba(10,14,20,0.62);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 14px;
  transition: transform .3s ease, border-color .3s ease, box-shadow .3s ease;
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}
.bc-stat::before {
  content: "";
  position: absolute; inset: 0; pointer-events: none;
  background: radial-gradient(ellipse at 0% 0%, rgba(34,197,94,0.12), transparent 55%);
  opacity: 0.9;
}
.bc-stat::after {
  content: "";
  position: absolute; inset: -1px;
  border-radius: inherit;
  padding: 1px;
  background: linear-gradient(135deg, rgba(34,197,94,0.35), transparent 45%, rgba(34,197,94,0.25));
  -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
          mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite: xor;
          mask-composite: exclude;
  opacity: 0;
  transition: opacity .3s ease;
}
.bc-stat:hover { transform: translateY(-4px); border-color: rgba(34,197,94,0.35); box-shadow: 0 24px 60px rgba(0,0,0,0.55); }
.bc-stat:hover::after { opacity: 1; }
.bc-stat__label {
  display: inline-block;
  font-family: var(--bufo-mono, 'JetBrains Mono', monospace);
  font-size: 0.7rem;
  letter-spacing: 0.22em;
  color: rgba(245,247,255,0.55);
  text-transform: uppercase;
}
.bc-stat__value {
  display: flex; align-items: baseline; gap: 6px;
  margin: 8px 0 4px;
  font-family: var(--bufo-display, 'Zen Dots'), var(--bufo-mono, monospace);
  font-size: clamp(2.8rem, 7vw, 4.4rem);
  line-height: 1;
  color: var(--bufo-green-bright, #4ade80);
  text-shadow: 0 0 22px rgba(34,197,94,0.25);
  letter-spacing: -0.02em;
  font-variant-numeric: tabular-nums;
}
.bc-stat__value small {
  font-family: var(--bufo-mono, monospace);
  font-size: 0.32em;
  color: rgba(245,247,255,0.78);
  letter-spacing: 0.08em;
}
.bc-stat__note {
  margin-top: 0.4rem;
  color: rgba(245,247,255,0.7);
  line-height: 1.5;
  font-size: 0.94rem;
}
.bc-stat__bar {
  margin-top: 14px;
  height: 3px;
  border-radius: 3px;
  background: rgba(255,255,255,0.06);
  overflow: hidden;
  position: relative;
}
.bc-stat__bar::after {
  content: ""; position: absolute; inset: 0 100% 0 0;
  background: linear-gradient(90deg, var(--bufo-green), var(--bufo-green-bright, #4ade80));
  transition: right 1.4s cubic-bezier(.2,.8,.2,1);
}
.bc-stat.is-revealed .bc-stat__bar::after { right: calc(100% - var(--_pct, 100%)); }
.bc-stat[data-accent="cyan"]   .bc-stat__value { color: #67e8f9; text-shadow: 0 0 22px rgba(34,211,238,0.25); }
.bc-stat[data-accent="amber"]  .bc-stat__value { color: #fbbf24; text-shadow: 0 0 22px rgba(251,191,36,0.25); }
.bc-stat[data-accent="magenta"].bc-stat__value,
.bc-stat[data-accent="magenta"] .bc-stat__value { color: #ff3a8c; text-shadow: 0 0 22px rgba(255,58,140,0.25); }
.bc-stat[data-accent="cyan"]   .bc-stat__bar::after   { background: linear-gradient(90deg, #22d3ee, #67e8f9); }
.bc-stat[data-accent="amber"]  .bc-stat__bar::after   { background: linear-gradient(90deg, #f59e0b, #fbbf24); }
.bc-stat[data-accent="magenta"] .bc-stat__bar::after  { background: linear-gradient(90deg, #ff3a8c, #ff77ae); }

/* ──────────────────────────────────────────────────────────────────────────
   3. TIMELINE SPINE — Animated vertical timeline
   ────────────────────────────────────────────────────────────────────────── */
.bc-spine {
  position: relative;
  margin: clamp(1.6rem, 4vw, 2.4rem) 0;
  padding-left: 40px;
}
.bc-spine::before {
  content: ""; position: absolute;
  left: 13px; top: 6px; bottom: 6px;
  width: 2px;
  background: linear-gradient(180deg, transparent, var(--bufo-green, #22c55e) 12%, var(--bufo-green, #22c55e) 88%, transparent);
  opacity: 0.45;
}
.bc-spine__event {
  position: relative;
  padding: 14px 0 22px 20px;
}
.bc-spine__event::before {
  content: "";
  position: absolute;
  left: -32px; top: 22px;
  width: 12px; height: 12px; border-radius: 50%;
  background: var(--bufo-space, #050508);
  border: 2px solid var(--bufo-green, #22c55e);
  box-shadow: 0 0 0 6px rgba(34,197,94,0.08);
}
.bc-spine__event.is-pivot::before {
  background: var(--bufo-green-bright, #4ade80);
  box-shadow: 0 0 0 8px rgba(34,197,94,0.16), 0 0 18px rgba(34,197,94,0.55);
}
.bc-spine__time {
  display: inline-block;
  font-family: var(--bufo-mono, monospace);
  font-size: 0.72rem;
  letter-spacing: 0.18em;
  color: var(--bufo-green-bright, #4ade80);
  text-transform: uppercase;
  margin-bottom: 4px;
}
.bc-spine__headline {
  margin: 2px 0 4px !important;
  font-family: var(--bufo-font, 'Outfit'), system-ui, sans-serif;
  font-size: clamp(1.05rem, 2vw, 1.2rem);
  font-weight: 700;
  line-height: 1.3;
  color: rgba(245,247,255,0.96);
}
.bc-spine__body {
  margin: 0 !important;
  color: rgba(245,247,255,0.74);
  line-height: 1.6;
  max-width: 62ch;
}
.bc-spine__src {
  display: inline-flex; align-items: center; gap: 4px;
  margin-top: 6px;
  font-family: var(--bufo-mono, monospace);
  font-size: 0.76rem;
  color: rgba(34,197,94,0.8);
  text-decoration: none;
  border-bottom: 1px dashed rgba(34,197,94,0.35);
}
.bc-spine__src:hover { color: #4ade80; border-bottom-color: #4ade80; }

/* ──────────────────────────────────────────────────────────────────────────
   4. COORDINATES CARD — GPS sat display
   ────────────────────────────────────────────────────────────────────────── */
.bc-coords {
  position: relative; overflow: hidden;
  margin: clamp(1.4rem, 3vw, 2rem) 0;
  padding: clamp(1.3rem, 3vw, 1.8rem);
  background:
    radial-gradient(ellipse at 100% 0%, rgba(34,197,94,0.1), transparent 55%),
    linear-gradient(160deg, rgba(10,14,20,0.9), rgba(5,7,9,0.9));
  border: 1px solid rgba(34,197,94,0.22);
  border-radius: 16px;
  display: grid;
  grid-template-columns: 1fr auto;
  gap: clamp(1rem, 2vw, 1.5rem);
  align-items: center;
}
@media (max-width: 640px) { .bc-coords { grid-template-columns: 1fr; } }
.bc-coords__head {
  display: flex; align-items: center; gap: 10px;
  font-family: var(--bufo-mono, monospace);
  font-size: 0.72rem;
  letter-spacing: 0.22em;
  color: rgba(245,247,255,0.6);
  text-transform: uppercase;
  margin-bottom: 12px;
}
.bc-coords__head::before {
  content: "";
  width: 10px; height: 10px; border-radius: 50%;
  background: var(--bufo-green-bright, #4ade80);
  box-shadow: 0 0 10px currentColor;
  animation: bcBlink 2s ease-in-out infinite;
}
.bc-coords__grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0,1fr));
  gap: 10px 18px;
  font-family: var(--bufo-mono, monospace);
}
.bc-coords__key {
  font-size: 0.7rem;
  letter-spacing: 0.14em;
  color: rgba(245,247,255,0.55);
  text-transform: uppercase;
}
.bc-coords__val {
  font-size: clamp(1.05rem, 2vw, 1.25rem);
  font-weight: 600;
  color: var(--bufo-green-bright, #4ade80);
  font-variant-numeric: tabular-nums;
  text-shadow: 0 0 12px rgba(34,197,94,0.25);
}
.bc-coords__loc {
  grid-column: 1 / -1;
  margin-top: 8px;
  font-family: var(--bufo-font, 'Outfit'), system-ui, sans-serif;
  color: rgba(245,247,255,0.88);
  font-size: 0.95rem;
}
.bc-coords__scope {
  position: relative;
  width: clamp(140px, 25vw, 200px);
  aspect-ratio: 1;
  border-radius: 50%;
  background:
    radial-gradient(circle, rgba(34,197,94,0.08) 0%, transparent 70%),
    conic-gradient(from 0deg at 50% 50%, rgba(34,197,94,0.4), transparent 28%);
  border: 1px solid rgba(34,197,94,0.3);
  display: grid; place-items: center;
  animation: bcScopeRotate 8s linear infinite;
}
.bc-coords__scope::before,
.bc-coords__scope::after {
  content: ""; position: absolute; inset: 0;
  border-radius: 50%;
  border: 1px solid rgba(34,197,94,0.2);
}
.bc-coords__scope::before { inset: 14%; }
.bc-coords__scope::after  { inset: 34%; border-color: rgba(34,197,94,0.3); }
.bc-coords__scope__dot {
  position: relative; width: 8px; height: 8px;
  background: var(--bufo-green-bright, #4ade80);
  border-radius: 50%;
  box-shadow: 0 0 10px currentColor;
  animation: bcBlink 1.2s ease-in-out infinite reverse;
}
.bc-coords__scope__cross {
  position: absolute; inset: 0; pointer-events: none;
  background:
    linear-gradient(0deg,   transparent 49%, rgba(34,197,94,0.2) 49%, rgba(34,197,94,0.2) 51%, transparent 51%),
    linear-gradient(90deg,  transparent 49%, rgba(34,197,94,0.2) 49%, rgba(34,197,94,0.2) 51%, transparent 51%);
  animation: none;
}

/* ──────────────────────────────────────────────────────────────────────────
   5. VERDICT — Final ruling
   ────────────────────────────────────────────────────────────────────────── */
.bc-verdict {
  position: relative; overflow: hidden;
  margin: clamp(1.6rem, 4vw, 2.4rem) 0;
  padding: clamp(1.5rem, 3.5vw, 2.2rem);
  border: 2px solid var(--_accent, var(--bufo-green, #22c55e));
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--_accent, #22c55e) 10%, transparent), transparent 80%),
    rgba(5,7,9,0.85);
  border-radius: 18px;
  color: rgba(245,247,255,0.94);
}
.bc-verdict--confirmed    { --_accent: #22c55e; }
.bc-verdict--inconclusive { --_accent: #fbbf24; }
.bc-verdict--refuted      { --_accent: #ef4444; }
.bc-verdict__head {
  display: flex; align-items: center; gap: 12px;
  font-family: var(--bufo-mono, monospace);
  font-size: 0.72rem;
  letter-spacing: 0.22em;
  color: var(--_accent);
  text-transform: uppercase;
  margin-bottom: 14px;
}
.bc-verdict__head::after {
  content: "";
  flex: 1; height: 1px;
  background: linear-gradient(90deg, var(--_accent), transparent);
  opacity: 0.6;
}
.bc-verdict__ruling {
  display: flex; align-items: center; gap: 14px;
  font-family: var(--bufo-display, 'Zen Dots'), sans-serif;
  font-size: clamp(1.6rem, 4vw, 2.4rem);
  font-weight: 700;
  letter-spacing: -0.005em;
  color: var(--_accent);
  margin: 0 0 10px !important;
  line-height: 1.1;
  text-shadow: 0 0 24px color-mix(in srgb, var(--_accent) 40%, transparent);
}
.bc-verdict__icon {
  display: inline-grid; place-items: center;
  width: clamp(42px, 7vw, 56px); height: clamp(42px, 7vw, 56px);
  flex-shrink: 0;
  border: 2px solid currentColor;
  border-radius: 50%;
  font-size: 1.4em;
}
.bc-verdict__body {
  margin: 0 !important;
  line-height: 1.65;
  color: rgba(245,247,255,0.86);
  font-size: clamp(1rem, 1.6vw, 1.1rem);
  max-width: 72ch;
}
.bc-verdict__confidence {
  margin-top: 18px;
  display: flex; align-items: center; gap: 12px;
  font-family: var(--bufo-mono, monospace);
  font-size: 0.75rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: rgba(245,247,255,0.58);
}
.bc-verdict__bar {
  flex: 1; height: 6px; border-radius: 3px;
  background: rgba(255,255,255,0.08); overflow: hidden; position: relative;
}
.bc-verdict__bar::after {
  content: ""; position: absolute; inset: 0 100% 0 0;
  background: var(--_accent);
  box-shadow: 0 0 10px var(--_accent);
  transition: right 1.4s cubic-bezier(.2,.8,.2,1);
}
.bc-verdict.is-revealed .bc-verdict__bar::after { right: calc(100% - var(--_fill, 60%)); }

/* ──────────────────────────────────────────────────────────────────────────
   6. DIVIDER — Cinematic intermission
   ────────────────────────────────────────────────────────────────────────── */
.bc-divider {
  margin: clamp(3rem, 7vw, 5rem) 0;
  display: flex; align-items: center; gap: clamp(14px, 3vw, 26px);
  font-family: var(--bufo-mono, monospace);
  font-size: 0.72rem;
  letter-spacing: 0.28em;
  color: rgba(245,247,255,0.5);
  text-transform: uppercase;
}
.bc-divider__line {
  flex: 1; height: 1px;
  background: linear-gradient(90deg, transparent, rgba(34,197,94,0.35) 50%, transparent);
}
.bc-divider__glyph {
  display: inline-grid; place-items: center;
  width: 28px; height: 28px;
  border: 1px solid rgba(34,197,94,0.45);
  border-radius: 50%;
  color: var(--bufo-green-bright, #4ade80);
  font-size: 0.9em;
  position: relative;
}
.bc-divider__glyph::before,
.bc-divider__glyph::after {
  content: ""; position: absolute;
  width: 8px; height: 8px;
  border: 1px solid rgba(34,197,94,0.35);
}
.bc-divider__glyph::before { top: -5px; left: -5px; border-right: 0; border-bottom: 0; }
.bc-divider__glyph::after  { bottom: -5px; right: -5px; border-left: 0; border-top: 0; }

/* ──────────────────────────────────────────────────────────────────────────
   7. DOCUMENT REVEAL — Redacted document with hover reveal
   ────────────────────────────────────────────────────────────────────────── */
.bc-doc {
  position: relative; overflow: hidden;
  margin: clamp(1.6rem, 4vw, 2.4rem) 0;
  background: #f5f0e6;
  color: #1a1a1a;
  border-radius: 4px;
  box-shadow:
    0 24px 80px rgba(0,0,0,0.7),
    0 0 0 1px rgba(255,255,255,0.05);
  font-family: 'Courier New', Courier, monospace;
  transform: rotate(-0.35deg);
}
.bc-doc__frame {
  padding: clamp(1.4rem, 3vw, 2.2rem);
  background-image:
    linear-gradient(rgba(0,0,0,0.04) 1px, transparent 1px);
  background-size: 100% 26px;
  background-position: 0 -2px;
}
.bc-doc__strip {
  display: flex; align-items: center; justify-content: space-between;
  gap: 10px;
  padding: 6px 10px;
  margin: -8px -8px 18px;
  background: #1a1a1a;
  color: #fff;
  font-size: 0.7rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  border-radius: 2px;
}
.bc-doc__title {
  font-family: 'Georgia', serif;
  font-size: clamp(1.2rem, 2.4vw, 1.5rem);
  font-weight: 700;
  margin: 0 0 4px !important;
  color: #1a1a1a;
  letter-spacing: -0.005em;
}
.bc-doc__ref {
  font-size: 0.85rem;
  color: rgba(0,0,0,0.55);
  margin: 0 0 14px !important;
}
.bc-doc__body {
  font-size: 0.98rem;
  line-height: 1.7;
  color: rgba(0,0,0,0.82);
}
.bc-doc__body p { margin: 0 0 10px !important; }
/* Redacted spans: <span class="bc-redact">...</span> */
.bc-redact {
  background: #000;
  color: transparent;
  padding: 0 4px;
  border-radius: 1px;
  cursor: help;
  transition: background .3s ease, color .3s ease;
  user-select: none;
  box-decoration-break: clone;
  -webkit-box-decoration-break: clone;
}
.bc-redact:hover,
.bc-redact:focus {
  background: rgba(0,0,0,0.08);
  color: #1a1a1a;
}
.bc-doc__stamp {
  position: absolute; top: 36%; right: 8%;
  padding: 10px 18px;
  border: 3px double #b91c1c;
  color: #b91c1c;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  transform: rotate(-12deg);
  opacity: 0.85;
  pointer-events: none;
  font-family: 'Courier New', Courier, monospace;
  background: rgba(255,240,240,0.35);
}
.bc-doc__fold {
  position: absolute; inset: 0; pointer-events: none;
  background:
    linear-gradient(135deg, rgba(0,0,0,0) 45%, rgba(0,0,0,0.06) 50%, rgba(0,0,0,0) 55%);
  mix-blend-mode: multiply;
}

/* ──────────────────────────────────────────────────────────────────────────
   SHARED KEYFRAMES
   ────────────────────────────────────────────────────────────────────────── */
@keyframes bcBlink { 0%,100% { opacity: 1; } 50% { opacity: 0.35; } }
@keyframes bcScanDown {
  0%   { transform: translateY(0);    opacity: 0; }
  10%  { opacity: 1; }
  90%  { opacity: 1; }
  100% { transform: translateY(100vh); opacity: 0; }
}
@keyframes bcScopeRotate {
  from { transform: rotate(0deg); }
  to   { transform: rotate(360deg); }
}
@keyframes bcReveal {
  from { opacity: 0; transform: translateY(18px); filter: blur(4px); }
  to   { opacity: 1; transform: none;               filter: none; }
}

/* Reveal-on-scroll base state (JS adds .is-revealed when visible) */
.bc-stat, .bc-verdict, .bc-coords, .bc-hero__body, .bc-spine__event, .bc-doc {
  opacity: 1;
}
.bc-reveal { opacity: 0; transform: translateY(22px); transition: opacity .6s ease, transform .6s cubic-bezier(.2,.8,.2,1); }
.bc-reveal.is-revealed { opacity: 1; transform: none; }

@media (prefers-reduced-motion: reduce) {
  .bc-hero__scan,
  .bc-hero__kicker::before,
  .bc-coords__head::before,
  .bc-coords__scope,
  .bc-coords__scope__dot { animation: none !important; }
  .bc-reveal { opacity: 1 !important; transform: none !important; }
}
