/* ============================================================
   Hero Component
   ============================================================ */

/* --- Full-screen hero (Home page) --- */
.hero {
  position: relative;
  min-height: 100vh;
  display: flex;
  align-items: center;
  overflow: hidden;
  background-color: var(--color-green-dark);
}

.hero__bg {
  position: absolute;
  inset: 0;
  background-image: url('/images/wqh-lavender-field-800w.webp');
  background-size: cover;
  background-position: center 40%;
  background-repeat: no-repeat;
  opacity: 0.6;
}

@media (min-width: 769px) {
  .hero__bg {
    background-image: url('/images/wqh-lavender-field.webp');
  }
}

.hero__overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(
    135deg,
    rgba(30, 61, 47, 0.85) 0%,
    rgba(30, 61, 47, 0.6) 50%,
    rgba(46, 90, 69, 0.4) 100%
  );
}

.hero__content {
  position: relative;
  z-index: var(--z-raised);
  max-width: var(--container-max);
  min-width: 0;
  margin-inline: auto;
  padding-inline: var(--space-6);
  padding-block: calc(var(--nav-height) + var(--space-20)) var(--space-20);
  text-align: center;
}

.hero__eyebrow {
  font-size: var(--text-sm);
  font-weight: var(--weight-bold);
  letter-spacing: var(--tracking-widest);
  text-transform: uppercase;
  color: var(--color-gold);
  margin-bottom: var(--space-5);
  text-align: center;
}

.hero__title {
  font-family: var(--font-heading);
  font-size: clamp(var(--text-4xl), 7vw, var(--text-7xl));
  line-height: var(--leading-tight);
  color: var(--color-white);
  max-width: 14ch;
  margin-inline: auto;
  margin-bottom: var(--space-6);
}

.hero__title em {
  font-style: italic;
  color: var(--color-gold);
}

/* Shimmer on "for years." — lighter green band, seamless loop (no jump) */
.hero__shimmer {
  /* Repeating gold–green–gold so 0% and 100% look identical */
  background: linear-gradient(
    90deg,
    var(--color-gold) 0%,
    var(--color-gold) 16%,
    color-mix(in srgb, var(--color-green-light) 55%, white) 25%,
    var(--color-gold) 33%,
    var(--color-gold) 50%,
    var(--color-gold) 58%,
    color-mix(in srgb, var(--color-green-light) 55%, white) 66%,
    var(--color-gold) 75%,
    var(--color-gold) 100%
  );
  background-size: 300% 100%;
  background-clip: text;
  -webkit-background-clip: text;
  color: transparent;
  animation: heroShimmer 3.2s cubic-bezier(0.35, 0, 0.25, 1) 0.6s infinite;
}

@keyframes heroShimmer {
  0%   { background-position: 0% 0; }
  100% { background-position: 100% 0; }
}

@media (prefers-reduced-motion: reduce) {
  .hero__shimmer { animation: none; background-position: 0% 0; }
}

.hero__body {
  font-size: var(--text-lg);
  line-height: var(--leading-loose);
  color: rgba(255, 255, 255, 0.8);
  max-width: 52ch;
  margin-inline: auto;
  margin-bottom: var(--space-10);
}

.hero__actions {
  display: flex;
  justify-content: center;
  gap: var(--space-4);
  flex-wrap: wrap;
}

.hero__scroll-hint {
  position: absolute;
  bottom: var(--space-8);
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-2);
  color: rgba(255, 255, 255, 0.5);
  font-size: var(--text-xs);
  letter-spacing: var(--tracking-wide);
  text-transform: uppercase;
  animation: bounce 2s infinite;
}

@keyframes bounce {
  0%, 100% { transform: translateX(-50%) translateY(0); }
  50%       { transform: translateX(-50%) translateY(6px); }
}

/* --- Page header (interior pages) --- */
.page-hero {
  background-color: var(--color-green);
  padding-top: calc(var(--nav-height) + var(--space-20));
  padding-bottom: var(--space-20);
  position: relative;
  overflow: hidden;
}

/* Background image layer — default; override with style="--page-hero-bg: url('...')" on the header */
.page-hero::before {
  content: '';
  position: absolute;
  inset: 0;
  z-index: 0;
  background-image: var(--page-hero-bg, url('/images/wqh-lavender-field-800w.webp'));
  background-size: cover;
  background-position: center 40%;
  background-repeat: no-repeat;
  transform-origin: center 40%;
  animation: kenBurns 10s ease-in-out infinite alternate;
}

@media (min-width: 769px) {
  .page-hero::before {
    background-image: var(--page-hero-bg, url('/images/wqh-lavender-field.webp'));
  }
}

/* Dark overlay for text readability */
.page-hero::after {
  content: '';
  position: absolute;
  inset: 0;
  z-index: 1;
  background: linear-gradient(
    135deg,
    rgba(30, 61, 47, 0.88) 0%,
    rgba(30, 61, 47, 0.65) 50%,
    rgba(46, 90, 69, 0.45) 100%
  );
}

.page-hero__content {
  position: relative;
  z-index: var(--z-raised);
  max-width: var(--container-max);
  margin-inline: auto;
  padding-inline: var(--space-6);
}

.page-hero__eyebrow {
  color: var(--color-gold);
  font-size: var(--text-xs);
  font-weight: var(--weight-bold);
  letter-spacing: var(--tracking-widest);
  text-transform: uppercase;
  margin-bottom: var(--space-4);
}

.page-hero__title {
  font-family: var(--font-heading);
  font-size: clamp(var(--text-4xl), 6vw, var(--text-6xl));
  color: var(--color-white);
  max-width: 18ch;
  margin-bottom: var(--space-5);
}

.page-hero__body {
  font-size: var(--text-lg);
  line-height: var(--leading-loose);
  color: rgba(255, 255, 255, 0.75);
  max-width: 55ch;
}

/* --- Responsive --- */
@media (max-width: 768px) {
  .hero__content { padding-inline: var(--space-4); }
  .hero__actions { flex-direction: column; align-items: center; }
}

@media (max-width: 768px) {
  .page-hero { padding-top: calc(var(--nav-height) + var(--space-12)); padding-bottom: var(--space-12); }
  .page-hero__content { padding-inline: var(--space-4); }
  .page-hero__title { max-width: none; font-size: clamp(var(--text-2xl), 5vw, var(--text-4xl)); }
}
