/* ==========================================================================
   contribute.css — give experience ported from ezofsigmachi.org/contribute
   onto the ezhc.org landing page (2026-06-02).

   Sections: campaign tracker (cm-tracker), give panel (cm-give: embed +
   naming ladder), more ways to give (cm-give__methods), talk-to-Rick (cm-rick).
   Tokens are shared with the source site via tokens.css + tokens-v2.css, so the
   rules port near-verbatim. Tracker animation is driven by the existing
   progress.js (shared data-progress-* hook contract); no JS port needed here.
   ========================================================================== */

/* ---------- Generic section spacing ---------- */
.cm-section {
  padding-block: clamp(var(--space-12), 6vw, var(--space-20));
}
.cm-section--alt {
  background: var(--color-cream-50);
}

.cm-form__lede {
  font-size: var(--text-base);
  line-height: 1.6;
  color: var(--color-ink-500);
  margin: var(--space-4) 0 0;
  max-width: 60ch;
}

/* ==========================================================================
   Campaign tracker — cinematic cream band (big $ + bar + 3 stat cards)
   ========================================================================== */
.cm-tracker {
  background: var(--color-bg-primary);
  color: var(--color-navy-900);
  padding-block: clamp(var(--space-12), 6vw, var(--space-20)) clamp(var(--space-8), 4vw, var(--space-12));
  text-align: center;
}

.cm-tracker__header {
  margin: 0 auto var(--space-8);
}
.cm-tracker__title {
  font-family: var(--font-display);
  font-size: clamp(2rem, 4vw, 2.75rem);
  font-weight: 700;
  letter-spacing: -0.02em;
  color: var(--color-navy-900);
  margin: var(--space-2) 0 0;
}

.cm-tracker__context {
  font-size: var(--text-sm);
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--color-gold-text, #9A6B00);
  margin: 0 auto var(--space-6);
  max-width: 48ch;
}

.cm-tracker__headline {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-2);
}

.cm-tracker__raised {
  font-family: var(--font-display);
  font-size: clamp(3.5rem, 11vw, 7rem);
  font-weight: 700;
  line-height: 0.95;
  letter-spacing: -0.02em;
  color: var(--color-navy-900);
  font-variant-numeric: tabular-nums;
}

.cm-tracker__of {
  font-size: clamp(1rem, 2vw, 1.375rem);
  font-weight: 500;
  color: var(--color-ink-500);
}

.cm-tracker__headline::after {
  content: '';
  width: 64px;
  height: 3px;
  margin-top: var(--space-4);
  background: var(--color-gold-500, #F9BD3D);
  border-radius: 2px;
}

/* Progress bar + above-bar milestone markers */
.cm-tracker__bar {
  position: relative;
  max-width: 960px;
  margin: var(--space-12) auto;
}

.cm-tracker__track {
  width: 100%;
  height: 30px;
  background: rgba(249, 189, 61, 0.18);
  border-radius: 999px;
  overflow: hidden;
}

.cm-tracker__fill {
  height: 100%;
  width: 0;
  background: linear-gradient(90deg, var(--color-gold-500, #F9BD3D), var(--color-gold-300, #F9D77E));
  border-radius: 999px;
  transition: width 2200ms cubic-bezier(0.22, 1, 0.36, 1);
}

.cm-tracker__marker {
  position: absolute;
  bottom: 100%;
  transform: translateX(-50%);
  display: flex;
  flex-direction: column;
  align-items: center;
  padding-bottom: 6px;
  pointer-events: none;
}

.cm-tracker__marker::after {
  content: '';
  width: 2px;
  height: 14px;
  background: var(--color-ink-300);
  border-radius: 2px;
  transition: background-color 300ms ease;
}

.cm-tracker__marker-label {
  font-size: var(--text-xs);
  font-weight: 600;
  letter-spacing: 0.04em;
  white-space: nowrap;
  color: var(--color-ink-500);
  margin-bottom: 4px;
  transition: color 300ms ease;
}

.cm-tracker__marker[data-passed="true"]::after {
  background: var(--color-gold-500, #F9BD3D);
}
.cm-tracker__marker[data-passed="true"] .cm-tracker__marker-label {
  color: var(--color-navy-900);
}

/* 3 stat chips — white cards on cream */
.cm-tracker__stats {
  list-style: none;
  margin: 0 auto var(--space-10);
  padding: 0;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-5);
  max-width: 760px;
}

.cm-tracker__stat {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  padding: var(--space-6);
  background: #fff;
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-card);
  border-top: 3px solid transparent;
  opacity: 0;
  transform: translateY(10px);
  transition: opacity 480ms var(--ease-cinematic, ease-out),
              transform 480ms var(--ease-cinematic, ease-out),
              border-color 480ms ease;
}

.cm-tracker__stat[data-revealed="true"] {
  opacity: 1;
  transform: none;
}

.cm-tracker__stat--secured[data-revealed="true"]  { border-top-color: var(--color-navy-900); }
.cm-tracker__stat--financed[data-revealed="true"] { border-top-color: rgba(0, 22, 41, 0.45); }
.cm-tracker__stat--toraise[data-revealed="true"]  { border-top-color: var(--color-gold-500, #F9BD3D); }

.cm-tracker__stat-value {
  font-family: var(--font-display);
  font-size: clamp(1.75rem, 3vw, 2.5rem);
  font-weight: 700;
  color: var(--color-navy-900);
  line-height: 1;
  font-variant-numeric: tabular-nums;
}

.cm-tracker__stat-label {
  font-size: var(--text-xs);
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--color-ink-500);
}

@media (max-width: 560px) {
  .cm-tracker__stats { grid-template-columns: 1fr; }
}

@media (prefers-reduced-motion: reduce) {
  .cm-tracker__fill,
  .cm-tracker__stat,
  .cm-tracker__marker::after,
  .cm-tracker__marker-label { transition: none; }
}

/* ==========================================================================
   Give Now — unified white panel (Givebutter form + naming ladder)
   ========================================================================== */
#give-now {
  padding-block-start: clamp(var(--space-6), 3vw, var(--space-10));
}
#give-now > .container {
  text-align: center;
  max-width: 1240px;
}
#give-now .gold-rule {
  margin-inline: auto;
}
#give-now .cm-form__lede {
  margin-inline: auto;
  max-width: 80ch;
}

