/* ============================================================
   PayrollPulse — premium.css
   Premium design layer inspired by vendr.com.
   Loaded AFTER styles.css. All new components are additive.
   ============================================================ */

/* --- Extended tokens ------------------------------------- */
:root {
  /* Pastel chip tints for feature icons (single dots of color) */
  --chip-mint:        #E8F4F4;
  --chip-periwinkle:  #E8F0FF;
  --chip-peach:       #FFF0E8;
  --chip-blush:       #FFE8EE;
  --chip-lime:        #F2FAD9;

  /* Glow palette */
  --glow-lime:  rgba(199, 236, 59, 0.55);
  --glow-teal:  rgba(31, 195, 161, 0.55);
  --glow-dark:  rgba(0, 60, 60, 0.40);

  /* UI card surface */
  --ui-card-bg:     #FFFFFF;
  --ui-card-border: rgba(10, 30, 40, 0.08);
  --ui-card-row:    #F6F7F3;

  /* Motion */
  --motion-swift: cubic-bezier(0.22, 1, 0.36, 1);
  --motion-spring: cubic-bezier(0.34, 1.56, 0.64, 1);
}

/* --- Eyebrow (tracked all-caps subheading) --------------- */
.eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-family: var(--font-display);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--dark-teal);
  margin-bottom: 16px;
}
.eyebrow::before {
  content: "";
  width: 24px;
  height: 1px;
  background: var(--teal);
}
.eyebrow--light { color: var(--acid-lime); }
.eyebrow--light::before { background: var(--acid-lime); }
.eyebrow--muted { color: var(--dark-grey); }
.eyebrow--muted::before { background: var(--light-grey); }

/* --- Display headline (oversized hero / mega moments) ---- */
.display {
  font-family: var(--font-display);
  font-weight: 800;
  letter-spacing: -0.045em;
  line-height: 0.98;
  color: var(--dark-teal);
}
.display--hero { font-size: clamp(48px, 7.2vw, 96px); }
.display--xl   { font-size: clamp(40px, 5.6vw, 72px); }
.display--light { color: var(--white); }

.lede {
  font-family: var(--font-body);
  font-size: clamp(17px, 1.4vw, 20px);
  line-height: 1.55;
  color: var(--light-navy);
  max-width: 620px;
}
.lede--light { color: rgba(255,255,255,0.72); }

/* --- Glow button (mouse-tracked) ------------------------- */
/* JS writes --mx and --my on pointermove in px relative to the button */
.btn-glow {
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 16px 28px;
  font-family: var(--font-display);
  font-size: 15px;
  font-weight: 700;
  letter-spacing: -0.01em;
  border-radius: 999px;
  cursor: pointer;
  overflow: hidden;
  isolation: isolate;
  transition: transform 0.25s var(--motion-swift), box-shadow 0.25s var(--motion-swift);
  --mx: 50%;
  --my: 50%;
}
.btn-glow::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: -1;
  background: radial-gradient(
    220px circle at var(--mx) var(--my),
    var(--glow-color, var(--glow-lime)) 0%,
    transparent 60%
  );
  opacity: 0;
  transition: opacity 0.35s var(--motion-swift);
}
.btn-glow:hover::before { opacity: 1; }
.btn-glow:hover { transform: translateY(-1px); }
.btn-glow .arrow {
  display: inline-block;
  transition: transform 0.25s var(--motion-swift);
}
.btn-glow:hover .arrow { transform: translateX(4px); }

.btn-glow--primary {
  background: var(--acid-lime);
  color: var(--dark-teal);
  border: 1px solid var(--acid-lime);
  --glow-color: rgba(255, 255, 255, 0.65);
}
.btn-glow--primary:hover { box-shadow: 0 12px 30px rgba(199,236,59,0.35); }

.btn-glow--dark {
  background: var(--dark-teal);
  color: var(--white);
  border: 1px solid var(--dark-teal);
  --glow-color: rgba(31, 195, 161, 0.55);
}
.btn-glow--dark:hover { box-shadow: 0 12px 30px rgba(0,60,60,0.25); }

.btn-glow--ghost {
  background: transparent;
  color: var(--dark-teal);
  border: 1px solid rgba(0, 60, 60, 0.18);
  --glow-color: rgba(31, 195, 161, 0.25);
}
.btn-glow--ghost:hover {
  border-color: rgba(0, 60, 60, 0.32);
  background: rgba(31,195,161,0.04);
}
.btn-glow--ghost-light {
  background: transparent;
  color: var(--white);
  border: 1px solid rgba(255,255,255,0.18);
  --glow-color: rgba(199, 236, 59, 0.32);
}
.btn-glow--ghost-light:hover {
  border-color: rgba(255,255,255,0.36);
  background: rgba(255,255,255,0.04);
}

