/* ==========================================================================
   CAMPAIGN STUDIO — CAMPAIGN PAGE STYLES
   Paste into: WordPress Admin → Appearance → Customize → Additional CSS
   ──────────────────────────────────────────────────────────────────────────
   Targets the campaign page at /campaign/your-campaign/
   (Body class .give-p2p scopes everything so it can't leak to other pages.)
   ──────────────────────────────────────────────────────────────────────────
   Sections:
     1.  Fonts + design tokens
     2.  Page reset (scoped)
     3.  HERO — wp-block-cover restyle
     4.  GOAL CARD — overlap + restyle of .give-p2p-campaign-header-block
     5.  CTA BUTTONS row — wp-block-buttons restyle
     6.  IMPACT TIERS (custom HTML block)
     7.  STORY column — wp-block-columns restyle
     8.  4-STEP PILLARS (custom HTML block)
     9.  RECENT DONATIONS sidebar — [give_donor_wall] restyle
     10. LEADERBOARD — .give-p2p-fundraiser-leaderboard-block restyle
     11. DONATIONS OVERVIEW (dark band) — .give-p2p-campaign-donations-overview-block
     12. FINAL CTA banner (custom HTML block)
     13. STICKY DONATE button (custom HTML block)
     14. FOOTER tweaks
     15. Responsive
   ========================================================================== */


/* ─── 1. FONTS + DESIGN TOKENS ─────────────────────────────────────────── */

@import url('https://fonts.googleapis.com/css2?family=Montserrat:wght@400;500;600;700;800;900&family=Fraunces:ital,opsz,wght@0,9..144,400..700;1,9..144,400..700&display=swap');

body.give-p2p {
  --kh-navy:      #0a1e4a;
  --kh-navy-deep: #061538;
  --kh-blue:      #0736e3;
  --kh-blue-dark: #0628b8;
  --kh-gold:      #fcb900;
  --kh-gold-dark: #e0a300;
  --kh-ink:       #11162a;
  --kh-ink-muted: #5b6478;
  --kh-line:      #e6e8ef;
  --kh-cream:     #faf7ef;
  --kh-shadow-sm: 0 1px 2px rgba(10,30,74,.06), 0 2px 6px rgba(10,30,74,.04);
  --kh-shadow-md: 0 4px 14px rgba(10,30,74,.08), 0 12px 32px rgba(10,30,74,.06);
  --kh-shadow-lg: 0 10px 30px rgba(10,30,74,.12), 0 30px 70px rgba(10,30,74,.10);

  /* Override GiveWP's CSS vars so its built-in blocks pick up our palette */
  --givewp-primary-color:   #0736e3;
  --givewp-secondary-color: #fcb900;

  font-family: var(--kh-font-body);
  color: var(--kh-ink);
}


/* ─── 2. PAGE-SCOPED RESET ─────────────────────────────────────────────── */

/* Global: kill horizontal page overflow site-wide. Any element that tries
   to push wider than the viewport gets clipped instead of breaking the
   layout / triggering the horizontal scrollbar.
   NOTE: not scoped to body.give-p2p — applies everywhere on the site. */
html,
body {
  overflow-x: hidden !important;
  max-width: 100% !important;
}

body.give-p2p .wp-site-blocks > * { margin-block-start: 0; margin-block-end: 0; }
body.give-p2p :where(.is-layout-flow, .is-layout-constrained) > * { margin-block-start: 0; margin-block-end: 0; }


/* ─── 3. HERO (wp-block-cover) ─────────────────────────────────────────── */
/* The existing cover block gets a clean image (no baked-in text), a stronger
   gradient overlay, more height, and room at the bottom for the goal card
   to overlap into. The headline is live HTML inside the cover (see snippet A
   in BUILD-GUIDE.md). */

body.give-p2p .wp-block-cover.alignfull {
  min-height: 720px;
  padding: 100px 24px 220px;   /* room for goal card to overlap into */
  position: relative;
}
body.give-p2p .wp-block-cover.alignfull .wp-block-cover__background {
  background:
    linear-gradient(90deg, rgba(6,21,56,.55) 0%, rgba(6,21,56,.20) 40%, rgba(6,21,56,.65) 75%, rgba(6,21,56,.92) 100%),
    linear-gradient(180deg, rgba(6,21,56,.20) 0%, rgba(6,21,56,.55) 100%) !important;
  opacity: 1 !important;
}
body.give-p2p .wp-block-cover.alignfull .wp-block-cover__image-background {
  object-position: center 35%;
}
/* Hide any empty <p> inside the cover that came from the original block */
body.give-p2p .wp-block-cover.alignfull .wp-block-cover__inner-container > p:empty { display: none; }
/* The inner container holds the live HTML headline */
body.give-p2p .wp-block-cover.alignfull .wp-block-cover__inner-container {
  max-width: 1240px;
  margin: 0 auto;
  width: 100%;
}

/* ──────────────────────────────────────────────────────────────
   HERO — v2: WP-NATIVE blocks inside the cover (no Custom HTML)
   You'll build the hero in the editor as:
     Cover block (existing)
       └ Columns block (60/40)
            ├ Column 1
            │    ├ Heading (H1)  → "Your story heading <em>Support it.</em>"
            │    └ Paragraph     → the kicker sentence
            └ Column 2
                 └ Quote block   → "Learn it one-on-one. Review it..." (with citation)
   The CSS below styles these WP-native blocks directly.
   ────────────────────────────────────────────────────────────── */

body.give-p2p .wp-block-cover .wp-block-columns {
  max-width: 1240px !important;
  margin: 0 auto !important;
  gap: 56px !important;
  align-items: end !important;
  width: 100% !important;
}
body.give-p2p .wp-block-cover .wp-block-column h1,
body.give-p2p .wp-block-cover .wp-block-column .wp-block-heading {
  font-size: clamp(40px, 5vw, 68px) !important;
  line-height: 1.05 !important;
  font-weight: 800 !important;
  letter-spacing: -0.02em !important;
  margin: 0 0 28px !important;
  color: #fff !important;
  font-family: var(--kh-font-head) !important;
  text-shadow: 0 2px 20px rgba(0,0,0,.35);
}
body.give-p2p .wp-block-cover .wp-block-column h1 br + em,
body.give-p2p .wp-block-cover .wp-block-column h1 em {
  display: inline-block !important;
  margin-top: 8px !important;
}
body.give-p2p .wp-block-cover .wp-block-column > p,
body.give-p2p .wp-block-cover .wp-block-column .wp-block-paragraph:not(.kh-eyebrow) {
  margin-top: 24px !important;
}
body.give-p2p .wp-block-cover .wp-block-column h1 em,
body.give-p2p .wp-block-cover .wp-block-column .wp-block-heading em,
body.give-p2p .wp-block-cover h1 em,
body.give-p2p .wp-block-cover .kh-support {
  font-family: var(--kh-font-accent) !important;
  font-style: italic !important;
  font-weight: 600 !important;
  color: var(--kh-gold) !important;
  font-size: 1.05em !important;
  display: inline-block;
}

/* Eyebrow pill above the headline — paste the HTML in BUILD-GUIDE (eyebrow snippet) as a Paragraph block in the LEFT column ABOVE the H1. Use additional CSS class "kh-eyebrow". */
/* Eyebrow — max specificity to beat Elementor/Paragraph font-size overrides */
/* MAX-SPECIFICITY eyebrow override — wins over any inherited paragraph font-size */
html body.give-p2p .wp-block-cover .kh-eyebrow,
html body.give-p2p .kh-eyebrow,
html body p.kh-eyebrow.kh-eyebrow {
  font-size: 14px !important;
  line-height: 1.2 !important;
  padding: 6px 14px !important;
  letter-spacing: 0.12em !important;
  text-transform: uppercase !important;
  font-weight: 700 !important;
  font-family: var(--kh-font-head) !important;
  color: var(--kh-gold) !important;
  background: rgba(252,185,0,0.12) !important;
  border: 1px solid rgba(252,185,0,0.35) !important;
  border-radius: 999px !important;
  display: inline-flex !important;
  align-items: center !important;
  gap: 8px !important;
  width: auto !important;
  max-width: max-content !important;
  margin: 0 0 28px !important;
}
body.give-p2p .wp-block-cover .kh-eyebrow::before {
  content: "" !important;
  width: 8px; height: 8px; border-radius: 50%;
  background: var(--kh-gold);
  box-shadow: 0 0 0 0 rgba(252,185,0,.7);
  animation: kh-pulse 2s infinite;
}
body.give-p2p .wp-block-cover .wp-block-column .wp-block-paragraph:not(.kh-eyebrow),
body.give-p2p .wp-block-cover .wp-block-column > p:not(.kh-eyebrow) {
  font-size: 18px !important;
  line-height: 1.5 !important;
  font-weight: 500 !important;
  color: rgba(255,255,255,0.88) !important;
  margin: 0 !important;
  max-width: 560px;
}

/* ──────────────────────────────────────────────────────────────
   Right-column GLASS card — Custom HTML version with label + quote + attribution
   See BUILD-GUIDE snippet A2 for the HTML to paste.
   ────────────────────────────────────────────────────────────── */
.kh-method-card {
  background: rgba(255,255,255,0.07) !important;
  backdrop-filter: blur(10px) !important;
  -webkit-backdrop-filter: blur(10px) !important;
  border: 1px solid rgba(255,255,255,0.18) !important;
  border-radius: var(--kh-radius) !important;
  padding: 26px 28px !important;
  box-shadow: 0 12px 36px rgba(0,0,0,0.25);
  max-width: 420px;
}
.kh-method-card__label {
  font-family: var(--kh-font-head) !important;
  font-size: 11px !important;
  font-weight: 800 !important;
  letter-spacing: 0.18em !important;
  text-transform: uppercase !important;
  color: var(--kh-gold) !important;
  margin: 0 0 16px !important;
  display: block;
}
.kh-method-card__quote {
  font-family: var(--kh-font-accent) !important;
  font-style: italic !important;
  font-size: 20px !important;
  line-height: 1.35 !important;
  color: #fff !important;
  margin: 0 !important;
  padding: 0 0 18px !important;
  border-bottom: 1px solid rgba(255,255,255,0.18) !important;
  font-weight: 600 !important;
}
.kh-method-card__attrib {
  font-family: var(--kh-font-head) !important;
  font-size: 12px !important;
  font-weight: 600 !important;
  color: rgba(255,255,255,0.75) !important;
  margin: 16px 0 0 !important;
  letter-spacing: 0.01em !important;
}

/* Right column: Quote block — GLASS card (frosted, brand-tinted border) */
body.give-p2p .wp-block-cover .wp-block-column .wp-block-quote {
  background: rgba(255,255,255,0.08) !important;
  backdrop-filter: blur(10px) !important;
  -webkit-backdrop-filter: blur(10px) !important;
  border: 1px solid rgba(255,255,255,0.18) !important;
  border-radius: var(--kh-radius) !important;
  padding: 28px 30px !important;
  margin: 0 0 12px !important;
  position: relative;
  box-shadow: 0 12px 36px rgba(0,0,0,0.25);
}
body.give-p2p .wp-block-cover .wp-block-column .wp-block-quote p {
  font-family: var(--kh-font-accent) !important;
  font-style: italic !important;
  font-size: 18px !important;
  line-height: 1.35 !important;
  color: #fff !important;
  margin: 0 0 16px !important;
  padding: 0 0 16px !important;
  border-bottom: 1px solid rgba(255,255,255,0.18) !important;
  font-weight: 600 !important;
}
body.give-p2p .wp-block-cover .wp-block-column .wp-block-quote cite {
  font-family: var(--kh-font-head) !important;
  font-style: normal !important;
  font-size: 12px !important;
  font-weight: 700 !important;
  letter-spacing: 0.15em !important;
  text-transform: uppercase !important;
  color: var(--kh-gold) !important;
}

/* ──────────────────────────────────────────────────────────────
   LEGACY: the old .kh-hero classes (Custom HTML version)
   Kept in place so existing installs don't break, but the
   .kh-hero__side glassmorphic + .kh-hero__meta are now hidden
   so they can't render even if the snippet is still in the page.
   ────────────────────────────────────────────────────────────── */
.kh-hero__meta { display: none !important; }
.kh-hero__side { display: none !important; }

/* Hero content — LEGACY .kh-hero (Custom HTML version) */
.kh-hero {
  display: grid;
  grid-template-columns: 1fr 420px;
  gap: 48px;
  align-items: end;
  color: #fff;
  text-align: left;
}
.kh-hero__eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  background: rgba(252,185,0,.15);
  color: var(--kh-gold);
  border: 1px solid rgba(252,185,0,.4);
  padding: 7px 14px;
  border-radius: 999px;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: .12em;
  text-transform: uppercase;
  font-family: var(--kh-font-head);
}
.kh-hero__eyebrow::before {
  content: "";
  width: 8px; height: 8px; border-radius: 50%;
  background: var(--kh-gold);
  box-shadow: 0 0 0 0 rgba(252,185,0,.7);
  animation: kh-pulse 2s infinite;
}
@keyframes kh-pulse {
  0%   { box-shadow: 0 0 0 0 rgba(252,185,0,.6); }
  70%  { box-shadow: 0 0 0 12px rgba(252,185,0,0); }
  100% { box-shadow: 0 0 0 0 rgba(252,185,0,0); }
}
.kh-hero h1 {
  font-size: clamp(48px, 6vw, 88px) !important;
  line-height: .98 !important;
  font-weight: 800 !important;
  margin: 22px 0 14px !important;
  letter-spacing: -.02em !important;
  text-shadow: 0 2px 20px rgba(0,0,0,.35);
  color: #fff !important;
  font-family: var(--kh-font-head) !important;
}
.kh-hero h1 .kh-hero__accent {
  font-family: var(--kh-font-accent);
  font-style: italic;
  font-weight: 600;
  color: var(--kh-gold);
  display: block;
  font-size: 1.05em;
  letter-spacing: -.01em;
}
.kh-hero__kicker {
  font-size: 18px !important;
  max-width: 560px;
  color: rgba(255,255,255,.85) !important;
  margin: 0 0 28px !important;
  font-weight: 500 !important;
  line-height: 1.5 !important;
}
.kh-hero__meta {
  display: flex;
  gap: 24px;
  align-items: center;
  font-size: 13px;
  color: rgba(255,255,255,.7);
  font-weight: 600;
  flex-wrap: wrap;
}
.kh-hero__meta .dot {
  width: 4px; height: 4px; border-radius: 50%;
  background: rgba(255,255,255,.5);
}
.kh-hero__side {
  background: rgba(255,255,255,.06);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  border: 1px solid rgba(255,255,255,.15);
  border-radius: var(--kh-radius);
  padding: 26px 28px;
  margin-bottom: 12px;
}
.kh-hero__side-label {
  font-size: 11px;
  letter-spacing: .15em;
  text-transform: uppercase;
  font-weight: 700;
  color: var(--kh-gold);
  margin-bottom: 12px;
}
.kh-hero__quote {
  margin: 0;
  font-family: var(--kh-font-accent);
  font-size: 22px;
  line-height: 1.3;
  color: #fff;
  font-style: italic;
  font-weight: 600;
}
.kh-hero__quote em {
  font-weight: 600;
}
.kh-hero__attrib {
  margin-top: 14px;
  font-size: 13px;
  color: rgba(255,255,255,.65);
  font-weight: 500;
  font-style: normal;
  font-family: var(--kh-font-head);
}


