/* ============================================
   Brava Landing Page
   Mobile-first. Conversion-focused. Same design system.
   ============================================ */

@import url('tokens.css');

/* --- Drawer Design Tokens --- */
:root {
  --drawer-width: 280px;
  --drawer-bg: var(--color-surface);
  --scrim-opacity: 0.5;
  --drawer-animation-duration: 300ms;
  --hamburger-animation-duration: 200ms;
  --radius-pill: 999px;
}

/* --- Reset --- */
*, *::before, *::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

html {
  font-size: var(--text-body-size);
  -webkit-text-size-adjust: 100%;
}

img, video {
  max-width: 100%;
  height: auto;
  display: block;
}

/* --- Focus --- */
:focus-visible {
  outline: var(--border-outline-volt);
  outline-offset: var(--space-xs);
}

/* --- Base --- */
body {
  background-color: var(--color-base);
  color: var(--color-warm-white);
  font-family: var(--font-body);
  font-weight: var(--text-body-weight);
  line-height: var(--text-body-line-height);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

a {
  color: inherit;
  text-decoration: none;
}

/* ============================================
   Top Navigation
   ============================================ */
.topnav {
  position: fixed;
  top: var(--space-sm);
  left: 50%;
  transform: translateX(-50%);
  width: calc(100% - 2 * var(--space-sm));
  max-width: var(--max-width);
  z-index: 100;
  background-color: rgba(13, 13, 15, 0.55);
  backdrop-filter: blur(18px) saturate(160%);
  -webkit-backdrop-filter: blur(18px) saturate(160%);
  border: 1px solid rgba(245, 240, 232, 0.1);
  border-radius: 0;
  box-shadow: 0 10px 30px rgba(0, 0, 0, 0.35), inset 0 1px 0 rgba(245, 240, 232, 0.06);
  transition: border-bottom-color var(--drawer-animation-duration) ease;
}

/* When drawer is open, topnav keeps its chrome — the dropdown grows
   from it rather than replacing it. The header background, opacity and
   color stay exactly as they are when closed (no "stage" darkening).
   Drop the bottom border so the panel feels contiguous, and drop the
   downward drop-shadow: the panel is semi-transparent, so that shadow
   would otherwise bleed through the top of the panel as a dark seam. */
.nav-drawer--open .topnav {
  border-bottom-color: transparent;
  border-bottom-left-radius: 0;
  border-bottom-right-radius: 0;
  box-shadow: inset 0 1px 0 rgba(245, 240, 232, 0.06);
}

/* Body scroll lock — prevents perceived accordion / scroll bleed-through
   while the drawer is open. */
body.nav-drawer--open {
  overflow: hidden;
}

.topnav__inner {
  padding: 0.85rem 0.85rem 0.85rem var(--space-lg);
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.topnav__brand {
  font-family: var(--brand-font);
  font-weight: var(--brand-weight);
  font-style: var(--brand-style);
  font-size: 1.35rem;
  text-transform: var(--brand-transform);
  letter-spacing: var(--brand-tracking);
  color: var(--color-warm-white);
}

.topnav__brand img,
.footer__wordmark img {
  display: block;
  height: 22px;
  width: auto;
}

.footer__wordmark img {
  margin: 0 auto;
}

.topnav__links {
  display: flex;
  align-items: center;
  gap: var(--space-lg);
}

.topnav__link {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 0.9rem;
  line-height: 1;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--color-mid-gray);
  padding: 0.55rem 0;
  transition: color 0.2s ease;
}

.topnav__link:hover {
  color: var(--color-warm-white);
}

.topnav__cta {
  color: var(--color-base) !important;
  background-color: var(--color-volt);
  padding: 0.4rem 1.1rem;
  transition: background-color 0.2s ease, transform 0.15s ease;
}

.topnav__cta:hover {
  background-color: #d4ff33;
  transform: translateY(-1px);
}

.topnav__cta:active {
  transform: translateY(0);
}

.topnav__link--active {
  color: var(--color-warm-white);
}

/* --- Mobile Navigation (Dropdown from Header) --- */
/* Hidden by default for progressive enhancement (FR-016) */
.nav-drawer {
  display: none;
}

/* Show mobile nav only when JS is enabled AND on mobile viewport (FR-017) */
@media (max-width: 767px) {
  .js-nav-enhanced .nav-drawer {
    display: block;
  }

  /* Hide horizontal links on mobile when JS enabled */
  .js-nav-enhanced .topnav__links {
    display: none;
  }
}

/* Light scrim behind dropdown — just enough to dim the page content
   without feeling like a full-page takeover. */
.nav-drawer__scrim {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  width: 100%;
  height: 100vh;
  background-color: rgba(13, 13, 15, 0.5);
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  z-index: 90;
  transition: opacity var(--drawer-animation-duration) ease-out, visibility var(--drawer-animation-duration);
}

/* Dropdown panel — grows from the bottom edge of the topnav, sized
   to its content.  Same glass material as the header so it reads as
   one continuous surface. */
.nav-drawer__panel {
  position: fixed;
  /* Top edge must sit exactly on the topnav's bottom edge or the panel's
     glass paints a hard line across the header. Derivation (mobile):
     2 x 0.85rem .topnav__inner padding + 48px hamburger (the tallest row
     item) + 2px borders, minus 1px so the surfaces overlap instead of
     leaving a subpixel gap. Update alongside any header sizing change. */
  top: calc(var(--space-sm) + 1.7rem + 49px);
  left: 50%;
  transform: translateX(-50%) translateY(-8px);
  width: calc(100% - 2 * var(--space-sm));
  max-width: var(--max-width);
  /* Same glass as the header (.topnav) — identical color/opacity so the
     two stack into one continuous surface with no seam between them. */
  background-color: rgba(13, 13, 15, 0.55);
  backdrop-filter: blur(18px) saturate(160%);
  -webkit-backdrop-filter: blur(18px) saturate(160%);
  border: 1px solid rgba(245, 240, 232, 0.1);
  border-top: none;
  border-radius: 0 0 12px 12px;
  /* Downward-only shadow. The negative spread pulls the blur below the
     panel's top edge so it can't paint a dark band onto the header at the
     seam (a plain `0 16px 40px` bleeds ~24px upward over the topnav). */
  box-shadow: 0 20px 30px -12px rgba(0, 0, 0, 0.5);
  opacity: 0;
  transition: transform var(--drawer-animation-duration) ease-out, opacity var(--drawer-animation-duration) ease-out;
  z-index: 160;
  display: flex;
  flex-direction: column;
  padding: var(--space-md);
  pointer-events: none;
}

/* Dropdown open state */
.nav-drawer--open .nav-drawer__scrim {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
}

.nav-drawer--open .nav-drawer__panel {
  transform: translateX(-50%) translateY(0);
  opacity: 1;
  pointer-events: auto;
}

/* Hamburger button */
.nav-drawer__toggle {
  display: none;
  width: 48px;
  height: 48px;
  padding: 12px;
  background: transparent;
  border: none;
  cursor: pointer;
  position: relative;
  z-index: 170;
}

/* Show hamburger only on mobile with JS enabled */
@media (max-width: 767px) {
  .js-nav-enhanced .nav-drawer__toggle {
    display: flex;
    align-items: center;
    justify-content: center;
  }
}

/* Hamburger icon (3 lines) */
.hamburger-icon {
  width: 24px;
  height: 24px;
  position: relative;
}

.hamburger-icon__line {
  display: block;
  position: absolute;
  width: 24px;
  height: 2px;
  background-color: var(--color-warm-white);
  transition: transform var(--hamburger-animation-duration) ease, opacity var(--hamburger-animation-duration) ease;
}

.hamburger-icon__line:nth-child(1) { top: 4px; }
.hamburger-icon__line:nth-child(2) { top: 11px; }
.hamburger-icon__line:nth-child(3) { bottom: 4px; }

/* Hamburger to X animation */
.nav-drawer--open .hamburger-icon__line:nth-child(1) {
  transform: translateY(7px) rotate(45deg);
}

.nav-drawer--open .hamburger-icon__line:nth-child(2) {
  opacity: 0;
}

.nav-drawer--open .hamburger-icon__line:nth-child(3) {
  transform: translateY(-7px) rotate(-45deg);
}

/* Dropdown navigation links */
.nav-drawer__nav {
  display: flex;
  flex-direction: column;
  gap: var(--space-xs);
}

.nav-drawer__link {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 0.95rem;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--color-mid-gray);
  padding: 0.75rem var(--space-sm);
  min-height: 44px;
  display: flex;
  align-items: center;
  transition: color 0.2s ease, background-color 0.2s ease;
  border-radius: 4px;
}

