/* ============================================================================
   Strafe Pass page — forked from the design system's Game Detail + Strafe Pass
   kit, rendered in the site's vanilla system. Reuses site.css tokens/components
   (nav, footer, buttons, badges, eyebrow, bands). New classes only below.
   ============================================================================ */

/* ---- GAME HERO (always-dark cinematic feature, auto cross-dissolve carousel) */
.ghero { position: relative; background: var(--canvas-dark); color: var(--on-dark); overflow: hidden; min-height: 640px; }
.ghero__slide { position: absolute; inset: 0; opacity: 0; visibility: hidden; pointer-events: none; transition: opacity .6s ease, visibility 0s linear .6s; }
.ghero__slide.is-active { opacity: 1; visibility: visible; pointer-events: auto; z-index: 1; transition: opacity .6s ease; }
@media (prefers-reduced-motion: reduce) { .ghero__slide { transition: none; } }
.ghero__art { position: absolute; inset: 0; z-index: 0; background-size: cover; background-position: center 28%; }
.ghero__scrim {
  position: absolute; inset: 0; z-index: 1; pointer-events: none;
  background:
    linear-gradient(90deg, #000 0%, rgba(0,0,0,0.82) 36%, rgba(0,0,0,0.2) 100%),
    linear-gradient(0deg, #000 0%, rgba(0,0,0,0) 52%);
}
.ghero__inner {
  position: relative; z-index: 2; min-height: 640px;
  display: flex; flex-direction: column; justify-content: flex-end;
  padding-top: 140px; padding-bottom: 124px;
}
.ghero__genre { background: rgba(255,255,255,0.16); }
.ghero__badges { display: flex; gap: var(--space-sm); margin-bottom: var(--space-md); }
.ghero__title { font-family: var(--font-title); font-weight: 800; text-transform: uppercase; color: #fff; font-size: clamp(42px, 6.6vw, 84px); line-height: 0.92; letter-spacing: 0.5px; margin: 0 0 var(--space-md); }
.ghero__blurb { max-width: 480px; color: var(--body-dark); font: var(--w-reg) 19px/1.55 var(--font-text); margin: 0 0 var(--space-xl); }
.ghero__cta { display: flex; gap: var(--space-md); flex-wrap: wrap; align-items: center; }
.ghero__cta .st-btn--ghost { color: var(--on-dark); box-shadow: inset 0 0 0 1px var(--hairline-dark); display: inline-flex; align-items: center; gap: 8px; }
.ghero__cta .st-btn--ghost:hover { background: rgba(255,255,255,0.06); opacity: 1; }

/* shared dots nav */
.ghero__nav { position: absolute; left: 0; right: 0; bottom: 48px; z-index: 5; }
.ghero__dots { display: flex; gap: var(--space-sm); }
.ghero__dot { width: 36px; height: 4px; border-radius: var(--radius-full); background: rgba(255,255,255,0.32); border: 0; padding: 0; cursor: pointer; transition: background-color .2s ease, transform .2s ease; }
.ghero__dot:hover { background: rgba(255,255,255,0.6); }
.ghero__dot.is-active { background: #fff; }

/* ---- STORE STRIP: "Every game. One library." ------------------------------ */
.store-grid { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-section); align-items: center; }
.store-copy h2 { margin: 0 0 var(--space-md); color: var(--svc-fg); }
.store-copy p { margin: 0 0 var(--space-xl); color: var(--svc-lead); max-width: 440px; font: var(--w-reg) 18px/1.55 var(--font-text); }
.store-cards { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-lg); }
.scard { background: var(--card-surface); color: var(--card-title); border-radius: var(--radius-md); padding: var(--space-xl); display: flex; flex-direction: column; gap: var(--space-xs); }
.scard__eyebrow { font: var(--w-semi) 11px/1 var(--font-text); letter-spacing: 1.4px; text-transform: uppercase; color: var(--card-muted); margin-bottom: var(--space-sm); }
.scard h4 { margin: 0; font: var(--w-semi) 20px/1.3 var(--font-text); color: var(--card-title); }
.scard p { margin: 4px 0 var(--space-lg); color: var(--card-body); font: var(--w-reg) 15px/1.5 var(--font-text); flex: 1; }
.scard .st-btn { align-self: flex-start; }

/* library preview row */
.lib-row { display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--space-md); margin-top: var(--space-section); }
.lib-tile { position: relative; border-radius: var(--radius-md); overflow: hidden; aspect-ratio: 16 / 10; display: block; }
.lib-tile img { width: 100%; height: 100%; object-fit: cover; transition: transform .5s ease; }
.lib-tile:hover img { transform: scale(1.05); }
.lib-tile::after { content: ""; position: absolute; inset: 0; background: linear-gradient(180deg, rgba(0,0,0,0) 45%, rgba(0,0,0,0.7) 100%); }
.lib-tile span { position: absolute; left: 12px; bottom: 10px; z-index: 2; font-family: var(--font-title); font-weight: 700; text-transform: uppercase; color: #fff; font-size: 16px; letter-spacing: 0.3px; line-height: 1; }

/* ---- STRAFE PASS ---------------------------------------------------------- */
.pass-card { background: var(--surface-dark-elevated); color: #fff; border-radius: var(--radius-md); overflow: hidden; }
.pass-card__bar { height: 6px; background: var(--pass-gradient); }
.pass-card__inner { padding: var(--space-xxl); }
.pass-head { display: flex; align-items: flex-end; justify-content: space-between; gap: var(--space-xl); flex-wrap: wrap; margin-bottom: var(--space-xl); }
.pass-eyebrow { font: var(--w-semi) 11px/1 var(--font-text); letter-spacing: 1.4px; text-transform: uppercase; color: var(--pass-gold-mid); margin-bottom: var(--space-md); }
.pass-head h2 { margin: 0 0 var(--space-xs); color: #fff; }
.pass-head p { margin: 0; color: var(--body-dark); font: var(--w-reg) 17px/1.5 var(--font-text); }

/* billing segmented toggle */
.billing { display: inline-flex; background: var(--surface-dark-card); border-radius: var(--radius-full); padding: 4px; gap: 4px; }
.billing button { border: 0; cursor: pointer; background: transparent; color: var(--on-dark-mute); font: var(--w-bold) 13px/1 var(--font-text); letter-spacing: 0.3px; padding: 9px 16px; border-radius: var(--radius-full); display: inline-flex; align-items: center; gap: 6px; transition: background-color .15s ease, color .15s ease; }
.billing button.is-active { background: #fff; color: #000; }
.billing .save { font: var(--w-bold) 10px/1 var(--font-text); letter-spacing: 0.5px; text-transform: uppercase; color: var(--volt); }
.billing button.is-active .save { color: var(--signal-orange); }

.tiers { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--space-lg); }
.tier { position: relative; background: var(--surface-dark-card); border-radius: var(--radius-md); padding: var(--space-xl); display: flex; flex-direction: column; gap: var(--space-md); }
.tier--popular { box-shadow: inset 0 0 0 1px var(--pass-gold-mid); }
.tier__flag { position: absolute; top: calc(var(--space-md) * -1); left: var(--space-xl); background: var(--pass-gradient); color: #1a1407; font: var(--w-bold) 10px/1 var(--font-text); letter-spacing: 1px; text-transform: uppercase; padding: 6px 12px; border-radius: var(--radius-full); }
.tier__name { font: var(--w-semi) 18px/1 var(--font-text); color: #fff; }
.tier__price { display: flex; align-items: baseline; gap: 6px; }
.tier__amount { font: var(--w-light) 40px/1 var(--font-display); color: #fff; }
.tier__period { font: var(--w-reg) 14px/1 var(--font-text); color: var(--on-dark-mute); }
.tier__note { font: var(--w-reg) 13px/1.4 var(--font-text); color: var(--on-dark-mute); min-height: 18px; }
.tier__list { list-style: none; margin: var(--space-xs) 0 var(--space-md); padding: 0; display: flex; flex-direction: column; gap: var(--space-sm); }
.tier__list li { display: flex; gap: var(--space-sm); align-items: flex-start; font: var(--w-reg) 15px/1.4 var(--font-text); color: var(--body-dark); }
.tier__list svg { color: var(--pass-gold-mid); flex: none; margin-top: 1px; }
.tier .st-btn { margin-top: auto; width: 100%; justify-content: center; }
.pass-foot { margin: var(--space-xl) 0 0; color: var(--on-dark-mute); font: var(--w-reg) 14px/1.5 var(--font-text); }
.pass-foot a { color: #fff; text-decoration: underline; text-underline-offset: 2px; }

/* ---- "coming soon" teaser bits ------------------------------------------- */
.store-eyebrow-row { display: flex; align-items: center; gap: var(--space-md); flex-wrap: wrap; margin-bottom: var(--space-md); }
.store-eyebrow-row .eyebrow { margin-bottom: 0; }
/* small "Soon" pill for not-yet-live store features (seasonal sale, cloud) */
.scard h4 { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.soon-pill { display: inline-flex; align-items: center; font: var(--w-semi) 9px/1 var(--font-text);
  letter-spacing: 1.4px; text-transform: uppercase; color: var(--card-muted);
  border: 1px solid currentColor; border-radius: var(--radius-full); padding: 3px 7px; opacity: 0.85; }
/* store pill sits directly on the projects band — adapt to band fg so it's
   visible in BOTH themes (the other pass-soon lives on an always-dark card) */
#store .pass-soon { color: var(--proj-fg); background: rgba(127,127,127,0.16); }
.pass-soon { display: inline-flex; align-items: center; gap: 8px; background: rgba(255,255,255,0.1); color: #fff; font: var(--w-semi) 12px/1 var(--font-text); letter-spacing: 1px; text-transform: uppercase; padding: 9px 14px; border-radius: var(--radius-full); white-space: nowrap; }
.pass-soon .dot { width: 7px; height: 7px; border-radius: var(--radius-full); background: var(--volt); box-shadow: 0 0 0 0 rgba(222,255,32,0.6); animation: soonPulse 1.8s ease-out infinite; }
@keyframes soonPulse { 0% { box-shadow: 0 0 0 0 rgba(222,255,32,0.55); } 70% { box-shadow: 0 0 0 7px rgba(222,255,32,0); } 100% { box-shadow: 0 0 0 0 rgba(222,255,32,0); } }
@media (prefers-reduced-motion: reduce) { .pass-soon .dot { animation: none; } }
.tier__tba { display: inline-flex; align-items: center; gap: 8px; color: var(--pass-gold-mid); font: var(--w-semi) 14px/1 var(--font-text); letter-spacing: 0.3px; padding: 6px 0 2px; }

/* waitlist */
.waitlist { margin-top: var(--space-xl); padding-top: var(--space-xl); border-top: 1px solid var(--hairline-dark); display: flex; align-items: center; justify-content: space-between; gap: var(--space-xl); flex-wrap: wrap; }
.waitlist__copy h3 { margin: 0 0 6px; font: var(--w-semi) 22px/1.2 var(--font-display); color: #fff; }
.waitlist__copy p { margin: 0; color: var(--body-dark); font: var(--w-reg) 16px/1.5 var(--font-text); max-width: 460px; }
.waitlist__form { display: flex; gap: var(--space-sm); flex: none; }
.waitlist__form .st-input { background: var(--surface-dark-card); border-color: var(--hairline-dark); color: #fff; width: 240px; }
.waitlist__form .st-input::placeholder { color: var(--on-dark-mute); opacity: 1; }
.waitlist__ok { margin: var(--space-md) 0 0; color: var(--volt); font: var(--w-med) 15px/1.5 var(--font-text); display: none; }
.waitlist__ok.show { display: block; }

/* ---- RATINGS -------------------------------------------------------------- */
.rating-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 360px)); gap: var(--space-lg); justify-content: center; }
.rcard { background: var(--card-surface); color: var(--card-title); border-radius: var(--radius-md); overflow: hidden; display: flex; flex-direction: column; }
.rcard__media { position: relative; aspect-ratio: 16 / 10; overflow: hidden; }
.rcard__media img { width: 100%; height: 100%; object-fit: cover; }
.rcard__media::after { content: ""; position: absolute; inset: 0; background: linear-gradient(180deg, rgba(0,0,0,0) 45%, rgba(0,0,0,0.7) 100%); }
.rcard__name { position: absolute; left: var(--space-md); bottom: var(--space-sm); z-index: 2; font-family: var(--font-title); font-weight: 700; text-transform: uppercase; color: #fff; font-size: 17px; letter-spacing: 0.3px; line-height: 1; }
.rcard__row { display: flex; align-items: center; gap: var(--space-sm); padding: var(--space-md) var(--space-lg) 0; }
.rcard__score { font: var(--w-light) 22px/1 var(--font-display); color: var(--card-title); }
.rcard__meta { padding: 6px var(--space-lg) var(--space-lg); color: var(--card-muted); font: var(--w-reg) 13px/1.4 var(--font-text); }

/* star meter */
.stars { position: relative; display: inline-flex; line-height: 0; }
.stars__base, .stars__fill { display: inline-flex; gap: 2px; }
.stars__base { color: var(--ash-light); }
[data-theme="dark"] .stars__base { color: var(--hairline-dark); }
.stars__fill { position: absolute; top: 0; left: 0; overflow: hidden; white-space: nowrap; color: var(--pass-gold-mid); }
.stars svg { width: 16px; height: 16px; flex: none; }

/* ---- TESTIMONIALS --------------------------------------------------------- */
.quote-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--space-lg); }
.quote { margin: 0; background: var(--pcard-bg); color: var(--proj-fg); border-radius: var(--radius-md); padding: var(--space-xl); display: flex; flex-direction: column; gap: var(--space-md); }
.quote__stars { display: inline-flex; gap: 2px; color: var(--pass-gold-mid); line-height: 0; }
.quote__stars svg { width: 16px; height: 16px; }
.quote blockquote { margin: 0; font: var(--w-light) 20px/1.4 var(--font-display); color: var(--proj-fg); letter-spacing: 0.1px; text-wrap: pretty; }
.quote figcaption { margin-top: auto; display: flex; flex-direction: column; gap: 2px; }
.quote__name { font: var(--w-semi) 15px/1.3 var(--font-text); color: var(--proj-fg); }
.quote__role { font: var(--w-reg) 13px/1.3 var(--font-text); color: var(--pcard-meta); }

/* ---- BACKERS (founding-backer appeal) ------------------------------------ */
.backers-grid { display: grid; grid-template-columns: 1.1fr 0.9fr; gap: var(--space-section); align-items: start; }
.backer-copy__head { margin: 0 0 var(--space-lg); color: var(--proj-fg); }
.backer-copy p { margin: 0 0 var(--space-md); color: var(--pcard-blurb); font: var(--w-reg) 18px/1.65 var(--font-text); max-width: 540px; }
.backer-copy p strong { color: var(--proj-fg); font-weight: var(--w-semi); }
.backer-stats { display: flex; flex-wrap: wrap; gap: var(--space-xl); margin-top: var(--space-lg); padding-top: var(--space-lg); border-top: 1px solid var(--ash-light); }
[data-theme="dark"] .backer-stats { border-top-color: var(--hairline-dark); }
.backer-stat .n { display: block; font: var(--w-light) 44px/1 var(--font-display); color: var(--strafe-blue); }
.backer-stat .l { display: block; margin-top: 6px; font: var(--w-reg) 14px/1.45 var(--font-text); color: var(--pcard-meta); max-width: 200px; }

.backer-card { background: var(--surface-dark-elevated); color: #fff; border-radius: var(--radius-md); overflow: hidden; }
.backer-card__bar { height: 6px; background: var(--signal-orange); }
.backer-card__inner { padding: var(--space-xxl); }
.backer-card__eyebrow { font: var(--w-semi) 11px/1 var(--font-text); letter-spacing: 1.4px; text-transform: uppercase; color: var(--signal-orange); margin-bottom: var(--space-md); }
.backer-card h3 { margin: 0 0 var(--space-sm); font: var(--w-light) 28px/1.2 var(--font-display); color: #fff; letter-spacing: 0.1px; }
.backer-card__sub { margin: 0 0 var(--space-lg); color: var(--body-dark); font: var(--w-reg) 16px/1.55 var(--font-text); }
.backer-perks { list-style: none; margin: 0 0 var(--space-xl); padding: 0; display: flex; flex-direction: column; gap: var(--space-sm); }
.backer-perks li { display: flex; gap: var(--space-sm); align-items: flex-start; color: var(--body-dark); font: var(--w-reg) 16px/1.45 var(--font-text); }
.backer-perks svg { color: var(--signal-orange); flex: none; margin-top: 1px; }

/* ---- REVIEWS carousel extras --------------------------------------------- */
#ratings .feature { box-shadow: inset 0 0 0 1px rgba(0,0,0,0.08); }
[data-theme="dark"] #ratings .feature { box-shadow: inset 0 0 0 1px var(--hairline-dark); }
.rev-rating { display: flex; align-items: center; gap: var(--space-md); flex-wrap: wrap; }
.rev-rating__score { font: var(--w-light) 26px/1 var(--font-display); color: var(--card-title); }
.rev-rating__count { font: var(--w-med) 13px/1.4 var(--font-mono); color: var(--card-muted); }
.rev-concept { display: flex; flex-direction: column; gap: var(--space-sm); }
.rev-concept__tag { display: inline-flex; align-items: center; gap: 8px; font: var(--w-semi) 12px/1 var(--font-text); letter-spacing: 1.5px; text-transform: uppercase; color: var(--volt-ink, #8a9e00); }
[data-theme="dark"] .rev-concept__tag { color: var(--volt); }
.rev-concept__copy { margin: 0; color: var(--card-body); font: var(--w-reg) 16px/1.5 var(--font-text); }
.rev-form { display: flex; gap: var(--space-sm); margin-top: 2px; }
.rev-form .st-input { flex: 1; min-width: 0; font-family: var(--font-text); }
.rev-form .st-btn { flex: none; }
.rev-form__ok { display: none; margin: var(--space-sm) 0 0; color: var(--strafe-blue); font: var(--w-med) 14px/1.4 var(--font-text); }
.rev-form__ok.show { display: block; }

/* ---- REVIEWS infinite marquee -------------------------------------------- */
.reviews-marquee { position: relative; overflow: hidden; width: 100%; margin-top: var(--space-xxl);
  -webkit-mask-image: linear-gradient(90deg, transparent 0, #000 8%, #000 92%, transparent 100%);
          mask-image: linear-gradient(90deg, transparent 0, #000 8%, #000 92%, transparent 100%); }
.reviews-track { display: flex; gap: var(--space-lg); width: max-content; will-change: transform;
  animation: reviews-scroll 80s linear infinite; }
.reviews-marquee:hover .reviews-track { animation-play-state: paused; }
@keyframes reviews-scroll { from { transform: translateX(0); } to { transform: translateX(-50%); } }
@media (prefers-reduced-motion: reduce) {
  .reviews-track { animation: none; flex-wrap: nowrap; overflow-x: auto; scroll-snap-type: x mandatory; padding-bottom: var(--space-sm); }
  .rcard-review { scroll-snap-align: start; }
}

.rcard-review { flex: 0 0 360px; box-sizing: border-box; background: var(--pcard-bg);
  border-radius: var(--radius-md); padding: var(--space-xl);
  box-shadow: inset 0 0 0 1px var(--hairline-dark);
  display: flex; flex-direction: column; gap: var(--space-md); }
[data-theme="light"] .rcard-review { box-shadow: inset 0 0 0 1px rgba(0,0,0,0.08); }
.rcard-review__top { display: flex; align-items: center; justify-content: space-between; gap: var(--space-md); }
.rcard-review__game { font: var(--w-bold) 12px/1 var(--font-text); letter-spacing: 1.4px; text-transform: uppercase; color: var(--strafe-blue); }
.rcard-review blockquote { margin: 0; color: var(--pcard-blurb); font: var(--w-reg) 17px/1.55 var(--font-text); flex: 1; }
.rcard-review figcaption { display: flex; flex-direction: column; gap: 2px; }
.rcard-review__name { font: var(--w-semi) 15px/1.3 var(--font-text); color: var(--card-title); }
.rcard-review__role { font: var(--w-reg) 13px/1.3 var(--font-text); color: var(--pcard-meta); }
.rcard-review .stars { width: 92px; }
.backer-card .st-btn { width: 100%; justify-content: center; }
.backer-card__note { margin: var(--space-md) 0 0; text-align: center; color: var(--on-dark-mute); font: var(--w-reg) 13px/1.4 var(--font-text); }

@media (max-width: 920px) {
  .backers-grid { grid-template-columns: 1fr; gap: var(--space-xxl); }
}

@media (max-width: 920px) {
  .rating-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .quote-grid { grid-template-columns: 1fr; }
  .waitlist { gap: var(--space-lg); }
  .waitlist__form { width: 100%; }
  .waitlist__form .st-input { flex: 1; width: auto; }
}
@media (max-width: 560px) {
  .rating-grid { grid-template-columns: minmax(0, 360px); }
}

/* ---- TRAILER MODAL -------------------------------------------------------- */
.modal { position: fixed; inset: 0; z-index: 200; display: none; align-items: center; justify-content: center; padding: var(--space-xl); }
.modal.open { display: flex; }
.modal__backdrop { position: absolute; inset: 0; background: rgba(0,0,0,0.82); }
.modal__dialog { position: relative; z-index: 1; width: min(960px, 100%); }
.modal__frame { position: relative; aspect-ratio: 16 / 9; background: #000; border-radius: var(--radius-md); overflow: hidden; box-shadow: var(--shadow-press); }
.modal__frame img { width: 100%; height: 100%; object-fit: cover; opacity: 0.45; }
.modal__frame iframe { position: absolute; inset: 0; width: 100%; height: 100%; border: 0; }
.modal__play { position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); width: 76px; height: 76px; border-radius: var(--radius-full); background: rgba(255,255,255,0.16); box-shadow: inset 0 0 0 1px rgba(255,255,255,0.4); display: flex; align-items: center; justify-content: center; color: #fff; }
.modal__cap { position: absolute; left: var(--space-lg); bottom: var(--space-lg); z-index: 2; color: #fff; }
.modal__cap .t { font-family: var(--font-title); font-weight: 800; text-transform: uppercase; font-size: 22px; letter-spacing: 0.5px; }
.modal__cap .s { display: block; margin-top: 4px; font: var(--w-reg) 14px/1.4 var(--font-text); color: rgba(255,255,255,0.7); }
.modal__close { position: absolute; top: -14px; right: -14px; width: 40px; height: 40px; border-radius: var(--radius-full); border: 0; cursor: pointer; background: #fff; color: #000; display: inline-flex; align-items: center; justify-content: center; box-shadow: var(--shadow-press); }
@media (max-width: 560px) { .modal__close { top: 8px; right: 8px; } }

/* ---- RESPONSIVE ----------------------------------------------------------- */
@media (max-width: 920px) {
  .store-grid { grid-template-columns: 1fr; gap: var(--space-xxl); }
  .tiers { grid-template-columns: 1fr; }
  .lib-row { grid-template-columns: repeat(2, 1fr); }
  .ghero { min-height: 560px; }
  .ghero__inner { min-height: 560px; }
}
@media (max-width: 680px) {
  .store-cards { grid-template-columns: 1fr; }
  .pass-card__inner { padding: var(--space-xl); }
  .pass-head { gap: var(--space-lg); }
}