/* ─── 4. GOAL CARD (.give-p2p-campaign-header-block) ───────────────────── */
/* Pull the header block up into the hero. Inside it lives the goal bar
   + stats; we restyle both. */

/* ════════════════════════════════════════════════════════════════
   GOAL CARD — white card sits on .give-p2p-campaign-header-block.
   Right-padding reserves space for the buttons block, which is a
   SIBLING below in the source but pulled up with margin-top: -260px
   (see the .wp-block-buttons rule further down) to overlap on the
   right side of the card.
   ════════════════════════════════════════════════════════════════ */

/* The .kh-goal-card outer is just a positioning context — keep it minimal */
body.give-p2p .kh-goal-card {
  max-width: 1240px !important;
  margin-left: auto !important;
  margin-right: auto !important;
  position: relative !important;
}

/* The actual white card */
body.give-p2p .give-p2p-campaign-header-block {
  background: #fff !important;
  border-radius: var(--kh-radius-lg) !important;
  box-shadow: var(--kh-shadow-lg) !important;
  padding: 40px 56px 32px 56px !important;  /* symmetric — content fills full card. Buttons overlap on right via z-index. */
  margin: -180px auto 0 !important;
  max-width: 1240px !important;
  position: relative !important;
  z-index: 5 !important;
  display: block !important;
}

/* Pull the existing wp-block-buttons row up into the goal card's reserved right column
   and stack them vertically — matches the mockup's right-side CTA panel. */
/* Pull the existing wp-block-buttons row up into the goal card's reserved right column
   and stack them vertically — matches the mockup's right-side CTA panel.
   Card has padding-right: 340px reserved. Buttons are 280px wide + 56px right edge. */
body.give-p2p .wp-block-cover.alignfull + .give-p2p-campaign-header-block + * .wp-block-buttons,
body.give-p2p .give-p2p-campaign-header-block + * .wp-block-buttons,
body.give-p2p .wp-block-buttons:has(.wp-block-button__link[href*="/donate/"]) {
  position: relative !important;
  z-index: 20 !important;  /* on top of any overlapping content from the card */
  margin: 0 auto !important;
  margin-top: -210px !important;
  margin-bottom: 80px !important;
  width: 100% !important;
  max-width: 1240px !important;
  padding: 0 56px 0 24px !important;
  box-sizing: border-box !important;
  display: flex !important;
  flex-direction: column !important;
  align-items: flex-end !important;
  justify-content: flex-start !important;
  gap: 12px !important;
  pointer-events: none !important;
}
body.give-p2p .wp-block-buttons:has(.wp-block-button__link[href*="/donate/"]) .wp-block-button,
body.give-p2p .wp-block-buttons:has(.wp-block-button__link[href*="/donate/"]) .wp-block-button__link {
  pointer-events: auto !important;  /* re-enable clicks on the buttons themselves */
}
body.give-p2p .wp-block-buttons:has(.wp-block-button__link[href*="/donate/"]) .wp-block-button {
  width: 300px !important;
  margin: 0 !important;
}
body.give-p2p .wp-block-buttons:has(.wp-block-button__link[href*="/donate/"]) .wp-block-button .wp-block-button__link {
  width: 100% !important;
  display: block !important;
  text-align: center !important;
  padding: 18px 22px !important;
}

/* Zero out the inner GiveWP blocks so they don't look like nested cards */
body.give-p2p .give-p2p-campaign-header-block .givewp-campaign-goal,
body.give-p2p .give-p2p-campaign-header-block .givewp-campaign-stats-block {
  background: transparent !important;
  box-shadow: none !important;
  border: none !important;
  padding: 0 !important;
  margin: 0 !important;
  border-radius: 0 !important;
}

/* Subtle divider between the big raised+progress section and the stats row */
body.give-p2p .give-p2p-campaign-header-block .givewp-campaign-stats-block {
  padding-top: 24px !important;
  border-top: 1px solid var(--kh-line) !important;
}

/* Existing custom CSS already hides .ch header and .ch h2 — keep it. */

/* GOAL BAR — .givewp-campaign-goal renders inside the header block */
body.give-p2p .givewp-campaign-goal {
  gap: 1rem;
  padding-bottom: 0;
}
body.give-p2p .givewp-campaign-goal__container {
  margin-bottom: 8px;
  align-items: flex-end;
}
body.give-p2p .givewp-campaign-goal__container-item span {
  font-size: 11px !important;
  letter-spacing: .15em !important;
  color: var(--kh-ink-muted) !important;
  font-weight: 700 !important;
}
body.give-p2p .givewp-campaign-goal__container-item strong {
  font-size: 42px !important;
  font-weight: 800 !important;
  color: var(--kh-navy) !important;
  letter-spacing: -.02em !important;
  line-height: 1 !important;
}
/* The "raised" number — first item — make it the hero number */
body.give-p2p .givewp-campaign-goal__container-item:first-child strong {
  font-size: 56px !important;
  color: var(--kh-navy) !important;
}
/* The "% / goal" item — smaller, right-aligned */
body.give-p2p .givewp-campaign-goal__container-item:last-child {
  text-align: right;
}
body.give-p2p .givewp-campaign-goal__container-item:last-child strong {
  font-size: 22px !important;
  color: var(--kh-ink-muted) !important;
  font-weight: 700 !important;
}