.nav-drawer__link:hover {
  color: var(--color-warm-white);
  background-color: rgba(245, 240, 232, 0.05);
}

.nav-drawer__link.is-active {
  color: var(--color-volt);
}

/* Dropdown CTA */
.nav-drawer__cta {
  margin-top: var(--space-xs);
  padding-top: var(--space-sm);
  padding-bottom: env(safe-area-inset-bottom, 0);
  border-top: 1px solid rgba(245, 240, 232, 0.1);
}

/* Reduced motion preference */
@media (prefers-reduced-motion: reduce) {
  .nav-drawer__panel,
  .nav-drawer__scrim,
  .hamburger-icon__line {
    transition: none;
  }
}

/* ============================================
   Pricing Hero
   ============================================ */
.pricing-hero {
  text-align: center;
  padding: var(--space-3xl) var(--space-md) var(--space-2xl);
}

.pricing-hero__eyebrow {
  font-family: var(--font-display);
  font-weight: var(--text-hero-eyebrow-weight);
  font-size: var(--text-hero-eyebrow-size);
  text-transform: var(--text-hero-eyebrow-transform);
  letter-spacing: var(--text-hero-eyebrow-tracking);
  color: var(--color-volt);
  margin-bottom: var(--space-md);
}

.pricing-hero__price {
  font-family: var(--font-display);
  font-weight: 800;
  font-size: clamp(4rem, 15vw, 8rem);
  text-transform: uppercase;
  letter-spacing: -0.02em;
  line-height: 1;
  color: var(--color-warm-white);
  margin-bottom: var(--space-sm);
}

.pricing-hero__subtitle {
  font-family: var(--font-body);
  font-weight: var(--text-hero-sub-weight);
  font-size: var(--text-hero-sub-size);
  color: var(--color-mid-gray);
  line-height: var(--text-hero-sub-line-height);
  margin-bottom: var(--space-xl);
}

.pricing-hero__ctas {
  display: flex;
  justify-content: center;
}

.pricing-hero__cta {
  display: inline-block;
  font-family: var(--font-display);
  font-weight: var(--text-cta-btn-weight);
  font-size: var(--text-cta-btn-size);
  text-transform: var(--text-cta-btn-transform);
  letter-spacing: var(--text-cta-btn-tracking);
  color: var(--color-base);
  background-color: var(--color-volt);
  padding: var(--btn-padding);
  border: none;
  transition: background-color var(--transition-base), transform var(--transition-fast);
}

