/* ─────────────────────────────────────────────────────────────────────────
   FPVR SALE-MODE styles. References the live canon :root tokens (declared in
   the inline critical block in widget.header.scripts.php) — does NOT redeclare
   them, so it stays byte-consistent with the rest of the site.
   Loaded only when a sale is live OR on the /sale landing page.

   Sections: [1] landing (/sale)  [2] header strap (block 6)  [3] floating bar
             [4] exit-intent modal  [5] expired best-price banner  [6] shared
   This pass ships [1] landing + [6] shared. Others added as each surface lands.
   ───────────────────────────────────────────────────────────────────────── */

/* ── [6] shared bits — countdown + eyebrow + pill (canon-matched) ── */
.fpvr-saleEyebrow{display:inline-flex;align-items:center;gap:8px;font-size:var(--t-eyebrow);font-weight:800;letter-spacing:2px;text-transform:uppercase;color:var(--c-brand)}
.fpvr-saleDot{width:7px;height:7px;border-radius:50%;background:var(--c-brand);animation:fpvrSalePulse 1.8s infinite}
@keyframes fpvrSalePulse{0%{box-shadow:0 0 0 0 rgba(245,60,70,.55)}70%{box-shadow:0 0 0 9px rgba(245,60,70,0)}100%{box-shadow:0 0 0 0 rgba(245,60,70,0)}}
@media (prefers-reduced-motion:reduce){.fpvr-saleDot,.fpvr-countdown--pulse{animation:none!important}}