/* Progress bar — gold gradient, taller, rounded */
body.give-p2p .givewp-campaign-goal__progress-bar-container {
  height: 14px !important;
  background: #eef0f6 !important;
  border-radius: 999px !important;
  box-shadow: inset 0 1px 2px rgba(10,30,74,.08) !important;
  overflow: visible !important;
}
body.give-p2p .givewp-campaign-goal__progress-bar-progress {
  height: 14px !important;
  background: linear-gradient(90deg, var(--kh-gold) 0%, #ffd64a 100%) !important;
  border-radius: 999px !important;
  position: relative;
  box-shadow: inset 0 -2px 0 rgba(0,0,0,.06) !important;
}
body.give-p2p .givewp-campaign-goal__progress-bar-progress::after {
  content: "";
  position: absolute; right: -8px; top: -3px;
  width: 20px; height: 20px;
  background: #fff;
  border: 4px solid var(--kh-gold);
  border-radius: 50%;
  box-shadow: 0 2px 8px rgba(0,0,0,.18);
}

/* STATS BLOCK — the 3-column donations/avg/fundraisers row */
body.give-p2p .givewp-campaign-stats-block {
  display: grid;
  margin-top: 24px;
  padding-top: 24px;
  border-top: 1px solid var(--kh-line);
}
body.give-p2p .givewp-campaign-stats-block > * {
  text-align: center;
}
body.give-p2p .givewp-campaign-stats-block strong {
  font-size: 26px !important;
  font-weight: 800 !important;
  color: var(--kh-navy) !important;
  letter-spacing: -.01em !important;
  display: block;
}
body.give-p2p .givewp-campaign-stats-block span {
  font-size: 11px !important;
  letter-spacing: .14em !important;
  color: var(--kh-ink-muted) !important;
  font-weight: 700 !important;
  text-align: center !important;
}


/* ─── 5. CTA BUTTONS row (wp-block-buttons) ────────────────────────────── */
/* The "Become an Ambassador" + "Donate" pair. */

body.give-p2p .wp-block-buttons {
  gap: 12px !important;
  margin: 0 auto 64px !important;
  justify-content: center;
  max-width: 1240px;
  padding: 0 24px;
}
body.give-p2p .wp-block-button .wp-block-button__link {
  border-radius: var(--kh-radius) !important;
  padding: 18px 28px !important;
  font-size: 16px !important;
  font-weight: 700 !important;
  letter-spacing: 0 !important;
  font-family: var(--kh-font-head) !important;
  transition: transform .15s ease, box-shadow .15s ease, background .2s ease;
  border: none !important;
  min-width: 220px;
}
body.give-p2p .wp-block-button .wp-block-button__link:hover {
  transform: translateY(-1px);
}
/* First button (Become an Ambassador) — ghost */
body.give-p2p .wp-block-buttons .wp-block-button:first-child .wp-block-button__link {
  background: transparent !important;
  color: var(--kh-navy) !important;
  border: 1.5px solid var(--kh-line) !important;
}
body.give-p2p .wp-block-buttons .wp-block-button:first-child .wp-block-button__link:hover {
  border-color: var(--kh-navy) !important;
  background: var(--kh-cream) !important;
}
/* Second button (Donate) — primary blue */
body.give-p2p .wp-block-buttons .wp-block-button:last-child .wp-block-button__link {
  background: var(--kh-blue) !important;
  color: #fff !important;
  box-shadow: 0 8px 20px rgba(7,54,227,.28);
}
body.give-p2p .wp-block-buttons .wp-block-button:last-child .wp-block-button__link:hover {
  background: var(--kh-blue-dark) !important;
  box-shadow: 0 10px 28px rgba(7,54,227,.36);
}


/* ─── 6. IMPACT TIERS (custom HTML block) ──────────────────────────────── */
/* Paste the HTML from BUILD-GUIDE.md, snippet "Impact Tiers". */

.kh-impact {
  background: linear-gradient(180deg, var(--kh-cream) 0%, #fff 100%);
  padding: 80px 24px;
  border-top: 1px solid var(--kh-line);
  border-bottom: 1px solid var(--kh-line);
  margin: 0 calc(50% - 50vw);     /* full-bleed inside constrained layout */
}
.kh-impact__head {
  text-align: center;
  max-width: 720px;
  margin: 0 auto 48px;
}
.kh-impact__head .eyebrow {
  font-size: 12px;
  letter-spacing: .18em;
  text-transform: uppercase;
  font-weight: 800;
  color: var(--kh-blue);
  margin-bottom: 12px;
}
.kh-impact__head h2 {
  font-size: clamp(32px, 4vw, 48px);
  font-weight: 800;
  letter-spacing: -.02em;
  color: var(--kh-navy);
  margin: 0 0 14px;
  line-height: 1.05;
}
.kh-impact__head h2 em {
  font-family: var(--kh-font-accent);
  font-style: italic;
  font-weight: 600;
  color: var(--kh-gold-dark);
}
.kh-impact__head p {
  font-size: 17px;
  color: var(--kh-ink-muted);
  margin: 0;
}
.kh-impact__grid {
  max-width: 1240px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 18px;
}
.kh-tier {
  background: #fff;
  border: 1px solid var(--kh-line);
  border-radius: var(--kh-radius);
  padding: 28px 24px;
  position: relative;
  display: flex;
  flex-direction: column;
  text-decoration: none !important;
  color: inherit;
  transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease;
}
.kh-tier:hover {
  transform: translateY(-4px);
  box-shadow: var(--kh-shadow-md);
  border-color: var(--kh-blue);
}
.kh-tier--featured {
  border-color: var(--kh-gold);
  box-shadow: 0 12px 32px rgba(252,185,0,.18);
}
.kh-tier__badge {
  position: absolute; top: -12px; right: 18px;
  background: var(--kh-gold);
  color: #1a1300;
  font-size: 10px; font-weight: 800;
  letter-spacing: .14em; text-transform: uppercase;
  padding: 5px 10px; border-radius: 999px;
}
.kh-tier__amt {
  font-size: 38px; font-weight: 800; color: var(--kh-navy);
  letter-spacing: -.02em; line-height: 1;
}
.kh-tier__amt .sym { font-size: 22px; vertical-align: top; margin-right: 2px; }
.kh-tier__name {
  font-size: 13px; font-weight: 800; color: var(--kh-gold-dark);
  letter-spacing: .14em; text-transform: uppercase;
  margin: 10px 0 14px;
}
.kh-tier__desc {
  font-size: 14px; color: var(--kh-ink-muted);
  line-height: 1.55;
  flex: 1; margin: 0 0 20px;
}
/* Per-tier mini button hidden — donors pick amount on the donate form via the single CTA below */
.kh-tier__cta {
  display: none !important;
}
/* Make the tile itself visually static (no hover-lift since there's no action) */
.kh-tier {
  cursor: default !important;
  pointer-events: none !important;
}
.kh-tier:hover {
  transform: none !important;
  border-color: var(--kh-line) !important;
  box-shadow: var(--kh-shadow-sm) !important;
}
.kh-tier--featured:hover {
  border-color: var(--kh-gold) !important;
  box-shadow: 0 12px 32px rgba(252,185,0,.18) !important;
}

/* Big primary donate button BELOW the tier grid */
.kh-impact__custom {
  text-align: center;
  margin-top: 40px;
  max-width: 1240px;
  margin-left: auto;
  margin-right: auto;
  padding: 0 24px;
}
.kh-impact__custom a {
  display: inline-flex !important;
  align-items: center;
  gap: 8px;
  background: var(--kh-blue) !important;
  color: #fff !important;
  font-weight: 700 !important;
  font-size: 16px !important;
  padding: 14px 36px !important;
  border-radius: var(--kh-radius) !important;
  border-bottom: none !important;
  text-decoration: none !important;
  font-family: var(--kh-font-head) !important;
  letter-spacing: -0.01em !important;
  box-shadow: 0 6px 18px rgba(7,54,227,0.28) !important;
  transition: transform .15s ease, box-shadow .15s ease, background .2s ease !important;
}
.kh-impact__custom a:hover {
  background: var(--kh-blue-dark) !important;
  transform: translateY(-2px) !important;
  box-shadow: 0 10px 26px rgba(7,54,227,0.36) !important;
}

.kh-impact__custom::after {
  content: "Pick your level on the next step — every gift fuels your program.";
  display: block;
  margin-top: 14px;
  font-size: 13px;
  color: var(--kh-ink-muted);
  font-weight: 600;
}


/* ─── 7. STORY column (wp-block-columns) ───────────────────────────────── */
/* The 2-col layout: story on the left, donor wall on the right. */

body.give-p2p .wp-block-columns:has(.give-donor-container) {
  max-width: 1240px;
  margin: 80px auto !important;
  padding: 0 24px;
  gap: 56px !important;
  align-items: flex-start !important;
}
/* Left column — story */
body.give-p2p .wp-block-columns:has(.give-donor-container) > .wp-block-column:first-child h2 {
  font-size: clamp(32px, 4vw, 48px) !important;
  font-weight: 800 !important;
  letter-spacing: -.02em !important;
  color: var(--kh-navy) !important;
  line-height: 1.05 !important;
  margin: 0 0 16px !important;
}
body.give-p2p .wp-block-columns:has(.give-donor-container) > .wp-block-column:first-child h3 {
  font-size: 28px !important;
  font-weight: 800 !important;
  color: var(--kh-navy) !important;
  margin: 32px 0 14px !important;
  letter-spacing: -.01em !important;
}
body.give-p2p .wp-block-columns:has(.give-donor-container) > .wp-block-column:first-child .wp-block-paragraph {
  font-size: 16px !important;
  line-height: 1.7 !important;
  color: #2a3147 !important;
  margin: 0 0 18px !important;
}
/* First paragraph after the H2 — lede style */
body.give-p2p .wp-block-columns:has(.give-donor-container) > .wp-block-column:first-child h2 + .wp-block-paragraph {
  font-size: 22px !important;
  line-height: 1.45 !important;
  font-weight: 500 !important;
  color: var(--kh-navy) !important;
}
/* Italic highlights */
body.give-p2p .wp-block-columns:has(.give-donor-container) em {
  background: linear-gradient(0deg, rgba(252,185,0,.35) 0%, rgba(252,185,0,.35) 38%, transparent 38%);
  padding: 0 2px;
  font-style: italic;
}


/* ─── 8. 4-STEP PILLARS (custom HTML block) ────────────────────────────── */

.kh-pillars {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 12px;
  margin: 28px 0;
}
.kh-pillar {
  border: 1px solid var(--kh-line);
  background: var(--kh-cream);
  border-radius: var(--kh-radius);
  padding: 18px 14px;
  text-align: center;
}
.kh-pillar__step {
  font-size: 11px;
  font-weight: 800;
  color: var(--kh-gold-dark);
  letter-spacing: .15em;
  text-transform: uppercase;
}
.kh-pillar__name {
  font-size: 18px;
  font-weight: 800;
  color: var(--kh-navy);
  margin-top: 4px;
  letter-spacing: -.01em;
}


/* ─── 9. RECENT DONATIONS sidebar ([give_donor_wall]) ──────────────────── */

body.give-p2p .wp-block-columns:has(.give-donor-container) > .wp-block-column:last-child {
  position: sticky;
  top: 96px;
}
body.give-p2p .wp-block-columns:has(.give-donor-container) > .wp-block-column:last-child h2 {
  font-size: 20px !important;
  font-weight: 800 !important;
  color: var(--kh-navy) !important;
  margin: 0 0 16px !important;
  display: flex;
  align-items: center;
  justify-content: space-between;
}
body.give-p2p .wp-block-columns:has(.give-donor-container) > .wp-block-column:last-child h2::after {
  content: "● Live";
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .1em;
  color: #14c168;
  text-transform: uppercase;
}

/* Sidebar Recent Donations — FLAT rows. */
/* Hide the P2P navbar (Campaign Page / My Page / My Team) — use the main menu instead */
body.give-p2p #p2p-navbar-app,
body.give-p2p [id*="p2p-navbar"],
body.give-p2p .give-p2p-navbar,
body.give-p2p [class*="p2p-navbar"] {
  display: none !important;
}

/* Sidebar Recent Donations — FLAT rows with avatar · (name + msg stacked) · amount.
   Real DOM: .give-card > [.give-donor-container(image + variation) | .give-donor-wrapper(comment) | .give-donor-details(amount)] */
body.give-p2p .wp-block-columns:has(.give-donor-container):not(.kh-donations-grid) .give-donor.give-card {
  background: transparent !important;
  border: none !important;
  border-bottom: 1px solid var(--kh-line) !important;
  border-radius: 0 !important;
  padding: 14px 20px !important;
  margin: 0 !important;
  box-shadow: none !important;
  display: grid !important;
  grid-template-columns: 36px 1fr auto !important;
  grid-auto-rows: auto !important;
  column-gap: 14px !important;
  row-gap: 2px !important;
  align-items: center !important;
  transition: none !important;
}

/* Kill any GiveWP grid-item margins/padding between donation rows */
body.give-p2p .wp-block-columns:has(.give-donor-container):not(.kh-donations-grid) .give-grid__item,
body.give-p2p .wp-block-columns:has(.give-donor-container):not(.kh-donations-grid) .give-grid > * {
  margin: 0 !important;
  padding: 0 !important;
}
body.give-p2p .wp-block-columns:has(.give-donor-container):not(.kh-donations-grid) .give-grid {
  display: block !important;
  margin: 0 !important;
  padding: 0 !important;
  gap: 0 !important;
}

/* "Load more" button — real class: .give-donor__load_more */
body.give-p2p button.give-donor__load_more,
body.give-p2p .give-donor__load_more {
  background: var(--kh-blue) !important;
  background-color: var(--kh-blue) !important;
  color: #fff !important;
  border: none !important;
  outline: none !important;
  border-radius: var(--kh-radius) !important;
  padding: 12px 28px !important;
  font-size: 14px !important;
  font-weight: 700 !important;
  font-family: var(--kh-font-head) !important;
  letter-spacing: 0 !important;
  cursor: pointer !important;
  box-shadow: 0 4px 12px rgba(7,54,227,0.25) !important;
  transition: transform .15s ease, box-shadow .15s ease, background .2s ease !important;
  text-transform: none !important;
  width: auto !important;
  display: inline-block !important;
  margin: 28px !important;
}
body.give-p2p button.give-donor__load_more:hover,
body.give-p2p .give-donor__load_more:hover {
  background: var(--kh-blue-dark) !important;
  transform: translateY(-1px) !important;
  box-shadow: 0 6px 18px rgba(7,54,227,0.35) !important;
}
body.give-p2p .give-donor__load_more .give-loading-animation { display: none !important; }

/* Center the "Show more" button under the donations grid */
body.give-p2p .kh-donations-grid button.give-donor__load_more,
body.give-p2p .kh-donations-grid .give-donor__load_more {
  display: block !important;
  margin: 32px auto 0 !important;  /* centered, with breathing room above */
}

/* Wrap the whole donor wall in one shadowed card */
body.give-p2p .wp-block-columns:has(.give-donor-container):not(.kh-donations-grid) .give-wrap {
  background: #fff !important;
  border: 1px solid var(--kh-line) !important;
  border-radius: var(--kh-radius) !important;
  box-shadow: var(--kh-shadow-md) !important;
  overflow: hidden !important;
  padding: 8px 6px !important;
  margin: 0 !important;
}
/* Last row inside the wrap has no bottom hairline */
body.give-p2p .wp-block-columns:has(.give-donor-container):not(.kh-donations-grid) .give-wrap .give-donor.give-card:last-child {
  border-bottom: none !important;
}
body.give-p2p .wp-block-columns:has(.give-donor-container):not(.kh-donations-grid) .give-donor.give-card:hover {
  background: transparent !important;
  box-shadow: none !important;
  transform: none !important;
}

/* Flatten .give-donor-container so its kids (image + name) become direct grid items of .give-card */
body.give-p2p .wp-block-columns:has(.give-donor-container):not(.kh-donations-grid) .give-donor-container {
  display: contents !important;
}

/* Avatar circle — gradient over the GiveWP initials (keep "RN" text on top) */
body.give-p2p .wp-block-columns:has(.give-donor-container):not(.kh-donations-grid) .give-donor-container__image {
  grid-column: 1 !important;
  grid-row: 1 / -1 !important;  /* span both rows so it stays vertically centered */
  width: 36px !important;
  height: 36px !important;
  min-width: 36px !important;
  border-radius: 50% !important;
  background: linear-gradient(135deg, var(--kh-blue) 0%, var(--kh-navy) 100%) !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  align-self: center !important;
  overflow: hidden !important;
  border: none !important;
}
body.give-p2p .wp-block-columns:has(.give-donor-container):not(.kh-donations-grid) .give-donor-container__image__name_initial {
  font-size: 12px !important;
  font-weight: 800 !important;
  color: #fff !important;
  letter-spacing: 0.02em !important;
  font-family: var(--kh-font-head) !important;
}
/* Belt-and-suspenders: hide any <img> Gravatar if one ever loads */
body.give-p2p .wp-block-columns:has(.give-donor-container):not(.kh-donations-grid) .give-donor-container__image img {
  display: none !important;
}

/* Name — column 2; align center so single-row cards put name next to amount on the same line */
body.give-p2p .wp-block-columns:has(.give-donor-container):not(.kh-donations-grid) .give-donor-container-variation {
  grid-column: 2 !important;
  grid-row: 1 !important;
  flex-direction: row !important;
  align-items: center !important;
  align-self: center !important;
  margin: 0 !important;
  padding: 0 !important;
  min-width: 0 !important;
}
body.give-p2p .wp-block-columns:has(.give-donor-container):not(.kh-donations-grid) .give-donor-container-variation__name {
  font-size: 14px !important;
  font-weight: 700 !important;
  color: var(--kh-navy) !important;
  line-height: 1.2 !important;
  margin: 0 !important;
  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  max-width: 100% !important;
}
/* Hide the date row entirely — keeps things tight */
body.give-p2p .wp-block-columns:has(.give-donor-container):not(.kh-donations-grid) .give-donor-container-variation__timestamp {
  display: none !important;
}

/* Message wrapper — second row of the card, indented to line up with names */
body.give-p2p .wp-block-columns:has(.give-donor-container):not(.kh-donations-grid) .give-donor-wrapper {
  grid-column: 1 / -1 !important;
  grid-row: 2 !important;
  padding-left: 50px !important;   /* avatar (36) + column gap (14) */
  margin: 0 !important;
  min-width: 0 !important;
  align-self: start !important;
}
body.give-p2p .wp-block-columns:has(.give-donor-container):not(.kh-donations-grid) .give-donor-content {
  background: transparent !important;
  border: none !important;
  border-left: none !important;
  padding: 0 !important;
  margin: 0 !important;
  box-shadow: none !important;
}
body.give-p2p .wp-block-columns:has(.give-donor-container):not(.kh-donations-grid) .give-donor-content__comment {
  font-family: var(--kh-font-accent) !important;
  font-style: italic !important;
  font-weight: 600 !important;
  font-size: 12px !important;
  color: var(--kh-ink-muted) !important;
  line-height: 1.3 !important;
  margin: 0 !important;
  padding: 0 !important;
  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  max-width: 100% !important;
  display: block !important;
}

/* Amount — column 3, vertically centered across both rows */
body.give-p2p .wp-block-columns:has(.give-donor-container):not(.kh-donations-grid) .give-donor-details {
  grid-column: 3 !important;
  grid-row: 1 / -1 !important;
  align-self: center !important;
  margin: 0 !important;
  padding: 0 !important;
}
body.give-p2p .wp-block-columns:has(.give-donor-container):not(.kh-donations-grid) .give-donor-details__wrapper {
  display: none !important;
}
body.give-p2p .wp-block-columns:has(.give-donor-container):not(.kh-donations-grid) .give-donor-details__total {
  font-size: 15px !important;
  font-weight: 800 !important;
  color: var(--kh-blue) !important;
  white-space: nowrap !important;
  display: block !important;
}

/* Kill the legacy gradient ::before fallback in the sidebar — we use the real avatar element */
body.give-p2p .wp-block-columns:has(.give-donor-container):not(.kh-donations-grid) .give-donor-container::before {
  display: none !important;
  content: none !important;
}

/* Default (GRID) card style — used by .kh-donations-grid and as fallback */
body.give-p2p .give-donor.give-card {
  background: #fff !important;
  border: 1px solid var(--kh-line) !important;
  border-radius: var(--kh-radius) !important;
  padding: 14px 16px !important;
  margin-bottom: 10px !important;
  box-shadow: var(--kh-shadow-sm) !important;
  transition: box-shadow .15s ease, transform .15s ease;
  display: grid !important;
  grid-template-columns: 44px 1fr auto !important;
  gap: 14px !important;
  align-items: center !important;
}
body.give-p2p .give-donor.give-card:hover { box-shadow: var(--kh-shadow-md) !important; transform: translateY(-1px); }

/* GLOBAL rule: hide GiveWP donor-container for the SIDEBAR only.
   The grid scope (.kh-donations-grid) needs the container to remain a real flex box. */
body.give-p2p .wp-block-columns:has(.give-donor-container):not(.kh-donations-grid) .give-donor-container { display: contents !important; }

/* Avatar — if GiveWP renders one (show_avatar=1), restyle. If not, the ::before fallback. */
body.give-p2p .give-donor img,
body.give-p2p .give-donor .gravatar,
body.give-p2p .give-donor .give-donor-avatar {
  width: 44px !important;
  height: 44px !important;
  border-radius: 50% !important;
  border: 2px solid #fff !important;
  box-shadow: 0 2px 8px rgba(10,30,74,0.15) !important;
  grid-column: 1 !important;
}
/* WordPress replaces emoji in comments with <img class="emoji"> — the avatar
   rule above was sizing them as 44px circles. Force them back to inline glyphs. */
body.give-p2p .give-donor img.emoji,
body.give-p2p .give-donor img.wp-smiley {
  width: 1em !important;
  height: 1em !important;
  border: 0 !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  background: none !important;
  display: inline !important;
  vertical-align: -0.1em !important;
  margin: 0 0.05em !important;
  grid-column: auto !important;
}
/* Gradient circle fallback if no avatar rendered */
body.give-p2p .give-donor:not(:has(img)) .give-donor-container::before {
  content: "" !important;
  display: block !important;
  width: 44px !important;
  height: 44px !important;
  border-radius: 50% !important;
  background: linear-gradient(135deg, var(--kh-blue) 0%, var(--kh-navy) 100%) !important;
  grid-column: 1 !important;
}

/* Name + timestamp column */
body.give-p2p .give-donor-container-variation {
  gap: 2px !important;
  grid-column: 2 !important;
  flex-direction: column !important;
  align-items: flex-start !important;
  display: flex !important;
}
body.give-p2p .give-donor-container-variation__name {
  font-size: 14px !important;
  font-weight: 700 !important;
  color: var(--kh-navy) !important;
  margin: 0 !important;
  letter-spacing: -0.01em !important;
}
body.give-p2p .give-donor-container-variation__timestamp {
  font-size: 11px !important;
  color: var(--kh-ink-muted) !important;
  margin: 0 !important;
  font-weight: 500 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.05em !important;
}

/* Right column — amount only, hide the "Donation Form / Amount Donated" labels */
body.give-p2p .give-donor-details {
  grid-column: 3 !important;
  margin: 0 !important;
}
body.give-p2p .give-donor-details__wrapper,
body.give-p2p .give-donor-details__form_title,
body.give-p2p [class*="give-donor-details__amount_donated"],
body.give-p2p .give-donor-details span:not(.give-donor-details__total) {
  display: none !important;
}
body.give-p2p .give-donor-details__total {
  font-size: 20px !important;
  font-weight: 800 !important;
  color: var(--kh-blue) !important;
  letter-spacing: -0.01em !important;
  display: block !important;
}

/* ────────────────────────────────────────────────────────────
   ALL DONATIONS GRID (.kh-donations-grid)
   Layout: flexbox with order so DOM order (image, variation,
   details, wrapper) renders as: [avatar] [name+date] [amount]
   on row 1, comment (if any) on row 2.
   ──────────────────────────────────────────────────────────── */

body.give-p2p .kh-donations-grid {
  max-width: 1320px;
  margin: 24px auto !important;  /* tight vertical rhythm — gives the section room without dead space */
  padding: 0 24px;
}
body.give-p2p .kh-donations-grid > h2 {
  font-size: clamp(32px, 4vw, 48px) !important;
  font-weight: 800 !important;
  color: var(--kh-navy) !important;
  letter-spacing: -0.02em !important;
  margin: 0 0 8px !important;
  line-height: 1.05 !important;
}
body.give-p2p .kh-donations-grid > .kh-donations-grid__sub {
  font-size: 16px;
  color: var(--kh-ink-muted);
  margin: 0 0 24px;
}

/* Override WordPress .is-layout-constrained which adds max-width + auto margins
   to children — this was squishing the grid to content-size width */
/* Outer wrapper: normal block flow so the "Show more" button can sit
   below the grid as a sibling, not be pulled into a grid column. */
body.give-p2p .kh-donations-grid .give-grid-ie-utility {
  display: block !important;
  width: 100% !important;
  max-width: 100% !important;
  margin-left: 0 !important;
  margin-right: 0 !important;
}
/* Inner .give-grid is the actual grid that holds donation items.
   3 columns to match the Top Fundraisers layout. */
body.give-p2p .kh-donations-grid .give-grid-ie-utility > .give-grid {
  display: grid !important;
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  gap: 18px !important;
  width: 100% !important;
  margin: 0 !important;
  padding: 0 !important;
}
/* Each donation card: bigger padding + equal height (stretches to row tallest)
   so that a row with a "Testing message" donor note is matched by its peers. */
body.give-p2p .kh-donations-grid .give-grid-ie-utility > .give-grid > .give-grid__item {
  display: flex !important;
  align-items: stretch !important;
  height: auto !important;
}
body.give-p2p .kh-donations-grid .give-grid-ie-utility > .give-grid .give-card {
  padding: 10px 18px !important;
  border-radius: var(--kh-radius) !important;
  width: 100% !important;
  height: 100% !important;
  min-height: 180px !important;
  display: flex !important;
  flex-direction: column !important;
  justify-content: flex-start !important;
  align-items: center !important;
}
/* Responsive: 2 cols on tablet, 1 col on mobile */
@media (max-width: 1100px) {
  body.give-p2p .kh-donations-grid .give-grid-ie-utility > .give-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }
}
@media (max-width: 720px) {
  body.give-p2p .kh-donations-grid .give-grid-ie-utility > .give-grid {
    grid-template-columns: 1fr !important;
  }
}
body.give-p2p .kh-donations-grid .give-grid__item {
  margin: 0 !important;
  padding: 0 !important;
  max-width: 100% !important;
}

/* CARD */
body.give-p2p .kh-donations-grid .give-donor.give-card {
  background: #fff !important;
  border: 1px solid var(--kh-line) !important;
  border-radius: var(--kh-radius) !important;
  padding: 0 !important;
  margin: 0 !important;
  box-shadow: var(--kh-shadow-sm) !important;
  display: block !important;
  overflow: hidden !important;
  transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease !important;
  grid-template-columns: none !important;
}
body.give-p2p .kh-donations-grid .give-donor.give-card:hover {
  transform: translateY(-3px) !important;
  border-color: var(--kh-blue) !important;
  box-shadow: var(--kh-shadow-md) !important;
}

/* Kill ::before circle — needs 4 classes to beat the generating rule's (0,3,2) specificity */
body.give-p2p .kh-donations-grid .give-donor.give-card .give-donor-container::before {
  display: none !important;
  content: none !important;
  background: none !important;
}

/* CONTAINER — flex row + wrap so comment falls to its own line */
body.give-p2p .kh-donations-grid .give-donor-container {
  display: flex !important;
  flex-direction: row !important;
  flex-wrap: wrap !important;
  align-items: center !important;
  gap: 16px !important;
  padding: 20px !important;
  margin: 0 !important;
  width: 100% !important;
  box-sizing: border-box !important;
}

/* Avatar — order 1, fixed 44px circle */
body.give-p2p .kh-donations-grid .give-donor-container__image {
  order: 1 !important;
  flex: 0 0 52px !important;
  width: 52px !important;
  height: 52px !important;
  min-width: 44px !important;
  border-radius: 50% !important;
  background: linear-gradient(135deg, var(--kh-blue) 0%, var(--kh-navy) 100%) !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  overflow: hidden !important;
  border: none !important;
  align-self: center !important;
}
body.give-p2p .kh-donations-grid .give-donor-container__image__name_initial {
  color: #fff !important;
  font-weight: 800 !important;
  font-size: 15px !important;
  font-family: var(--kh-font-head) !important;
  line-height: 1 !important;
}
body.give-p2p .kh-donations-grid .give-donor-container__image img { display: none !important; }

/* Name + date — order 2, fills remaining space */
body.give-p2p .kh-donations-grid .give-donor-container-variation {
  order: 2 !important;
  flex: 1 !important;
  min-width: 0 !important;
  display: flex !important;
  flex-direction: column !important;
  gap: 3px !important;
  align-self: center !important;
  margin: 0 !important;
  padding: 0 !important;
  height: auto !important;
  width: auto !important;
}
body.give-p2p .kh-donations-grid h3.give-donor-container-variation__name {
  font-size: 20px !important;
  font-weight: 700 !important;
  color: var(--kh-ink) !important;
  margin: 0 !important;
  letter-spacing: -.01em !important;
  text-align: center !important;
}
body.give-p2p .kh-donations-grid p.give-donor-container-variation__timestamp {
  font-size: 12px !important;
  font-weight: 600 !important;
  color: var(--kh-ink-muted) !important;
  text-transform: uppercase !important;
  letter-spacing: 0.06em !important;
  margin: 0 !important;
  padding: 0 !important;
  line-height: 1.2 !important;
  display: block !important;
}

/* Amount — order 3, right side of row 1 */
body.give-p2p .kh-donations-grid .give-donor-details {
  order: 3 !important;
  flex: 0 0 auto !important;
  align-self: center !important;
  margin: 0 !important;
  padding: 0 !important;
}
/* Hide the broken "AMOUNT DONATED" label (GiveWP renders it with spaces in the class name) */
body.give-p2p .kh-donations-grid .give-donor-details__wrapper {
  display: none !important;
}
/* old 18px rule removed — superseded by 56px below */

/* Comment — order 4, full width → wraps to its own row, indented */
body.give-p2p .kh-donations-grid .give-donor-wrapper {
  order: 4 !important;
  flex: 0 0 100% !important;
  padding: 4px 0 0 58px !important;
  margin: 0 !important;
}
body.give-p2p .kh-donations-grid .give-donor-content {
  background: transparent !important;
  border: none !important;
  padding: 0 !important;
  margin: 0 !important;
  box-shadow: none !important;
}
/* old comment rule removed — superseded by centered version below */

@media (max-width: 640px) {
  body.give-p2p .kh-donations-grid .give-grid-ie-utility { grid-template-columns: 1fr !important; }
}

/* ────────────────────────────────────────────────────────────
   HIDE Top Donors tab inside the donations-overview block.
   The overview block likely also lives in shadow DOM — if this CSS
   alone doesn't hide it, we'll inject equivalent into its shadow.
   ──────────────────────────────────────────────────────────── */
body.give-p2p .kh-darkband [role="tab"]:nth-of-type(2),
body.give-p2p .kh-darkband button[aria-selected]:not(:first-of-type) {
  display: none !important;
}


/* ─── 10. LEADERBOARD ──────────────────────────────────────────────────── */
/* The fundraiser leaderboard renders inside a Shadow DOM (sealed scope) —
   external CSS can't reach it. Styling for the leaderboard lives in:
       snippets/leaderboard-shadow-styles.html
   That file injects a <style> element into the shadow root via JS.
   Paste it as a Custom HTML block at the bottom of the campaign page. */



/* ─── 11. DONATIONS OVERVIEW (dark band) ───────────────────────────────── */
/* Wrap the .give-p2p-campaign-donations-overview-block in a WP group with
   class "kh-darkband" (see BUILD-GUIDE.md). */

.kh-darkband {
  background: var(--kh-navy-deep) !important;
  color: #fff !important;
  padding: 80px 24px !important;
  margin: 0 calc(50% - 50vw) !important;   /* full-bleed */
}
.kh-darkband > .wp-block-group__inner-container,
.kh-darkband > * {
  max-width: 1240px;
  margin: 0 auto;
  padding: 0 !important;  /* strip any editor-set inner padding */
}
/* Reset block-gap and any default GiveWP block margins inside the dark band */
body.give-p2p .kh-darkband .give-p2p-campaign-donations-overview-block {
  margin: 0 !important;
  padding: 0 !important;
  --wp--style--block-gap: 0px;
}
.kh-darkband .give-p2p-campaign-donations-overview-block * {
  color: #fff !important;
}
.kh-darkband .give-p2p-campaign-donations-overview-block button,
.kh-darkband .give-p2p-campaign-donations-overview-block [role="tab"] {
  background: transparent !important;
  color: rgba(255,255,255,.6) !important;
  border: none !important;
  border-bottom: 2px solid transparent !important;
  font-weight: 700 !important;
  padding: 14px 22px !important;
  font-family: var(--kh-font-head) !important;
}
.kh-darkband .give-p2p-campaign-donations-overview-block [aria-selected="true"],
.kh-darkband .give-p2p-campaign-donations-overview-block [role="tab"].active {
  color: #fff !important;
  border-bottom-color: var(--kh-gold) !important;
}
.kh-darkband .give-p2p-campaign-donations-overview-block [class*="row"],
.kh-darkband .give-p2p-campaign-donations-overview-block li {
  border-bottom: 1px solid rgba(255,255,255,.08) !important;
  padding: 18px 4px !important;
}
.kh-darkband .give-p2p-campaign-donations-overview-block [class*="amount"],
.kh-darkband .give-p2p-campaign-donations-overview-block [class*="total"] {
  color: var(--kh-gold) !important;
  font-size: 18px !important;
  font-weight: 800 !important;
}
.kh-darkband__head {
  text-align: center;
  margin: 0 auto 24px;
  max-width: 720px;
}
.kh-darkband__head .eyebrow {
  font-size: 12px; letter-spacing: .18em; text-transform: uppercase;
  font-weight: 800; color: var(--kh-gold); margin-bottom: 12px;
}
.kh-darkband__head h2 {
  color: #fff !important;
  font-size: clamp(32px, 4vw, 48px) !important;
  font-weight: 800 !important;
  letter-spacing: -.02em !important;
  margin: 0 !important;
  line-height: 1.05 !important;
}
.kh-darkband__head h2 em {
  font-family: var(--kh-font-accent);
  font-style: italic;
  font-weight: 600;
  color: var(--kh-gold);
}


/* ─── 12. FINAL CTA banner (custom HTML block) ─────────────────────────── */

.kh-final {
  background: linear-gradient(135deg, var(--kh-blue) 0%, var(--kh-navy) 100%);
  color: #fff;
  text-align: center;
  padding: 90px 24px;
  margin: 0 calc(50% - 50vw);
}
.kh-final h2 {
  color: #fff !important;
  font-size: clamp(36px, 5vw, 56px) !important;
  margin: 0 0 18px !important;
  font-weight: 800 !important;
  letter-spacing: -.02em !important;
  line-height: 1.05 !important;
}
.kh-final h2 em {
  font-family: var(--kh-font-accent);
  font-style: italic;
  font-weight: 600;
  color: var(--kh-gold);
}
.kh-final p {
  font-size: 19px;
  max-width: 620px;
  margin: 0 auto 32px;
  color: rgba(255,255,255,.85);
}
.kh-final__btns {
  display: flex;
  justify-content: center;
  gap: 14px;
  flex-wrap: wrap;
}
.kh-final__btns a {
  display: inline-flex; align-items: center; gap: 10px;
  padding: 20px 28px;
  border-radius: var(--kh-radius);
  font-weight: 700;
  font-size: 17px;
  text-decoration: none !important;
  transition: transform .15s ease, background .2s ease;
}
.kh-final__btns a:hover { transform: translateY(-1px); }
.kh-final__btns a.primary {
  background: var(--kh-gold);
  color: #1a1300;
  box-shadow: 0 6px 16px rgba(252,185,0,.35);
}
.kh-final__btns a.primary:hover { background: var(--kh-gold-dark); }
.kh-final__btns a.ghost {
  background: transparent;
  color: #fff;
  border: 1.5px solid rgba(255,255,255,.4);
}
.kh-final__btns a.ghost:hover { border-color: #fff; background: rgba(255,255,255,.06); }


/* ─── 13. STICKY DONATE BUTTON (custom HTML block) ─────────────────────── */

.kh-sticky-donate {
  position: fixed;
  bottom: 24px;
  right: 24px;
  z-index: 99;
  background: var(--kh-blue);
  color: #fff !important;
  padding: 16px 22px;
  border-radius: 999px;
  font-weight: 800;
  font-size: 15px;
  box-shadow: 0 12px 30px rgba(7,54,227,.45);
  display: inline-flex;
  align-items: center;
  gap: 12px;
  text-decoration: none !important;
  transition: transform .15s ease;
  font-family: var(--kh-font-head);
}
.kh-sticky-donate:hover { transform: translateY(-2px); color: #fff !important; }
.kh-sticky-donate__bar {
  width: 88px; height: 7px; background: rgba(255,255,255,.22);
  border-radius: 999px; overflow: hidden;
  flex-shrink: 0;
  box-shadow: inset 0 1px 2px rgba(0,0,0,.15);
}
.kh-sticky-donate__bar > span {
  display: block;
  width: var(--kh-progress, 1%);
  min-width: 10px;       /* keep the gold visible even at <1% */
  height: 100%;
  background: var(--kh-gold);
  border-radius: 999px;
  box-shadow: 0 0 6px rgba(252,185,0,.6);
  transition: width .6s cubic-bezier(.22,1,.36,1);
}
.kh-sticky-donate__meta { font-size: 12px; opacity: .85; font-weight: 600; }

/* "+$X just in!" flash that pops above the sticky donate on a new donation */
.kh-flash {
  position: fixed;
  bottom: 88px;     /* sits just above the sticky donate (16px gap + ~72px tall) */
  right: 24px;
  z-index: 100;
  background: linear-gradient(135deg, var(--kh-gold) 0%, #ffd64a 100%);
  color: #1a1300;
  font-family: var(--kh-font-head);
  font-weight: 800;
  font-size: 14px;
  letter-spacing: -.01em;
  padding: 10px 16px;
  border-radius: 999px;
  box-shadow: 0 12px 30px rgba(252,185,0,.5), 0 0 0 4px rgba(252,185,0,.18);
  display: inline-flex;
  align-items: center;
  gap: 8px;
  pointer-events: none;
  white-space: nowrap;
  opacity: 0;
  transform: translateY(16px) scale(.9);
  animation: kh-flash-pop 2.8s cubic-bezier(.22,1,.36,1) forwards;
}
.kh-flash::before {
  content: "🎉";
  font-size: 16px;
}
@keyframes kh-flash-pop {
  0%   { opacity: 0; transform: translateY(16px) scale(.9); }
  12%  { opacity: 1; transform: translateY(0)    scale(1.08); }
  22%  { transform: translateY(0)   scale(1); }
  72%  { opacity: 1; transform: translateY(-12px) scale(1); }
  100% { opacity: 0; transform: translateY(-48px) scale(.95); }
}
@media (max-width: 640px) {
  .kh-flash {
    bottom: 96px;
    right: 16px;
    left: 16px;
    justify-content: center;
  }
}


/* ─── 14. FOOTER tweaks ────────────────────────────────────────────────── */

body.give-p2p footer.site-footer { border-top: 1px solid var(--kh-line); padding: 40px 24px; }


/* ─── 15. RESPONSIVE ───────────────────────────────────────────────────── */

@media (max-width: 1024px) {
  body.give-p2p .wp-block-cover.alignfull { min-height: 620px; padding-top: 64px; }
  .kh-hero { grid-template-columns: 1fr; gap: 28px; }
  .kh-hero__side { max-width: 480px; }
  body.give-p2p .give-p2p-campaign-header-block {
    padding: 28px;
    margin-top: -120px;
  }
  body.give-p2p .givewp-campaign-goal__container-item:first-child strong { font-size: 42px !important; }
  .kh-impact__grid { grid-template-columns: repeat(2, 1fr); }
  body.give-p2p .wp-block-columns:has(.give-donor-container) { grid-template-columns: 1fr !important; gap: 32px !important; }
  body.give-p2p .wp-block-columns:has(.give-donor-container) > .wp-block-column:last-child { position: static; }
  .kh-pillars { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 640px) {
  body.give-p2p .wp-block-cover.alignfull { min-height: 540px; padding: 48px 16px 180px; }
  .kh-hero h1 { font-size: 44px !important; }
  .kh-hero__kicker { font-size: 16px !important; }
  .kh-hero__meta { gap: 12px; font-size: 12px; }
  body.give-p2p .give-p2p-campaign-header-block { padding: 22px; margin-top: -150px; }
  body.give-p2p .givewp-campaign-goal__container { flex-direction: column; align-items: flex-start; gap: 12px; }
  body.give-p2p .givewp-campaign-goal__container-item:last-child { text-align: left; }
  body.give-p2p .givewp-campaign-stats-block { grid-template-columns: 1fr 1fr; }
  body.give-p2p .wp-block-buttons { flex-direction: column; padding: 0 16px; }
  body.give-p2p .wp-block-button { width: 100%; }
  body.give-p2p .wp-block-button .wp-block-button__link { width: 100%; }
  .kh-impact { padding: 56px 16px; }
  .kh-impact__grid { grid-template-columns: 1fr; }
  .kh-darkband { padding: 56px 16px !important; }
  .kh-final { padding: 56px 16px; }
  .kh-sticky-donate {
    left: 16px; right: 16px; bottom: 16px;
    justify-content: center;
  }
}

/*donor dashboard styles*/
.post-46390 .entry-title{
	display:none;
}
.page-id-46390{
	background:#F9F7F0!important;
}


/*all h1s and ems*/
.kh-h1 {
    font-family: var(--kh-font-head) !important;
    font-size: clamp(32px, 5vw, 56px) !important;
    font-weight: 800 !important;
    letter-spacing: -0.02em !important;
    color: #0a1e4a !important;
    line-height: 1.05 !important;
    margin: 0 0 16px !important;
}
.kh-h1 em {
    font-family: var(--kh-font-accent) !important;
    font-style: italic !important;
    font-weight: 600 !important;
    color: #fcb900 !important;
}

/* ════════════════════════════════════════════════════════════════
   48-HOUR MATCH CARD
   Place a Custom HTML block in the campaign page hero with the
   markup pattern .kh-match-card / .kh-match-card__* — these
   styles theme it. Also applies on the fundraiser sub-page where
   the markup is rendered server-side (§9 of the all-in-one).
   ════════════════════════════════════════════════════════════════ */

body.give-p2p .kh-match-card {
  background: linear-gradient(155deg, rgba(252,185,0,.22) 0%, rgba(252,185,0,.08) 100%);
  border: 1px solid rgba(252,185,0,.55);
  border-radius: var(--kh-radius-lg);
  padding: 28px 28px 24px;
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  box-shadow: 0 14px 40px rgba(0,0,0,.4), inset 0 1px 0 rgba(255,255,255,.1);
  position: relative;
  overflow: hidden;
  color: #fff;
  font-family: var(--kh-font-head);
  max-width: 460px;
  width: 100%;
  box-sizing: border-box;
}
body.give-p2p .kh-match-card::before {
  content: ""; position: absolute; top: -40px; right: -40px;
  width: 160px; height: 160px;
  background: radial-gradient(circle, rgba(252,185,0,.4) 0%, transparent 70%);
  pointer-events: none;
}
body.give-p2p .kh-match-card__eyebrow {
  display: inline-flex; align-items: center; gap: 8px;
  color: var(--kh-gold); font-size: 10.5px; font-weight: 800;
  letter-spacing: .2em; text-transform: uppercase;
  margin-bottom: 14px;
}
body.give-p2p .kh-match-card__eyebrow::before { content: "✦"; font-size: 12px; }
body.give-p2p .kh-match-card__dot {
  width: 7px; height: 7px; border-radius: 50%; display: inline-block;
  background: #6ce26c; margin-right: 4px;
  animation: kh-match-pulse 2s infinite;
}
@keyframes kh-match-pulse {
  0%   { box-shadow: 0 0 0 0 rgba(108,226,108,.6); }
  70%  { box-shadow: 0 0 0 10px rgba(108,226,108,0); }
  100% { box-shadow: 0 0 0 0 rgba(108,226,108,0); }
}
body.give-p2p .kh-match-card__amount {
  font-size: 68px; font-weight: 900; color: #fff;
  line-height: .88; letter-spacing: -.04em; margin: 0;
  display: flex; align-items: baseline; flex-wrap: wrap; gap: 12px;
}
body.give-p2p .kh-match-card__sym {
  color: var(--kh-gold); font-size: .65em; font-weight: 800;
  vertical-align: top; margin-right: 4px;
}
body.give-p2p .kh-match-card__tail {
  font-size: 16px; font-weight: 600;
  color: rgba(255,255,255,.78); letter-spacing: 0;
  text-transform: lowercase; align-self: baseline; margin-bottom: 4px;
}
body.give-p2p .kh-match-card__headline {
  font-family: var(--kh-font-accent);
  font-size: 28px; font-style: italic; line-height: 1.18;
  color: #fff; margin: 8px 0 14px; font-weight: 400;
}
body.give-p2p .kh-match-card__headline em {
  font-style: italic; color: var(--kh-gold); white-space: nowrap;
}
body.give-p2p .kh-match-card__countdown {
  display: inline-flex; align-items: center; gap: 10px;
  font-size: 11px; font-weight: 800; letter-spacing: .14em;
  text-transform: uppercase; padding: 8px 12px; border-radius: 8px;
  background: rgba(252,185,0,.18); color: var(--kh-gold);
  border: 1px solid rgba(252,185,0,.5);
  font-variant-numeric: tabular-nums;
}
body.give-p2p .kh-match-card__time { letter-spacing: .06em; font-size: 12px; }
body.give-p2p .kh-match-card__suffix { opacity: .75; letter-spacing: .12em; font-size: 10px; }
body.give-p2p .kh-match-card__clock { opacity: .8; }
body.give-p2p .kh-match-card__divider {
  height: 1px; margin: 16px 0;
  background: linear-gradient(90deg, rgba(252,185,0,.5) 0%, rgba(252,185,0,0) 100%);
}
body.give-p2p .kh-match-card__attrib {
  font-size: 12.5px; color: rgba(255,255,255,.78);
  line-height: 1.55; font-weight: 500;
}
body.give-p2p .kh-match-card__attrib strong { color: #fff; font-weight: 700; }
body.give-p2p .kh-match-card__attrib-by {
  display: block; color: var(--kh-gold);
  font-size: 10px; letter-spacing: .14em; text-transform: uppercase;
  font-weight: 700; margin-bottom: 4px;
}
body.give-p2p .kh-match-card__attrib-ded {
  display: block; margin-top: 8px; font-style: italic;
  font-family: var(--kh-font-accent); font-size: 13px;
  color: rgba(255,255,255,.72);
}

/* Mobile: shrink and adjust spacing */
@media (max-width: 880px) {
  body.give-p2p .kh-match-card {
    max-width: 100%; padding: 22px;
  }
  body.give-p2p .kh-match-card__amount { font-size: 56px; }
  body.give-p2p .kh-match-card__headline { font-size: 22px; }
}


/* ════════════════════════════════════════════════════════════════
   COMPREHENSIVE RESPONSIVE PASS
   Two breakpoints, consistent across the whole campaign:
   ≤1024px — TABLET (single-column layouts, downsized fonts)
   ≤640px  — PHONE (further tightening, full-width buttons)
   These rules are LAST in the file so they cascade-win.
   ════════════════════════════════════════════════════════════════ */

/* ─── TABLET (≤1024px) ─── */
@media (max-width: 1024px) {

  /* HERO: stack to one column, kill the right-side overlap */
  body.give-p2p .wp-block-cover__inner-container {
    grid-template-columns: 1fr !important;
    gap: 32px !important;
  }
  body.give-p2p .wp-block-cover.alignfull { padding: 80px 24px 160px !important; }
  body.give-p2p .wp-block-cover h1 { font-size: clamp(36px, 7vw, 56px) !important; }

  /* MATCH CARD: full width, tighter padding, comes first on mobile */
  body.give-p2p .kh-match-card {
    max-width: 100% !important;
    padding: 22px !important;
    order: -1;
  }
  body.give-p2p .kh-match-card__amount { font-size: 54px !important; }
  body.give-p2p .kh-match-card__headline { font-size: 22px !important; }

  /* GOAL CARD: symmetric padding, kill negative margins, buttons go below */
  body.give-p2p .give-p2p-campaign-header-block {
    padding: 32px 24px !important;
    margin: -100px 16px 0 !important;
    max-width: calc(100% - 32px) !important;
  }
  body.give-p2p .wp-block-buttons:has(.wp-block-button__link[href*="/donate/"]) {
    position: static !important;
    margin: 24px auto 56px !important;
    flex-direction: row !important;
    align-items: center !important;
    justify-content: center !important;
    flex-wrap: wrap !important;
    padding: 0 16px !important;
    gap: 12px !important;
  }
  body.give-p2p .wp-block-buttons:has(.wp-block-button__link[href*="/donate/"]) .wp-block-button {
    width: auto !important;
    flex: 1 1 220px !important;
    max-width: 320px !important;
  }

  /* IMPACT TIERS: 2-col grid (was 4-col) */
  body.give-p2p .kh-impact__grid { grid-template-columns: repeat(2, 1fr) !important; gap: 12px !important; }
  body.give-p2p .kh-impact h2 { font-size: clamp(28px, 4vw, 42px) !important; }

  /* STORY + DONOR WALL: stack vertically */
  body.give-p2p .wp-block-columns:has(.give-donor-container) {
    flex-direction: column !important;
    gap: 32px !important;
    margin: 48px auto !important;
  }
  body.give-p2p .wp-block-columns:has(.give-donor-container) > .wp-block-column {
    flex-basis: 100% !important;
    width: 100% !important;
    max-width: 100% !important;
  }
  body.give-p2p .wp-block-columns:has(.give-donor-container) > .wp-block-column:last-child {
    position: static !important;
  }

  /* DONATIONS GRID: 2 cols (existing rule covered ≤1100 but unify it here too) */
  body.give-p2p .kh-donations-grid .give-grid-ie-utility > .give-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }
  body.give-p2p .kh-donations-grid .give-grid .give-card {
    min-height: auto !important;
    padding: 20px 22px !important;
  }
  body.give-p2p .kh-donations-grid > h2 { font-size: clamp(28px, 4vw, 42px) !important; }

  /* FINAL CTA */
  body.give-p2p .kh-final h2 { font-size: clamp(32px, 5vw, 56px) !important; }
  body.give-p2p .kh-final__btns { flex-direction: column !important; gap: 12px !important; align-items: stretch !important; }
  body.give-p2p .kh-final__btns > a { width: 100% !important; text-align: center !important; }
}

/* ─── PHONE (≤640px) ─── */
@media (max-width: 640px) {

  /* IMPACT TIERS: 1-col */
  body.give-p2p .kh-impact__grid { grid-template-columns: 1fr !important; }
  body.give-p2p .kh-tier { padding: 22px 20px !important; }
  body.give-p2p .kh-tier__amt { font-size: 48px !important; }

  /* DONATIONS GRID: 1-col */
  body.give-p2p .kh-donations-grid { padding: 0 16px !important; }
  body.give-p2p .kh-donations-grid .give-grid-ie-utility > .give-grid {
    grid-template-columns: 1fr !important;
  }

  /* MATCH CARD: tighter on phone */
  body.give-p2p .kh-match-card { padding: 20px !important; border-radius: var(--kh-radius) !important; }
  body.give-p2p .kh-match-card__amount { font-size: 44px !important; gap: 8px !important; }
  body.give-p2p .kh-match-card__tail { font-size: 13px !important; }
  body.give-p2p .kh-match-card__headline { font-size: 18px !important; margin: 4px 0 12px !important; }
  body.give-p2p .kh-match-card__attrib { font-size: 11.5px !important; }
  body.give-p2p .kh-match-card__countdown { font-size: 10px !important; padding: 6px 10px !important; gap: 6px !important; }

  /* GOAL CARD: tighter */
  body.give-p2p .give-p2p-campaign-header-block {
    padding: 24px 18px !important;
    margin: -60px 12px 0 !important;
    border-radius: var(--kh-radius) !important;
  }

  /* HERO: smaller */
  body.give-p2p .wp-block-cover.alignfull { padding: 56px 16px 100px !important; min-height: auto !important; }
  body.give-p2p .wp-block-cover h1 { font-size: 36px !important; }
  body.give-p2p .wp-block-cover .wp-block-paragraph { font-size: 15px !important; }

  /* FINAL CTA tighten */
  body.give-p2p .kh-final { padding: 56px 24px !important; }
  body.give-p2p .kh-final h2 { font-size: 32px !important; }

  /* STICKY DONATE: keep it visible but compact */
  #kh-sticky-donate, .kh-sticky-donate {
    bottom: 12px !important; right: 12px !important;
    padding: 10px 18px !important; font-size: 13px !important;
  }
}

/* ════════════════════════════════════════════════════════════════
   MOBILE POLISH PASS — task list from May 27 review
   ════════════════════════════════════════════════════════════════ */

@media (max-width: 880px) {
  body.give-p2p #kh-sticky-donate,
  body.give-p2p .kh-sticky-donate {
    bottom: 14px !important;
    left: 50% !important;
    right: auto !important;
    transform: translateX(-50%) !important;
    padding: 12px 28px !important;
    font-size: 14px !important;
    font-weight: 800 !important;
    border-radius: 999px !important;
    box-shadow: 0 10px 30px rgba(7,54,227,.4) !important;
    width: auto !important;
    max-width: none !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 8px !important;
  }
  body.give-p2p .kh-sticky-amount { font-size: 14px !important; }
  body.give-p2p .kh-sticky-progress { height: 8px !important; flex: 1 !important; }
}

@media (max-width: 880px) {
  .kh-fr-eyebrow { padding: 8px 14px !important; font-size: 11px !important; }
  .kh-fr-eyebrow__avatar { width: 32px !important; height: 32px !important; }
  .kh-fr-eyebrow__campaign,
  .kh-fr-eyebrow__name__suffix { display: none !important; }
}

@media (max-width: 880px) {
  body.give-p2p .wp-block-cover.alignfull .wp-block-cover__inner-container,
  .kh-fr-hero__inner {
    display: flex !important;
    flex-direction: column !important;
    gap: 16px !important;
  }
  body.give-p2p .wp-block-cover.alignfull .kh-match-card,
  .kh-fr-hero__inner .kh-match-card { order: 1 !important; }
  .kh-fr-hero__inner .kh-fr-eyebrow { order: 2 !important; }
  body.give-p2p .wp-block-cover.alignfull h1,
  .kh-fr-hero__inner h1 { order: 3 !important; }
  body.give-p2p .wp-block-cover.alignfull .wp-block-paragraph,
  .kh-fr-hero__inner .kh-fr-hero__kicker { order: 4 !important; }
  body.give-p2p .wp-block-cover.alignfull { padding-bottom: 56px !important; }
  .kh-fr-hero { padding-bottom: 56px !important; }
  body.give-p2p .give-p2p-campaign-header-block { margin-top: -32px !important; }
  .kh-fr-stats { margin-top: -32px !important; }
}

@media (max-width: 880px) {
  /* Thin strip layout: small square image | (title hidden) progress only | back link */
  body.give-p2p .kh-campaign-banner {
    padding: 8px 12px !important;
    border-radius: 0 !important;
    margin: 0 0 12px !important;
  }
  body.give-p2p .kh-campaign-banner__inner {
    display: grid !important;
    grid-template-columns: 44px 1fr auto !important;
    column-gap: 10px !important;
    row-gap: 2px !important;
    align-items: center !important;
  }
  body.give-p2p .kh-campaign-banner__image {
    display: block !important;
    grid-row: 1 / span 2 !important;
    width: 44px !important;
    height: 44px !important;
    max-width: 44px !important;
    max-height: 44px !important;
    flex: 0 0 44px !important;
    border-radius: 8px !important;
    background-size: cover !important;
    background-position: center !important;
  }
  body.give-p2p .kh-campaign-banner__body {
    grid-column: 2 !important;
    grid-row: 1 !important;
    flex: 1 1 auto !important;
    min-width: 0 !important;
  }
  /* Hide the title + eyebrow on mobile — we just want the progress strip */
  body.give-p2p .kh-campaign-banner__eyebrow,
  body.give-p2p .kh-campaign-banner__title { display: none !important; }
  body.give-p2p .kh-campaign-banner__progress {
    margin: 0 !important;
  }
  body.give-p2p .kh-campaign-banner__progress-stats {
    font-size: 12px !important;
    line-height: 1.2 !important;
    margin-bottom: 2px !important;
    display: flex !important;
    justify-content: space-between !important;
    align-items: baseline !important;
  }
  body.give-p2p .kh-campaign-banner__progress-stats > span:first-child strong,
  body.give-p2p #kh-banner-raised { font-weight: 800 !important; }
  body.give-p2p .kh-campaign-banner__progress-bar {
    height: 4px !important;
    margin-top: 2px !important;
  }
  body.give-p2p .kh-campaign-banner__stats,
  body.give-p2p .kh-campaign-banner__supporting { display: none !important; }
  body.give-p2p .kh-campaign-banner__back {
    grid-column: 3 !important;
    grid-row: 1 / span 2 !important;
    flex: 0 0 auto !important;
    font-size: 11px !important;
    padding: 4px 8px !important;
    white-space: nowrap !important;
    line-height: 1 !important;
    align-self: center !important;
  }
}

@media (max-width: 880px) {
  body.give-p2p .give-p2p-fundraiser-leaderboard-block {
    max-width: 100% !important;
    overflow-x: hidden !important;
    padding-left: 16px !important;
    padding-right: 16px !important;
    box-sizing: border-box !important;
  }
  body.give-p2p .give-p2p-fundraiser-leaderboard-block * {
    max-width: 100% !important;
    box-sizing: border-box !important;
  }
}

@media (max-width: 880px) {
  body.give-p2p .give-p2p-fundraiser-registration-block {
    padding: 24px 16px 100px !important;
    margin: 0 !important;
    max-width: 100% !important;
    box-sizing: border-box !important;
  }
}

body.give-p2p .kh-tier__desc { display: none !important; }
body.give-p2p .kh-tier { padding-bottom: 28px !important; }

/* ════════════════════════════════════════════════════════════════
   POLISH PASS #2 — items from May 27 review (round 2)
   ════════════════════════════════════════════════════════════════ */

/* #1 Tier cards centered (no body text anymore) */
body.give-p2p .kh-tier,
.kh-fr-tier {
  text-align: center !important;
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  justify-content: center !important;
}
body.give-p2p .kh-tier .kh-tier__amt,
.kh-fr-tier .kh-fr-tier__amt {
  text-align: center !important;
}
body.give-p2p .kh-tier .kh-tier__name,
.kh-fr-tier .kh-fr-tier__name {
  text-align: center !important;
}

/* #2 Donations cards — causematch-inspired layout
   Big amount on top, small donor info below, comment in italic. */
body.give-p2p .kh-donations-grid .give-donor.give-card {
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  justify-content: flex-start !important;  /* amount always at top — comment falls below */
  text-align: center !important;
  gap: 4px !important;
  background: #f4f5fb !important;
  border: 1px solid var(--kh-line) !important;
  padding: 22px 20px !important;
  border-radius: var(--kh-radius) !important;
  min-height: 140px !important;
}
/* Hide the avatar (causematch doesn't show one) */
body.give-p2p .kh-donations-grid .give-donor-container__image { display: none !important; }
/* Amount: BIG and FIRST */
body.give-p2p .kh-donations-grid .give-donor-details {
  order: 1 !important;
  width: auto !important;
  flex: 0 0 auto !important;
  margin: 0 0 4px !important;
  padding: 0 !important;
}
/* old 30px rule removed — superseded by 56px below */
/* Donor name + date: small, below amount */
body.give-p2p .kh-donations-grid .give-donor-container {
  order: 2 !important;
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  width: 100% !important;
  flex-wrap: nowrap !important;
}
body.give-p2p .kh-donations-grid .give-donor-container-variation {
  order: 2 !important;
  flex: 0 0 auto !important;
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  text-align: center !important;
}
/* duplicate 14px name rule removed — 20px earlier in file now wins */
body.give-p2p .kh-donations-grid p.give-donor-container-variation__timestamp {
  font-size: 11px !important;
  color: var(--kh-ink-muted) !important;
  letter-spacing: .04em !important;
  text-transform: uppercase !important;
  font-weight: 600 !important;
  margin: 2px 0 0 !important;
}
/* Comment (if exists): italic below */
body.give-p2p .kh-donations-grid .give-donor-wrapper {
  order: 3 !important;
  width: 100% !important;
  text-align: center !important;
}
body.give-p2p .kh-donations-grid .give-donor-content__comment {
  font-family: var(--kh-font-accent) !important;
  font-style: italic !important;
  font-size: 13px !important;
  color: var(--kh-ink-muted) !important;
  margin: 6px 0 0 !important;
  padding: 0 !important;
}
/* FIX: hide GiveWP's truncated preview + "Read more" so only the full
   styled comment shows (they were rendering together = duplicate text). */
body.give-p2p .kh-donations-grid .give-donor-content__excerpt {
  display: none !important;
}

/* #3 Hero on desktop — shrink so match card is more above-the-fold */
@media (min-width: 881px) {
  body.give-p2p .wp-block-cover.alignfull {
    min-height: auto !important;
    padding: 80px 24px 200px !important;
  }
  body.give-p2p .wp-block-cover h1 {
    font-size: clamp(48px, 5.5vw, 72px) !important;
  }
  /* Same shrink for fundraiser hero */
  .kh-fr-hero {
    min-height: auto !important;
    padding: 72px 24px 180px !important;
  }
  .kh-fr-hero h1 { font-size: clamp(40px, 5vw, 64px) !important; }
}

/* #4 Donate/register page banner — smaller strip on all sizes */
body.give-p2p .kh-campaign-banner {
  padding: 14px 20px !important;
}
body.give-p2p .kh-campaign-banner__image {
  max-width: 80px !important;
  max-height: 80px !important;
  flex: 0 0 80px !important;
  border-radius: 8px !important;
}
body.give-p2p .kh-campaign-banner__title {
  font-size: clamp(15px, 1.6vw, 18px) !important;
  margin: 0 !important;
}
body.give-p2p .kh-campaign-banner__eyebrow {
  font-size: 10px !important;
  letter-spacing: .12em !important;
  margin-bottom: 2px !important;
}

/* #5 Mobile hero reorder — REVISED: just match card visible, hide everything else.
   Goal card naturally follows. Campaign name will appear AFTER goal card (below). */
@media (max-width: 880px) {
  /* Inside the hero cover, hide everything except the match card */
  body.give-p2p .wp-block-cover.alignfull .hero-eyebrow,
  body.give-p2p .wp-block-cover.alignfull .kh-hero-eyebrow,
  body.give-p2p .wp-block-cover.alignfull h1,
  body.give-p2p .wp-block-cover.alignfull .wp-block-paragraph {
    display: none !important;
  }
  /* Shrink hero padding since it now only holds the match card */
  body.give-p2p .wp-block-cover.alignfull {
    padding: 16px 16px 24px !important;
    min-height: auto !important;
  }
  /* On fundraiser page: same — hide everything except the match card and stats */
  .kh-fr-hero { padding: 16px 16px 24px !important; min-height: auto !important; }
  .kh-fr-hero h1,
  .kh-fr-hero .kh-fr-hero__kicker { display: none !important; }
  /* Reduce match card size slightly on mobile (was already 56px, dial to ~48) */
  body.give-p2p .kh-match-card { padding: 18px !important; }
  body.give-p2p .kh-match-card__amount { font-size: 48px !important; }
}

/* #6 Stats bar mobile — bar fills card width, less right padding */
@media (max-width: 880px) {
  body.give-p2p .give-p2p-campaign-header-block {
    padding: 22px 16px !important;
  }
  body.give-p2p .givewp-campaign-goal__container,
  body.give-p2p .a9oyaLsl4U0GnSoC8mge,
  .kh-fr-stats__progress {
    width: 100% !important;
    max-width: 100% !important;
  }
  /* In case GiveWP imposes its own width: */
  body.give-p2p .give-p2p-campaign-header-block * {
    box-sizing: border-box !important;
  }
}

/* #7 Center donation amounts on mobile (raised number + stats) */
@media (max-width: 880px) {
  body.give-p2p .SqJPIMMg2B2kQVhcvEiA,
  body.give-p2p .give-p2p-campaign-header-block .raised-amount,
  body.give-p2p .give-p2p-campaign-header-block ul {
    text-align: center !important;
    justify-self: center !important;
  }
  body.give-p2p .give-p2p-campaign-header-block li:first-child > div:first-child {
    justify-content: center !important;
    text-align: center !important;
  }
  /* Center the goal text too */
  body.give-p2p .give-p2p-campaign-header-block li:first-child > div:nth-child(2) {
    text-align: center !important;
    align-self: center !important;
  }
  /* The bottom 3 stats: stay distributed but centered as a row */
  body.give-p2p .give-p2p-campaign-header-block ul > li {
    text-align: center !important;
  }
}

/* #9 Donations cards: less internal spacing on mobile */
@media (max-width: 880px) {
  body.give-p2p .kh-donations-grid .give-donor.give-card {
    padding: 16px 14px !important;
    min-height: 110px !important;
    gap: 2px !important;
  }
  body.give-p2p .kh-donations-grid .give-donor-details__total { font-size: 26px !important; }
  body.give-p2p .kh-donations-grid h3.give-donor-container-variation__name { font-size: 13px !important; }
  body.give-p2p .kh-donations-grid p.give-donor-container-variation__timestamp { font-size: 10px !important; }
}

/* #10 Footer / Final CTA buttons — center text on mobile */
@media (max-width: 880px) {
  body.give-p2p .kh-final__btns > a,
  .kh-fr-final__btns > a {
    text-align: center !important;
    justify-content: center !important;
  }
}

/* #11 Fundraiser eyebrow — desktop vs mobile variant */
.kh-fr-eyebrow__mobile { display: none !important; }
@media (max-width: 880px) {
  .kh-fr-eyebrow__desktop { display: none !important; }
  .kh-fr-eyebrow__mobile { display: inline !important; }
}

/* ════════════════════════════════════════════════════════════════
   POLISH PASS #3 — May 27 review round 3
   ════════════════════════════════════════════════════════════════ */

/* #1 DONATION CARDS — bigger amounts, white bg, underline under amount,
   centered comment, show donation source (which fundraiser) */
body.give-p2p .kh-donations-grid .give-donor.give-card {
  background: #fff !important;
  border: 1px solid var(--kh-line) !important;
  padding: 10px 18px !important;
  border-radius: var(--kh-radius) !important;
  min-height: 180px !important;  /* uniform height so amounts align top across cards */
  box-shadow: 0 2px 8px rgba(10,30,74,.04) !important;
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  justify-content: flex-start !important;
}
body.give-p2p .kh-donations-grid span.give-donor-details__total,
body.give-p2p .kh-donations-grid .give-donor-details__total {
  font-size: 38px !important;
  font-weight: 800 !important;
  color: var(--kh-blue) !important;
  letter-spacing: -.02em !important;
  line-height: 1 !important;
  padding-bottom: 10px !important;
  border-bottom: 2px solid rgba(7,54,227,.12) !important;
  margin-bottom: 10px !important;
  display: inline-block !important;
}
/* Show the form title / source: "Donation through X" */
body.give-p2p .kh-donations-grid .give-donor-details__form_title {
  display: block !important;
  font-size: 11px !important;
  font-weight: 700 !important;
  letter-spacing: .12em !important;
  text-transform: uppercase !important;
  color: var(--kh-gold-dark, #c98800) !important;
  margin-top: 4px !important;
  text-align: center !important;
}
body.give-p2p .kh-donations-grid .give-donor-details__form_title::before {
  content: "Donation through ";
  font-weight: 600 !important;
  color: var(--kh-ink-muted) !important;
  text-transform: none !important;
  letter-spacing: 0 !important;
}
/* Center the comment, italic */
body.give-p2p .kh-donations-grid .give-donor-wrapper {
  text-align: center !important;
  width: 100% !important;
  margin-top: 8px !important;
}
body.give-p2p .kh-donations-grid p.give-donor-content__comment,
body.give-p2p .kh-donations-grid .give-donor-content__comment {
  text-align: center !important;
  font-family: var(--kh-font-accent) !important;
  font-style: italic !important;
  font-size: 16px !important;
  color: var(--kh-ink) !important;
  line-height: 1.5 !important;
  margin: 4px 0 0 !important;
  padding: 0 !important;
  max-width: 100% !important;
  text-indent: 0 !important;
}

/* #2 BANNER mobile — even tighter, NO image */
@media (max-width: 880px) {
  body.give-p2p .kh-campaign-banner__image { display: none !important; }
  body.give-p2p .kh-campaign-banner {
    padding: 6px 12px !important;
  }
  body.give-p2p .kh-campaign-banner__inner {
    grid-template-columns: 1fr auto !important;
    gap: 12px !important;
  }
  body.give-p2p .kh-campaign-banner__body {
    grid-column: 1 !important;
    grid-row: 1 !important;
  }
  body.give-p2p .kh-campaign-banner__back {
    grid-column: 2 !important;
    grid-row: 1 !important;
  }
}

/* #3 HERO MOBILE — restore headline but keep it small, match card stays prominent */
@media (max-width: 880px) {
  /* UN-HIDE the headline + kicker */
  body.give-p2p .wp-block-cover.alignfull .hero-eyebrow,
  body.give-p2p .wp-block-cover.alignfull .kh-hero-eyebrow,
  body.give-p2p .wp-block-cover.alignfull h1,
  body.give-p2p .wp-block-cover.alignfull .wp-block-paragraph,
  .kh-fr-hero h1,
  .kh-fr-hero .kh-fr-hero__kicker { display: block !important; }

  /* Smaller and tighter */
  body.give-p2p .wp-block-cover.alignfull h1,
  .kh-fr-hero h1 {
    font-size: 36px !important;
    line-height: 1 !important;
    margin: 8px 0 !important;
  }
  body.give-p2p .wp-block-cover.alignfull .wp-block-paragraph,
  .kh-fr-hero .kh-fr-hero__kicker {
    font-size: 14px !important;
    line-height: 1.4 !important;
    margin-top: 8px !important;
  }
  body.give-p2p .wp-block-cover.alignfull {
    padding: 32px 16px 80px !important;
  }
  .kh-fr-hero {
    padding: 32px 16px 80px !important;
  }

  /* Order: match card first, eyebrow, headline, kicker */
  body.give-p2p .wp-block-cover.alignfull .kh-match-card { order: 1 !important; }
  body.give-p2p .wp-block-cover.alignfull .hero-eyebrow,
  body.give-p2p .wp-block-cover.alignfull .kh-hero-eyebrow { order: 2 !important; margin-top: 4px !important; }
  body.give-p2p .wp-block-cover.alignfull h1 { order: 3 !important; }
  body.give-p2p .wp-block-cover.alignfull .wp-block-paragraph { order: 4 !important; }

  .kh-fr-hero__inner .kh-match-card { order: 1 !important; }
  .kh-fr-hero__inner .kh-fr-eyebrow { order: 2 !important; }
  .kh-fr-hero__inner h1 { order: 3 !important; }
  .kh-fr-hero__inner .kh-fr-hero__kicker { order: 4 !important; }

  /* Slim PROGRESS BAR inside the match card showing campaign progress */
  body.give-p2p .kh-match-card__progress-strip {
    display: block !important;
    height: 6px !important;
    background: rgba(255,255,255,.18) !important;
    border-radius: 999px !important;
    margin: 12px 0 4px !important;
    position: relative !important;
    overflow: hidden !important;
  }
  body.give-p2p .kh-match-card__progress-strip::before {
    content: "";
    position: absolute; left: 0; top: 0; bottom: 0;
    width: var(--kh-progress, 2%);
    background: linear-gradient(90deg, var(--kh-gold) 0%, var(--kh-gold-soft, #ffd64a) 100%);
    border-radius: 999px;
  }
}

/* #4 TIER cards — more vertical space + remove badge */
body.give-p2p .kh-tier,
.kh-fr-tier {
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 14px !important;
  padding: 32px 24px !important;
  min-height: 180px !important;
}
body.give-p2p .kh-tier__amt,
.kh-fr-tier__amt {
  margin: 0 !important;
}
body.give-p2p .kh-tier__name,
.kh-fr-tier__name {
  margin: 0 !important;
}
body.give-p2p .kh-tier__badge,
.kh-fr-tier__badge { display: none !important; }
body.give-p2p .kh-tier--featured,
.kh-fr-tier--featured {
  border: 2px solid var(--kh-gold) !important;
  box-shadow: 0 12px 32px rgba(252,185,0,.18) !important;
}

/* #5 TOP FUNDRAISERS — shrink avatar, replace with gradient circle */
body.give-p2p .give-p2p-fundraiser-leaderboard-block {
  /* This is a shadow-DOM block; we mostly need to inject into the shadow root.
     For the page-level layout we just constrain width on mobile. */
}
@media (max-width: 880px) {
  body.give-p2p .give-p2p-fundraiser-leaderboard-block {
    padding-left: 16px !important;
    padding-right: 16px !important;
  }
}

/* #6 REGISTER PAGE — fix mobile overflow */
@media (max-width: 880px) {
  body.give-p2p form,
  body.give-p2p form > div {
    max-width: 100% !important;
    width: 100% !important;
    box-sizing: border-box !important;
  }
  /* The form inner padding */
  body.give-p2p form .gIxAOIZrCdhiGAGl0rax,
  body.give-p2p form > div[style*="padding"] {
    padding: 20px 16px !important;
  }
  /* All form inputs full width */
  body.give-p2p form input,
  body.give-p2p form select,
  body.give-p2p form textarea,
  body.give-p2p form button {
    max-width: 100% !important;
    width: 100% !important;
    box-sizing: border-box !important;
  }
}

/* Force comment wrapper + content to have no internal padding (kill the 58px left padding) */
body.give-p2p .kh-donations-grid .give-donor-wrapper,
body.give-p2p .kh-donations-grid .give-donor-wrapper > *,
body.give-p2p .kh-donations-grid .give-donor-content,
body.give-p2p .kh-donations-grid p.give-donor-content__comment {
  padding-left: 0 !important;
  padding-right: 0 !important;
  margin-left: 0 !important;
  margin-right: 0 !important;
  border-left: 0 !important;
  text-indent: 0 !important;
}

/* ════════════════════════════════════════════════════════════════
   SECTION SEPARATION — Donations vs Top Fundraisers
   ════════════════════════════════════════════════════════════════ */

/* More breathing room around Donations section */
body.give-p2p .kh-donations-grid {
  margin: 64px auto !important;
  padding: 0 24px !important;
}

/* Top Fundraisers leaderboard — soft cream/blue bg, generous padding */
body.give-p2p .give-p2p-fundraiser-leaderboard-block {
  background: var(--kh-cream, #faf7ef) !important;
  padding: 64px 24px !important;
  margin: 0 auto 80px !important;  /* breathing room before next section */
  border-radius: var(--kh-radius-lg) !important;
  max-width: 1320px !important;
}

@media (max-width: 880px) {
  body.give-p2p .kh-donations-grid {
    margin: 40px auto !important;
  }
  body.give-p2p .give-p2p-fundraiser-leaderboard-block {
    padding: 40px 16px !important;
    border-radius: var(--kh-radius) !important;
  }
}

/* ════════════════════════════════════════════════════════════════
   FUNDRAISER STATS — restore spacing under hero
   ════════════════════════════════════════════════════════════════ */
@media (max-width: 880px) {
  .kh-fr-stats { margin-top: 24px !important; }
}

/* Reverted: 8px was too tight. Card needs comfortable horizontal padding. */

/* Goal card mobile: tighter horizontal padding so the bar fills more of the visible card */
@media (max-width: 880px) {
  body.give-p2p .give-p2p-campaign-header-block {
    padding-left: 12px !important;
    padding-right: 12px !important;
  }
}

/* ════════════════════════════════════════════════════════════════
   FUNDRAISER LEADERBOARD PAGE — /fundraiser-leaderboard/
   Matches the rest of the campaign visual language.
   ════════════════════════════════════════════════════════════════ */

/* Kill the bright purple/blue background — use cream like Top Fundraisers section */
body.give-p2p .give-p2p-fundraisers-block,
body.give-p2p [class*="fundraisers-list"],
body.give-p2p [class*="leaderboard"] > div[style*="background"] {
  background: var(--kh-cream, #faf7ef) !important;
  color: var(--kh-ink) !important;
  border-radius: var(--kh-radius-lg) !important;
  padding: 48px 32px !important;
  max-width: 1320px !important;
  margin: 32px auto !important;
}

/* "All Fundraisers" heading and "Searching for a fundraiser?" text */
body.give-p2p .give-p2p-fundraisers-block h2,
body.give-p2p .give-p2p-fundraisers-block h3,
body.give-p2p [class*="fundraisers-list"] h2,
body.give-p2p [class*="fundraisers-list"] h3 {
  color: var(--kh-navy) !important;
  font-family: var(--kh-font-accent) !important;
}
body.give-p2p .give-p2p-fundraisers-block label,
body.give-p2p [class*="fundraisers-list"] label {
  color: var(--kh-ink-muted) !important;
}

/* Top white empty card — hide if it's mostly empty */
body.give-p2p .give-p2p-fundraisers-block > div:first-child:not(:has(input)):not(:has(.give-card)) {
  background: transparent !important;
  padding: 32px 24px 16px !important;
  border-radius: 0 !important;
  box-shadow: none !important;
}
body.give-p2p .give-p2p-fundraisers-block > div:first-child h2 {
  font-size: clamp(28px, 4vw, 44px) !important;
  text-align: center !important;
  color: var(--kh-navy) !important;
  margin: 0 !important;
  line-height: 1.15 !important;
}

/* Fundraiser cards in the grid */
body.give-p2p .give-p2p-fundraisers-block .give-card,
body.give-p2p [class*="fundraisers-list"] .give-card {
  background: #fff !important;
  border: 1px solid var(--kh-line) !important;
  border-radius: var(--kh-radius) !important;
  padding: 24px !important;
  box-shadow: 0 2px 8px rgba(10,30,74,.04) !important;
}

/* Gray default avatars → gradient circle */
body.give-p2p .give-p2p-fundraisers-block img[src*="default-avatar"],
body.give-p2p .give-p2p-fundraisers-block [class*="avatar"] img,
body.give-p2p [class*="fundraisers-list"] [class*="avatar"] img {
  display: none !important;
}
body.give-p2p .give-p2p-fundraisers-block [class*="avatar"],
body.give-p2p [class*="fundraisers-list"] [class*="avatar"] {
  background: linear-gradient(135deg, var(--kh-blue, #0736e3) 0%, var(--kh-navy, #0a1e4a) 100%) !important;
  border-radius: 50% !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  color: #fff !important;
  font-weight: 800 !important;
  font-size: 18px !important;
}

/* View Fundraiser button — match site blue */
body.give-p2p .give-p2p-fundraisers-block a[href*="/fundraiser/"],
body.give-p2p [class*="fundraisers-list"] a[href*="/fundraiser/"] {
  background: var(--kh-blue, #0736e3) !important;
  color: #fff !important;
  border-radius: 999px !important;
  font-weight: 700 !important;
}

/* Search input — softer styling */
body.give-p2p .give-p2p-fundraisers-block input[type="text"],
body.give-p2p .give-p2p-fundraisers-block input[type="search"] {
  background: #fff !important;
  border: 1px solid var(--kh-line) !important;
  border-radius: 999px !important;
  padding: 10px 16px 10px 40px !important;
}

/* Pagination strip */
body.give-p2p .give-p2p-fundraisers-block [class*="pagination"],
body.give-p2p [class*="fundraisers-list"] [class*="pagination"] {
  background: #fff !important;
  border-radius: var(--kh-radius) !important;
  color: var(--kh-ink) !important;
  border: 1px solid var(--kh-line) !important;
}

@media (max-width: 880px) {
  body.give-p2p .give-p2p-fundraisers-block,
  body.give-p2p [class*="fundraisers-list"] {
    padding: 24px 16px !important;
    margin: 16px 8px !important;
    border-radius: var(--kh-radius) !important;
  }
}

/* ════════════════════════════════════════════════════════════════
   FUNDRAISER LEADERBOARD PAGE v2 — broader selector net
   give-peer-to-peer plugin uses .give-peer-to-peer-* prefix
   ════════════════════════════════════════════════════════════════ */

body.give-p2p .give-peer-to-peer-leaderboard,
body.give-p2p .give-peer-to-peer-fundraisers-list,
body.give-p2p [class*="give-peer-to-peer-fundraisers"],
body.give-p2p [class*="give-peer-to-peer-leaderboard"] {
  background: var(--kh-cream, #faf7ef) !important;
  color: var(--kh-ink) !important;
  border-radius: var(--kh-radius-lg) !important;
  padding: 48px 32px !important;
  max-width: 1320px !important;
  margin: 32px auto !important;
}

/* Kill purple/blue tinted backgrounds anywhere on this page */
body.give-p2p .give-peer-to-peer-leaderboard *,
body.give-p2p [class*="give-peer-to-peer-fundraisers"] * {
  --primary-color: var(--kh-blue) !important;
}
body.give-p2p [class*="give-peer-to-peer"] [style*="background-color: rgb(108"],
body.give-p2p [class*="give-peer-to-peer"] [style*="background: rgb(108"],
body.give-p2p [class*="give-peer-to-peer"] [style*="background-color: #6"] {
  background: var(--kh-cream, #faf7ef) !important;
  background-color: var(--kh-cream, #faf7ef) !important;
}

/* Search input */
body.give-p2p [class*="give-peer-to-peer"] input[type="text"],
body.give-p2p [class*="give-peer-to-peer"] input[type="search"] {
  background: #fff !important;
  border: 1px solid var(--kh-line) !important;
  border-radius: 999px !important;
  color: var(--kh-ink) !important;
  padding: 10px 16px !important;
}

/* Fundraiser cards */
body.give-p2p [class*="give-peer-to-peer-fundraiser-card"],
body.give-p2p [class*="give-peer-to-peer"] .card,
body.give-p2p [class*="give-peer-to-peer"] [class*="fundraiser-card"] {
  background: #fff !important;
  border: 1px solid var(--kh-line) !important;
  border-radius: var(--kh-radius) !important;
  padding: 24px !important;
  box-shadow: 0 2px 8px rgba(10,30,74,.04) !important;
  color: var(--kh-ink) !important;
}
body.give-p2p [class*="give-peer-to-peer-fundraiser-card"] * { color: inherit; }

/* View Fundraiser button */
body.give-p2p [class*="give-peer-to-peer"] a[href*="/fundraiser/"],
body.give-p2p [class*="give-peer-to-peer"] button:not(.give-peer-to-peer-search) {
  background: var(--kh-blue, #0736e3) !important;
  color: #fff !important;
  border-radius: 999px !important;
  font-weight: 700 !important;
  border: none !important;
}

/* Default gray avatar img → hide, replace parent with gradient circle */
body.give-p2p [class*="give-peer-to-peer"] img[src*="default-avatar"],
body.give-p2p [class*="give-peer-to-peer"] img[src*="mystery-man"],
body.give-p2p [class*="give-peer-to-peer"] [class*="avatar"] img[src*="default"] {
  display: none !important;
}
body.give-p2p [class*="give-peer-to-peer"] [class*="avatar"] {
  background: linear-gradient(135deg, var(--kh-blue, #0736e3) 0%, var(--kh-navy, #0a1e4a) 100%) !important;
  border-radius: 50% !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  color: #fff !important;
  font-weight: 800 !important;
}

/* "Start fundraising for X" headline — center properly, kill weird whitespace card */
body.give-p2p [class*="give-peer-to-peer"] h2,
body.give-p2p [class*="give-peer-to-peer"] h3 {
  color: var(--kh-navy) !important;
  font-family: var(--kh-font-accent) !important;
}

/* Pagination */
body.give-p2p [class*="give-peer-to-peer"] [class*="pagination"] {
  background: #fff !important;
  border: 1px solid var(--kh-line) !important;
  border-radius: var(--kh-radius) !important;
  color: var(--kh-ink) !important;
}
body.give-p2p [class*="give-peer-to-peer"] [class*="pagination"] [class*="active"],
body.give-p2p [class*="give-peer-to-peer"] [class*="pagination"] .active {
  background: var(--kh-blue, #0736e3) !important;
  color: #fff !important;
}

@media (max-width: 880px) {
  body.give-p2p .give-peer-to-peer-leaderboard,
  body.give-p2p [class*="give-peer-to-peer-fundraisers"] {
    padding: 24px 16px !important;
    margin: 16px 8px !important;
    border-radius: var(--kh-radius) !important;
  }
}


/* ==========================================================================
   SHARED COMPONENTS (Option B) — rendered by the plugin from GiveWP data,
   reused on the campaign page, fundraiser pages and the live board.
   All consume the dashboard tokens (--kh-*), so they re-skin automatically.
   ========================================================================== */
body.give-p2p .kh-campaign { max-width: 1240px; margin: 0 auto; padding: 0 20px; }
body.give-p2p .kh-campaign > * { margin-top: 28px; }

/* GOAL BAR */
body.give-p2p .kh-goalbar {
  background: #fff; border: 1px solid var(--kh-line);
  border-radius: var(--kh-radius-lg, 24px); box-shadow: var(--kh-shadow-md);
  padding: 24px 28px; margin-top: -60px; position: relative; z-index: 3;
}
body.give-p2p .kh-goalbar__row { display: flex; justify-content: space-between; align-items: baseline; gap: 16px; }
body.give-p2p .kh-goalbar__amount { font-family: var(--kh-font-head); font-weight: 800; font-size: clamp(28px,4vw,40px); color: var(--kh-navy); }
body.give-p2p .kh-goalbar__of { color: var(--kh-ink-muted); font-size: 14px; margin-left: 8px; }
body.give-p2p .kh-goalbar__pct { font-family: var(--kh-font-head); font-weight: 800; font-size: 22px; color: var(--kh-blue); }
body.give-p2p .kh-goalbar__track { height: 12px; background: var(--kh-line); border-radius: 999px; overflow: hidden; margin: 12px 0; }
body.give-p2p .kh-goalbar__fill { height: 100%; background: linear-gradient(90deg, var(--kh-blue), var(--kh-gold)); border-radius: 999px; transition: width .6s cubic-bezier(.22,1,.36,1); }
body.give-p2p .kh-goalbar__match { display: flex; align-items: center; gap: 8px; background: rgba(252,185,0,.1); border: 1px solid rgba(252,185,0,.4); border-radius: var(--kh-radius); padding: 9px 13px; font-size: 13px; color: var(--kh-ink); }
body.give-p2p .kh-goalbar__cta { display: block; text-align: center; margin-top: 14px; background: var(--kh-blue); color: #fff !important; text-decoration: none !important; font-family: var(--kh-font-head); font-weight: 700; font-size: 16px; padding: 14px; border-radius: var(--kh-radius); transition: background .2s; }
body.give-p2p .kh-goalbar__cta:hover { background: var(--kh-blue-dark); }

/* STORY + SIDEBAR */
body.give-p2p .kh-story-wrap { display: grid; grid-template-columns: 1fr; gap: 32px; }
body.give-p2p .kh-story-wrap--split { grid-template-columns: 1.6fr 1fr; }
body.give-p2p .kh-story { font-size: 17px; line-height: 1.7; color: var(--kh-ink); }
@media (max-width: 860px) { body.give-p2p .kh-story-wrap--split { grid-template-columns: 1fr; } }

/* DONATIONS LIST */
body.give-p2p .kh-donations__head { display: flex; align-items: center; gap: 8px; font-family: var(--kh-font-head); font-weight: 700; font-size: 12px; letter-spacing: .1em; text-transform: uppercase; color: var(--kh-blue); margin-bottom: 12px; }
body.give-p2p .kh-donations__dot { width: 8px; height: 8px; border-radius: 50%; background: #39d98a; box-shadow: 0 0 0 3px rgba(57,217,138,.22); }
body.give-p2p .kh-donations__list { display: flex; flex-direction: column; gap: 8px; }
body.give-p2p .kh-donation { display: flex; align-items: center; gap: 12px; background: #fff; border: 1px solid var(--kh-line); border-radius: var(--kh-radius); padding: 12px 14px; }
body.give-p2p .kh-donation__avatar { flex: 0 0 36px; width: 36px; height: 36px; border-radius: 50%; background: var(--kh-blue); color: #fff; display: flex; align-items: center; justify-content: center; font-family: var(--kh-font-head); font-weight: 700; font-size: 12px; }
body.give-p2p .kh-donation__body { flex: 1; min-width: 0; }
body.give-p2p .kh-donation__name { font-family: var(--kh-font-head); font-weight: 700; font-size: 14px; color: var(--kh-ink); }
body.give-p2p .kh-donation__rec { font-size: 10px; font-weight: 700; color: var(--kh-blue); margin-left: 6px; }
body.give-p2p .kh-donation__page { font-size: 11px; color: var(--kh-ink-muted); }
body.give-p2p .kh-donation__comment { font-family: var(--kh-font-accent); font-style: italic; font-size: 13px; color: var(--kh-ink-muted); margin-top: 2px; }
body.give-p2p .kh-donation__amt { font-family: var(--kh-font-head); font-weight: 800; font-size: 15px; color: var(--kh-blue); white-space: nowrap; }
body.give-p2p .kh-donations__empty { color: var(--kh-ink-muted); font-size: 14px; padding: 8px 0; }

/* LEADERBOARD */
body.give-p2p .kh-leaderboard__head { font-family: var(--kh-font-head); font-weight: 800; font-size: 22px; color: var(--kh-navy); margin-bottom: 14px; }
body.give-p2p .kh-leaderboard__list { display: flex; flex-direction: column; gap: 8px; }
body.give-p2p .kh-lb-row { display: grid; grid-template-columns: 28px 1fr auto auto; align-items: center; gap: 12px; background: #fff; border: 1px solid var(--kh-line); border-radius: var(--kh-radius); padding: 12px 16px; }
body.give-p2p .kh-lb-row__rank { font-family: var(--kh-font-head); font-weight: 800; color: var(--kh-gold-dark); font-size: 15px; }
body.give-p2p .kh-lb-row__name { font-family: var(--kh-font-head); font-weight: 700; color: var(--kh-ink); }
body.give-p2p .kh-lb-row__meta { font-size: 12px; color: var(--kh-ink-muted); }
body.give-p2p .kh-lb-row__amt { font-family: var(--kh-font-head); font-weight: 800; color: var(--kh-blue); }
body.give-p2p .kh-leaderboard__empty { color: var(--kh-ink-muted); }