.pricing-hero__cta:hover {
  background-color: var(--color-volt-hover);
  transform: translateY(-1px);
}

.pricing-hero__cta:active {
  transform: translateY(0);
}

/* ============================================
   Inclusions
   ============================================ */
.inclusions {
  padding: var(--space-2xl) var(--space-md);
  max-width: var(--max-width-content);
  margin: 0 auto;
  border-top: var(--border-divider-surface);
}

.inclusions__heading {
  font-family: var(--font-display);
  font-weight: var(--text-showcase-heading-weight);
  font-size: var(--text-showcase-heading-size);
  text-transform: var(--text-showcase-heading-transform);
  line-height: var(--text-showcase-heading-line-height);
  color: var(--color-warm-white);
  text-align: center;
  margin-bottom: var(--space-xl);
}

.inclusions__list {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: var(--space-md);
}

.inclusions__item {
  font-size: var(--text-showcase-body-size);
  line-height: var(--text-showcase-body-line-height);
  color: var(--color-warm-white);
  padding-left: 1.5rem;
  position: relative;
}

.inclusions__item::before {
  content: '✓';
  position: absolute;
  left: 0;
  color: var(--color-volt);
  font-weight: 700;
}

/* ============================================
   Value Context
   ============================================ */
.value-context {
  padding: var(--space-xl) var(--space-md) var(--space-2xl);
  max-width: var(--max-width-content);
  margin: 0 auto;
}

.value-context__body {
  font-size: var(--text-showcase-body-size);
  line-height: var(--text-showcase-body-line-height);
  color: var(--color-mid-gray);
  text-align: center;
}

/* ============================================
   Add-ons
   ============================================ */
.addons {
  padding: var(--space-2xl) var(--space-md);
  max-width: var(--max-width);
  margin: 0 auto;
  border-top: var(--border-divider-surface);
}

.addons__heading {
  font-family: var(--font-display);
  font-weight: var(--text-process-heading-weight);
  font-size: var(--text-process-heading-size);
  text-transform: var(--text-process-heading-transform);
  text-align: center;
  color: var(--color-warm-white);
  margin-bottom: var(--space-2xl);
}

.addons__grid {
  display: grid;
  gap: var(--space-xl);
}

.addons__item {
  background-color: var(--color-surface);
  padding: var(--space-lg);
}

.addons__name {
  font-family: var(--font-display);
  font-weight: var(--text-process-title-weight);
  font-size: var(--text-process-title-size);
  text-transform: var(--text-process-title-transform);
  letter-spacing: var(--text-process-title-tracking);
  color: var(--color-warm-white);
  margin-bottom: var(--space-xs);
}

.addons__price {
  font-family: var(--font-display);
  font-weight: 800;
  font-size: var(--text-proof-stat-size);
  color: var(--color-volt);
  line-height: var(--text-proof-stat-line-height);
  margin-bottom: var(--space-sm);
}

.addons__desc {
  font-size: var(--text-process-desc-size);
  line-height: var(--text-process-desc-line-height);
  color: var(--color-mid-gray);
}

/* ============================================
   Hero
   ============================================ */
.hero {
  position: relative;
  min-height: 90vh;
  display: flex;
  align-items: flex-end;
  justify-content: center;
  padding: var(--space-2xl) var(--space-md) clamp(3rem, 14vh, 6rem);
  overflow: hidden;
  text-align: center;
}

.hero__bg {
  position: absolute;
  inset: 0;
  z-index: var(--z-bg);
}

.hero__bg img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
}

/* Heavy dark overlay — text must read cleanly */
.hero::after {
  content: '';
  position: absolute;
  inset: 0;
  background: var(--hero-gradient-landing);
  z-index: var(--z-overlay);
}

.hero__content {
  position: relative;
  z-index: var(--z-content);
  max-width: var(--max-width-content);
}

.hero__eyebrow {
  font-family: var(--font-display);
  font-weight: var(--text-hero-eyebrow-weight);
  font-size: var(--text-hero-eyebrow-size);
  text-transform: var(--text-hero-eyebrow-transform);
  letter-spacing: var(--text-hero-eyebrow-tracking);
  color: var(--color-volt);
  margin-bottom: var(--space-md);
}

.hero__headline {
  font-family: var(--font-display);
  font-weight: var(--text-hero-headline-weight);
  font-size: var(--text-hero-headline-size);
  text-transform: var(--text-hero-headline-transform);
  line-height: var(--text-hero-headline-line-height);
  letter-spacing: var(--text-hero-headline-tracking);
  color: var(--color-warm-white);
  margin-bottom: var(--space-lg);
}

.hero__sub {
  font-family: var(--font-body);
  font-weight: var(--text-hero-sub-weight);
  font-size: var(--text-hero-sub-size);
  color: var(--color-mid-gray);
  line-height: var(--text-hero-sub-line-height);
  margin-bottom: var(--space-lg);
  max-width: 38ch;
  margin-left: auto;
  margin-right: auto;
}

.hero__ctas {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-md);
}

.hero__cta {
  display: inline-block;
  font-family: var(--font-display);
  font-weight: var(--text-cta-btn-weight);
  font-size: var(--text-cta-btn-size);
  text-transform: var(--text-cta-btn-transform);
  letter-spacing: var(--text-cta-btn-tracking);
  color: var(--color-base);
  background-color: var(--color-volt);
  padding: var(--btn-padding);
  border: none;
  transition: background-color var(--transition-base), transform var(--transition-fast);
}

