/* ============================================================
   FREE HORSES TAG CORPORATION — style.css
   ============================================================ */

:root {
  --clr-forest:     #1e3a2f;
  --clr-forest-mid: #2d5443;
  --clr-forest-lt:  #3d7057;
  --clr-cream:      #faf6ef;
  --clr-cream-dk:   #f0e8da;
  --clr-warm-white: #fffcf7;
  --clr-terra:      #b85c2c;
  --clr-terra-lt:   #d4733d;
  --clr-gold:       #c8963c;
  --clr-gold-lt:    #e2b050;
  --clr-ink:        #1a1a18;
  --clr-ink-mid:    #3d3d38;
  --clr-ink-lt:     #6b6b62;
  --clr-border:     #e0d8ca;
  --clr-border-dk:  #c8bfb0;
  --ff-display: 'Playfair Display', Georgia, serif;
  --ff-body:    'Lora', Georgia, serif;
  --ff-ui:      'DM Sans', system-ui, sans-serif;
  --sp-sm: 1rem; --sp-md: 1.5rem; --sp-lg: 2.5rem;
  --sp-xl: 4rem; --sp-2xl: 6rem; --sp-3xl: 9rem;
  --r-sm: 6px; --r-md: 12px; --r-lg: 20px; --r-xl: 32px; --r-full: 9999px;
  --shadow-sm:  0 1px 3px rgba(30,58,47,.08);
  --shadow-md:  0 4px 16px rgba(30,58,47,.10);
  --shadow-lg:  0 12px 40px rgba(30,58,47,.14);
  --shadow-xl:  0 24px 64px rgba(30,58,47,.18);
  --t-fast: .15s ease; --t-mid: .3s ease;
  --container-max: 1200px; --container-pad: 1.5rem; --header-h: 80px;
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; font-size: 16px; -webkit-text-size-adjust: 100%; }
body { font-family: var(--ff-body); font-size: 1rem; line-height: 1.7; color: var(--clr-ink); background: var(--clr-cream); overflow-x: hidden; }
img { max-width: 100%; height: auto; display: block; }
a { color: var(--clr-terra); text-decoration: underline; text-underline-offset: 3px; transition: color var(--t-fast); }
a:hover { color: var(--clr-terra-lt); }
a:focus-visible { outline: 2px solid var(--clr-gold); outline-offset: 3px; border-radius: 2px; }
h1,h2,h3,h4,h5,h6 { font-family: var(--ff-display); font-weight: 700; line-height: 1.2; color: var(--clr-ink); }
address { font-style: normal; }

.skip-link { position: absolute; top: -100%; left: 1rem; z-index: 9999; padding: .75rem 1.5rem; background: var(--clr-forest); color: var(--clr-cream); text-decoration: none; border-radius: 0 0 var(--r-md) var(--r-md); }
.skip-link:focus { top: 0; }
.container { max-width: var(--container-max); margin-inline: auto; padding-inline: var(--container-pad); }
.section-padding { padding-block: var(--sp-3xl); }
@media (max-width: 768px) { .section-padding { padding-block: var(--sp-2xl); } }
.section-dark { background: var(--clr-forest); color: var(--clr-cream); }
.section-warm { background: var(--clr-cream-dk); }

.section-eyebrow { display: inline-block; font-family: var(--ff-ui); font-size: .75rem; font-weight: 500; letter-spacing: .15em; text-transform: uppercase; color: var(--clr-terra); margin-bottom: .75rem; }
.section-eyebrow.light { color: var(--clr-gold-lt); }
.section-headline { font-size: clamp(2rem, 4vw, 3rem); font-weight: 700; line-height: 1.15; margin-bottom: 1.25rem; }
.section-headline em { font-style: italic; color: var(--clr-terra); }
.section-headline.light { color: var(--clr-cream); }
.section-headline.light em { color: var(--clr-gold-lt); }
.section-intro { font-size: 1.125rem; color: var(--clr-ink-lt); max-width: 620px; line-height: 1.75; }
.section-intro.light { color: rgba(250,246,239,.8); }
.body-text { font-size: 1.0625rem; color: var(--clr-ink-mid); line-height: 1.8; margin-bottom: 1.25rem; }
.section-header.centered { text-align: center; display: flex; flex-direction: column; align-items: center; margin-bottom: var(--sp-xl); }

