/* Scroll reveal utilities — pair with js/reveal.js (IntersectionObserver, toggles .is-visible). */

:root {
  --wlc-reveal-ease: cubic-bezier(0.22, 1, 0.36, 1);
  --wlc-reveal-dur: 0.62s;
  --wlc-reveal-slide: clamp(22px, 3.6vw, 36px);
}

/* Hidden state: fade + motion (enter from below / left / right). */
.reveal-card:not(.is-visible),
.reveal-left:not(.is-visible),
.reveal-right:not(.is-visible) {
  opacity: 0;
  pointer-events: none;
  transition:
    opacity var(--wlc-reveal-dur) var(--wlc-reveal-ease),
    transform var(--wlc-reveal-dur) var(--wlc-reveal-ease);
}

/* .reveal-card always pairs with .reveal-left / .reveal-right (assigned in reveal.js). */
.reveal-left:not(.is-visible) {
  transform: translate3d(calc(-1 * var(--wlc-reveal-slide)), 0, 0);
}

.reveal-right:not(.is-visible) {
  transform: translate3d(var(--wlc-reveal-slide), 0, 0);
}

/* Visible resting transforms */
.reveal-card.is-visible,
.reveal-left.is-visible,
.reveal-right.is-visible {
  opacity: 1;
  pointer-events: auto;
  transform: none;
  transition:
    opacity var(--wlc-reveal-dur) var(--wlc-reveal-ease),
    transform var(--wlc-reveal-dur) var(--wlc-reveal-ease);
}

/* Popular tier: keep scale + horizontal slide */
.price-card.popular.reveal-left:not(.is-visible) {
  transform: scale(1.015) translate3d(calc(-1 * var(--wlc-reveal-slide)), 0, 0);
}

.price-card.popular.reveal-right:not(.is-visible) {
  transform: scale(1.015) translate3d(var(--wlc-reveal-slide), 0, 0);
}

.price-card.popular.reveal-card.is-visible {
  transform: scale(1.015);
}

/* ---------- Restore component hovers (beat .reveal-*.is-visible { transform: none }) ---------- */

.price-card.reveal-card.is-visible:hover,
.price-card.reveal-left.is-visible:hover,
.price-card.reveal-right.is-visible:hover {
  border-color: var(--border-h);
  transform: translateY(-4px);
  box-shadow: 0 20px 50px rgba(0, 0, 0, 0.38);
}

.price-card.popular.reveal-card.is-visible:hover,
.price-card.popular.reveal-left.is-visible:hover,
.price-card.popular.reveal-right.is-visible:hover {
  transform: scale(1.015) translateY(-5px);
}

.know-card.reveal-card.is-visible:hover,
.know-card.reveal-left.is-visible:hover,
.know-card.reveal-right.is-visible:hover {
  border-color: var(--border-h);
  transform: translateY(-4px);
  box-shadow: 0 18px 50px rgba(0, 0, 0, 0.35);
}

.work-card.reveal-card.is-visible:hover,
.work-card.reveal-left.is-visible:hover,
.work-card.reveal-right.is-visible:hover {
  border-color: rgba(139, 92, 246, 0.38);
  transform: translateY(-2px);
  box-shadow: 0 12px 32px rgba(0, 0, 0, 0.28);
  background: var(--surface-2);
}

.story-card.reveal-card.is-visible:hover,
.story-card.reveal-left.is-visible:hover,
.story-card.reveal-right.is-visible:hover {
  transform: translateY(-2px);
  border-color: rgba(139, 92, 246, 0.22);
  background: var(--surface-2);
  box-shadow: 0 12px 36px rgba(0, 0, 0, 0.28);
}

.faq-card.reveal-card.is-visible:hover,
.faq-card.reveal-left.is-visible:hover,
.faq-card.reveal-right.is-visible:hover {
  transform: translateY(-1px);
  border-color: rgba(139, 92, 246, 0.22);
  background: var(--surface-2);
  box-shadow: 0 8px 28px rgba(0, 0, 0, 0.22);
}

/* Keep open FAQ readable/interactive even if IO marks it off-screen */
.faq-card.reveal-card[open] {
  opacity: 1;
  transform: none;
  pointer-events: auto;
}

.about-page .story-card.reveal-card.is-visible:hover,
.about-page .story-card.reveal-left.is-visible:hover,
.about-page .story-card.reveal-right.is-visible:hover,
.about-page .canada-card.reveal-card.is-visible:hover,
.about-page .canada-card.reveal-left.is-visible:hover,
.about-page .canada-card.reveal-right.is-visible:hover,
.about-page .final-cta-card.reveal-card.is-visible:hover,
.about-page .final-cta-card.reveal-left.is-visible:hover,
.about-page .final-cta-card.reveal-right.is-visible:hover {
  transform: translateY(-2px);
  border-color: rgba(139, 92, 246, 0.35);
  box-shadow: 0 14px 40px rgba(0, 0, 0, 0.28);
}