.hero__cta:hover {
  background-color: var(--color-volt-hover);
  transform: translateY(-1px);
}

.hero__cta:active {
  transform: translateY(0);
}

/* Secondary button variant — outline style */
.btn-secondary {
  background-color: transparent !important;
  border: 1px solid var(--color-volt);
  color: var(--color-volt) !important;
}

.btn-secondary:hover {
  background-color: rgba(200, 255, 0, 0.08) !important;
}

.hero__cta-secondary {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: var(--text-cta-btn-size);
  color: var(--color-mid-gray);
  text-decoration: underline;
  text-underline-offset: 3px;
  transition: color var(--transition-base);
}

.hero__cta-secondary:hover {
  color: var(--color-warm-white);
}

/* ============================================
   Proof Strip
   ============================================ */
.proof {
  padding: var(--space-2xl) var(--space-md);
  border-top: var(--border-divider-surface);
  border-bottom: var(--border-divider-surface);
}

.proof__grid {
  max-width: var(--max-width);
  margin: 0 auto;
  display: grid;
  gap: var(--space-xl);
}

.proof__item {
  text-align: center;
}

.proof__stat {
  font-family: var(--font-display);
  font-weight: var(--text-proof-stat-weight);
  font-size: var(--text-proof-stat-size);
  text-transform: var(--text-proof-stat-transform);
  color: var(--color-warm-white);
  line-height: var(--text-proof-stat-line-height);
  margin-bottom: var(--space-xs);
}

.proof__unit {
  font-weight: var(--text-proof-unit-weight);
  font-size: var(--text-proof-unit-size);
  color: var(--color-volt);
  letter-spacing: var(--text-proof-unit-tracking);
}

.proof__label {
  font-size: var(--text-proof-label-size);
  color: var(--color-mid-gray);
  line-height: var(--text-proof-label-line-height);
  max-width: var(--max-width-proof-label);
  margin: 0 auto;
}

/* ============================================
   Showcase (Profile Mockup)
   ============================================ */
.showcase {
  padding: var(--space-3xl) var(--space-md);
  max-width: var(--max-width);
  margin: 0 auto;
  display: grid;
  gap: var(--space-2xl);
  align-items: center;
  background: var(--showcase-gradient);
}

.showcase__heading {
  font-family: var(--font-display);
  font-weight: var(--text-showcase-heading-weight);
  font-size: var(--text-showcase-heading-size);
  text-transform: var(--text-showcase-heading-transform);
  line-height: var(--text-showcase-heading-line-height);
  color: var(--color-warm-white);
  margin-bottom: var(--space-lg);
}

.showcase__body {
  font-size: var(--text-showcase-body-size);
  line-height: var(--text-showcase-body-line-height);
  color: var(--color-mid-gray);
  margin-bottom: var(--space-md);
}

.showcase__body em {
  color: var(--color-warm-white);
  font-style: normal;
  font-weight: 500;
}

.showcase__cta {
  display: inline-block;
  font-family: var(--font-display);
  font-weight: var(--text-showcase-cta-weight);
  font-size: var(--text-showcase-cta-size);
  text-transform: var(--text-showcase-cta-transform);
  letter-spacing: var(--text-showcase-cta-tracking);
  color: var(--color-volt);
  margin-top: var(--space-md);
  transition: color var(--transition-base);
}

.showcase__cta:hover {
  color: var(--color-volt-hover);
}

.showcase__device {
  display: flex;
  justify-content: center;
}

.showcase__device img {
  max-width: var(--showcase-device-max-width);
  width: 100%;
  height: auto;
}

/* --- Live profile preview: an auto-scrolling phone showing the real
   product (sample athlete). The motion IS the content — the profile
   behaving like the real thing — not decoration. Pauses on hover;
   holds still for prefers-reduced-motion. --- */