/* BUTTONS */
.btn { display: inline-flex; align-items: center; justify-content: center; gap: .5rem; padding: .875rem 2rem; border: 2px solid transparent; border-radius: var(--r-full); font-family: var(--ff-ui); font-size: .9375rem; font-weight: 500; text-decoration: none; cursor: pointer; transition: all var(--t-mid); white-space: nowrap; }
.btn-primary { background: var(--clr-terra); color: #fff; border-color: var(--clr-terra); }
.btn-primary:hover { background: var(--clr-terra-lt); color: #fff; transform: translateY(-2px); box-shadow: 0 8px 24px rgba(184,92,44,.35); }
.btn-secondary { background: transparent; color: var(--clr-terra); border-color: var(--clr-terra); }
.btn-secondary:hover { background: var(--clr-terra); color: #fff; transform: translateY(-2px); }
.btn-ghost { background: transparent; color: var(--clr-cream); border-color: rgba(250,246,239,.6); }
.btn-ghost:hover { background: rgba(250,246,239,.15); color: var(--clr-cream); }
.btn-gold { background: var(--clr-gold); color: var(--clr-forest); border-color: var(--clr-gold); font-weight: 700; }
.btn-gold:hover { background: var(--clr-gold-lt); transform: translateY(-2px); box-shadow: 0 8px 24px rgba(200,150,60,.45); }
.btn-full { width: 100%; }

/* IMG PLACEHOLDER */
.img-placeholder { background: var(--clr-cream-dk); border: 2px dashed var(--clr-border-dk); border-radius: var(--r-md); width: 100%; height: 100%; min-height: 360px; display: flex; align-items: center; justify-content: center; }
.img-placeholder-inner { display: flex; flex-direction: column; align-items: center; gap: .75rem; opacity: .5; }
.img-placeholder-icon { font-size: 3rem; }
.img-placeholder-text { font-family: var(--ff-ui); font-size: .8125rem; color: var(--clr-ink-lt); }

/* REVEAL */
.reveal { opacity: 0; transform: translateY(28px); transition: opacity .7s ease, transform .7s ease; }
.reveal.visible { opacity: 1; transform: translateY(0); }
.reveal:nth-child(2) { transition-delay: .1s; }
.reveal:nth-child(3) { transition-delay: .2s; }
.reveal:nth-child(4) { transition-delay: .3s; }
.reveal:nth-child(5) { transition-delay: .4s; }
.reveal:nth-child(6) { transition-delay: .5s; }

/* ── HEADER ── */
.site-header { position: fixed; top: 0; left: 0; right: 0; z-index: 1000; height: var(--header-h); background: rgba(250,246,239,.95); backdrop-filter: blur(12px); border-bottom: 1px solid transparent; transition: border-color var(--t-mid), box-shadow var(--t-mid); }
.site-header.scrolled { border-bottom-color: var(--clr-border); box-shadow: var(--shadow-md); }
.nav-container { max-width: var(--container-max); margin-inline: auto; padding-inline: var(--container-pad); height: 100%; display: flex; align-items: center; justify-content: space-between; gap: 2rem; }
.nav-logo { display: flex; align-items: center; gap: .625rem; text-decoration: none; flex-shrink: 0; }
.logo-icon { font-size: 1.75rem; line-height: 1; }
.logo-text { display: flex; flex-direction: column; line-height: 1.1; }
.logo-main { font-family: var(--ff-display); font-size: 1.125rem; font-weight: 700; color: var(--clr-forest); }
.logo-sub { font-family: var(--ff-ui); font-size: .65rem; font-weight: 400; letter-spacing: .08em; color: var(--clr-ink-lt); text-transform: uppercase; }
.nav-links { display: flex; align-items: center; gap: .25rem; list-style: none; }
.nav-link { font-family: var(--ff-ui); font-size: .875rem; color: var(--clr-ink-mid); text-decoration: none; padding: .5rem .75rem; border-radius: var(--r-sm); transition: color var(--t-fast), background var(--t-fast); }
.nav-link:hover { color: var(--clr-forest); background: rgba(30,58,47,.06); }
.nav-link.nav-cta { background: var(--clr-terra); color: #fff; padding: .5rem 1.25rem; border-radius: var(--r-full); font-weight: 500; margin-left: .5rem; }
.nav-link.nav-cta:hover { background: var(--clr-terra-lt); color: #fff; }
.nav-toggle { display: none; flex-direction: column; justify-content: center; gap: 5px; width: 44px; height: 44px; background: none; border: none; cursor: pointer; padding: 8px; border-radius: var(--r-sm); }
.nav-toggle:hover { background: rgba(30,58,47,.06); }
.hamburger-line { display: block; width: 100%; height: 2px; background: var(--clr-ink); border-radius: 2px; transition: all var(--t-mid); transform-origin: center; }
.nav-toggle[aria-expanded="true"] .hamburger-line:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.nav-toggle[aria-expanded="true"] .hamburger-line:nth-child(2) { opacity: 0; }
.nav-toggle[aria-expanded="true"] .hamburger-line:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

/* ── HERO ── */
.hero { position: relative; min-height: 100vh; display: flex; align-items: center; padding-top: var(--header-h);
  /* REPLACE: add background-image: url('images/horse-hero.jpg'); below */
  background-color: var(--clr-forest);
  background-image: linear-gradient(160deg, rgba(30,58,47,.95) 0%, rgba(45,84,67,.80) 50%, rgba(61,112,87,.70) 100%);
  background-size: cover; background-position: center; background-attachment: fixed;
}
.hero-overlay { position: absolute; inset: 0; background: linear-gradient(to right, rgba(20,40,30,.85) 0%, rgba(20,40,30,.45) 60%, rgba(20,40,30,.20) 100%); pointer-events: none; }
.hero-content { position: relative; z-index: 1; max-width: 700px; padding-inline: var(--container-pad); padding-block: var(--sp-2xl); padding-left: max(var(--container-pad), 6vw); margin-inline: auto; }
.hero-eyebrow { display: inline-block; font-family: var(--ff-ui); font-size: .75rem; letter-spacing: .18em; text-transform: uppercase; color: rgba(250,246,239,.7); margin-bottom: 1.25rem; }
.hero-headline { font-family: var(--ff-display); font-size: clamp(3rem, 7vw, 5.5rem); font-weight: 900; line-height: 1.05; color: var(--clr-cream); margin-bottom: 1.5rem; letter-spacing: -.02em; }
.hero-headline em { font-style: italic; color: var(--clr-gold-lt); font-weight: 400; }
.hero-sub { font-size: 1.125rem; color: rgba(250,246,239,.85); line-height: 1.75; margin-bottom: 2.5rem; max-width: 520px; }
.hero-actions { display: flex; gap: 1rem; flex-wrap: wrap; margin-bottom: 2.5rem; }
.hero-trust { display: flex; flex-wrap: wrap; gap: .75rem; }
.trust-badge { font-family: var(--ff-ui); font-size: .75rem; font-weight: 500; color: rgba(250,246,239,.7); letter-spacing: .05em; }
.hero-scroll { position: absolute; bottom: 2.5rem; left: 50%; transform: translateX(-50%); display: flex; flex-direction: column; align-items: center; text-decoration: none; opacity: .5; transition: opacity var(--t-mid); }
.hero-scroll:hover { opacity: 1; }
.scroll-line { display: block; width: 1px; height: 60px; background: linear-gradient(to bottom, transparent, var(--clr-cream)); animation: scrollPulse 2s ease-in-out infinite; }
@keyframes scrollPulse { 0%,100%{opacity:.4;transform:scaleY(1)} 50%{opacity:1;transform:scaleY(1.2)} }

/* ── IMPACT BAR ── */
.impact-bar { background: var(--clr-forest); padding-block: var(--sp-lg); }
.impact-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1rem; list-style: none; }
.impact-item { display: flex; flex-direction: column; align-items: center; text-align: center; padding: var(--sp-sm); border-right: 1px solid rgba(250,246,239,.1); }
.impact-item:last-child { border-right: none; }
.impact-number { font-family: var(--ff-display); font-size: clamp(2.5rem, 4vw, 3.5rem); font-weight: 900; color: var(--clr-gold-lt); line-height: 1; margin-bottom: .5rem; }
.impact-label { font-family: var(--ff-ui); font-size: .8125rem; letter-spacing: .05em; color: rgba(250,246,239,.65); text-transform: uppercase; }

/* ── ABOUT ── */
.about { background: var(--clr-warm-white); }
.about-grid { display: grid; grid-template-columns: 1fr 1fr; gap: var(--sp-2xl); align-items: center; }
.about-image { position: relative; }
.about-image .img-placeholder { min-height: 480px; border-radius: var(--r-xl); overflow: hidden; }
.about-badge { position: absolute; bottom: -1.5rem; right: -1.5rem; background: var(--clr-terra); color: #fff; border-radius: var(--r-lg); padding: 1.25rem 1.5rem; text-align: center; box-shadow: var(--shadow-lg); min-width: 120px; }
.badge-year { display: block; font-family: var(--ff-ui); font-size: .7rem; letter-spacing: .12em; text-transform: uppercase; opacity: .8; }
.badge-num { display: block; font-family: var(--ff-display); font-size: 2.5rem; font-weight: 900; line-height: 1; margin-block: .25rem; }
.badge-label { display: block; font-family: var(--ff-ui); font-size: .65rem; letter-spacing: .06em; opacity: .8; }
.about-content { padding-left: var(--sp-sm); }
.about-cta { margin-top: var(--sp-md); }

/* ── PROGRAMS ── */
.programs-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--sp-md); }
.program-card { background: rgba(250,246,239,.06); border: 1px solid rgba(250,246,239,.12); border-radius: var(--r-lg); padding: var(--sp-lg); transition: all var(--t-mid); }
.program-card:hover { background: rgba(250,246,239,.1); transform: translateY(-4px); }
.program-card-icon { font-size: 2.25rem; margin-bottom: 1rem; display: block; }
.program-card-title { font-family: var(--ff-display); font-size: 1.25rem; font-weight: 600; color: var(--clr-cream); margin-bottom: .75rem; }
.program-card-text { font-size: .9375rem; color: rgba(250,246,239,.72); line-height: 1.75; }

/* ── STORIES ── */
.stories { background: var(--clr-cream); }
.stories-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--sp-md); }
.story-card { background: var(--clr-warm-white); border: 1px solid var(--clr-border); border-radius: var(--r-lg); overflow: hidden; box-shadow: var(--shadow-md); transition: all var(--t-mid); }
.story-card:hover { box-shadow: var(--shadow-xl); transform: translateY(-6px); }
.story-card-image { position: relative; height: 240px; }
.story-card-image .img-placeholder { height: 100%; min-height: unset; border-radius: 0; border: none; border-bottom: 2px dashed var(--clr-border-dk); }
.story-card-tag { position: absolute; bottom: 1rem; left: 1rem; font-family: var(--ff-ui); font-size: .7rem; font-weight: 500; letter-spacing: .08em; text-transform: uppercase; color: #fff; background: var(--clr-terra); padding: .35rem .75rem; border-radius: var(--r-full); }
.story-card-body { padding: var(--sp-md); }
.story-card-name { font-family: var(--ff-display); font-size: 1.5rem; font-weight: 700; color: var(--clr-forest); margin-bottom: .25rem; }
.story-card-breed { font-family: var(--ff-ui); font-size: .8125rem; color: var(--clr-ink-lt); margin-bottom: .875rem; }
.story-card-text { font-size: .9375rem; color: var(--clr-ink-mid); line-height: 1.75; margin-bottom: 1rem; }
.story-outcome { display: inline-block; font-family: var(--ff-ui); font-size: .75rem; font-weight: 600; color: var(--clr-forest-lt); background: rgba(61,112,87,.1); border: 1px solid rgba(61,112,87,.25); padding: .35rem .875rem; border-radius: var(--r-full); }

/* ── GET INVOLVED ── */
.get-involved { background: var(--clr-warm-white); }
.involve-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: var(--sp-md); }
.involve-card { background: var(--clr-cream); border: 1px solid var(--clr-border); border-radius: var(--r-lg); padding: var(--sp-lg); display: flex; flex-direction: column; gap: .875rem; transition: all var(--t-mid); box-shadow: var(--shadow-sm); }
.involve-card:hover { box-shadow: var(--shadow-lg); transform: translateY(-4px); }
.involve-card--primary { background: var(--clr-forest); border-color: var(--clr-forest-mid); }
.involve-card-icon { font-size: 2.5rem; }
.involve-card-title { font-family: var(--ff-display); font-size: 1.5rem; font-weight: 700; }
.involve-card--primary .involve-card-title { color: var(--clr-cream); }
.involve-card-text { font-size: .9375rem; line-height: 1.75; flex: 1; }
.involve-card--primary .involve-card-text { color: rgba(250,246,239,.8); }

/* ══════════════════════════════════════════════════════════
   DONATION CARDS — 3×2 grid matching screenshot style
══════════════════════════════════════════════════════════ */
.donate-section { background: var(--clr-cream); }

.donation-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  max-width: 960px;
  margin: 0 auto var(--sp-lg);
}

