/* ============================================================
   INNER SALES PAGE — Donations Make Difference
   Alternating card rows · uniform headings · form hero
   ============================================================ */

/* ---------- INNER HERO (shorter than landing, different image) ---------- */
.inner-hero {
  position: relative; min-height: 80svh;
  margin-top: -74px; padding: 150px var(--pad-x) 64px;
  display: flex; align-items: center;
  background: var(--forest-deep); overflow: hidden;
}
.inner-hero .hero-bg img { object-position: 50% 54%; }
.inner-hero-grid {
  position: relative; z-index: 4; width: 100%;
  display: grid; grid-template-columns: minmax(0,1.05fr) minmax(338px,0.95fr);
  gap: clamp(32px,5vw,72px); align-items: center;
}
.inner-hero-copy { position: relative; color: var(--cream); max-width: 600px; text-shadow: 0 1px 16px rgba(8,20,38,0.5); }
.inner-hero-copy::before {
  content: ""; position: absolute; z-index: -1; pointer-events: none;
  inset: -54px -120px -40px -92px;
  background: radial-gradient(ellipse 70% 64% at 26% 46%, rgba(8,20,38,0.52), rgba(8,20,38,0.2) 56%, transparent 80%);
  filter: blur(8px);
}
.inner-hero h1 {
  font-family: var(--display); font-weight: 800;
  font-size: clamp(36px, 4.9vw, 62px); line-height: 1.03;
  letter-spacing: -0.03em; margin: 18px 0 18px;
  text-shadow: 0 2px 22px rgba(8,20,38,0.7), 0 1px 4px rgba(8,20,38,0.5);
  text-wrap: balance;
}
.inner-hero h1 .serif-accent { color: var(--brass-bright); font-size: 1.04em; }
.inner-lede {
  font-size: clamp(16px,1.5vw,18px); line-height: 1.65;
  color: rgba(242,246,252,0.84); max-width: 520px; margin-bottom: 26px; text-wrap: pretty;
}
.inner-cta { display: flex; align-items: center; gap: 16px; flex-wrap: wrap; }
.inner-badges {
  display: flex; gap: clamp(20px,3vw,40px); flex-wrap: wrap;
  margin-top: 30px; border-top: 1px solid var(--line-dark); padding-top: 22px;
}
.inner-badge .v { display: block; font-family: var(--display); font-weight: 800; font-size: clamp(22px,2.4vw,30px); color: var(--cream); letter-spacing: -0.03em; font-variant-numeric: tabular-nums; }
.inner-badge .k { font-size: 12.5px; color: var(--sage); font-weight: 600; }
@media (max-width: 980px) { .inner-hero-grid { grid-template-columns: 1fr; } .inner-hero-card { max-width: 460px; } .inner-hero { min-height: auto; } }

/* ---------- INTRO BAND ---------- */
.inner-section { padding: clamp(64px,8vw,118px) var(--pad-x); }
.inner-section.tinted {
  background:
    radial-gradient(ellipse 46% 40% at 92% -4%, rgba(31,111,214,0.06), transparent 60%),
    radial-gradient(ellipse 40% 34% at -6% 104%, rgba(224,58,44,0.05), transparent 60%),
    var(--cream);
}
.inner-section.light { background: var(--cream-2); }
.inner-intro { max-width: 820px; margin: 0 auto; text-align: center; }
.inner-intro .eyebrow { color: var(--brass); display: block; margin-bottom: 16px; }
.inner-intro p { margin-top: 18px; color: var(--text-soft); font-size: 16.5px; line-height: 1.75; text-wrap: pretty; }
.inner-intro .btn { margin-top: 30px; }

/* uniform content headings (all H tags ≈ H2 size, per brief) */
.inner-content h2, .inner-content h3, .inner-content h4, .inner-content h5,
.inner-intro h2, .inner-intro h3 {
  font-family: var(--display); font-weight: 800;
  font-size: clamp(25px, 3vw, 33px); line-height: 1.14;
  letter-spacing: -0.02em; color: var(--text); text-wrap: balance;
}

/* ---------- ALTERNATING CONTENT ROWS ---------- */
.inner-content { background: var(--cream); }
.content-row {
  display: grid; grid-template-columns: 1fr 1fr;
  gap: clamp(30px,5vw,68px); align-items: center;
  max-width: var(--maxw); margin: 0 auto;
  padding: clamp(40px,4.6vw,62px) 0;
}
.content-row + .content-row { border-top: 1px solid var(--line-light); }
.content-row.reverse .ct-text { order: 2; }
.ct-text .eyebrow { color: var(--brass); display: block; margin-bottom: 14px; }
.ct-text h2, .ct-text h3 { margin-bottom: 16px; }
.ct-text p { color: var(--text-soft); line-height: 1.8; font-size: 16px; text-align: justify; hyphens: auto; -webkit-hyphens: auto; text-wrap: pretty; }
.ct-text p + p { margin-top: 14px; }
.ct-text .row-link { display: inline-flex; align-items: center; gap: 8px; margin-top: 20px; font-family: var(--display); font-weight: 700; font-size: 15px; color: var(--fern); text-decoration: none; transition: gap 0.25s; }
.ct-text .row-link:hover { gap: 12px; }
.ct-text .row-link svg { color: var(--brass); }
@media (max-width: 860px) {
  .content-row { grid-template-columns: 1fr; gap: 28px; }
  .content-row.reverse .ct-text { order: 0; }
  .ct-text p { text-align: left; }
}