.cm-give__panel {
  max-width: 1200px;
  margin: var(--space-10) auto 0;
  padding: clamp(var(--space-6), 4vw, var(--space-10));
  background: #fff;
  border-radius: var(--radius-lg);
  box-shadow: 0 24px 60px -24px rgba(0, 22, 41, 0.20);
  text-align: center;
}
.cm-give__panel h2 {
  font-family: var(--font-display);
  font-size: clamp(1.75rem, 3.5vw, 2.5rem);
  font-weight: 700;
  letter-spacing: -0.02em;
  color: var(--color-navy-900);
  margin: var(--space-3) 0 0;
}

/* Center the live Givebutter giving form. */
.cm-give__embed {
  margin: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
}
.cm-give__embed givebutter-widget {
  display: block;
  width: 100%;
  max-width: 100%;
  margin-inline: auto;
}

/* Two-column give layout (form + naming ladder). Stacks under 1180px. */
.cm-give__layout {
  display: grid;
  grid-template-columns: 560px minmax(0, 1fr);
  gap: clamp(var(--space-8), 5vw, var(--space-12));
  align-items: stretch;
  margin-top: var(--space-8);
  text-align: left;
}
@media (max-width: 1180px) {
  .cm-give__layout {
    grid-template-columns: 1fr;
    gap: var(--space-8);
    max-width: 600px;
    margin-inline: auto;
  }
  .cm-give__tiers {
    border-left: none;
    border-top: 3px solid var(--color-gold-500);
    padding-left: 0;
    padding-top: var(--space-6);
  }
  /* Stacked: rows take their natural height instead of the equal-height
     distribution used to match the form column, so multi-line descriptions
     don't collapse and overlap. Descendant selector raises specificity above
     the base .cm-give__tier rule, which is defined later in source order. */
  .cm-give__tiers .cm-give__tier {
    flex: 0 0 auto;
    min-height: 0;
    padding-block: var(--space-3);
  }
}
.cm-give__col--form {
  min-width: 0;
}