.donation-card {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  padding: 2.75rem 1.75rem 2rem;
  background: var(--clr-cream);
  border: 1.5px solid var(--clr-border);
  border-radius: 22px;
  transition: box-shadow var(--t-mid), transform var(--t-mid);
}

.donation-card:hover {
  box-shadow: 0 16px 48px rgba(30,58,47,.13);
  transform: translateY(-5px);
}

.donation-card--featured {
  background: var(--clr-ink);
  border-color: var(--clr-ink);
}

.donation-card--patron {
  background: var(--clr-warm-white);
  border-color: var(--clr-border-dk);
}

/* Badge (MOST POPULAR / PATRON) */
.donation-badge {
  position: absolute;
  top: -15px;
  left: 50%;
  transform: translateX(-50%);
  white-space: nowrap;
  background: var(--clr-gold);
  color: var(--clr-forest);
  font-family: var(--ff-ui);
  font-size: .625rem;
  font-weight: 800;
  letter-spacing: .14em;
  text-transform: uppercase;
  padding: 5px 16px;
  border-radius: var(--r-full);
  box-shadow: 0 2px 8px rgba(200,150,60,.3);
}

.donation-badge--patron {
  background: var(--clr-ink);
  color: #fff;
  box-shadow: none;
}

/* Tier label */
.donation-tier {
  font-family: var(--ff-ui);
  font-size: .65rem;
  font-weight: 700;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--clr-ink-lt);
  margin-bottom: 1.375rem;
}
.donation-card--featured .donation-tier { color: rgba(250,246,239,.5); }