/* ---------- ASIDE CARDS (the side-to-side visuals) ---------- */
.aside-photo { position: relative; border-radius: var(--radius); overflow: hidden; aspect-ratio: 1693 / 929; box-shadow: 0 2px 4px rgba(17,36,64,0.06), 0 42px 82px -46px rgba(17,36,64,0.5); }
.aside-photo img { width: 100%; height: 100%; object-fit: cover; object-position: center; display: block; }
.aside-photo .ap-tag { position: absolute; left: 16px; bottom: 16px; background: rgba(8,20,38,0.78); backdrop-filter: blur(8px); color: var(--cream); font-size: 13px; font-weight: 600; padding: 9px 16px; border-radius: 999px; border: 1px solid var(--line-dark); }

.aside-card {
  position: relative; overflow: hidden;
  background: linear-gradient(180deg,#fff,var(--card));
  border: 1px solid rgba(17,36,64,0.08); border-radius: var(--radius);
  padding: clamp(28px,3vw,38px);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.9), 0 1px 2px rgba(17,36,64,0.04), 0 28px 56px -36px rgba(17,36,64,0.24);
}
.aside-card.dark {
  background: linear-gradient(165deg, var(--forest-soft) 0%, var(--forest) 60%);
  color: var(--cream); border-color: transparent;
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.08), 0 30px 60px -38px rgba(0,0,0,0.55);
}
.aside-card.dark h3, .aside-card.dark h4 { color: var(--cream); }
.aside-card .ac-eyebrow { font-family: var(--display); font-size: 12px; font-weight: 700; letter-spacing: 0.2em; text-transform: uppercase; color: var(--brass); display: block; margin-bottom: 14px; }
.aside-card.dark .ac-eyebrow { color: var(--brass-bright); }
.ac-glow { position: absolute; width: 280px; height: 280px; border-radius: 50%; background: radial-gradient(circle, rgba(224,58,44,0.2), transparent 65%); top: -70px; right: -60px; pointer-events: none; }

/* checklist inside aside */
.ac-checks { list-style: none; display: flex; flex-direction: column; gap: 13px; }
.ac-checks li { position: relative; padding-left: 30px; font-size: 15px; line-height: 1.45; }
.aside-card:not(.dark) .ac-checks li { color: var(--text); }
.aside-card.dark .ac-checks li { color: rgba(242,246,252,0.9); }
.ac-checks li::before {
  content: ""; position: absolute; left: 0; top: 1px; width: 20px; height: 20px; border-radius: 50%;
  background: var(--fern) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 14 14'%3E%3Cpath d='M3 7.4 5.8 10.2 11 4.2' stroke='white' stroke-width='2' fill='none' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E") no-repeat center / 13px;
}

/* stat block inside aside */
.ac-stats { display: grid; grid-template-columns: 1fr 1fr; gap: 22px 18px; }
.ac-stat .n { display: block; font-family: var(--display); font-weight: 800; font-size: clamp(28px,3.4vw,40px); letter-spacing: -0.03em; color: var(--fern); line-height: 1; }
.aside-card.dark .ac-stat .n { color: var(--brass-bright); }
.ac-stat .l { font-size: 13px; color: var(--text-soft); margin-top: 6px; display: block; }
.aside-card.dark .ac-stat .l { color: var(--sage); }

/* quote aside */
.aside-quote { font-family: var(--display); font-weight: 600; font-size: clamp(19px,2vw,23px); line-height: 1.4; letter-spacing: -0.01em; color: var(--cream); }
.aside-quote .serif-accent { color: var(--brass-bright); }
.aq-by { display: flex; align-items: center; gap: 12px; margin-top: 22px; }
.aq-avatar { width: 42px; height: 42px; border-radius: 50%; background: var(--brass); color: var(--ink); display: grid; place-items: center; font-family: var(--display); font-weight: 800; }
.aq-by-name { font-weight: 700; font-size: 14px; color: var(--cream); display: block; }
.aq-by-role { font-size: 13px; color: var(--sage); }