.pf-phone {
  --pf-w: 300px;
  --pf-screen-h: 520px;
  position: relative;
  width: var(--pf-w);
  max-width: 100%;
  padding: 12px;
  border-radius: 46px;
  background: linear-gradient(155deg, #2b2b32 0%, #0d0d0f 58%);
  box-shadow:
    inset 0 1px 0 rgba(245, 240, 232, 0.10),
    0 0 0 1px rgba(245, 240, 232, 0.06),
    0 32px 60px -22px rgba(0, 0, 0, 0.8);
}

.pf-notch {
  position: absolute;
  top: 22px;
  left: 50%;
  transform: translateX(-50%);
  width: 92px;
  height: 26px;
  background: #000;
  border-radius: 999px;
  z-index: 3;
}

.pf-screen {
  position: relative;
  height: var(--pf-screen-h);
  border-radius: 36px;
  overflow: hidden;
  background: var(--color-base);
  /* Soft top/bottom edges so content scrolls in and out, not snaps. */
  -webkit-mask-image: linear-gradient(to bottom, transparent 0, #000 6%, #000 94%, transparent 100%);
          mask-image: linear-gradient(to bottom, transparent 0, #000 6%, #000 94%, transparent 100%);
}

.pf-track {
  will-change: transform;
  animation: pf-scroll 20s cubic-bezier(0.45, 0, 0.55, 1) infinite;
}

.pf-phone:hover .pf-track {
  animation-play-state: paused;
}

@keyframes pf-scroll {
  0%, 6%    { transform: translateY(0); }
  48%, 56%  { transform: translateY(calc(-100% + var(--pf-screen-h))); }
  98%, 100% { transform: translateY(0); }
}

/* Profile: hero */
.pf-hero {
  position: relative;
  min-height: 250px;
  padding: 20px 18px;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  background-color: #15151a;
  background-image: image-set(
    url('assets/hero-bg-640w.webp') type('image/webp'),
    url('assets/hero-bg-640w.jpg') type('image/jpeg'));
  background-size: cover;
  background-position: center 28%;
}

.pf-hero::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(to top,
    var(--color-base) 5%,
    rgba(13, 13, 15, 0.55) 46%,
    rgba(13, 13, 15, 0.12) 100%);
}

.pf-hero > * { position: relative; z-index: 1; }

.pf-name {
  font-family: var(--font-display);
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: -0.02em;
  line-height: 0.9;
  font-size: 2.45rem;
  color: var(--color-warm-white);
}

.pf-pos {
  font-family: var(--font-display);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  font-size: 0.82rem;
  color: var(--color-volt);
  margin-top: 9px;
}

.pf-meta {
  font-size: 0.72rem;
  color: var(--color-mid-gray);
  margin-top: 4px;
}

/* Profile: coach verification */
.pf-verify {
  display: flex;
  align-items: center;
  gap: 11px;
  padding: 13px 18px;
  background: rgba(200, 255, 0, 0.05);
  border-bottom: 1px solid var(--color-surface);
}

.pf-check {
  flex: none;
  width: 22px;
  height: 22px;
  border-radius: 50%;
  background: var(--color-volt);
  color: var(--color-base);
  font-size: 12px;
  font-weight: 800;
  display: grid;
  place-items: center;
}

.pf-eyebrow {
  font-family: var(--font-display);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  font-size: 0.6rem;
  color: var(--color-volt);
}

.pf-verify-name {
  font-family: var(--font-display);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.03em;
  font-size: 0.85rem;
  color: var(--color-warm-white);
}

.pf-verify-sub {
  font-size: 0.66rem;
  color: var(--color-mid-gray);
}

/* Profile: stats */
.pf-stats { padding: 4px 18px 6px; }

.pf-stat {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 11px 0;
  border-bottom: 1px solid var(--color-surface);
}

.pf-stat-l {
  font-family: var(--font-display);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  font-size: 0.9rem;
  color: var(--color-warm-white);
}

.pf-stat-ctx {
  display: block;
  font-family: var(--font-body);
  font-weight: 400;
  text-transform: none;
  letter-spacing: 0;
  font-size: 0.62rem;
  color: var(--color-mid-gray);
  margin-top: 1px;
}

.pf-stat-r { text-align: right; }

.pf-stat-v {
  display: block;
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 1.1rem;
  color: var(--color-warm-white);
}

.pf-stat-vf {
  display: block;
  font-size: 0.58rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--color-volt);
  margin-top: 1px;
}

/* Profile: film */
.pf-section-h {
  font-family: var(--font-display);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  font-size: 0.7rem;
  color: var(--color-mid-gray);
  padding: 16px 18px 4px;
}

.pf-clip {
  position: relative;
  height: 98px;
  margin: 8px 18px 0;
  border-radius: 6px;
  overflow: hidden;
  background: linear-gradient(135deg, #232830 0%, #121316 100%);
}

.pf-play {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 38px;
  height: 38px;
  border-radius: 50%;
  background: var(--color-base-70);
  border: 1.5px solid rgba(245, 240, 232, 0.5);
}

.pf-play::after {
  content: '';
  position: absolute;
  top: 50%;
  left: 53%;
  transform: translate(-50%, -50%);
  border-style: solid;
  border-width: 7px 0 7px 11px;
  border-color: transparent transparent transparent var(--color-warm-white);
}

.pf-clip-label {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  padding: 16px 10px 7px;
  font-size: 0.66rem;
  font-weight: 500;
  color: var(--color-warm-white);
  background: linear-gradient(to top, rgba(13, 13, 15, 0.92), transparent);
}

/* Profile: contact footer */
.pf-foot {
  padding: 18px;
  text-align: center;
}

.pf-foot-btn {
  display: block;
  background: var(--color-volt);
  color: var(--color-base);
  font-family: var(--font-display);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  font-size: 0.85rem;
  padding: 11px;
  border-radius: 2px;
}

.pf-foot-sub {
  font-size: 0.66rem;
  color: var(--color-mid-gray);
  margin-top: 8px;
}

@media (prefers-reduced-motion: reduce) {
  .pf-track { animation: none; }
}

/* ============================================
   How It Works
   ============================================ */
.process {
  padding: var(--space-3xl) var(--space-md);
  border-top: var(--border-divider-surface);
}

.process__heading {
  font-family: var(--font-display);
  font-weight: var(--text-process-heading-weight);
  font-size: var(--text-process-heading-size);
  text-transform: var(--text-process-heading-transform);
  text-align: center;
  color: var(--color-warm-white);
  margin-bottom: var(--space-2xl);
  max-width: var(--max-width);
  margin-left: auto;
  margin-right: auto;
}

.process__grid {
  max-width: var(--max-width);
  margin: 0 auto;
  display: grid;
  gap: var(--space-xl);
}

.process__step {
  padding: var(--space-lg);
  border-left: var(--border-accent-surface);
}

.process__number {
  font-family: var(--font-display);
  font-weight: var(--text-process-number-weight);
  font-size: var(--text-process-number-size);
  color: var(--color-volt);
  line-height: var(--text-process-number-line-height);
  margin-bottom: var(--space-sm);
}

.process__title {
  font-family: var(--font-display);
  font-weight: var(--text-process-title-weight);
  font-size: var(--text-process-title-size);
  text-transform: var(--text-process-title-transform);
  letter-spacing: var(--text-process-title-tracking);
  color: var(--color-warm-white);
  margin-bottom: var(--space-sm);
}

.process__desc {
  font-size: var(--text-process-desc-size);
  line-height: var(--text-process-desc-line-height);
  color: var(--color-mid-gray);
}

/* ============================================
   Recruiting Toolkit Section
   ============================================ */
.toolkit {
  padding: var(--space-3xl) var(--space-md);
  border-top: var(--border-divider-surface);
}

.toolkit__heading {
  font-family: var(--font-display);
  font-weight: var(--text-process-heading-weight);
  font-size: var(--text-process-heading-size);
  text-transform: var(--text-process-heading-transform);
  text-align: center;
  color: var(--color-warm-white);
  margin-bottom: var(--space-sm);
  max-width: var(--max-width);
  margin-left: auto;
  margin-right: auto;
}

.toolkit__intro {
  text-align: center;
  color: var(--color-mid-gray);
  font-size: var(--text-process-desc-size);
  line-height: var(--text-process-desc-line-height);
  max-width: 600px;
  margin: 0 auto var(--space-2xl);
}

.toolkit__grid {
  max-width: var(--max-width);
  margin: 0 auto;
  display: grid;
  gap: var(--space-xl);
}

.toolkit__item {
  padding: var(--space-lg);
  border-left: var(--border-accent-surface);
}

.toolkit__media {
  display: block;
  width: 100%;
  height: auto;
  margin-bottom: var(--space-lg);
  border-radius: var(--radius-sm);
}

.toolkit__title {
  font-family: var(--font-display);
  font-weight: var(--text-process-title-weight);
  font-size: var(--text-process-title-size);
  text-transform: var(--text-process-title-transform);
  letter-spacing: var(--text-process-title-tracking);
  color: var(--color-warm-white);
  margin-bottom: var(--space-sm);
}

.toolkit__desc {
  font-size: var(--text-process-desc-size);
  line-height: var(--text-process-desc-line-height);
  color: var(--color-mid-gray);
}

/* ============================================
   CTA Section
   ============================================ */
.cta-section {
  padding: var(--space-3xl) var(--space-md);
  text-align: center;
  border-top: var(--border-divider-surface);
}

.cta-section__heading {
  font-family: var(--font-display);
  font-weight: var(--text-cta-heading-weight);
  font-size: var(--text-cta-heading-size);
  text-transform: var(--text-cta-heading-transform);
  line-height: var(--text-cta-heading-line-height);
  color: var(--color-warm-white);
  max-width: var(--max-width-content);
  margin: 0 auto var(--space-lg);
}

.cta-section__body {
  font-size: var(--text-cta-body-size);
  line-height: var(--text-cta-body-line-height);
  color: var(--color-mid-gray);
  max-width: var(--max-width-cta-body);
  margin: 0 auto var(--space-xl);
}

.cta-section__btn {
  display: inline-block;
  font-family: var(--font-display);
  font-weight: var(--text-cta-btn-weight);
  font-size: var(--text-cta-btn-size-lg);
  text-transform: var(--text-cta-btn-transform);
  letter-spacing: var(--text-cta-btn-tracking);
  color: var(--color-base);
  background-color: var(--color-volt);
  padding: var(--btn-padding-lg);
  border: none;
  transition: background-color var(--transition-base), transform var(--transition-fast);
}

.cta-section__btn:hover {
  background-color: var(--color-volt-hover);
  transform: translateY(-1px);
}

.cta-section__btn:active {
  transform: translateY(0);
}

.cta-section__footnote {
  font-size: var(--text-cta-footnote-size);
  color: var(--color-mid-gray);
  margin-top: var(--space-lg);
}

.cta-section__footnote a {
  color: var(--color-cyan);
  text-decoration: none;
}

.cta-section__footnote a:hover {
  text-decoration: underline;
}

/* ============================================
   Footer
   ============================================ */
.footer {
  padding: var(--space-2xl) var(--space-md) var(--space-xl);
  text-align: center;
  border-top: var(--border-divider-surface);
}

.footer__mark {
  margin-bottom: var(--space-sm);
}

.footer__wordmark {
  display: block;
  font-family: var(--brand-font);
  font-weight: var(--brand-weight);
  font-style: var(--brand-style);
  font-size: 1.35rem;
  text-transform: var(--brand-transform);
  letter-spacing: var(--brand-tracking);
  color: var(--color-mid-gray);
  opacity: 0.6;
}

.footer__tagline {
  font-family: var(--brand-font);
  font-weight: var(--brand-tagline-weight);
  font-size: var(--brand-tagline-size);
  text-transform: var(--brand-transform);
  letter-spacing: var(--brand-tagline-tracking);
  color: var(--color-mid-gray);
  opacity: 0.6;
}

.footer__updated {
  font-family: var(--font-body);
  font-size: 0.75rem;
  color: var(--color-mid-gray);
  opacity: 0.55;
  margin-top: var(--space-md);
}

/* ============================================
   Recruiting Questions (FAQ) Page
   ============================================ */
.faq-hero {
  padding: var(--space-3xl) var(--space-md) var(--space-2xl);
  max-width: var(--max-width-content);
  margin: 0 auto;
  text-align: center;
}

.faq-hero__eyebrow {
  font-family: var(--font-display);
  font-weight: var(--text-hero-eyebrow-weight);
  font-size: var(--text-hero-eyebrow-size);
  text-transform: var(--text-hero-eyebrow-transform);
  letter-spacing: var(--text-hero-eyebrow-tracking);
  color: var(--color-volt);
  margin-bottom: var(--space-md);
}

.faq-hero__headline {
  font-family: var(--font-display);
  font-weight: var(--text-cta-heading-weight);
  font-size: var(--text-cta-heading-size);
  text-transform: var(--text-cta-heading-transform);
  line-height: var(--text-cta-heading-line-height);
  color: var(--color-warm-white);
  margin-bottom: var(--space-lg);
}

.faq-hero__sub {
  font-family: var(--font-body);
  font-size: var(--text-hero-sub-size);
  font-weight: var(--text-hero-sub-weight);
  line-height: var(--text-hero-sub-line-height);
  color: var(--color-mid-gray);
}

.faq {
  padding: var(--space-xl) var(--space-md) var(--space-2xl);
  max-width: var(--max-width-content);
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  gap: var(--space-xl);
}

.faq__item {
  padding: var(--space-lg) 0 var(--space-lg) var(--space-lg);
  border-left: var(--border-accent-surface);
}

.faq__question {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: clamp(1.15rem, 3.5vw, 1.5rem);
  text-transform: uppercase;
  letter-spacing: 0.01em;
  line-height: 1.2;
  color: var(--color-warm-white);
  margin-bottom: var(--space-md);
}

.faq__answer {
  font-family: var(--font-body);
  font-size: var(--text-showcase-body-size);
  line-height: var(--text-showcase-body-line-height);
  color: var(--color-warm-white);
}

.faq__inline-link {
  display: inline-block;
  margin-top: var(--space-sm);
  font-family: var(--font-display);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  font-size: 0.85rem;
  color: var(--color-volt);
  border-bottom: 1px solid currentColor;
  padding-bottom: 2px;
  transition: color var(--transition-base);
}

.faq__inline-link:hover {
  color: var(--color-volt-hover);
}

/* --- Search bar + jumplinks --- */
.faq-search {
  position: sticky;
  top: 0;
  z-index: 10;
  padding: var(--space-md) var(--space-md) var(--space-md);
  background: linear-gradient(
    to bottom,
    var(--color-base) 0%,
    var(--color-base) 70%,
    var(--color-base-90) 100%
  );
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  border-bottom: var(--border-divider-surface);
}

.faq-search__form {
  position: relative;
  max-width: var(--max-width-content);
  margin: 0 auto;
  display: flex;
  align-items: center;
}

.faq-search__icon {
  position: absolute;
  left: 1rem;
  top: 50%;
  transform: translateY(-50%);
  color: var(--color-mid-gray);
  pointer-events: none;
  display: inline-flex;
}

.faq-search__input {
  width: 100%;
  font-family: var(--font-body);
  font-size: 1rem;
  font-weight: 500;
  color: var(--color-warm-white);
  background-color: var(--color-surface);
  border: 1px solid var(--color-surface);
  border-radius: var(--radius-pill);
  padding: 0.85rem 3rem 0.85rem 3rem;
  outline: none;
  transition: border-color var(--transition-base), background-color var(--transition-base);
  -webkit-appearance: none;
  appearance: none;
}

.faq-search__input::placeholder {
  color: var(--color-mid-gray);
}

.faq-search__input::-webkit-search-cancel-button {
  -webkit-appearance: none;
  appearance: none;
}

.faq-search__input:focus-visible {
  border-color: var(--color-volt);
  outline: none;
}

.faq-search__clear {
  position: absolute;
  right: 0.6rem;
  top: 50%;
  transform: translateY(-50%);
  width: 2rem;
  height: 2rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: transparent;
  border: none;
  border-radius: var(--radius-pill);
  color: var(--color-mid-gray);
  cursor: pointer;
  padding: 0;
  transition: color var(--transition-fast), background-color var(--transition-fast);
}

.faq-search__clear:hover,
.faq-search__clear:focus-visible {
  color: var(--color-warm-white);
  background-color: var(--color-base);
}

.faq-search__count {
  max-width: var(--max-width-content);
  margin: var(--space-sm) auto 0;
  font-family: var(--font-body);
  font-size: 0.85rem;
  color: var(--color-mid-gray);
  text-align: center;
}

.faq-jumplinks {
  max-width: var(--max-width-content);
  margin: var(--space-md) auto 0;
  display: flex;
  flex-wrap: wrap;
  gap: 0.4rem;
  justify-content: center;
}

.faq-jumplink {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  font-family: var(--font-display);
  font-size: 0.72rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--color-warm-white);
  background-color: var(--color-surface);
  border: 1px solid var(--color-surface);
  border-radius: var(--radius-pill);
  padding: 0.4rem 0.8rem;
  transition: color var(--transition-fast), border-color var(--transition-fast), opacity var(--transition-fast);
}

.faq-jumplink__num {
  color: var(--color-volt);
  font-weight: 800;
  letter-spacing: 0.04em;
}

.faq-jumplink:hover,
.faq-jumplink:focus-visible {
  border-color: var(--color-volt);
  color: var(--color-warm-white);
}

.faq-jumplink--empty {
  opacity: 0.3;
  pointer-events: none;
}

/* --- Section grouping (JTBD + anxiety) --- */
.faq__section {
  display: flex;
  flex-direction: column;
  gap: var(--space-xl);
}

.faq__section-header {
  padding: var(--space-lg) 0 var(--space-md);
  border-bottom: var(--border-divider-surface);
  margin-bottom: var(--space-sm);
  scroll-margin-top: 7rem;
}

.faq__section-eyebrow {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 0.78rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--color-volt);
  margin-bottom: var(--space-sm);
}