/* Price — editorial style: large italic numeral */
.donation-price {
  display: flex;
  align-items: flex-start;
  line-height: 1;
  margin-bottom: 1rem;
  color: var(--clr-ink);
}
.donation-card--featured .donation-price { color: var(--clr-cream); }

.price-sup {
  font-family: var(--ff-display);
  font-size: 1.5rem;
  font-weight: 400;
  margin-top: .625rem;
  margin-right: 2px;
  line-height: 1;
}

.price-int {
  font-family: var(--ff-display);
  font-size: clamp(3.25rem, 5.5vw, 4.75rem);
  font-weight: 400;
  font-style: italic;
  line-height: .88;
  letter-spacing: -.02em;
}

.price-dec {
  font-family: var(--ff-display);
  font-size: 1.375rem;
  font-weight: 400;
  margin-top: .625rem;
  color: var(--clr-ink-lt);
  line-height: 1;
}
.donation-card--featured .price-dec { color: rgba(250,246,239,.55); }

/* Description */
.donation-desc {
  font-family: var(--ff-body);
  font-size: .9375rem;
  color: var(--clr-ink-lt);
  line-height: 1.5;
  margin-bottom: 1.75rem;
  flex: 1;
}
.donation-card--featured .donation-desc { color: rgba(250,246,239,.6); }