/* ---------- 3-STEP STRIP ---------- */
.mini-steps { max-width: var(--maxw); margin: clamp(36px,4vw,52px) auto 0; display: grid; grid-template-columns: repeat(3,1fr); gap: 22px; }
.mini-step { position: relative; background: linear-gradient(180deg,#fff,var(--card)); border: 1px solid rgba(17,36,64,0.08); border-radius: var(--radius); padding: 30px 28px; box-shadow: inset 0 1px 0 rgba(255,255,255,0.9), 0 22px 46px -34px rgba(17,36,64,0.2); transition: transform 0.4s var(--ease), box-shadow 0.4s var(--ease); }
.mini-step:hover { transform: translateY(-6px); box-shadow: inset 0 1px 0 rgba(255,255,255,0.9), 0 40px 72px -40px rgba(17,36,64,0.32); }
.mini-step .ms-n { width: 44px; height: 44px; border-radius: 50%; display: grid; place-items: center; font-family: var(--display); font-weight: 800; font-size: 18px; color: #fff; background: linear-gradient(150deg, var(--fern), #1657b0); margin-bottom: 18px; box-shadow: inset 0 1px 0 rgba(255,255,255,0.25); }
.mini-step h3 { margin-bottom: 9px; }
.mini-step p { font-size: 14.5px; line-height: 1.6; color: var(--text-soft); }
@media (max-width: 760px) { .mini-steps { grid-template-columns: 1fr; max-width: 480px; } }

/* ---------- FEATURE DUO (small labeled cards, 2-up) ---------- */
.feature-duo { max-width: var(--maxw); margin: 0 auto; display: grid; grid-template-columns: 1fr 1fr; gap: 20px; }
.fd-card { display: flex; align-items: flex-start; gap: 16px; background: linear-gradient(180deg,#fff,var(--card)); border: 1px solid rgba(17,36,64,0.08); border-radius: 18px; padding: 24px 26px; box-shadow: inset 0 1px 0 rgba(255,255,255,0.9), 0 18px 40px -32px rgba(17,36,64,0.2); }
.fd-ic { width: 44px; height: 44px; flex-shrink: 0; border-radius: 12px; display: grid; place-items: center; color: var(--fern); background: rgba(31,111,214,0.09); border: 1px solid rgba(31,111,214,0.18); }
.fd-card h4 { margin-bottom: 5px; }
.fd-card p { font-size: 14px; line-height: 1.55; color: var(--text-soft); }
@media (max-width: 680px) { .feature-duo { grid-template-columns: 1fr; } }

/* ---------- PAGE CTA BAND ---------- */
.page-cta { position: relative; overflow: hidden; background: var(--ink); color: var(--cream); padding: clamp(70px,8vw,110px) var(--pad-x); }
.page-cta .cta-glow { position: absolute; inset: 0; background: radial-gradient(ellipse 60% 80% at 18% 120%, rgba(31,111,214,0.4), transparent 60%), radial-gradient(circle at 90% -10%, rgba(224,58,44,0.16), transparent 45%); }
.page-cta-inner { position: relative; z-index: 2; max-width: var(--maxw); margin: 0 auto; display: grid; grid-template-columns: 1.05fr 0.95fr; gap: clamp(32px,5vw,72px); align-items: center; }
.page-cta h2 { font-family: var(--display); font-weight: 800; font-size: clamp(30px,4vw,50px); line-height: 1.04; letter-spacing: -0.03em; margin-bottom: 16px; text-wrap: balance; }
.page-cta h2 .serif-accent { color: var(--brass-bright); }
.page-cta .pc-lede { color: rgba(242,246,252,0.78); font-size: 16.5px; line-height: 1.7; margin-bottom: 24px; max-width: 46ch; }
.pc-points { list-style: none; display: flex; flex-direction: column; gap: 12px; }
.pc-points li { display: flex; align-items: center; gap: 12px; font-size: 15.5px; color: rgba(242,246,252,0.9); }
.pc-points .pc-ic { width: 26px; height: 26px; flex-shrink: 0; border-radius: 50%; background: var(--fern); color: #fff; display: grid; place-items: center; }
@media (max-width: 880px) { .page-cta-inner { grid-template-columns: 1fr; } }


/* ---------- MOBILE PASS (inner) ---------- */
@media (max-width: 760px) {
  .inner-hero { padding-top: 120px; min-height: auto; }
  .inner-hero h1 { font-size: clamp(32px, 9.5vw, 46px); }
  .inner-content h2, .inner-content h3, .inner-content h4, .inner-intro h2 { font-size: clamp(23px, 6.6vw, 30px); }
  .content-row { padding: 30px 0; }
  .aside-photo { aspect-ratio: 1693 / 929; }
}
@media (max-width: 560px) {
  .inner-badges { gap: 18px; }
  .ac-stats { grid-template-columns: 1fr 1fr; gap: 18px 14px; }
  .page-cta-inner { gap: 28px; }
  .mini-steps { gap: 16px; }
}
@media (max-width: 420px) {
  .brand-text { font-size: 15px; }
  .brand-logo { width: 38px; height: 38px; }
  .inner-hero h1 { font-size: clamp(29px, 10vw, 40px); }
  .ct-text p { font-size: 15.5px; }
}