.about-page .story-card.reveal-card.is-visible:hover,
.about-page .story-card.reveal-left.is-visible:hover,
.about-page .story-card.reveal-right.is-visible:hover {
  background: var(--surface-2);
}

.about-page .canada-card.reveal-card.is-visible:hover,
.about-page .canada-card.reveal-left.is-visible:hover,
.about-page .canada-card.reveal-right.is-visible:hover,
.about-page .final-cta-card.reveal-card.is-visible:hover,
.about-page .final-cta-card.reveal-left.is-visible:hover,
.about-page .final-cta-card.reveal-right.is-visible:hover {
  background: linear-gradient(135deg, rgba(139, 92, 246, 0.12) 0%, rgba(236, 72, 153, 0.08) 100%);
}

.about-page .problem-card.reveal-card.is-visible:hover,
.about-page .problem-card.reveal-left.is-visible:hover,
.about-page .problem-card.reveal-right.is-visible:hover {
  border-color: rgba(139, 92, 246, 0.28);
  background: var(--surface-2);
  transform: translateY(-2px);
  box-shadow: 0 12px 32px rgba(0, 0, 0, 0.22);
}

.about-page .expect-card.reveal-card.is-visible:hover,
.about-page .expect-card.reveal-left.is-visible:hover,
.about-page .expect-card.reveal-right.is-visible:hover {
  border-color: rgba(139, 92, 246, 0.32);
  background: var(--surface-2);
  transform: translateY(-2px);
  box-shadow: 0 10px 28px rgba(0, 0, 0, 0.18);
}

.about-page .value-card.reveal-card.is-visible:hover,
.about-page .value-card.reveal-left.is-visible:hover,
.about-page .value-card.reveal-right.is-visible:hover {
  border-color: rgba(139, 92, 246, 0.32);
  background: var(--surface-2);
  transform: translateY(-2px);
  box-shadow: 0 10px 28px rgba(0, 0, 0, 0.18);
}

@media (max-width: 900px) {
  .price-card.popular.reveal-card.is-visible:hover,
  .price-card.popular.reveal-left.is-visible:hover,
  .price-card.popular.reveal-right.is-visible:hover {
    transform: translateY(-4px);
  }
}

/* Text groups: fade-in only (staggered opacity), no slide */
.reveal-text > * {
  opacity: 0;
  transform: none;
  transition: opacity 0.58s var(--wlc-reveal-ease);
}

.reveal-text.is-visible > * {
  opacity: 1;
}

.reveal-text.is-visible > *:nth-child(1) {
  transition-delay: 0.03s;
}
.reveal-text.is-visible > *:nth-child(2) {
  transition-delay: 0.08s;
}
.reveal-text.is-visible > *:nth-child(3) {
  transition-delay: 0.13s;
}
.reveal-text.is-visible > *:nth-child(4) {
  transition-delay: 0.18s;
}
.reveal-text.is-visible > *:nth-child(5) {
  transition-delay: 0.23s;
}
.reveal-text.is-visible > *:nth-child(6) {
  transition-delay: 0.28s;
}
.reveal-text.is-visible > *:nth-child(7) {
  transition-delay: 0.33s;
}
.reveal-text.is-visible > *:nth-child(8) {
  transition-delay: 0.38s;
}
.reveal-text.is-visible > *:nth-child(9) {
  transition-delay: 0.43s;
}
.reveal-text.is-visible > *:nth-child(10) {
  transition-delay: 0.48s;
}
.reveal-text.is-visible > *:nth-child(11) {
  transition-delay: 0.53s;
}
.reveal-text.is-visible > *:nth-child(12) {
  transition-delay: 0.58s;
}
.reveal-text.is-visible > *:nth-child(13) {
  transition-delay: 0.63s;
}
.reveal-text.is-visible > *:nth-child(14) {
  transition-delay: 0.68s;
}
.reveal-text.is-visible > *:nth-child(15) {
  transition-delay: 0.73s;
}
.reveal-text.is-visible > *:nth-child(16) {
  transition-delay: 0.78s;
}
.reveal-text.is-visible > *:nth-child(17) {
  transition-delay: 0.83s;
}
.reveal-text.is-visible > *:nth-child(18) {
  transition-delay: 0.88s;
}
.reveal-text.is-visible > *:nth-child(19) {
  transition-delay: 0.93s;
}
.reveal-text.is-visible > *:nth-child(20) {
  transition-delay: 0.98s;
}

/* When fading out, collapse stagger so exit feels cohesive */
.reveal-text:not(.is-visible) > * {
  transition-delay: 0s !important;
}

@media (prefers-reduced-motion: reduce) {
  .reveal-card,
  .reveal-left,
  .reveal-right,
  .reveal-text > * {
    opacity: 1 !important;
    transform: none !important;
    transition: none !important;
    pointer-events: auto !important;
  }
}