.faq__section-job {
  font-family: var(--font-display);
  font-weight: 800;
  font-size: clamp(1.3rem, 4vw, 1.85rem);
  text-transform: uppercase;
  line-height: 1.15;
  letter-spacing: 0.01em;
  color: var(--color-warm-white);
  margin-bottom: var(--space-md);
}

.faq__section-anxiety,
.faq__section-help {
  font-family: var(--font-body);
  font-size: 1rem;
  line-height: 1.55;
  color: var(--color-mid-gray);
  margin-bottom: var(--space-xs);
}

.faq__section-anxiety {
  color: var(--color-warm-white);
}

.faq__section-label {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 0.72rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--color-volt);
  margin-right: 0.4rem;
}

/* Questions inside sections are h3 now, but inherit the original h2 styling. */
.faq__section .faq__question {
  font-size: clamp(1.05rem, 3vw, 1.35rem);
}

/* --- No results state --- */
.faq__no-results {
  padding: var(--space-2xl) var(--space-md);
  text-align: center;
  border-top: var(--border-divider-surface);
}

.faq__no-results-headline {
  font-family: var(--font-display);
  font-weight: 800;
  font-size: clamp(1.2rem, 4vw, 1.6rem);
  text-transform: uppercase;
  color: var(--color-warm-white);
  margin-bottom: var(--space-sm);
}

