/* Chase Financial Holdings — client-side enhancements
   No build step, no dependencies. Loaded via <link> in index.html. */

/* --- Smooth scrolling for in-page anchors --- */
html { scroll-behavior: smooth; }

/* --- Reveal on scroll --- */
.cfh-reveal {
  opacity: 0;
  transform: translateY(28px);
  transition: opacity 900ms cubic-bezier(0.22, 1, 0.36, 1),
              transform 900ms cubic-bezier(0.22, 1, 0.36, 1);
  will-change: opacity, transform;
}
.cfh-reveal-in {
  opacity: 1 !important;
  transform: translateY(0) !important;
}

/* --- Hero entrance (text fade + rise) --- */
[data-testid="home-hero"] .eyebrow,
[data-testid="home-hero"] h1,
[data-testid="home-hero"] > div > div > p,
[data-testid="page-eyebrow"],
[data-testid="page-title"] {
  animation: cfh-hero-in 1100ms cubic-bezier(0.22, 1, 0.36, 1) both;
}
[data-testid="home-hero"] h1 { animation-delay: 80ms; }
[data-testid="home-hero"] > div > div > p { animation-delay: 220ms; }
[data-testid="home-hero"] [data-testid="hero-cta-primary"],
[data-testid="home-hero"] [data-testid="hero-cta-secondary"] {
  animation: cfh-hero-in 1100ms 360ms cubic-bezier(0.22, 1, 0.36, 1) both;
}
@keyframes cfh-hero-in {
  from { opacity: 0; transform: translateY(20px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* --- Hero image: subtle background zoom --- */
[data-testid="hero-image"] {
  animation: cfh-hero-zoom 16s ease-out both;
  transform-origin: center;
}
@keyframes cfh-hero-zoom {
  from { transform: scale(1.08); }
  to   { transform: scale(1); }
}

/* Page-header background image — same subtle zoom */
[data-testid="page-header"] > div[aria-hidden="true"]:first-of-type {
  animation: cfh-hero-zoom 18s ease-out both;
}

/* --- Card / tile hover lift --- */
a[data-testid^="segment-card-"],
a[data-testid^="segment-tile-"],
a[data-testid^="about-tile-"],
a[data-testid^="segment-related-"] {
  transition: transform 450ms cubic-bezier(0.22, 1, 0.36, 1),
              box-shadow 450ms ease;
  will-change: transform;
}
a[data-testid^="segment-card-"]:hover,
a[data-testid^="segment-tile-"]:hover,
a[data-testid^="about-tile-"]:hover,
a[data-testid^="segment-related-"]:hover {
  transform: translateY(-4px);
  box-shadow: 0 28px 60px -22px rgba(10, 17, 40, 0.28);
}

/* Image zoom inside segment tiles on hover already exists; reinforce easing */
a[data-testid^="segment-tile-"] img {
  transition: transform 900ms cubic-bezier(0.22, 1, 0.36, 1);
}

/* --- Button hover lift --- */
[data-testid="hero-cta-primary"],
[data-testid="header-cta"],
[data-testid="contact-submit"],
[data-testid="mobile-nav-cta"] {
  transition: transform 280ms ease, background-color 280ms ease,
              box-shadow 280ms ease;
}
[data-testid="hero-cta-primary"]:hover,
[data-testid="header-cta"]:hover,
[data-testid="contact-submit"]:hover:not(:disabled),
[data-testid="mobile-nav-cta"]:hover {
  transform: translateY(-1px);
  box-shadow: 0 14px 30px -12px rgba(10, 17, 40, 0.45);
}

/* --- Nav link colour transitions --- */
nav a, header a {
  transition: color 280ms ease;
}

/* --- Mobile menu slide-down --- */
[data-testid="mobile-menu"] {
  animation: cfh-menu-down 420ms cubic-bezier(0.22, 1, 0.36, 1) both;
}
[data-testid="mobile-menu"] a {
  animation: cfh-menu-item-in 520ms cubic-bezier(0.22, 1, 0.36, 1) both;
}
@keyframes cfh-menu-down {
  from { opacity: 0; transform: translateY(-8px); }
  to   { opacity: 1; transform: translateY(0); }
}
@keyframes cfh-menu-item-in {
  from { opacity: 0; transform: translateY(-4px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* --- Dropdown menu fade --- */
[data-testid="dropdown-about"],
[data-testid="dropdown-focus"] {
  animation: cfh-dropdown-in 260ms cubic-bezier(0.22, 1, 0.36, 1) both;
}
@keyframes cfh-dropdown-in {
  from { opacity: 0; transform: translateY(-4px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* --- Reduced motion: disable everything that moves --- */
@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  .cfh-reveal,
  .cfh-reveal-in,
  [data-testid="home-hero"] .eyebrow,
  [data-testid="home-hero"] h1,
  [data-testid="home-hero"] > div > div > p,
  [data-testid="page-eyebrow"],
  [data-testid="page-title"],
  [data-testid="hero-image"],
  [data-testid="page-header"] > div[aria-hidden="true"]:first-of-type,
  [data-testid="mobile-menu"],
  [data-testid="mobile-menu"] a,
  [data-testid="dropdown-about"],
  [data-testid="dropdown-focus"] {
    animation: none !important;
    transition: none !important;
    opacity: 1 !important;
    transform: none !important;
  }
}
