/* =============================================================
   hero.css
   Full viewport hero. Desktop: two-column split. Mobile: stacked.
   ============================================================= */

.hero {
  min-height: calc(100vh - 72px);
  display: flex;
  align-items: center;
  background: var(--color-bg);
  padding: 80px 0;
}

.hero__inner {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 80px;
  align-items: center;
}

.hero__content {
  max-width: 560px;
}

.hero__badge {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 8px 16px;
  background: var(--color-bg-alt);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-button);
  font-size: 13px;
  font-weight: 500;
  letter-spacing: 0.04em;
  color: var(--color-text-primary);
  margin-bottom: 28px;
}

.hero__badge-mark {
  color: var(--color-gold);
}

.hero__eyebrow {
  margin-bottom: 20px;
}

.hero__headline {
  font-size: clamp(40px, 6vw, 68px);
  letter-spacing: 0.005em;
  line-height: 1.05;
  margin-bottom: 24px;
}

.hero__headline em {
  font-style: italic;
  font-weight: 400;
}

.hero__sub {
  font-size: 19px;
  color: var(--color-text-secondary);
  margin-bottom: 40px;
  line-height: 1.5;
}

/* Hero image. Landscape frame; background-image fills it.
   Position is left-center so the bell anchors near the headline. */
.hero__media {
  width: 100%;
  aspect-ratio: 5 / 4;
  background-color: var(--color-bg-alt);
  background-image: url('../images/hero.jpg');
  background-size: cover;
  background-position: left center;
  border-radius: 18px;
  overflow: hidden;
}

/* Tablet */
@media (max-width: 1024px) {
  .hero__inner {
    gap: 48px;
  }
}

/* Mobile */
@media (max-width: 768px) {
  .hero {
    min-height: auto;
    padding: 48px 0 64px;
  }

  .hero__inner {
    grid-template-columns: 1fr;
    gap: 40px;
  }

  .hero__media {
    order: -1;
    aspect-ratio: 4 / 3;
  }

  .hero__headline {
    font-size: clamp(36px, 9vw, 52px);
  }

  .hero__sub {
    font-size: 17px;
    margin-bottom: 32px;
  }
}

/* =========================
   Email capture form (shared form styles, used in hero + final CTA)
   ========================= */

.email-form {
  display: flex;
  gap: 10px;
  background: #fff;
  padding: 6px;
  border-radius: var(--radius-button);
  border: 1px solid var(--color-border);
  max-width: 480px;
}

.email-form__input {
  flex: 1;
  padding: 12px 18px;
  border: none;
  background: transparent;
  font-size: 15px;
  color: var(--color-text-primary);
  outline: none;
  min-width: 0;
}

.email-form__input::placeholder {
  color: var(--color-text-secondary);
}

.email-form__button {
  padding: 12px 20px;
  background: var(--color-accent);
  color: #fff;
  border-radius: var(--radius-button);
  font-size: 14px;
  font-weight: 500;
  letter-spacing: 0.02em;
  transition: background var(--transition-base);
  white-space: nowrap;
}

.email-form__button:hover {
  background: var(--color-accent-hover);
}

.email-form__message {
  margin-top: 14px;
  font-size: 14px;
  color: var(--color-accent);
  min-height: 20px;
}

.email-form__message[data-state="error"] {
  color: #B0492E;
}

@media (max-width: 540px) {
  .email-form {
    flex-direction: column;
    background: transparent;
    border: none;
    padding: 0;
    gap: 12px;
  }

  .email-form__input {
    background: #fff;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-button);
    padding: 16px 20px;
    min-height: 52px;
  }

  .email-form__button {
    padding: 16px 20px;
    min-height: 52px;
    width: 100%;
  }
}
