/* ============================================
   Give Page — Gateway Bible Church
   Clean, purposeful, no guilt.
   ============================================ */


/* ============================================
   HERO — Centered, warm
   ============================================ */

.give-hero {
  background: var(--dark-blue);
  padding: calc(var(--nav-height) + var(--space-16)) var(--space-6) var(--space-16);
  position: relative;
  overflow: hidden;
  text-align: center;
}

.give-hero--photo {
  background-image: url('assets/photos/legacy/high-school-5-1920.jpg');
  background-size: cover;
  background-position: center 40%;
}

/* Dark overlay for text readability */
.give-hero--photo::after {
  content: '';
  position: absolute;
  inset: 0;
  z-index: 1;
  /* Approved overlay recipe (matches homepage). */
  background:
    radial-gradient(ellipse at 50% 40%, rgba(13, 32, 56, 0.18) 0%, rgba(13, 32, 56, 0.45) 60%),
    linear-gradient(to bottom, rgba(0, 15, 35, 0.12) 0%, rgba(0, 15, 35, 0.25) 50%, rgba(13, 32, 56, 0.78) 100%);
}

@media (min-width: 768px) {
  .give-hero {
    padding: calc(var(--nav-height) + var(--space-24)) var(--space-10) var(--space-24);
  }
}

.give-hero-inner {
  position: relative;
  z-index: 2;
  max-width: 680px;
  margin: 0 auto;
}

.give-hero-title {
  font-size: clamp(2.5rem, 7vw, 5rem);
  font-weight: var(--font-weight-black);
  color: var(--white);
  letter-spacing: -0.04em;
  line-height: 1.0;
  margin-bottom: var(--space-5);
}

.give-hero-sub {
  font-size: clamp(var(--text-base), 2vw, var(--text-lg));
  font-weight: var(--font-weight-book);
  color: var(--white-70);
  line-height: 1.7;
  max-width: 520px;
  margin: 0 auto var(--space-8);
}

.give-hero-btn {
  font-size: var(--text-base);
  padding: var(--space-4) var(--space-12);
}

.give-hero-note {
  font-size: var(--text-xs);
  font-weight: var(--font-weight-book);
  color: var(--white-50);
  margin-top: var(--space-3);
}


/* ============================================
   WHERE YOUR GIVING GOES — 3-card impact
   ============================================ */

.give-impact-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-6);
}

@media (min-width: 768px) {
  .give-impact-grid {
    grid-template-columns: repeat(3, 1fr);
  }
}

.give-impact-card {
  padding: var(--space-8) var(--space-6);
  border-radius: var(--radius-lg);
  border: 1px solid var(--dark-blue-10);
  text-align: center;
}

.give-impact-card:first-child {
  background: var(--deep-blue);
  border-color: transparent;
  color: var(--white);
}

.give-impact-card:first-child .give-impact-title {
  color: var(--white);
}

.give-impact-card:first-child .give-impact-desc {
  color: var(--white-70);
}

.give-impact-stat {
  display: block;
  margin-bottom: var(--space-4);
}

.give-impact-icon {
  width: 56px;
  height: 56px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: var(--radius-md);
  background: var(--bright-blue-10);
  color: var(--bright-blue);
  margin: 0 auto var(--space-4);
}

.give-impact-title {
  font-size: var(--text-lg);
  font-weight: var(--font-weight-bold);
  color: var(--dark-blue);
  margin-bottom: var(--space-3);
}

.give-impact-desc {
  font-size: var(--text-sm);
  font-weight: var(--font-weight-book);
  color: var(--gray-blue);
  line-height: 1.7;
}


/* ============================================
   PHOTO BREAK — full-width warm moment
   ============================================ */

.give-photo-break {
  width: 100%;
  height: 360px;
  overflow: hidden;
  position: relative;
  margin-bottom: var(--space-10);
}

@media (min-width: 768px) {
  .give-photo-break {
    height: 440px;
  }
}

.give-photo-break img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center 40%;
  display: block;
  filter: saturate(0.9);
}


/* ============================================
   OTHER WAYS TO GIVE — split content + CTA card
   ============================================ */

.give-ways-layout {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-10);
  align-items: start;
}

@media (min-width: 768px) {
  .give-ways-layout {
    grid-template-columns: 1.3fr 1fr;
    gap: var(--space-12);
  }
}

.give-ways-list {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  margin-bottom: var(--space-8);
}

.give-way-item {
  display: flex;
  flex-direction: column;
  gap: 2px;
  padding: var(--space-3) var(--space-4);
  border-radius: var(--radius-md);
  background: var(--white);
}

.give-way-item strong {
  font-size: var(--text-xs);
  font-weight: var(--font-weight-bold);
  color: var(--dark-blue);
  text-transform: uppercase;
  letter-spacing: 0.06em;
}

.give-way-item span {
  font-size: var(--text-sm);
  font-weight: var(--font-weight-book);
  color: var(--gray-blue);
  line-height: 1.5;
}

/* Sticky CTA card */
.give-cta-card {
  background: var(--white);
  border-radius: var(--radius-lg);
  padding: var(--space-8);
  box-shadow: var(--shadow-md);
  text-align: center;
}

@media (min-width: 768px) {
  .give-cta-card {
    position: sticky;
    top: calc(var(--nav-height-scrolled) + var(--space-6));
  }
}

.give-cta-card-title {
  font-size: var(--text-xl);
  font-weight: var(--font-weight-bold);
  color: var(--dark-blue);
  margin-bottom: var(--space-3);
}

.give-cta-card-desc {
  font-size: var(--text-sm);
  font-weight: var(--font-weight-book);
  color: var(--gray-blue);
  line-height: 1.6;
  margin-bottom: var(--space-6);
}

/* ============================================
   CLOSING
   ============================================ */

.give-closing-inner {
  text-align: center;
  max-width: 700px;
  margin: 0 auto;
  position: relative;
  z-index: 2;
}

.give-closing-headline {
  font-size: clamp(2.5rem, 7vw, var(--text-5xl));
  font-weight: var(--font-weight-black);
  color: var(--white);
  letter-spacing: -0.03em;
  line-height: 1.05;
  margin-bottom: var(--space-5);
}

.give-closing-sub {
  font-size: var(--text-lg);
  font-weight: var(--font-weight-book);
  color: rgba(255, 255, 255, 0.85);
  line-height: 1.7;
  max-width: 560px;
  margin: 0 auto var(--space-8);
}

.give-closing-actions {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: var(--space-3);
}
