/* =========================================================================
   VeriTrust Access — Cinematic scroll-scrubbed video hero
   ========================================================================= */

.vhero { position: relative; background: #05080f; }
.vhero-track { position: relative; height: 560vh; }      /* scroll length that drives the scrub */
.vhero-stage {
  position: sticky; top: 0; height: 100vh; min-height: 560px;
  overflow: hidden; background: #05080f;
}
.vhero-canvas { position: absolute; inset: 0; width: 100%; height: 100%; display: block; }

/* cinematic grade + edge darkening so white UI always reads */
.vhero-grade {
  position: absolute; inset: 0; z-index: 2; pointer-events: none;
  background:
    linear-gradient(180deg, rgba(5,8,15,0.55) 0%, rgba(5,8,15,0) 22%, rgba(5,8,15,0) 60%, rgba(5,8,15,0.78) 100%),
    radial-gradient(120% 80% at 50% 120%, rgba(46,123,255,0.16), transparent 60%);
}

/* ---- Loader ---- */
.vhero-loader {
  position: absolute; inset: 0; z-index: 30; display: flex; flex-direction: column;
  align-items: center; justify-content: center; gap: 22px;
  background: #05080f; transition: opacity 0.6s var(--ease-out);
}
.vhero-loader.hide { opacity: 0; pointer-events: none; }
.vl-mark img { width: 220px; max-width: 60vw; opacity: 0.95; filter: drop-shadow(0 8px 30px rgba(46,123,255,0.25)); }
.vl-bar { width: 220px; max-width: 60vw; height: 3px; border-radius: 3px; background: rgba(255,255,255,0.12); overflow: hidden; }
.vl-fill { display: block; height: 100%; width: 0%; background: linear-gradient(90deg, var(--accent), var(--cyan)); transition: width 0.2s linear; }
.vl-txt { font-family: var(--font-mono); font-size: 0.78rem; letter-spacing: 0.22em; text-transform: uppercase; color: var(--text-2); }

/* ---- Panels (shared) ---- */
.vpanel {
  position: absolute; z-index: 10; left: 0; right: 0;
  padding-inline: clamp(20px, 6vw, 92px);
  opacity: 0; visibility: hidden;
  transition: opacity 0.5s var(--ease-out), transform 0.6s var(--ease-out), visibility 0.5s;
  will-change: opacity, transform;
}
.vpanel[data-active] { opacity: 1; visibility: visible; }

/* intro: bottom-left lockup */
.vpanel-intro { bottom: clamp(96px, 16vh, 200px); max-width: 1240px; margin-inline: auto; }
.vpanel-intro { transform: translateY(28px); }
.vpanel-intro[data-active] { transform: none; }
.vh-badge {
  display: inline-flex; align-items: center; gap: 10px;
  padding: 8px 16px 8px 12px; border-radius: var(--r-pill);
  border: 1px solid rgba(255,255,255,0.18); background: rgba(8,12,22,0.4);
  backdrop-filter: blur(12px); -webkit-backdrop-filter: blur(12px);
  font-size: var(--fs-micro); color: var(--text-1); margin-bottom: 22px;
}
.vh-badge .dot { width: 8px; height: 8px; border-radius: 50%; background: var(--ok); box-shadow: 0 0 0 4px var(--ok-soft); }
.vpanel-intro h1 {
  font-family: var(--font-display); font-weight: 700; letter-spacing: -0.035em; line-height: 1.0;
  font-size: var(--fs-hero); color: #fff; margin-bottom: 20px;
  text-shadow: 0 8px 40px rgba(0,0,0,0.5);
}
.vpanel-intro h1 .accent { background: linear-gradient(120deg, var(--accent-bright), var(--cyan)); -webkit-background-clip: text; background-clip: text; color: transparent; }
.vpanel-intro p { font-size: var(--fs-lg); color: var(--text-1); max-width: 540px; text-shadow: 0 2px 20px rgba(0,0,0,0.6); }

/* narrative message panels: glass card, alternating side */
.vpanel-msg { top: 50%; transform: translateY(-50%) translateX(40px); display: flex; }
.vpanel-msg[data-active] { transform: translateY(-50%) translateX(0); }
.vpanel-msg { justify-content: flex-end; }
.vpanel-msg:nth-of-type(odd) { justify-content: flex-start; }
.vp-glass {
  position: relative; max-width: 440px; padding: 34px 34px 32px;
  border-radius: var(--r-xl);
  background: linear-gradient(160deg, rgba(255,255,255,0.16), rgba(255,255,255,0.05) 55%, rgba(8,12,22,0.18));
  border: 1px solid rgba(255,255,255,0.28);
  backdrop-filter: blur(26px) saturate(130%); -webkit-backdrop-filter: blur(26px) saturate(130%);
  box-shadow: 0 30px 70px -22px rgba(0,0,0,0.7), inset 0 1px 0 rgba(255,255,255,0.4);
}
.vp-step {
  position: absolute; top: -16px; left: 30px;
  font-family: var(--font-mono); font-weight: 700; font-size: 0.8rem; letter-spacing: 0.1em;
  padding: 7px 13px; border-radius: var(--r-pill); color: #fff;
  background: linear-gradient(180deg, var(--accent-bright), var(--accent-deep));
  box-shadow: 0 8px 22px -8px var(--accent-glow);
}
.vp-ico { display: grid; place-items: center; width: 52px; height: 52px; border-radius: 15px; margin-bottom: 18px;
  background: rgba(255,255,255,0.16); border: 1px solid rgba(255,255,255,0.35); color: #fff; }
.vp-ico svg { width: 26px; height: 26px; }
.vp-glass h2 { font-family: var(--font-display); font-size: var(--fs-xl); color: #fff; margin-bottom: 10px; letter-spacing: -0.02em; }
.vp-glass p { font-size: var(--fs-base); color: rgba(255,255,255,0.86); line-height: 1.55; }

/* final cluster: centered */
.vpanel-final { top: 50%; transform: translate(0, calc(-50% + 26px)); text-align: center; max-width: 900px; margin-inline: auto; }
.vpanel-final[data-active] { transform: translate(0, -50%); }
.vh-eyebrow { font-family: var(--font-mono); font-size: var(--fs-eyebrow); letter-spacing: 0.24em; text-transform: uppercase; color: var(--accent-bright); }
.vpanel-final h2 { font-family: var(--font-display); font-weight: 700; font-size: var(--fs-3xl); color: #fff; margin: 16px 0 28px; letter-spacing: -0.03em; text-shadow: 0 8px 40px rgba(0,0,0,0.5); }
.vh-chips { display: flex; flex-wrap: wrap; justify-content: center; gap: 12px; margin-bottom: 34px; }
.vh-chip { display: inline-flex; align-items: center; gap: 10px; padding: 11px 18px; border-radius: var(--r-pill);
  background: rgba(255,255,255,0.1); border: 1px solid rgba(255,255,255,0.24);
  backdrop-filter: blur(14px); -webkit-backdrop-filter: blur(14px);
  font-size: var(--fs-sm); font-weight: 600; color: #fff; }
.vh-chip svg { width: 18px; height: 18px; color: var(--accent-bright); }
.vh-cta { display: flex; flex-wrap: wrap; justify-content: center; gap: 14px; }

/* progress bar + hint */
.vhero-progress { position: absolute; left: 0; right: 0; bottom: 0; height: 3px; z-index: 12; background: rgba(255,255,255,0.08); }
.vhp-fill { display: block; height: 100%; width: 0%; background: linear-gradient(90deg, var(--accent), var(--cyan)); box-shadow: 0 0 14px var(--accent-glow); }
.vhero-hint { position: absolute; bottom: 24px; left: 50%; transform: translateX(-50%); z-index: 12;
  display: flex; flex-direction: column; align-items: center; gap: 8px;
  font-size: var(--fs-micro); color: rgba(255,255,255,0.7); letter-spacing: 0.04em;
  transition: opacity var(--dur-mid); }
.vhero-hint.hide { opacity: 0; }
.vhero-hint .mouse { width: 22px; height: 34px; border: 1.5px solid rgba(255,255,255,0.4); border-radius: var(--r-pill); position: relative; }
.vhero-hint .mouse::after { content: ""; position: absolute; top: 6px; left: 50%; transform: translateX(-50%); width: 3px; height: 7px; border-radius: 2px; background: var(--accent-bright); animation: scrollDot 1.6s var(--ease-in-out) infinite; }

/* RTL: mirror message panel sides */
[dir="rtl"] .vpanel-msg { justify-content: flex-start; }
[dir="rtl"] .vpanel-msg:nth-of-type(odd) { justify-content: flex-end; }
[dir="rtl"] .vp-step { left: auto; right: 30px; }

/* Mobile */
@media (max-width: 760px) {
  .vhero-track { height: 480vh; }
  .vpanel-msg, .vpanel-msg:nth-of-type(odd) { justify-content: center; top: auto; bottom: clamp(80px, 14vh, 150px); transform: translateY(28px); }
  .vpanel-msg[data-active] { transform: translateY(0); }
  .vp-glass { max-width: 520px; }
  .vpanel-intro { bottom: auto; top: 90px; }
  .vpanel-final { top: 50%; }
}
@media (prefers-reduced-motion: reduce) {
  .vhero-track { height: 100vh; }
  .vpanel { transition: opacity 0.3s; }
}