.faq__no-results-body {
  font-family: var(--font-body);
  color: var(--color-mid-gray);
  font-size: 1rem;
  line-height: 1.55;
}

.faq__no-results-body a {
  color: var(--color-volt);
  border-bottom: 1px solid currentColor;
}

.faq__no-results-clear {
  font: inherit;
  color: var(--color-volt);
  background: transparent;
  border: none;
  border-bottom: 1px solid currentColor;
  padding: 0;
  cursor: pointer;
}

.faq__no-results-clear:hover {
  color: var(--color-volt-hover);
}

/* ============================================
   Small phones (375px)
   ============================================ */
@media (max-width: 390px) {
  .hero__headline {
    font-size: 2rem;
  }

  .proof__stat {
    font-size: var(--text-proof-stat-size-small);
  }

  .hero__cta,
  .cta-section__btn {
    padding: var(--btn-padding-sm);
    font-size: var(--text-cta-btn-size-sm);
  }

  .pricing-hero__price {
    font-size: 3.5rem;
  }

  .pricing-hero__cta {
    padding: var(--btn-padding-sm);
    font-size: var(--text-cta-btn-size-sm);
  }
}

/* ============================================
   Tablet (768px+)
   ============================================ */
@media (min-width: 768px) {
  .hero {
    align-items: center;
    padding: var(--space-2xl) var(--space-md);
  }

  .hero__sub {
    max-width: none;
  }

  .hero__ctas {
    flex-direction: row;
    justify-content: center;
  }

  .proof__grid {
    grid-template-columns: 1fr 1fr 1fr;
    gap: var(--space-lg);
  }

  .showcase {
    grid-template-columns: 1fr 1fr;
  }

  .process__grid {
    grid-template-columns: 1fr 1fr 1fr;
  }

  .addons__grid {
    grid-template-columns: 1fr 1fr;
  }

  .process__step {
    border-left: none;
    border-top: var(--border-accent-surface);
    padding: var(--space-lg) 0 0;
  }

  .toolkit__grid {
    grid-template-columns: 1fr 1fr;
  }
}