/* Donate button */
.donation-btn {
  width: 100%;
  padding: .875rem 1.25rem;
  border-radius: 11px;
  background: var(--clr-ink);
  color: #fff;
  border: 2px solid var(--clr-ink);
  font-family: var(--ff-ui);
  font-size: .8125rem;
  font-weight: 800;
  letter-spacing: .14em;
  cursor: pointer;
  transition: all var(--t-mid);
  line-height: 1;
}

.donation-btn:hover {
  background: var(--clr-forest);
  border-color: var(--clr-forest);
  transform: translateY(-2px);
  box-shadow: 0 8px 20px rgba(30,58,47,.28);
}

.donation-btn:disabled {
  opacity: .55;
  cursor: not-allowed;
  transform: none;
  box-shadow: none;
}

/* Featured card button: white on dark */
.donation-btn--featured {
  background: transparent;
  border-color: rgba(255,255,255,.7);
  color: #fff;
}
.donation-btn--featured:hover {
  background: rgba(255,255,255,.12);
  border-color: #fff;
  box-shadow: none;
}

/* Trust row */
.donate-trust {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  gap: .75rem 2rem;
  padding-top: var(--sp-md);
  border-top: 1px solid var(--clr-border);
}
.dtrust-item { font-family: var(--ff-ui); font-size: .8125rem; color: var(--clr-ink-lt); font-weight: 500; }

/* ══════════════════════════════════════════════════════════
   STRIPE INLINE CHECKOUT OVERLAY
   Built and injected by script.js — styles defined here
══════════════════════════════════════════════════════════ */
.fh-overlay {
  display: none;
  position: fixed;
  inset: 0;
  z-index: 9990;
  background: rgba(10, 20, 15, .72);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  align-items: flex-start;
  justify-content: center;
  padding: calc(var(--header-h) + 1.5rem) 1rem 2rem;
  overflow-y: auto;
}
.fh-overlay.open { display: flex; }

.fh-modal {
  background: #fff;
  border-radius: 24px;
  width: 100%;
  max-width: 480px;
  flex-shrink: 0;
  box-shadow: 0 32px 80px rgba(0,0,0,.28), 0 8px 24px rgba(0,0,0,.14);
  overflow: hidden;
  animation: fhIn .32s cubic-bezier(.2, .9, .3, 1);
}
@keyframes fhIn { from { opacity:0; transform: translateY(20px) scale(.97); } to { opacity:1; transform: none; } }