/* Naming-tier quick-list (right column). */
.cm-give__tiers {
  display: flex;
  flex-direction: column;
  border-left: 3px solid var(--color-gold-500);
  padding-left: clamp(var(--space-6), 3vw, var(--space-8));
}
.cm-give__tiers-title {
  font-family: var(--font-display);
  font-size: var(--text-xl);
  font-weight: 700;
  color: var(--color-navy-900);
  margin: 0 0 var(--space-5);
}
.cm-give__tier-list {
  list-style: none;
  margin: 0 0 var(--space-5);
  padding: 0;
  flex: 1 1 auto;
  display: flex;
  flex-direction: column;
}
.cm-give__tier {
  display: grid;
  grid-template-columns: 6.5rem 1fr auto;
  gap: var(--space-3);
  align-items: center;
  align-content: center;
  flex: 1 1 0;
  min-height: 4.5rem;
  padding-block: var(--space-2);
  border-bottom: 1px solid rgba(0, 22, 41, 0.08);
}
.cm-give__tier:last-child {
  border-bottom: none;
}
.cm-give__tier-amount {
  font-family: var(--font-display);
  font-size: var(--text-lg);
  font-weight: 700;
  color: var(--color-navy-900);
  white-space: nowrap;
}
.cm-give__tier-text {
  font-size: var(--text-sm);
  line-height: 1.6;
  color: var(--color-ink-500);
}
.cm-give__tier-name {
  font-weight: 700;
  color: var(--color-navy-900);
}
/* Live availability pill — populated by site-data.js from the Recognition sheet. */
.cm-give__tier-status {
  justify-self: end;
  display: inline-block;
  padding: 0.15em 0.65em;
  border-radius: 999px;
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.02em;
  white-space: nowrap;
}
.cm-give__tier-status:empty {
  display: none;
}
.cm-give__tier-status--available {
  background: rgba(249, 189, 61, 0.22);
  color: var(--color-navy-900);
}
.cm-give__tier-status--open {
  background: var(--color-gold-500);
  color: var(--color-navy-900);
}
.cm-give__tier-status--reserved {
  background: rgba(0, 22, 41, 0.06);
  color: var(--color-ink-500);
}
.cm-give__tiers-link {
  align-self: center;
  display: inline-block;
  margin-top: var(--space-4);
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--color-sx-blue);
  text-decoration: none;
}
.cm-give__tiers-link:hover,
.cm-give__tiers-link:focus-visible {
  text-decoration: underline;
}

/* "Powered by RRFlows" badge under the give form. */
.gb-poweredby {
  margin: 1.5rem auto 0;
  text-align: center;
}
.gb-poweredby a {
  display: inline-flex;
  align-items: center;
  gap: 0.45em;
  font-size: 0.78rem;
  letter-spacing: 0.04em;
  color: #64748B;
  text-decoration: none;
  opacity: 0.8;
  transition: opacity 160ms ease;
}
.gb-poweredby a:hover,
.gb-poweredby a:focus-visible { opacity: 1; }
.gb-poweredby img {
  height: auto;
  display: inline-block;
}

/* Horizontal-lockup logo reads larger; size it up under the give panel. */
#give-now .gb-poweredby img {
  width: 132px;
}

/* More ways to give — method cards under the panel. */
.cm-give__more {
  max-width: 1200px;
  margin: var(--space-12) auto 0;
}
.cm-give__more-title {
  font-family: var(--font-display);
  font-size: var(--text-lg);
  font-weight: 700;
  color: var(--color-navy-900);
  margin: 0 0 var(--space-4);
}
.cm-give__methods {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-4);
  text-align: left;
}
@media (max-width: 760px) {
  .cm-give__methods { grid-template-columns: 1fr; }
}
.cm-give__method {
  background: #fff;
  border-radius: var(--radius-md);
  padding: var(--space-4) var(--space-5);
  box-shadow: var(--shadow-card);
  border-top: 2px solid var(--color-gold-500);
}
.cm-give__method-name {
  font-family: var(--font-display);
  font-size: var(--text-base);
  font-weight: 700;
  color: var(--color-navy-900);
  margin: 0 0 var(--space-1);
}
.cm-give__method-desc {
  font-size: var(--text-sm);
  line-height: 1.5;
  color: var(--color-ink-500);
  margin: 0 0 var(--space-2);
}
.cm-give__method-link {
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--color-sx-blue);
  text-decoration: none;
}
.cm-give__method-link:hover,
.cm-give__method-link:focus-visible {
  text-decoration: underline;
}
.cm-give__more-note {
  font-size: var(--text-sm);
  line-height: 1.6;
  color: var(--color-ink-500);
  margin: var(--space-10) auto 0;
  max-width: 60ch;
  text-align: center;
}

/* ==========================================================================
   Talk to Rick — leadership / offline / tax-deductible gifts
   ========================================================================== */
.cm-rick h2 {
  font-family: var(--font-display);
  font-size: clamp(2rem, 4vw, 2.75rem);
  font-weight: 700;
  letter-spacing: -0.02em;
  margin: var(--space-3) 0 var(--space-5);
  color: var(--color-navy-900);
}
.cm-rick p {
  font-size: var(--text-base);
  line-height: 1.6;
  color: var(--color-ink-500);
  max-width: 56ch;
  margin: 0 auto var(--space-6);
}
.cm-rick__actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-4);
  justify-content: center;
}
.cm-rick__note {
  margin-top: var(--space-6);
  font-size: var(--text-sm);
  color: var(--color-ink-300);
  letter-spacing: 0.04em;
}