/* --- Pastel chip icons ----------------------------------- */
.chip-icon {
  width: 44px;
  height: 44px;
  border-radius: 12px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.chip-icon--mint       { background: var(--chip-mint); color: #0A8474; }
.chip-icon--periwinkle { background: var(--chip-periwinkle); color: #3E5BB7; }
.chip-icon--peach      { background: var(--chip-peach); color: #C55A1E; }
.chip-icon--blush      { background: var(--chip-blush); color: #B83567; }
.chip-icon--lime       { background: var(--chip-lime); color: var(--dark-teal); }

/* --- Persona toggle (binary switch) ---------------------- */
.persona-toggle {
  display: inline-flex;
  padding: 5px;
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.12);
  border-radius: 999px;
  position: relative;
  backdrop-filter: blur(10px);
}
.persona-toggle__btn {
  position: relative;
  z-index: 2;
  padding: 10px 22px;
  font-family: var(--font-display);
  font-size: 13px;
  font-weight: 600;
  letter-spacing: -0.01em;
  color: rgba(255,255,255,0.65);
  background: transparent;
  border: none;
  border-radius: 999px;
  cursor: pointer;
  transition: color 0.25s var(--motion-swift);
  white-space: nowrap;
}
.persona-toggle__btn.active { color: var(--dark-teal); }
.persona-toggle__btn:not(.active):hover { color: rgba(255,255,255,0.88); }
.persona-toggle__thumb {
  position: absolute;
  top: 5px;
  bottom: 5px;
  background: var(--acid-lime);
  border-radius: 999px;
  box-shadow: 0 4px 14px rgba(199,236,59,0.35);
  transition: transform 0.4s var(--motion-swift), width 0.4s var(--motion-swift), left 0.4s var(--motion-swift);
  z-index: 1;
}

/* --- Persona-driven sections (fade between) -------------- */
.persona-view {
  display: none;
  animation: fadeUp 0.55s var(--motion-swift) both;
}
.persona-view.active { display: block; }
@keyframes fadeUp {
  from { opacity: 0; transform: translateY(14px); }
  to { opacity: 1; transform: translateY(0); }
}

/* --- Ambient brand glow (oversized blurred glyph) -------- */
.ambient-glow {
  position: relative;
  overflow: hidden;
}
.ambient-glow__glyph {
  position: absolute;
  pointer-events: none;
  width: min(960px, 90%);
  height: auto;
  opacity: 0.14;
  filter: blur(60px);
  z-index: 0;
}
.ambient-glow__glyph--tl {
  top: -14%;
  left: -12%;
  transform: rotate(-12deg);
}
.ambient-glow__glyph--br {
  bottom: -18%;
  right: -10%;
  transform: rotate(9deg);
  opacity: 0.10;
}
.ambient-glow > .container { position: relative; z-index: 1; }

/* --- Mini-UI mockup card (dashboard-in-card) ------------- */
.ui-mock {
  background: var(--ui-card-bg);
  border: 1px solid var(--ui-card-border);
  border-radius: 18px;
  box-shadow:
    0 1px 2px rgba(10,30,40,0.04),
    0 12px 32px rgba(10,30,40,0.06);
  overflow: hidden;
  transition: transform 0.5s var(--motion-swift), box-shadow 0.5s var(--motion-swift);
}
.ui-mock:hover {
  transform: translateY(-4px);
  box-shadow:
    0 2px 4px rgba(10,30,40,0.06),
    0 24px 48px rgba(10,30,40,0.10);
}
.ui-mock__bar {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 12px 16px;
  background: #FAFAF7;
  border-bottom: 1px solid var(--ui-card-border);
}
.ui-mock__dot {
  width: 10px; height: 10px; border-radius: 50%;
  background: #E3E3DF;
}
.ui-mock__dot--live { background: var(--teal); box-shadow: 0 0 0 4px rgba(31,195,161,0.15); }
.ui-mock__title {
  margin-left: 6px;
  font-family: var(--font-display);
  font-size: 12px;
  font-weight: 600;
  color: var(--light-navy);
  letter-spacing: -0.005em;
}
.ui-mock__body { padding: 18px; }

/* Vendor match rows */
.vrow {
  display: grid;
  grid-template-columns: 28px 1fr auto;
  gap: 12px;
  align-items: center;
  padding: 10px 12px;
  border-radius: 10px;
  background: var(--ui-card-row);
  margin-bottom: 8px;
  transition: background 0.25s var(--motion-swift);
}
.vrow:hover { background: #EFF1EC; }
.vrow__avatar {
  position: relative;
  width: 32px; height: 32px; border-radius: 8px;
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
  background: var(--white);
  border: 1px solid var(--ui-card-border);
  overflow: hidden;
}
.vrow__avatar img.logo-auto {
  width: 100%;
  height: 100%;
  object-fit: contain;
  padding: 4px;
  box-sizing: border-box;
}
.logo-fallback {
  position: absolute;
  inset: 0;
  display: none;
  align-items: center;
  justify-content: center;
  font-family: var(--font-display);
  font-size: 11px;
  font-weight: 700;
  color: var(--white);
  background: linear-gradient(135deg, var(--dark-teal), var(--teal));
}
/* Inline logo for mini-UI title bars (Paylocity logo in Contract Check mock) */
.ui-mock__logo {
  width: 22px;
  height: 22px;
  border-radius: 6px;
  background: var(--white);
  border: 1px solid var(--ui-card-border);
  overflow: hidden;
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.ui-mock__logo img.logo-auto {
  width: 100%;
  height: 100%;
  object-fit: contain;
  padding: 3px;
  box-sizing: border-box;
}
.vrow__name {
  font-family: var(--font-display);
  font-size: 13px; font-weight: 600; color: var(--dark-teal);
  letter-spacing: -0.01em;
}
.vrow__meta { font-size: 11px; color: var(--dark-grey); }
.vrow__score {
  font-family: var(--font-display);
  font-size: 13px; font-weight: 700; color: var(--dark-teal);
  padding: 4px 10px;
  background: rgba(31,195,161,0.10);
  border-radius: 999px;
  min-width: 48px;
  text-align: center;
}
.vrow__score--high { background: rgba(31,195,161,0.18); }
.vrow__score--mid  { background: rgba(209,143,1,0.14); color: #9C6A00; }
.vrow__score--low  { background: rgba(232,69,60,0.12); color: #C0362D; }

/* Contract flag mockup */
.flag-line {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  padding: 10px 12px;
  margin-bottom: 8px;
  background: var(--ui-card-row);
  border-radius: 10px;
  font-size: 12.5px;
  line-height: 1.55;
  color: var(--light-navy);
}
.flag-line__bullet {
  flex-shrink: 0;
  width: 18px; height: 18px;
  border-radius: 6px;
  display: inline-flex; align-items: center; justify-content: center;
  font-family: var(--font-display); font-weight: 700; font-size: 11px;
  margin-top: 1px;
}
.flag-line--high .flag-line__bullet  { background: rgba(232,69,60,0.14); color: #C0362D; }
.flag-line--med  .flag-line__bullet  { background: rgba(209,143,1,0.16); color: #9C6A00; }
.flag-line--low  .flag-line__bullet  { background: rgba(31,195,161,0.16); color: #0A8474; }
.flag-line__text strong {
  color: var(--dark-teal);
  font-family: var(--font-display);
  font-weight: 600;
}

/* Verdict chip */
.verdict {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 6px 12px;
  background: rgba(232,69,60,0.10);
  color: #C0362D;
  border-radius: 999px;
  font-family: var(--font-display); font-size: 11px; font-weight: 700;
  letter-spacing: 0.08em; text-transform: uppercase;
  margin-bottom: 14px;
}
.verdict::before {
  content: ""; width: 6px; height: 6px; border-radius: 50%;
  background: currentColor;
}

/* --- Stat badge (vendr-style metric card corner) --------- */
.stat-badge {
  display: inline-flex;
  flex-direction: column;
  gap: 4px;
  padding: 14px 18px;
  background: var(--white);
  border: 1px solid var(--ui-card-border);
  border-radius: 12px;
  min-width: 130px;
}
.stat-badge__label {
  font-family: var(--font-display);
  font-size: 10px; font-weight: 700;
  letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--dark-grey);
}
.stat-badge__value {
  font-family: var(--font-display);
  font-size: 22px; font-weight: 800;
  color: var(--dark-teal);
  letter-spacing: -0.025em;
}
.stat-badge--floating {
  position: absolute;
  box-shadow: 0 12px 32px rgba(10,30,40,0.10);
}

/* --- Mega counter (giant single-number moment) ----------- */
.mega-counter {
  font-family: var(--font-display);
  font-size: clamp(72px, 13vw, 176px);
  font-weight: 800;
  letter-spacing: -0.055em;
  line-height: 1;
  background: linear-gradient(180deg, var(--acid-lime) 0%, var(--teal) 100%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  display: inline-block;
}

/* --- Marquee refinements (fade edges) -------------------- */
.marquee {
  position: relative;
  overflow: hidden;
  padding: 32px 0;
  background: var(--white);
  border-top: 1px solid var(--light-grey);
  border-bottom: 1px solid var(--light-grey);
}
.marquee::before,
.marquee::after {
  content: "";
  position: absolute;
  top: 0; bottom: 0;
  width: clamp(60px, 12vw, 160px);
  z-index: 2;
  pointer-events: none;
}
.marquee::before {
  left: 0;
  background: linear-gradient(90deg, var(--white), transparent);
}
.marquee::after {
  right: 0;
  background: linear-gradient(-90deg, var(--white), transparent);
}
.marquee__track {
  display: flex;
  gap: 56px;
  animation: marquee-scroll 40s linear infinite;
  width: max-content;
}
.marquee__label {
  text-align: center;
  font-family: var(--font-display);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--dark-grey);
  margin-bottom: 22px;
}
.marquee__item {
  font-family: var(--font-display);
  font-size: 18px;
  font-weight: 600;
  color: var(--light-navy);
  opacity: 0.70;
  letter-spacing: -0.01em;
  white-space: nowrap;
  transition: opacity 0.25s var(--motion-swift), color 0.25s var(--motion-swift), filter 0.25s var(--motion-swift);
  display: inline-flex;
  align-items: center;
  height: 40px;
}
.marquee__item:hover {
  opacity: 1;
  color: var(--dark-teal);
}
/* Logo variant — used when marquee__item contains an img.logo-auto */
.marquee__logo {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  height: 36px;
  min-width: 110px;
  opacity: 0.55;
  filter: grayscale(100%);
  transition: opacity 0.3s var(--motion-swift), filter 0.3s var(--motion-swift);
}
.marquee__logo:hover {
  opacity: 1;
  filter: grayscale(0%);
}
.marquee__logo img.logo-auto {
  max-height: 28px;
  max-width: 130px;
  width: auto;
  height: auto;
  object-fit: contain;
}
.marquee__logo .logo-fallback {
  position: absolute;
  inset: 0;
  display: none;
  align-items: center;
  justify-content: center;
  font-family: var(--font-display);
  font-size: 15px;
  font-weight: 600;
  color: var(--light-navy);
  background: transparent;
}
@keyframes marquee-scroll {
  from { transform: translateX(0); }
  to { transform: translateX(-50%); }
}

/* --- Reveal with stagger --------------------------------- */
.reveal-stagger > * {
  opacity: 0;
  transform: translateY(20px);
  transition:
    opacity 0.7s var(--motion-swift),
    transform 0.7s var(--motion-swift);
}
/* Default: all children become visible when parent is .visible */
.reveal-stagger.visible > * {
  opacity: 1;
  transform: none;
}
/* First 8 children get staggered delays for the cascade effect */
.reveal-stagger.visible > *:nth-child(1) { transition-delay: 0.00s; }
.reveal-stagger.visible > *:nth-child(2) { transition-delay: 0.07s; }
.reveal-stagger.visible > *:nth-child(3) { transition-delay: 0.14s; }
.reveal-stagger.visible > *:nth-child(4) { transition-delay: 0.21s; }
.reveal-stagger.visible > *:nth-child(5) { transition-delay: 0.28s; }
.reveal-stagger.visible > *:nth-child(6) { transition-delay: 0.35s; }
.reveal-stagger.visible > *:nth-child(7) { transition-delay: 0.42s; }
.reveal-stagger.visible > *:nth-child(8) { transition-delay: 0.49s; }

/* --- Hero v2 --------------------------------------------- */
.hero-v2 {
  position: relative;
  min-height: 92vh;
  padding: 160px 0 100px;
  background: linear-gradient(180deg, #06292F 0%, var(--dark-navy) 58%, #08353E 100%);
  overflow: hidden;
  color: var(--white);
}

/* Hero ambient motion — organic drifting gradient blobs (vendr-inspired) */
.hero-v2__pulse {
  position: absolute;
  inset: 0;
  overflow: hidden;
  pointer-events: none;
  z-index: 0;
}
/* Hide the literal EKG traces — replaced by organic breathing blobs below */
.hero-v2__pulse .pulse-trace { display: none; }

/* Drifting blurred blobs — the primary background motion */
.hero-v2__pulse::before,
.hero-v2__pulse::after,
.hero-v2 .hero-breathe__orb {
  content: "";
  position: absolute;
  border-radius: 50%;
  filter: blur(80px);
  mix-blend-mode: screen;
  pointer-events: none;
  will-change: transform;
}
.hero-v2__pulse::before {
  width: 640px;
  height: 640px;
  top: -18%;
  left: 8%;
  background: rgba(31, 195, 161, 0.45);
  animation: heroDrift1 28s ease-in-out infinite;
}
.hero-v2__pulse::after {
  width: 560px;
  height: 560px;
  top: 22%;
  right: -6%;
  background: rgba(199, 236, 59, 0.28);
  animation: heroDrift2 32s ease-in-out infinite;
  animation-delay: -8s;
}
.hero-v2 .hero-breathe__orb {
  width: 720px;
  height: 720px;
  bottom: -28%;
  left: 28%;
  background: rgba(0, 60, 60, 0.55);
  animation: heroDrift3 38s ease-in-out infinite;
  animation-delay: -16s;
}

@keyframes heroDrift1 {
  0%, 100% { transform: scale(1) translate(0, 0); }
  33% { transform: scale(1.12) translate(4%, -3%); }
  66% { transform: scale(0.94) translate(-2%, 4%); }
}
@keyframes heroDrift2 {
  0%, 100% { transform: scale(1) translate(0, 0); }
  50% { transform: scale(1.18) translate(-5%, 3%); }
}
@keyframes heroDrift3 {
  0%, 100% { transform: scale(1) translate(0, 0); }
  40% { transform: scale(1.08) translate(3%, -4%); }
  80% { transform: scale(0.92) translate(-4%, 2%); }
}

@media (prefers-reduced-motion: reduce) {
  .hero-v2__pulse::before,
  .hero-v2__pulse::after,
  .hero-v2 .hero-breathe__orb { animation: none; }
}
.hero-v2__glow {
  position: absolute;
  width: 900px; height: 900px;
  background: radial-gradient(circle, rgba(31,195,161,0.25) 0%, transparent 60%);
  top: -30%; right: -18%;
  pointer-events: none;
  filter: blur(10px);
}
.hero-v2__glow--alt {
  left: -22%; right: auto; top: auto; bottom: -40%;
  background: radial-gradient(circle, rgba(199,236,59,0.15) 0%, transparent 60%);
}
.hero-v2__grid {
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(255,255,255,0.03) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.03) 1px, transparent 1px);
  background-size: 64px 64px;
  mask-image: radial-gradient(ellipse at center, black 35%, transparent 75%);
  -webkit-mask-image: radial-gradient(ellipse at center, black 35%, transparent 75%);
  pointer-events: none;
}
.hero-v2__content {
  position: relative;
  z-index: 2;
  max-width: 860px;
  margin: 0 auto;
  text-align: center;
}
.hero-v2__persona {
  display: flex;
  justify-content: center;
  margin-bottom: 36px;
}
.hero-v2__actions {
  display: flex;
  gap: 14px;
  justify-content: center;
  margin-top: 32px;
  flex-wrap: wrap;
}
.hero-v2__trust {
  margin-top: 48px;
  display: flex;
  justify-content: center;
  gap: 40px;
  flex-wrap: wrap;
  font-family: var(--font-display);
  font-size: 12px;
  color: rgba(255,255,255,0.55);
  letter-spacing: 0.02em;
}
.hero-v2__trust strong { color: var(--acid-lime); font-weight: 700; margin-right: 4px; }

/* --- Page hero (secondary pages) ------------------------- */
.page-hero {
  position: relative;
  padding: 140px 0 80px;
  background: linear-gradient(180deg, #06292F 0%, var(--dark-navy) 100%);
  overflow: hidden;
  color: var(--white);
  text-align: center;
}
.page-hero__pulse {
  position: absolute;
  inset: 0;
  overflow: hidden;
  pointer-events: none;
  z-index: 0;
}
/* Hide literal EKG — replaced by organic breathing blobs */
.page-hero__pulse .pulse-trace { display: none; }

.page-hero__pulse::before,
.page-hero__pulse::after {
  content: "";
  position: absolute;
  border-radius: 50%;
  filter: blur(70px);
  mix-blend-mode: screen;
  pointer-events: none;
  will-change: transform;
}
.page-hero__pulse::before {
  width: 520px;
  height: 520px;
  top: -20%;
  left: 12%;
  background: rgba(31, 195, 161, 0.40);
  animation: heroDrift1 28s ease-in-out infinite;
}
.page-hero__pulse::after {
  width: 460px;
  height: 460px;
  bottom: -26%;
  right: 6%;
  background: rgba(199, 236, 59, 0.22);
  animation: heroDrift2 34s ease-in-out infinite;
  animation-delay: -10s;
}
@media (prefers-reduced-motion: reduce) {
  .page-hero__pulse::before,
  .page-hero__pulse::after { animation: none; }
}
.page-hero__glow {
  position: absolute;
  width: 720px; height: 720px;
  background: radial-gradient(circle, rgba(31,195,161,0.22) 0%, transparent 60%);
  top: -40%; right: -14%;
  pointer-events: none;
  filter: blur(6px);
  z-index: 0;
}
.page-hero__glow--alt {
  left: -18%; right: auto; top: auto; bottom: -50%;
  background: radial-gradient(circle, rgba(199,236,59,0.12) 0%, transparent 60%);
}
.page-hero__grid {
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(255,255,255,0.03) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.03) 1px, transparent 1px);
  background-size: 56px 56px;
  mask-image: radial-gradient(ellipse at center, black 35%, transparent 75%);
  -webkit-mask-image: radial-gradient(ellipse at center, black 35%, transparent 75%);
  pointer-events: none;
  z-index: 0;
}
.page-hero > .container {
  position: relative;
  z-index: 1;
}
.page-hero .eyebrow { justify-content: center; }
.page-hero h1,
.page-hero .display {
  color: var(--white);
  font-size: clamp(40px, 5.2vw, 64px);
  letter-spacing: -0.045em;
  line-height: 1.02;
  max-width: 820px;
  margin: 0 auto;
}
.page-hero .lede {
  margin: 20px auto 0;
  color: rgba(255,255,255,0.68);
  text-align: center;
  max-width: 640px;
}
.page-hero__actions {
  display: flex;
  justify-content: center;
  gap: 14px;
  margin-top: 36px;
  flex-wrap: wrap;
}
@media (max-width: 700px) {
  .page-hero { padding: 110px 0 64px; }
}

/* --- Feature v2 grid (pastel chips) ---------------------- */
.feature-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 20px;
}
@media (max-width: 1000px) { .feature-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 600px)  { .feature-grid { grid-template-columns: 1fr; } }

.feature-v2 {
  position: relative;
  padding: 28px 24px 24px;
  background: var(--white);
  border: 1px solid var(--ui-card-border);
  border-radius: 18px;
  transition:
    transform 0.4s var(--motion-swift),
    box-shadow 0.4s var(--motion-swift),
    border-color 0.4s var(--motion-swift);
}
.feature-v2:hover {
  transform: translateY(-4px);
  border-color: rgba(0,60,60,0.16);
  box-shadow: 0 20px 40px rgba(10,30,40,0.08);
}
.feature-v2__title {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 17px;
  color: var(--dark-teal);
  margin: 18px 0 6px;
  letter-spacing: -0.015em;
}
.feature-v2__desc {
  font-size: 13.5px;
  line-height: 1.6;
  color: var(--light-navy);
  margin: 0 0 18px;
}
.feature-v2__metric {
  display: flex;
  align-items: baseline;
  gap: 6px;
  padding-top: 14px;
  border-top: 1px solid var(--ui-card-border);
}
.feature-v2__metric-value {
  font-family: var(--font-display);
  font-weight: 800;
  font-size: 22px;
  color: var(--red);
  letter-spacing: -0.025em;
}
.feature-v2__metric-label {
  font-size: 11.5px;
  color: var(--dark-grey);
  letter-spacing: 0.01em;
}

/* --- Step card (numbered 3-step variant of feature-v2) --- */
.step-card {
  position: relative;
  padding: 32px 28px 28px;
  text-align: center;
  overflow: hidden;
}
/* Colored top accent bar driven by --accent */
.step-card::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 3px;
  background: var(--accent, var(--teal));
  opacity: 0.85;
  transition: opacity 0.4s var(--motion-swift);
}
.step-card:hover::before { opacity: 1; }

.step-card__chip {
  margin: 0 auto 18px;
}

.step-card__num {
  font-family: var(--font-display);
  font-weight: 800;
  font-size: 52px;
  letter-spacing: -0.045em;
  line-height: 1;
  margin-bottom: 14px;
  background: var(--num-gradient, linear-gradient(135deg, var(--teal) 0%, var(--dark-teal) 100%));
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  display: inline-block;
}

/* Accent color variants */
.step-card--teal  { --accent: var(--teal); --num-gradient: linear-gradient(135deg, #1FC3A1 0%, #003C3C 100%); }
.step-card--lime  { --accent: var(--acid-lime); --num-gradient: linear-gradient(135deg, #C7EC3B 0%, #1FC3A1 100%); }
.step-card--deep  { --accent: #3E5BB7; --num-gradient: linear-gradient(135deg, #3E5BB7 0%, #003C3C 100%); }

/* --- Split feature layout (mockup + copy) ---------------- */
.split {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 64px;
  align-items: center;
}
.split--reverse .split__copy { order: 2; }
.split--reverse .split__visual { order: 1; }
@media (max-width: 900px) {
  .split { grid-template-columns: 1fr; gap: 32px; }
  .split--reverse .split__copy,
  .split--reverse .split__visual { order: 0; }
}
.split__copy .eyebrow { margin-bottom: 14px; }
.split__copy h2 {
  font-size: clamp(28px, 3.2vw, 42px);
  letter-spacing: -0.035em;
  line-height: 1.05;
  margin-bottom: 16px;
}
.split__copy p {
  font-size: 16px;
  line-height: 1.65;
  color: var(--light-navy);
  margin-bottom: 20px;
  max-width: 520px;
}
.split__stats {
  display: flex;
  gap: 12px;
  margin-top: 22px;
  flex-wrap: wrap;
}

/* --- Section frame overrides ----------------------------- */
.section--lede {
  padding: clamp(80px, 10vw, 140px) 0;
}
.section--dark-premium {
  background: linear-gradient(180deg, #06292F 0%, var(--dark-navy) 100%);
  color: var(--white);
}
.section--dark-premium .eyebrow { color: var(--acid-lime); }
.section--dark-premium .eyebrow::before { background: var(--acid-lime); }
.section--dark-premium h2,
.section--dark-premium h3 { color: var(--white); }

/* --- Mega counter section -------------------------------- */
.mega-section {
  position: relative;
  padding: clamp(100px, 12vw, 160px) 0;
  background: linear-gradient(180deg, var(--dark-teal) 0%, #06292F 100%);
  color: var(--white);
  overflow: hidden;
  text-align: center;
}
.mega-section__glow {
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse at 30% 40%, rgba(199,236,59,0.12), transparent 55%),
    radial-gradient(ellipse at 70% 60%, rgba(31,195,161,0.18), transparent 55%);
  pointer-events: none;
}
.mega-section > .container { position: relative; z-index: 1; }
.mega-section .lede { margin: 16px auto 0; color: rgba(255,255,255,0.70); }

/* --- Nav v2 polish --------------------------------------- */
.nav--v2 .nav__cta {
  border-radius: 999px;
  padding: 10px 20px;
}

/* --- Testimonial v2 -------------------------------------- */
.tv2-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
}
@media (max-width: 900px) { .tv2-grid { grid-template-columns: 1fr; } }
.tv2 {
  padding: 28px 28px 24px;
  background: var(--white);
  border: 1px solid var(--ui-card-border);
  border-radius: 18px;
  display: flex;
  flex-direction: column;
  gap: 20px;
  transition: transform 0.4s var(--motion-swift), box-shadow 0.4s var(--motion-swift);
}
.tv2:hover {
  transform: translateY(-4px);
  box-shadow: 0 20px 40px rgba(10,30,40,0.07);
}
.tv2__quote {
  font-size: 16px;
  line-height: 1.6;
  color: var(--dark-teal);
  letter-spacing: -0.01em;
  flex: 1;
}
.tv2__author {
  display: flex;
  align-items: center;
  gap: 12px;
  padding-top: 18px;
  border-top: 1px solid var(--ui-card-border);
}
.tv2__avatar {
  width: 40px; height: 40px; border-radius: 50%;
  background: linear-gradient(135deg, var(--dark-teal), var(--teal));
  color: var(--white);
  display: flex; align-items: center; justify-content: center;
  font-family: var(--font-display); font-size: 13px; font-weight: 700;
}
.tv2__name {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 14px;
  color: var(--dark-teal);
  letter-spacing: -0.01em;
}
.tv2__role { font-size: 12px; color: var(--dark-grey); }

/* --- Testimonial v3 (portrait-sticker overlay) ----------- */
.tv3-v2-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 28px;
  padding-top: 60px; /* breathing room so portraits don't clip against section top */
}
@media (max-width: 960px)  { .tv3-v2-grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 640px)  { .tv3-v2-grid { grid-template-columns: 1fr; gap: 80px; } }

.tv3 {
  position: relative;
  background: var(--tv3-bg, #E8F4F4);
  border: 1px solid rgba(10, 30, 40, 0.04);
  border-radius: 22px;
  padding: 78px 30px 30px; /* top padding reserved for portrait overlap */
  text-align: center;
  transition:
    transform 0.45s var(--motion-swift),
    box-shadow 0.45s var(--motion-swift);
}
.tv3:hover {
  transform: translateY(-5px);
  box-shadow: 0 24px 48px rgba(10, 30, 40, 0.10);
}
.tv3:hover .tv3__portrait {
  transform: translateX(-50%) translateY(-4px);
}

.tv3__portrait {
  position: absolute;
  top: -58px;
  left: 50%;
  transform: translateX(-50%);
  width: 116px;
  height: 116px;
  border-radius: 50%;
  object-fit: cover;
  background: var(--white);
  border: 4px solid var(--white);
  box-shadow: 0 12px 28px rgba(10, 30, 40, 0.14);
  transition: transform 0.45s var(--motion-swift);
  z-index: 1;
}

.tv3__stars {
  display: flex;
  justify-content: center;
  gap: 3px;
  margin-bottom: 16px;
  color: var(--acid-lime);
}
.tv3__stars svg {
  width: 16px;
  height: 16px;
  fill: currentColor;
}
.tv3--mint  .tv3__stars,
.tv3--lime  .tv3__stars { color: #D18F01; } /* gold stars read better on lighter tints */
.tv3--blush .tv3__stars { color: #C55A1E; }
.tv3--cream .tv3__stars { color: #D18F01; }

.tv3__quote {
  font-family: var(--font-body);
  font-size: 16px;
  line-height: 1.58;
  color: var(--dark-teal);
  letter-spacing: -0.005em;
  margin: 0 0 22px;
}

.tv3__author {
  padding-top: 18px;
  border-top: 1px solid rgba(10, 30, 40, 0.08);
}
.tv3__name {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 14px;
  color: var(--dark-teal);
  letter-spacing: -0.005em;
}
.tv3__role {
  font-size: 12.5px;
  color: var(--dark-grey);
  margin-top: 3px;
  line-height: 1.45;
}

/* Pastel background variants — rotate across cards */
.tv3--mint  { --tv3-bg: #E8F4F4; }
.tv3--lime  { --tv3-bg: #F2FAD9; }
.tv3--blush { --tv3-bg: #FFE8EE; }
.tv3--cream { --tv3-bg: #FAF8F1; }
.tv3--periwinkle { --tv3-bg: #E8F0FF; }

/* --- Prefooter CTA v2 ------------------------------------ */
.cta-v2 {
  position: relative;
  padding: clamp(80px, 10vw, 120px) 0;
  background: var(--dark-teal);
  color: var(--white);
  overflow: hidden;
  text-align: center;
}
.cta-v2__glow {
  position: absolute;
  inset: -20%;
  background:
    radial-gradient(circle at 20% 30%, rgba(199,236,59,0.14), transparent 45%),
    radial-gradient(circle at 80% 70%, rgba(31,195,161,0.18), transparent 45%);
  pointer-events: none;
}
.cta-v2 > .container { position: relative; z-index: 1; }

/* --- Hover lift (cards, links) --------------------------- */
.hover-lift { transition: transform 0.35s var(--motion-swift), box-shadow 0.35s var(--motion-swift); }
.hover-lift:hover { transform: translateY(-3px); }

/* --- Reduced motion -------------------------------------- */
@media (prefers-reduced-motion: reduce) {
  .marquee__track { animation: none; }
  .reveal-stagger > * { opacity: 1 !important; transform: none !important; }
  .btn-glow::before { display: none; }
  .ui-mock:hover { transform: none; }
  .feature-v2:hover, .tv2:hover { transform: none; }
  .persona-toggle__thumb { transition: none; }
}

/* --- Responsive tweaks ----------------------------------- */
@media (max-width: 700px) {
  .hero-v2 { padding: 130px 0 80px; min-height: auto; }
  .hero-v2__trust { gap: 18px; font-size: 11.5px; }
  .hero-v2__trust strong { margin-right: 3px; }
  .persona-toggle__btn { padding: 8px 12px; font-size: 11.5px; letter-spacing: -0.005em; }
  .persona-toggle { padding: 4px; }
  .hero-v2__actions { flex-direction: column; align-items: stretch; gap: 10px; }
  .hero-v2__actions .btn-glow { justify-content: center; }
}

@media (max-width: 700px) {
  /* Display headline scaling — keep readable on narrow screens */
  .display--hero { font-size: clamp(36px, 9vw, 56px); letter-spacing: -0.04em; }
  .display--xl { font-size: clamp(30px, 7.5vw, 44px); }

  /* Split features stack and tighten copy padding */
  .split { gap: 28px; }
  .split__copy h2 { font-size: clamp(26px, 6vw, 32px); }
  .split__stats { gap: 8px; }
  .stat-badge { padding: 12px 14px; min-width: auto; flex: 1; }

  /* CTA section spacing */
  .cta-v2 { padding: 64px 0 56px; }

  /* Mega counter — ensure number doesn't overflow */
  .mega-counter { font-size: clamp(56px, 16vw, 110px); }

  /* Marquee sizes */
  .marquee { padding: 22px 0; }
  .marquee__logo { min-width: 90px; height: 32px; }
  .marquee__logo img.logo-auto { max-height: 22px; max-width: 90px; }
  .marquee__track { gap: 36px; }

  /* Section padding */
  .section--lede { padding: clamp(56px, 9vw, 100px) 0; }

  /* Page hero padding */
  .page-hero { padding: 100px 16px 56px; }
  .page-hero h1, .page-hero .display { font-size: clamp(34px, 8vw, 48px); }

  /* Eyebrow slightly tighter */
  .eyebrow { font-size: 10px; letter-spacing: 0.14em; }
}