.fpvr-salePill{display:inline-block;background:linear-gradient(135deg,var(--c-brand),var(--c-brand-dark));color:#fff;font-weight:800;font-size:var(--t-small);letter-spacing:.4px;padding:15px 30px;border-radius:var(--r-pill);box-shadow:var(--shadow-brand);transition:transform .15s ease;border:0;cursor:pointer}
.fpvr-salePill:hover{transform:translateY(-2px);color:#fff}

/* countdown grid (shared API with fpvr-countdown.js) */
.fpvr-cd{display:inline-flex;gap:8px;justify-content:center}
.fpvr-cd__u{background:rgba(255,255,255,.06);border:1px solid var(--c-border);border-radius:var(--r-sm);padding:12px 14px;min-width:64px;text-align:center}
.fpvr-cd__u b{display:block;font-size:28px;font-weight:900;color:var(--c-text);line-height:1;font-variant-numeric:tabular-nums}
.fpvr-cd__u em{font-style:normal;color:var(--c-text-muted);font-size:9px;letter-spacing:1.5px;text-transform:uppercase}
.fpvr-countdown--pulse{animation:fpvrSaleCdPulse 1s ease-in-out infinite}
@keyframes fpvrSaleCdPulse{0%,100%{opacity:1}50%{opacity:.55}}

/* ── [1] /sale landing (scoped to body.page-sale) ── */
body.page-sale .fpvr-saleMain{width:100%;align-self:stretch;max-width:1700px;margin:0 auto;padding:0 85px}
@media (max-width:1500px){body.page-sale .fpvr-saleMain{padding:0 55px}}
@media (max-width:1090px){body.page-sale .fpvr-saleMain{padding:0 40px}}
@media (max-width:700px){body.page-sale .fpvr-saleMain{padding:0 20px}}
@media (max-width:500px){body.page-sale .fpvr-saleMain{padding:0 15px}}

.fpvr-saleHero{text-align:center;padding:70px 0 50px}
.fpvr-saleHero__title{font-size:46px;font-weight:900;letter-spacing:-1px;line-height:1.08;color:var(--c-text);margin:16px 0 14px}
.fpvr-saleHero__title em{font-style:normal;color:var(--c-brand)}
.fpvr-saleHero__sub{color:var(--c-text-muted);font-size:var(--t-body);max-width:620px;margin:0 auto 26px}
.fpvr-saleHero__cd{margin:0 auto 28px}
.fpvr-saleHero__micro{color:var(--c-text-dim);font-size:var(--t-micro);margin-top:14px}

.fpvr-saleTiers{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin:10px 0 50px}
.fpvr-saleTier{position:relative;background:linear-gradient(135deg,var(--c-bg-elev-1),var(--c-bg-elev-2));border:1px solid var(--c-border);border-radius:var(--r-lg);padding:28px 22px;text-align:center;overflow:hidden;transition:transform .15s ease,border-color .15s ease}
.fpvr-saleTier:hover{transform:translateY(-3px);border-color:var(--c-brand)}
.fpvr-saleTier--best{border-color:var(--c-brand);box-shadow:0 0 0 1px var(--c-brand),0 18px 50px rgba(245,60,70,.18)}
.fpvr-saleTier--best::after{content:"";position:absolute;inset:0;background:radial-gradient(circle at 90% 8%,rgba(245,60,70,.22),transparent 45%);pointer-events:none}
.fpvr-saleTier__badge{display:inline-block;font-size:10px;font-weight:900;letter-spacing:1.5px;text-transform:uppercase;color:#fff;background:linear-gradient(135deg,var(--c-brand),var(--c-brand-dark));padding:5px 12px;border-radius:var(--r-pill);margin-bottom:12px}
.fpvr-saleTier__term{font-size:var(--t-micro);font-weight:800;letter-spacing:1.5px;text-transform:uppercase;color:var(--c-text-muted)}
.fpvr-saleTier__price{font-size:40px;font-weight:900;color:var(--c-text);line-height:1;margin:8px 0 4px}
.fpvr-saleTier__price span{font-size:15px;color:var(--c-text-muted);font-weight:600}
.fpvr-saleTier__msrp{font-size:var(--t-small);color:var(--c-text-dim);margin-bottom:16px}
.fpvr-saleTier__msrp s{color:var(--c-text-dim)}
.fpvr-saleTier__save{color:var(--c-brand);font-weight:800}
.fpvr-saleTier .fpvr-salePill{width:100%}

.fpvr-saleBand{text-align:center;padding:30px 0}
.fpvr-saleBand__h{font-size:var(--t-small);font-weight:800;letter-spacing:2px;text-transform:uppercase;color:var(--c-text-muted);margin-bottom:22px}
.fpvr-saleStats{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:14px}
.fpvr-saleStat{background:linear-gradient(135deg,var(--c-bg-elev-1),var(--c-bg-elev-2));border:1px solid var(--c-border);border-radius:var(--r-md);padding:20px}
.fpvr-saleStat b{display:block;font-size:30px;font-weight:900;color:var(--c-text)}
.fpvr-saleStat em{font-style:normal;font-size:var(--t-micro);color:var(--c-text-muted);letter-spacing:.5px}
.fpvr-saleHeadsets{color:var(--c-text-muted);font-size:var(--t-small)}
.fpvr-saleHeadsets b{color:var(--c-text)}

.fpvr-saleFaq{max-width:720px;margin:10px auto 0}
.fpvr-saleFaq__h{text-align:center;font-size:22px;font-weight:900;color:var(--c-text);margin-bottom:18px}
.fpvr-saleFaq details{background:linear-gradient(135deg,var(--c-bg-elev-1),var(--c-bg-elev-2));border:1px solid var(--c-border);border-radius:var(--r-md);padding:16px 20px;margin-bottom:10px}
.fpvr-saleFaq summary{font-weight:700;color:var(--c-text);cursor:pointer;list-style:none}
.fpvr-saleFaq summary::-webkit-details-marker{display:none}
.fpvr-saleFaq p{color:var(--c-text-muted);font-size:var(--t-small);margin-top:10px}

.fpvr-saleBottom{text-align:center;background:linear-gradient(135deg,var(--c-bg-elev-1),var(--c-bg-elev-2));border:1px solid var(--c-border);border-radius:var(--r-lg);padding:48px 24px;margin:50px 0;position:relative;overflow:hidden}
.fpvr-saleBottom::after{content:"";position:absolute;inset:0;background:radial-gradient(circle at 88% 12%,rgba(245,60,70,.2),transparent 45%);pointer-events:none}
.fpvr-saleBottom__h{font-size:30px;font-weight:900;letter-spacing:-.5px;color:var(--c-text);margin-bottom:10px}
.fpvr-saleBottom__h em{font-style:normal;color:var(--c-brand)}
.fpvr-saleBottom__sub{color:var(--c-text-muted);margin-bottom:22px}

/* dormant state (before/after the window — universal join CTA, no sale claims) */
.fpvr-saleDormant{text-align:center;padding:90px 0 200px}
.fpvr-saleDormant .fpvr-saleHero__title{margin-bottom:14px}
.fpvr-saleDormant .fpvr-salePill{margin-bottom:40px}
@media (max-width:760px){.fpvr-saleDormant{padding:60px 0 140px}}

@media (max-width:760px){
  .fpvr-saleHero__title{font-size:32px}
  .fpvr-saleTiers{grid-template-columns:1fr}
  .fpvr-saleStats{grid-template-columns:repeat(2,1fr)}
}

/* ── [2] header sale strap — .header-promo--sale (overrides the 40px black .header-promo) ── */
.header-promo--sale{background:linear-gradient(135deg,var(--c-brand),var(--c-brand-dark))!important;gap:14px!important}
.header-promoSale__eye{display:inline-flex;align-items:center;gap:6px;font-weight:800;font-size:11px;letter-spacing:1.2px;text-transform:uppercase;color:#fff;flex-shrink:0}
.header-promoSale__dot{width:6px;height:6px;border-radius:50%;background:#fff;animation:fpvrSalePulseW 1.8s infinite}
@keyframes fpvrSalePulseW{0%{box-shadow:0 0 0 0 rgba(255,255,255,.5)}70%{box-shadow:0 0 0 7px rgba(255,255,255,0)}100%{box-shadow:0 0 0 0 rgba(255,255,255,0)}}
.header-promoSale__copy{font-weight:600;color:#fff;overflow:hidden;text-overflow:ellipsis}
.header-promoSale__copy strong{color:#fff!important;font-weight:900}
.header-promoSale__cd{display:inline-flex;gap:4px;font-weight:900;font-variant-numeric:tabular-nums;color:#fff;flex-shrink:0}
.header-promoSale__cd b{background:rgba(0,0,0,.18);border-radius:4px;padding:1px 5px;font-size:12px}
.header-promoSale__cta{background:#fff;color:var(--c-brand-dark)!important;font-weight:900;font-size:11px;letter-spacing:.4px;text-transform:uppercase;padding:5px 14px;border-radius:var(--r-pill);flex-shrink:0;white-space:nowrap;text-decoration:none}
@media (max-width:700px){
  .header-promoSale__cd{display:none}
  .header-promoSale__eye span:not(.header-promoSale__dot){display:none}
}
@media (prefers-reduced-motion:reduce){.header-promoSale__dot{animation:none!important}}

/* ── [3] floating sale bar — .fpvr-floating--sale (reuses .fpvr-floating base + JS) ── */
.fpvr-floating--sale{right:auto;left:50%;max-width:min(740px,94vw);min-height:0;border-radius:var(--r-lg);border:1px solid var(--c-brand);background:linear-gradient(135deg,var(--c-bg-elev-1),var(--c-bg-elev-2));gap:14px;padding:12px 18px 12px 20px;transform:translate(-50%,12px)}
.fpvr-floating--sale.fpvr-floating--in{transform:translate(-50%,0)}
.fpvr-floating--sale:hover{transform:translate(-50%,-2px)}
.fpvr-floatingSale__eye{display:inline-flex;align-items:center;gap:6px;font-size:11px;font-weight:800;letter-spacing:1.2px;text-transform:uppercase;color:var(--c-brand);flex-shrink:0}
.fpvr-floatingSale__dot{width:6px;height:6px;border-radius:50%;background:var(--c-brand);animation:fpvrSalePulse 1.8s infinite}
.fpvr-floatingSale__copy{font-weight:700;font-size:14px;color:var(--c-text);white-space:nowrap;min-width:0;overflow:hidden;text-overflow:ellipsis}
.fpvr-floatingSale__cd{display:inline-flex;gap:4px;font-weight:900;font-variant-numeric:tabular-nums;color:var(--c-text);flex-shrink:0;margin-left:auto}
.fpvr-floatingSale__cd b{background:rgba(255,255,255,.06);border:1px solid var(--c-border);border-radius:4px;padding:1px 5px;font-size:12px}
.fpvr-floatingSale__cta{background:linear-gradient(135deg,var(--c-brand),var(--c-brand-dark));color:#fff!important;font-weight:800;font-size:12px;letter-spacing:.3px;padding:9px 18px;border-radius:var(--r-pill);box-shadow:var(--shadow-brand);flex-shrink:0;white-space:nowrap;text-decoration:none}
@media (max-width:700px){
  .fpvr-floating--sale{left:12px;right:12px;max-width:none;flex-wrap:wrap;transform:translateY(12px)}
  .fpvr-floating--sale.fpvr-floating--in{transform:translateY(0)}
  .fpvr-floating--sale:hover{transform:translateY(0)}
  .fpvr-floatingSale__cd{display:none}
}

/* ── [4] pre-footer sale strip — body-level (needs align-self:stretch per body-flex gotcha) ── */
.fpvr-salePrefooter{width:100%;align-self:stretch;background:linear-gradient(135deg,var(--c-bg-elev-1),var(--c-bg-elev-2));border-top:1px solid var(--c-border);position:relative;overflow:hidden}
.fpvr-salePrefooter::after{content:"";position:absolute;inset:0;background:radial-gradient(circle at 88% 12%,rgba(245,60,70,.16),transparent 45%);pointer-events:none}
.fpvr-salePrefooter__inner{max-width:1700px;margin:0 auto;padding:48px 85px;text-align:center;position:relative;z-index:1}
.fpvr-salePrefooter__h{font-size:28px;font-weight:900;letter-spacing:-.5px;color:var(--c-text);margin:12px 0 8px}
.fpvr-salePrefooter__h em{font-style:normal;color:var(--c-brand)}
.fpvr-salePrefooter__sub{color:var(--c-text-muted);font-size:14px;margin:0 0 18px}
/* display:flex (not the base inline-flex) so the countdown takes its own line
   and the Claim CTA stacks BELOW it with clear breathing room (2026-06-24). */
.fpvr-salePrefooter__cd{display:flex;margin:0 auto 30px}
@media (max-width:1500px){.fpvr-salePrefooter__inner{padding:48px 55px}}
@media (max-width:1090px){.fpvr-salePrefooter__inner{padding:40px 40px}}
@media (max-width:700px){.fpvr-salePrefooter__inner{padding:36px 20px}.fpvr-salePrefooter__h{font-size:22px}}
@media (max-width:500px){.fpvr-salePrefooter__inner{padding:32px 15px}}

/* ── [5] exit-intent modal — guest, fires once/session on exit-intent ── */
body.fpvr-saleExit-open{overflow:hidden}
.fpvr-saleExit{position:fixed;inset:0;z-index:200;display:flex;align-items:center;justify-content:center;padding:20px}
.fpvr-saleExit[hidden]{display:none}
.fpvr-saleExit__backdrop{position:absolute;inset:0;background:rgba(5,7,15,.78);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}
.fpvr-saleExit__card{position:relative;z-index:1;width:min(440px,94vw);background:linear-gradient(135deg,var(--c-bg-elev-1),var(--c-bg-elev-2));border:1px solid var(--c-brand);border-radius:var(--r-lg);padding:34px 30px;text-align:center;overflow:hidden;box-shadow:0 30px 80px rgba(0,0,0,.6)}
.fpvr-saleExit__card::after{content:"";position:absolute;inset:0;background:radial-gradient(circle at 50% 0%,rgba(245,60,70,.18),transparent 55%);pointer-events:none}
.fpvr-saleExit__close{position:absolute;top:12px;right:14px;background:none;border:0;color:var(--c-text-dim);font-size:24px;line-height:1;cursor:pointer;z-index:2}
.fpvr-saleExit__h{font-size:26px;font-weight:900;letter-spacing:-.5px;color:var(--c-text);margin:12px 0 8px;position:relative;z-index:1}
.fpvr-saleExit__px{font-size:38px;font-weight:900;color:var(--c-text);margin:6px 0;position:relative;z-index:1}
.fpvr-saleExit__px s{font-size:18px;color:var(--c-text-dim)}
.fpvr-saleExit__px span{font-size:15px;color:var(--c-text-muted);font-weight:600}
.fpvr-saleExit__sub{color:var(--c-text-muted);font-size:14px;margin:0 0 18px;position:relative;z-index:1}
.fpvr-saleExit__cd{margin:0 0 18px;position:relative;z-index:1}
.fpvr-saleExit .fpvr-saleEyebrow,.fpvr-saleExit .fpvr-salePill{position:relative;z-index:1}
.fpvr-saleExit__no{display:block;margin-top:14px;color:var(--c-text-dim);font-size:12px;text-decoration:underline;cursor:pointer;position:relative;z-index:1}

/* ── [6] homepage hero 6th slide (sale-only overrides — normal 5-slide hero untouched) ── */
/* retime the rotation to 6 slides × 8s = 48s, only on .fpvr-hero--sale */
.fpvr-hero--sale .fpvr-hero__slide{animation-name:fpvrHeroSlide6;animation-duration:48s}
.fpvr-hero--sale .fpvr-hero__slide:nth-child(6){animation-delay:40s;z-index:0}
@keyframes fpvrHeroSlide6{
  0%,100%{opacity:0;pointer-events:none}
  2.1%,14.6%{opacity:1;pointer-events:auto}
  16.7%{opacity:0;pointer-events:none}
}
.fpvr-hero--sale .fpvr-hero__dot{animation-name:fpvrHeroDot6;animation-duration:48s}
.fpvr-hero--sale .fpvr-hero__dot:nth-child(6){animation-delay:40s}
@keyframes fpvrHeroDot6{
  0%,16.67%{background:var(--c-brand);width:40px}
  16.68%,100%{background:rgba(255,255,255,0.24);width:24px}
}
/* the sale panel that fills the hero's left video area for its slot */
.fpvr-hero__slide--sale{background:linear-gradient(135deg,var(--c-brand),var(--c-brand-dark));display:flex;align-items:center;justify-content:center;text-align:center}
.fpvr-heroSale{padding:32px;max-width:92%}
.fpvr-heroSale__eye{display:inline-flex;align-items:center;gap:8px;font-size:12px;font-weight:800;letter-spacing:2px;text-transform:uppercase;color:#fff;margin-bottom:14px}
.fpvr-heroSale__dot{width:7px;height:7px;border-radius:50%;background:#fff;animation:fpvrSalePulseW 1.8s infinite}
.fpvr-heroSale__h{font-size:34px;font-weight:900;letter-spacing:-.5px;line-height:1.1;color:#fff;margin:0 0 18px}
.fpvr-heroSale__h strong{color:#fff;font-weight:900}
.fpvr-heroSale__cd{margin:0 0 22px}
.fpvr-heroSale__cd .fpvr-cd__u{background:rgba(0,0,0,.18);border-color:rgba(255,255,255,.22)}
.fpvr-heroSale__cd .fpvr-cd__u b{color:#fff}
.fpvr-heroSale__cd .fpvr-cd__u em{color:rgba(255,255,255,.82)}
.fpvr-heroSale__cta{display:inline-block;background:#fff;color:var(--c-brand-dark)!important;font-weight:800;font-size:14px;letter-spacing:.4px;padding:14px 30px;border-radius:var(--r-pill);text-decoration:none;box-shadow:0 8px 24px rgba(0,0,0,.25)}
@media (max-width:700px){.fpvr-heroSale__h{font-size:24px}.fpvr-heroSale{padding:20px}}
@media (prefers-reduced-motion:reduce){.fpvr-heroSale__dot{animation:none!important}}

/* ── [7] expired /user "best price" banner (audience split — expired members only) ── */
.fpvr-account__saleBanner{display:flex;align-items:center;gap:22px;flex-wrap:wrap;background:linear-gradient(135deg,var(--c-bg-elev-1),var(--c-bg-elev-2));border:1px solid var(--c-border);border-left:4px solid var(--c-brand);border-radius:var(--r-lg);padding:22px 26px;margin:0 0 24px;position:relative;overflow:hidden}
.fpvr-account__saleBanner::after{content:"";position:absolute;inset:0;background:radial-gradient(circle at 92% 12%,rgba(245,60,70,.16),transparent 45%);pointer-events:none}
.fpvr-account__saleBannerTxt{flex:1;min-width:240px;position:relative;z-index:1}
.fpvr-account__saleBannerH{font-size:22px;font-weight:900;letter-spacing:-.3px;color:var(--c-text);margin:6px 0 4px}
.fpvr-account__saleBannerH em{font-style:normal;color:var(--c-brand)}
.fpvr-account__saleBannerSub{color:var(--c-text-muted);font-size:14px;line-height:1.55;margin:0}
.fpvr-account__saleBannerSub b{color:var(--c-text)}
.fpvr-account__saleBannerCta{position:relative;z-index:1;flex-shrink:0}
@media (max-width:700px){.fpvr-account__saleBanner{padding:20px}.fpvr-account__saleBannerH{font-size:19px}}

/* ── [8] scene-page sale banner (above the join panel; guest) ── */
.fpvr-sceneSale{background:linear-gradient(135deg,var(--c-bg-elev-1),var(--c-bg-elev-2));border:1px solid var(--c-brand);border-radius:var(--r-lg);padding:20px 22px;margin:0 0 16px;text-align:center;position:relative;overflow:hidden}
.fpvr-sceneSale::after{content:"";position:absolute;inset:0;background:radial-gradient(circle at 88% 10%,rgba(245,60,70,.2),transparent 50%);pointer-events:none}
.fpvr-sceneSale>*{position:relative;z-index:1}
.fpvr-sceneSale__copy{font-size:18px;font-weight:900;letter-spacing:-.3px;color:var(--c-text);margin:10px 0 14px}
.fpvr-sceneSale__copy strong{color:var(--c-brand)}
.fpvr-sceneSale__cd{margin:0 0 16px}
.fpvr-sceneSale__cd .fpvr-cd__u{padding:8px 10px;min-width:50px}
.fpvr-sceneSale__cd .fpvr-cd__u b{font-size:21px}
.fpvr-sceneSale__cta{width:100%}

/* ── [9] mid-grid sale card (JS-injected into .videos grid as a tile; guest) ── */
.fpvr-gridSale[hidden]{display:none!important}
.fpvr-gridSale__inner{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:10px;height:100%;min-height:240px;background:linear-gradient(135deg,var(--c-brand),var(--c-brand-dark));border-radius:var(--r-md);padding:24px 18px;text-decoration:none;color:#fff;box-shadow:var(--shadow-brand);transition:transform .15s ease}
.fpvr-gridSale__inner:hover{transform:translateY(-3px)}
.fpvr-gridSale .fpvr-saleEyebrow{color:#fff}
.fpvr-gridSale .fpvr-saleDot{background:#fff}
.fpvr-gridSale__h{font-size:20px;font-weight:900;letter-spacing:-.3px;color:#fff;line-height:1.15}
.fpvr-gridSale__h strong{color:#fff}
.fpvr-gridSale__cd{gap:5px;flex-wrap:wrap;justify-content:center}
.fpvr-gridSale__cd .fpvr-cd__u{background:rgba(0,0,0,.18);border-color:rgba(255,255,255,.25);padding:6px 8px;min-width:40px}
.fpvr-gridSale__cd .fpvr-cd__u b{color:#fff;font-size:17px}
.fpvr-gridSale__cd .fpvr-cd__u em{color:rgba(255,255,255,.8);font-size:9px}
.fpvr-gridSale__cta{background:#fff;color:var(--c-brand-dark)!important;margin-top:4px}
