:root {
  --brand-700: #1b4332;
  --brand-600: #2d6a4f;
  --brand-500: #40916c;
  --brand-100: #d8f3dc;
  --accent: #d97706;
  --accent-dark: #b45309;
  --ink: #0f172a;
  --cream: #faf9f6;
}

html {
  scroll-behavior: smooth;
}

body {
  background-color: var(--cream);
}

.font-serif {
  font-family: 'Fraunces', Georgia, serif;
  font-optical-sizing: auto;
}

/* Premium hero surface: soft warm radial + gradient, no clutter */
.hero-surface {
  background:
    radial-gradient(1100px 460px at 50% -12%, rgba(64, 145, 108, 0.14), transparent 62%),
    linear-gradient(180deg, #f3f7f2 0%, var(--cream) 58%);
}

/* Deep green conversion band */
.cta-band {
  background:
    radial-gradient(700px 300px at 85% 20%, rgba(64, 145, 108, 0.35), transparent 60%),
    linear-gradient(135deg, #1b4332 0%, #2d6a4f 100%);
}

/* Animated nav underline */
.nav-link {
  position: relative;
}
.nav-link::after {
  content: '';
  position: absolute;
  left: 0;
  bottom: -6px;
  height: 2px;
  width: 0;
  background: var(--brand-600);
  transition: width 0.25s ease;
}
.nav-link:hover::after,
.nav-link[aria-current='page']::after {
  width: 100%;
}

/* Reveal on scroll: content stays visible; motion is optional enhancement */
.reveal {
  opacity: 1;
  transform: none;
}
.js .reveal {
  transform: translateY(14px);
  transition: transform 0.55s cubic-bezier(0.22, 1, 0.36, 1), opacity 0.55s cubic-bezier(0.22, 1, 0.36, 1);
}
.js .reveal.is-visible {
  transform: none;
}

/* Editorial image treatments */
.hero-photo {
  object-fit: cover;
  width: 100%;
  height: 100%;
}
.card-cover {
  aspect-ratio: 16 / 10;
  overflow: hidden;
}
.card-cover img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.45s cubic-bezier(0.22, 1, 0.36, 1);
}
.group:hover .card-cover img {
  transform: scale(1.04);
}
.reveal[data-delay='1'] { transition-delay: 0.07s; }
.reveal[data-delay='2'] { transition-delay: 0.14s; }
.reveal[data-delay='3'] { transition-delay: 0.21s; }
.reveal[data-delay='4'] { transition-delay: 0.28s; }
.reveal[data-delay='5'] { transition-delay: 0.35s; }

/* Clear, consistent focus states */
a:focus-visible,
button:focus-visible,
input:focus-visible,
textarea:focus-visible,
select:focus-visible {
  outline: none;
  box-shadow: 0 0 0 2px #ffffff, 0 0 0 4px var(--brand-600);
  border-radius: 8px;
}

/* Mobile sticky CTA spacing so it never hides footer content */
@media (max-width: 767px) {
  body {
    padding-bottom: 4.5rem;
  }
}

@media (prefers-reduced-motion: reduce) {
  html {
    scroll-behavior: auto;
  }
  .reveal {
    opacity: 1 !important;
    transform: none !important;
    transition: none !important;
  }
  *,
  *::before,
  *::after {
    animation-duration: 0.001ms !important;
    transition-duration: 0.001ms !important;
  }
}
