/* =========================================================================
   QPN Catalyst — "Where this is going" vision beat  (.qpn-vision)
   -------------------------------------------------------------------------
   A click-to-play video facade, placed AFTER "Why participate" and BEFORE the
   "Start contributing" CTA. Deliberately subordinate to the "it's just an
   email" promise: a still poster with a play button (no autoload, no second
   hero), clearly tagged as a FUTURE preview, that swaps in the Vimeo iframe
   only on click (see /js/vision-player.js) and links back to the CTA.

   Load order: … → qpn-why.css → THIS FILE. Tokens only; the sole raw values
   are the system navy-/gold-tint alphas rgba(11,31,58,*) / rgba(138,107,46,*)
   already used across the system (--qpn-ink #0B1F3A, --qpn-accent #8A6B2E).
   ========================================================================= */

.qpn-vision__media {
  margin: var(--qpn-sp-7) auto 0;
  max-width: 760px;
}

/* ── Poster facade — 16:9; click swaps in the Vimeo iframe ──────────────── */
.qpn-vision__facade {
  position: relative;
  display: block;
  width: 100%;
  aspect-ratio: 16 / 9;
  margin: 0;
  padding: 0;
  border: var(--qpn-rule-hair) solid var(--qpn-rule);
  border-radius: 10px;
  overflow: hidden;
  cursor: pointer;
  background-color: var(--qpn-ink);
  background-image: url('/img/vision-poster.jpg');
  background-size: cover;
  background-position: center;
  box-shadow: 0 1px 2px rgba(11, 31, 58, 0.04), 0 18px 44px -12px rgba(11, 31, 58, 0.22);
}
.qpn-vision__facade:focus-visible {
  outline: 2px solid var(--qpn-accent);
  outline-offset: 3px;
}

/* Navy scrim so the gold play button and labels read on any poster frame. */
.qpn-vision__scrim {
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(11, 31, 58, 0.10), rgba(11, 31, 58, 0.34) 62%, rgba(11, 31, 58, 0.56));
  transition: background 0.2s ease;
}
.qpn-vision__facade:hover .qpn-vision__scrim {
  background: linear-gradient(180deg, rgba(11, 31, 58, 0.18), rgba(11, 31, 58, 0.42) 62%, rgba(11, 31, 58, 0.62));
}

/* Gold play button. */
.qpn-vision__play {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 64px;
  height: 64px;
  transform: translate(-50%, -50%);
  border-radius: 50%;
  background: var(--qpn-accent);
  box-shadow: 0 6px 20px rgba(11, 31, 58, 0.35);
  transition: transform 0.18s ease;
}
.qpn-vision__play::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 54%;
  transform: translate(-50%, -50%);
  border-style: solid;
  border-width: 10px 0 10px 17px;
  border-color: transparent transparent transparent var(--qpn-page);
}
.qpn-vision__facade:hover .qpn-vision__play { transform: translate(-50%, -50%) scale(1.07); }

/* "Future preview" tag — top-left. The key framing guardrail. */
.qpn-vision__tag {
  position: absolute;
  top: var(--qpn-sp-4);
  left: var(--qpn-sp-4);
  padding: 5px 10px;
  border-radius: 4px;
  background: rgba(11, 31, 58, 0.55);
  color: var(--qpn-page);
  font-family: var(--qpn-font-body);
  font-size: var(--qpn-fs-micro);
  letter-spacing: var(--qpn-tracking-label);
  text-transform: uppercase;
  font-weight: 600;
}

/* Duration — bottom-right, mono. */
.qpn-vision__meta {
  position: absolute;
  right: var(--qpn-sp-4);
  bottom: var(--qpn-sp-4);
  font-family: var(--qpn-font-mono);
  font-size: var(--qpn-fs-micro);
  letter-spacing: var(--qpn-tracking-mono);
  color: var(--qpn-page);
}

/* Swapped-in iframe keeps the framed look. */
.qpn-vision__iframe {
  display: block;
  width: 100%;
  aspect-ratio: 16 / 9;
  border: 0;
  border-radius: 10px;
  box-shadow: 0 1px 2px rgba(11, 31, 58, 0.04), 0 18px 44px -12px rgba(11, 31, 58, 0.22);
}

/* Caption — frames it as future + links back to the CTA. */
.qpn-vision__cap {
  margin: var(--qpn-sp-4) 0 0;
  text-align: center;
  font-family: var(--qpn-font-body);
  font-size: var(--qpn-fs-body-sm);
  line-height: var(--qpn-lh-body);
  color: var(--qpn-ink-muted);
}
.qpn-vision__cap a {
  color: var(--qpn-accent);
  font-weight: 600;
  white-space: nowrap;
}

/* ── Responsive ────────────────────────────────────────────────────────── */
@media (max-width: 480px) {
  .qpn-vision__play { width: 52px; height: 52px; }
  .qpn-vision__play::before { border-width: 9px 0 9px 14px; }
}