/* Modal header */
.fh-header {
  background: var(--clr-forest);
  padding: 1.25rem 1.375rem 1.125rem;
  display: flex;
  align-items: center;
  gap: .875rem;
}
.fh-header-info { flex: 1; min-width: 0; }
.fh-org { font-family: var(--ff-ui); font-size: .65rem; font-weight: 500; letter-spacing: .12em; text-transform: uppercase; color: rgba(250,246,239,.5); margin-bottom: .2rem; }
.fh-desc { font-family: var(--ff-display); font-size: 1rem; font-weight: 700; color: var(--clr-cream); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.fh-price { font-family: var(--ff-display); font-size: 1.625rem; font-weight: 900; color: var(--clr-gold-lt); white-space: nowrap; flex-shrink: 0; }
.fh-close { flex-shrink: 0; width: 32px; height: 32px; border-radius: 50%; background: rgba(250,246,239,.1); border: none; color: rgba(250,246,239,.75); font-size: 1.25rem; line-height: 1; cursor: pointer; display: flex; align-items: center; justify-content: center; transition: background var(--t-fast); }
.fh-close:hover { background: rgba(250,246,239,.22); }

/* Modal body */
.fh-body { padding: 1.5rem; }
.fh-step { display: none; }
.fh-step.active { display: block; }

/* Step title */
.fh-step-title { font-family: var(--ff-display); font-size: 1.125rem; color: var(--clr-forest); margin-bottom: 1.125rem; }

/* Form layout */
.fh-row { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; margin-bottom: 12px; }
.fh-field { display: flex; flex-direction: column; gap: 5px; }
.fh-label { font-family: var(--ff-ui); font-size: .75rem; font-weight: 600; color: var(--clr-ink-mid); letter-spacing: .02em; }
.fh-input { padding: .75rem 1rem; border: 1.5px solid var(--clr-border); border-radius: 10px; font-family: var(--ff-body); font-size: .9375rem; color: var(--clr-ink); background: var(--clr-cream); width: 100%; transition: border-color var(--t-fast), box-shadow var(--t-fast); }
.fh-input:focus { outline: none; border-color: var(--clr-forest-lt); box-shadow: 0 0 0 3px rgba(30,58,47,.1); }
.fh-input::placeholder { color: var(--clr-ink-lt); opacity: .65; }

/* Error message */
.fh-error { display: none; background: rgba(184,92,44,.08); border: 1px solid rgba(184,92,44,.25); color: var(--clr-terra); font-family: var(--ff-ui); font-size: .8125rem; font-weight: 500; padding: .75rem 1rem; border-radius: 10px; margin-bottom: 1rem; }

/* Continue button */
.fh-btn-main { width: 100%; padding: .9375rem; background: var(--clr-forest); color: #fff; border: none; border-radius: 12px; font-family: var(--ff-ui); font-size: 1rem; font-weight: 700; cursor: pointer; margin-top: 4px; transition: background var(--t-fast), transform var(--t-fast); }
.fh-btn-main:hover { background: var(--clr-forest-mid); transform: translateY(-1px); }
.fh-btn-main:disabled { opacity: .6; cursor: not-allowed; transform: none; }

/* Note text */
.fh-note { text-align: left; margin-top: .875rem; font-family: var(--ff-ui); font-size: .75rem; color: var(--clr-ink-lt); line-height: 1.5; }
.fh-note--center { text-align: center; }

/* Step 2 — buyer bar */
.fh-buyer-bar { display: flex; align-items: center; justify-content: space-between; gap: 1rem; background: var(--clr-cream); border: 1px solid var(--clr-border); border-radius: 10px; padding: .75rem 1rem; margin-bottom: 1.25rem; flex-wrap: wrap; }
.fh-buyer-name { font-family: var(--ff-ui); font-size: .875rem; font-weight: 600; color: var(--clr-ink); }
.fh-change { background: none; border: none; font-family: var(--ff-ui); font-size: .8rem; color: var(--clr-terra); cursor: pointer; text-decoration: underline; padding: 0; }
.fh-change:hover { color: var(--clr-terra-lt); }

/* Stripe Elements container */
#fh-elements { background: var(--clr-cream); border: 1.5px solid var(--clr-border); border-radius: 12px; padding: 1rem; margin-bottom: 1rem; min-height: 60px; }

/* Pay button */
.fh-btn-pay { width: 100%; padding: 1rem; background: var(--clr-terra); color: #fff; border: none; border-radius: 12px; font-family: var(--ff-ui); font-size: 1rem; font-weight: 700; cursor: pointer; display: flex; align-items: center; justify-content: center; gap: 8px; transition: background var(--t-fast), transform var(--t-fast); }
.fh-btn-pay:hover { background: var(--clr-terra-lt); transform: translateY(-1px); }
.fh-btn-pay:disabled { opacity: .6; cursor: not-allowed; transform: none; }

/* Step 3 — success */
.fh-success { text-align: center; padding: 1rem 0; }
.fh-success-icon { font-size: 3.5rem; margin-bottom: 1rem; }
.fh-success-title { font-family: var(--ff-display); font-size: 1.75rem; color: var(--clr-forest); margin-bottom: .875rem; }
.fh-success-text { font-size: .9375rem; color: var(--clr-ink-mid); line-height: 1.75; margin-bottom: 1.5rem; }
.fh-btn-close-success { padding: .75rem 2rem; background: var(--clr-forest); color: #fff; border: none; border-radius: var(--r-full); font-family: var(--ff-ui); font-size: .9375rem; font-weight: 600; cursor: pointer; transition: background var(--t-fast); }
.fh-btn-close-success:hover { background: var(--clr-forest-mid); }

/* ── FAQ ── */
.faq-list { max-width: 780px; margin-inline: auto; display: flex; flex-direction: column; gap: .5rem; }
.faq-item { background: var(--clr-warm-white); border: 1px solid var(--clr-border); border-radius: var(--r-md); overflow: hidden; }
.faq-item:hover { box-shadow: var(--shadow-md); }
.faq-question { width: 100%; display: flex; justify-content: space-between; align-items: center; gap: 1rem; padding: 1.25rem 1.5rem; background: none; border: none; cursor: pointer; font-family: var(--ff-display); font-size: 1.0625rem; font-weight: 600; color: var(--clr-ink); text-align: left; transition: color var(--t-fast); }
.faq-question:hover { color: var(--clr-forest); }
.faq-icon { font-size: 1.375rem; color: var(--clr-terra); transition: transform var(--t-mid); flex-shrink: 0; }
.faq-question[aria-expanded="true"] .faq-icon { transform: rotate(45deg); }
.faq-answer { max-height: 0; overflow: hidden; transition: max-height .4s ease, padding .3s ease; padding: 0 1.5rem; }
.faq-answer.open { max-height: 400px; padding: 0 1.5rem 1.25rem; }
.faq-answer p { font-size: .9375rem; color: var(--clr-ink-mid); line-height: 1.8; border-top: 1px solid var(--clr-border); padding-top: 1rem; }

/* ── CONTACT ── */
.contact-grid { display: grid; grid-template-columns: 1fr 1.5fr; gap: var(--sp-2xl); align-items: start; }
.contact-info { display: flex; flex-direction: column; gap: var(--sp-md); }
.contact-block { padding: var(--sp-md); background: rgba(250,246,239,.05); border: 1px solid rgba(250,246,239,.1); border-radius: var(--r-md); }
.contact-block-title { font-family: var(--ff-ui); font-size: .75rem; font-weight: 600; letter-spacing: .12em; text-transform: uppercase; color: var(--clr-gold-lt); margin-bottom: .75rem; }
.contact-address { font-size: .9375rem; line-height: 1.8; color: rgba(250,246,239,.7); }
.legal-details { display: grid; grid-template-columns: auto 1fr; gap: .35rem 1rem; font-size: .875rem; }
.legal-details dt { font-family: var(--ff-ui); font-size: .75rem; font-weight: 600; text-transform: uppercase; color: rgba(250,246,239,.45); }
.legal-details dd { color: rgba(250,246,239,.8); }
.contact-form-wrap { background: rgba(250,246,239,.05); border: 1px solid rgba(250,246,239,.1); border-radius: var(--r-xl); padding: var(--sp-xl); box-shadow: var(--shadow-md); }
.contact-form { display: flex; flex-direction: column; gap: 1.25rem; }
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; }
.form-group { display: flex; flex-direction: column; gap: .5rem; }
.form-group--full { grid-column: 1/-1; }
.form-label { font-family: var(--ff-ui); font-size: .8125rem; font-weight: 600; color: rgba(250,246,239,.8); }
.form-label span { color: var(--clr-gold-lt); }
.form-input { width: 100%; padding: .875rem 1rem; background: rgba(255,255,255,.07); border: 1.5px solid rgba(255,255,255,.14); border-radius: var(--r-md); font-family: var(--ff-body); font-size: .9375rem; color: var(--clr-cream); transition: border-color var(--t-fast), box-shadow var(--t-fast); appearance: none; }
.form-input:focus { outline: none; border-color: var(--clr-gold-lt); box-shadow: 0 0 0 3px rgba(200,150,60,.18); }
.form-input::placeholder { color: rgba(250,246,239,.35); }
.form-textarea { min-height: 140px; resize: vertical; }
.form-message { padding: .875rem 1rem; border-radius: var(--r-md); font-family: var(--ff-ui); font-size: .875rem; font-weight: 500; display: none; }
.form-message.success { display: block; background: rgba(45,84,67,.15); border: 1px solid rgba(45,84,67,.4); color: var(--clr-gold-lt); }
.form-message.error { display: block; background: rgba(184,92,44,.1); border: 1px solid rgba(184,92,44,.3); color: var(--clr-terra-lt); }

/* ── FOOTER ── */
.site-footer { background: var(--clr-forest); color: rgba(250,246,239,.75); }
.footer-top { padding-block: var(--sp-3xl); border-bottom: 1px solid rgba(250,246,239,.08); }
.footer-grid { display: grid; grid-template-columns: 2fr 1fr 1fr 1.5fr; gap: var(--sp-xl); }
.footer-logo { display: inline-flex; align-items: center; gap: .5rem; font-family: var(--ff-display); font-size: 1.125rem; font-weight: 700; color: var(--clr-cream); text-decoration: none; margin-bottom: 1rem; }
.footer-tagline { font-family: var(--ff-body); font-style: italic; font-size: .9375rem; color: rgba(250,246,239,.55); margin-bottom: 1.25rem; }
.footer-legal { font-family: var(--ff-ui); font-size: .8125rem; color: rgba(250,246,239,.5); line-height: 1.75; }
.footer-legal strong { color: var(--clr-gold-lt); }
.footer-nav-title { font-family: var(--ff-ui); font-size: .7rem; font-weight: 600; letter-spacing: .15em; text-transform: uppercase; color: var(--clr-gold-lt); margin-bottom: 1.25rem; }
.footer-nav ul { list-style: none; padding: 0; display: flex; flex-direction: column; gap: .625rem; }
.footer-nav a { font-family: var(--ff-ui); font-size: .875rem; color: rgba(250,246,239,.65); text-decoration: none; transition: color var(--t-fast); }
.footer-nav a:hover { color: var(--clr-cream); }
.footer-contact address { font-size: .875rem; line-height: 1.8; color: rgba(250,246,239,.6); margin-bottom: .875rem; }
.footer-email { font-family: var(--ff-ui); font-size: .875rem; color: var(--clr-gold-lt); text-decoration: none; display: inline-block; margin-bottom: 1.25rem; }
.footer-email:hover { color: var(--clr-gold); }
.footer-bottom { padding-block: 1.5rem; }
.footer-bottom-inner { display: flex; justify-content: space-between; align-items: center; gap: 1rem; flex-wrap: wrap; }
.footer-copy { font-family: var(--ff-ui); font-size: .8125rem; color: rgba(250,246,239,.4); }
.footer-legal-links { display: flex; gap: 1.5rem; }
.footer-legal-links a { font-family: var(--ff-ui); font-size: .8125rem; color: rgba(250,246,239,.4); text-decoration: none; transition: color var(--t-fast); }
.footer-legal-links a:hover { color: rgba(250,246,239,.75); }
.back-to-top { position: fixed; bottom: 2rem; right: 2rem; width: 48px; height: 48px; border-radius: 50%; background: var(--clr-terra); color: #fff; border: none; cursor: pointer; font-size: 1.25rem; display: flex; align-items: center; justify-content: center; box-shadow: var(--shadow-lg); opacity: 0; visibility: hidden; transform: translateY(12px); transition: all var(--t-mid); z-index: 900; }
.back-to-top.visible { opacity: 1; visibility: visible; transform: translateY(0); }
.back-to-top:hover { background: var(--clr-terra-lt); transform: translateY(-3px); }

/* ══ RESPONSIVE ══════════════════════════════════════════════ */
@media (max-width: 1100px) { .footer-grid { grid-template-columns: 1fr 1fr; gap: var(--sp-lg); } }

@media (max-width: 900px) {
  .about-grid { grid-template-columns: 1fr; }
  .about-badge { bottom: -1rem; right: -.5rem; }
  .about-content { padding-left: 0; }
  .programs-grid { grid-template-columns: repeat(2, 1fr); }
  .stories-grid { grid-template-columns: 1fr; }
  .involve-grid { grid-template-columns: 1fr; }
  .contact-grid { grid-template-columns: 1fr; }
  .impact-grid { grid-template-columns: repeat(2, 1fr); }
  .donation-grid { grid-template-columns: repeat(2, 1fr); max-width: 640px; }
}

@media (max-width: 768px) {
  :root { --header-h: 68px; }
  .nav-toggle { display: flex; }
  .nav-links { position: fixed; top: var(--header-h); left: 0; right: 0; background: var(--clr-warm-white); border-top: 1px solid var(--clr-border); flex-direction: column; align-items: stretch; padding: 1rem var(--container-pad) 1.5rem; gap: .25rem; transform: translateY(-100%); opacity: 0; visibility: hidden; transition: transform .35s ease, opacity .35s ease, visibility .35s ease; box-shadow: var(--shadow-lg); z-index: 999; }
  .nav-links.open { transform: translateY(0); opacity: 1; visibility: visible; }
  .nav-link { padding: .75rem 1rem; font-size: 1rem; }
  .nav-link.nav-cta { margin-left: 0; text-align: center; margin-top: .5rem; }
  .hero-content { padding-left: var(--container-pad); }
  .hero-actions { flex-direction: column; }
  .programs-grid { grid-template-columns: 1fr; }
  .footer-grid { grid-template-columns: 1fr; }
  .footer-bottom-inner { flex-direction: column; text-align: center; }
  .footer-legal-links { justify-content: center; }
  .form-row { grid-template-columns: 1fr; }
  .contact-form-wrap { padding: var(--sp-md); }
  .fh-row { grid-template-columns: 1fr; }
  .fh-body { padding: 1.25rem; }
}

@media (max-width: 560px) {
  .donation-grid { grid-template-columns: 1fr; max-width: 380px; }
  .price-int { font-size: 3.5rem; }
  .impact-grid { grid-template-columns: 1fr 1fr; }
}

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