/* ── Page-level styles & motion for the Playseer marketing site ── */

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; background: var(--bg-0); }
body { overflow-x: hidden; }
a { color: inherit; text-decoration: none; }
button { font-family: inherit; }
img { display: block; }
input, textarea { font-family: var(--font-body); }

/* Smooth scroll for anchor jumps */
html { scroll-behavior: smooth; }

/* ── Aurora drift (used in hero + CTA washes) ── */
@keyframes ps-aurora-drift {
  0%   { transform: translate3d(0,0,0)    scale(1.0); }
  50%  { transform: translate3d(-2%, 1%, 0) scale(1.06); }
  100% { transform: translate3d(0,0,0)    scale(1.0); }
}

/* ── Subtle CTA glow pulse ── */
@keyframes ps-glow-pulse {
  0%, 100% { box-shadow: 0 0 28px rgba(138,63,252,0.45), 0 0 60px rgba(0,212,255,0.18); }
  50%      { box-shadow: 0 0 40px rgba(138,63,252,0.65), 0 0 96px rgba(0,212,255,0.28); }
}
@keyframes ps-glow-pulse-cyan {
  0%, 100% { box-shadow: 0 0 24px rgba(0,212,255,0.35), 0 0 56px rgba(0,212,255,0.12); }
  50%      { box-shadow: 0 0 36px rgba(0,212,255,0.55), 0 0 88px rgba(0,212,255,0.20); }
}

/* ── Orbit ring rotation (used on icon mark badges) ── */
@keyframes ps-orbit {
  0%   { transform: rotate(0deg); }
  100% { transform: rotate(360deg); }
}

/* ── Gradient edge sweep for marquee row ── */
@keyframes ps-marquee {
  0%   { transform: translateX(0); }
  100% { transform: translateX(-50%); }
}

/* ── Reveal in (fade + slight rise) ── */
@keyframes ps-reveal {
  from { opacity: 0; transform: translateY(14px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* ── Shared utility classes ── */
.ps-reveal { animation: ps-reveal 700ms var(--ease-out) both; }
.ps-cta-primary {
  font-family: var(--font-display); font-size: 15px; font-weight: 500;
  letter-spacing: 0.04em; padding: 16px 30px; border-radius: 999px;
  border: 0; color: #0A0C14; cursor: pointer;
  background: var(--ps-gradient);
  animation: ps-glow-pulse 3.6s var(--ease-in-out) infinite;
  transition: transform 200ms var(--ease-out), filter 200ms var(--ease-out);
}
.ps-cta-primary:hover { transform: translateY(-1px); filter: brightness(1.08); }
.ps-cta-primary:active { transform: scale(0.97); filter: brightness(0.92); }

.ps-cta-secondary {
  font-family: var(--font-display); font-size: 15px; font-weight: 500;
  letter-spacing: 0.04em; padding: 16px 28px; border-radius: 999px;
  background: rgba(255,255,255,0.04);
  color: var(--fg-1);
  border: 1px solid rgba(255,255,255,0.14);
  cursor: pointer;
  transition: all 200ms var(--ease-out);
}
.ps-cta-secondary:hover {
  border-color: rgba(0,212,255,0.55);
  background: rgba(0,212,255,0.06);
  transform: translateY(-1px);
}

/* ── Input field (used in signup cards) ── */
.ps-input {
  width: 100%;
  background: rgba(10,12,20,0.55);
  color: var(--fg-1);
  border: 1px solid rgba(255,255,255,0.10);
  border-radius: 10px;
  padding: 13px 16px;
  font-size: 14px;
  outline: none;
  transition: border-color 180ms var(--ease-out), box-shadow 180ms var(--ease-out);
}
.ps-input::placeholder { color: var(--fg-3); }
.ps-input:focus {
  border-color: rgba(0,212,255,0.55);
  box-shadow: 0 0 0 3px rgba(0,212,255,0.18);
}

/* ── Eyebrow ── */
.ps-eyebrow {
  font-family: var(--font-display);
  font-size: 12px;
  font-weight: 500;
  letter-spacing: 0.24em;
  text-transform: uppercase;
  color: var(--fg-3);
}

/* ── Mono micro-label (e.g. "// LIVE COHORT 24.2") ── */
.ps-mono {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.14em;
  color: var(--fg-2);
}

/* ── Hairline gradient rule ── */
.ps-rule {
  height: 1px; border: 0;
  background: var(--ps-gradient);
  opacity: 0.55;
}

/* ── Section spacing ── */
.ps-section { max-width: 1240px; margin: 0 auto; padding: 0 32px; }

/* ── Card base ── */
.ps-card {
  background: var(--bg-2);
  border: 1px solid var(--border-1);
  border-radius: 18px;
  position: relative;
  overflow: hidden;
  transition: transform 240ms var(--ease-out), border-color 240ms var(--ease-out);
}
.ps-card:hover { transform: translateY(-2px); }

/* ── Showcase frame ── */
.ps-frame {
  position: relative;
  border-radius: 24px;
  overflow: hidden;
  border: 1px solid rgba(138,63,252,0.30);
  box-shadow: 0 0 56px rgba(138,63,252,0.20), 0 0 120px rgba(0,212,255,0.12);
}

/* ── Floating HUD chip (e.g. over images) ── */
.ps-hud-chip {
  position: absolute;
  background: rgba(10,12,20,0.6);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border: 1px solid rgba(255,255,255,0.10);
  border-radius: 10px;
  padding: 10px 14px;
  display: flex; align-items: center; gap: 10px;
  color: var(--fg-1); font-size: 12px;
}
.ps-hud-chip .dot {
  width: 7px; height: 7px; border-radius: 999px;
  background: var(--ps-cyan);
  box-shadow: 0 0 10px var(--ps-cyan);
  animation: ps-pulse-dot 1.6s infinite;
}
@keyframes ps-pulse-dot {
  0%, 100% { opacity: 1; }
  50%      { opacity: 0.35; }
}

/* ── Scroll reveal (armed by site-motion.js) ── */
@media (prefers-reduced-motion: no-preference) {
  .ps-sr.ps-sr-armed {
    opacity: 0;
    transform: translateY(22px);
    transition: opacity 700ms var(--ease-out) var(--sr-delay, 0ms),
                transform 700ms var(--ease-out) var(--sr-delay, 0ms);
  }
  .ps-sr.ps-sr-armed.ps-sr-in {
    opacity: 1;
    transform: translateY(0);
  }
}

/* ── Hide scrollbars on marquee ── */
.ps-no-scrollbar::-webkit-scrollbar { display: none; }
.ps-no-scrollbar { scrollbar-width: none; }

/* ── Responsive breakpoints (very light) ── */
@media (max-width: 900px) {
  .ps-hero-grid { grid-template-columns: 1fr !important; }
  .ps-signup-grid { grid-template-columns: 1fr !important; }
  .ps-feature-grid { grid-template-columns: 1fr !important; }
  .ps-triptych { grid-template-columns: 1fr !important; }
  .ps-h-display { font-size: 64px !important; }
  .ps-section { padding: 0 20px !important; }
}