/* ============================================
   Desktop (1024px+)
   ============================================ */
@media (min-width: 1024px) {
  .hero {
    min-height: 85vh;
  }

  .showcase__device img {
    max-width: var(--showcase-device-max-width-desktop);
  }

  .pf-phone {
    --pf-w: 322px;
    --pf-screen-h: 560px;
  }
}

/* ============================================
   Strike Ripple — Button Tap Feedback
   ============================================ */
.btn-tap {
  position: relative;
  overflow: hidden;
  isolation: isolate;
}

.btn-tap::after {
  content: '';
  position: absolute;
  top: 50%;
  left: 50%;
  width: 40%;
  padding-bottom: 40%;
  border-radius: var(--radius-full);
  background: var(--btn-ripple-color);
  transform: translate(-50%, -50%) scale(var(--btn-ripple-start-scale));
  opacity: 0;
  pointer-events: none;
  z-index: -1;
}

.btn-tap.is-tapped {
  animation: btn-compress var(--btn-tap-duration) ease forwards;
}

.btn-tap.is-tapped::after {
  animation: strike-ripple var(--btn-tap-duration) ease forwards;
}

/* ============================================
   Screen Reader Only
   ============================================ */
.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

/* ============================================
   Skip Link — visually hidden until focused
   ============================================ */
.skip-link {
  position: absolute;
  top: -100px;
  left: 0;
  z-index: 1000;
  padding: var(--space-sm) var(--space-md);
  background-color: var(--color-volt);
  color: var(--color-base);
  font-family: var(--font-display);
  font-weight: 700;
  text-decoration: none;
}

.skip-link:focus {
  top: 0;
}

/* ============================================
   Prevent Widow Words
   ============================================ */
.no-widow {
  display: inline;
  white-space: nowrap;
}
