/* donate.css — page-specific styles for donate.html
   Extracted from inline <style> by tools/css-consolidate.py. */

/* ============================================
   DONATE PAGE — page-specific styles (.donate- namespace)
   ============================================ */
.donate-heading-accent{font-family:'Fraunces',Georgia,'Times New Roman',serif;font-variation-settings:'opsz' 144,'SOFT' 100;font-style:italic;font-weight:700;letter-spacing:-0.005em}

/* HERO */
.donate-hero{position:relative;min-height:clamp(540px,74vh,720px);overflow:hidden;background:#0a1408;margin:clamp(16px,2vw,28px);border-radius:var(--r-xl)}

.donate-hero-bg{position:absolute;inset:0}

.donate-hero-bg img{width:100%;height:100%;object-fit:cover;object-position:center 38%;filter:saturate(0.95) contrast(1.04)}

.donate-hero-bg::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,0.15) 0%,rgba(0,0,0,0) 30%,rgba(0,0,0,0.5) 70%,rgba(0,0,0,0.85) 100%),linear-gradient(90deg,rgba(0,0,0,0.6) 0%,rgba(0,0,0,0.1) 60%,rgba(0,0,0,0) 100%);}

.donate-hero-content{position:relative;z-index:2;max-width:var(--maxw);margin:0 auto;padding:clamp(70px,10vh,120px) var(--gutter);color:#fbf6e7;display:flex;flex-direction:column;justify-content:center;min-height:clamp(540px,74vh,720px)}

.donate-hero-eyebrow{font:700 11px/1 var(--sans);letter-spacing:0.28em;text-transform:uppercase;color:#fff;margin-bottom:24px;display:inline-flex;align-items:center;gap:14px;background:rgba(255,255,255,0.10);backdrop-filter:blur(6px);padding:10px 16px 10px 14px;border-radius:999px;border:1px solid rgba(255,255,255,0.20);align-self:flex-start}

.donate-hero-eyebrow::before{content:"";width:8px;height:8px;background:var(--gold);border-radius:50%;box-shadow:0 0 12px rgba(244,211,94,0.6)}

.donate-hero h1{font-family:var(--slab);font-weight:800;font-size:clamp(44px,6.4vw,86px);line-height:0.98;letter-spacing:-0.025em;margin:0 0 22px;max-width:18ch;text-wrap:balance;color:#fbf6e7}

.donate-hero h1 span{color:var(--gold-l)}

.donate-hero p.lede{font-size:clamp(18px,1.8vw,22px);max-width:54ch;margin:0 0 36px;color:rgba(255,255,255,0.92);line-height:1.5;font-family:var(--slab);font-weight:500}

.donate-hero p.lede strong{color:#fff;font-weight:700}

.donate-hero-actions{display:flex;gap:14px;flex-wrap:wrap}

/* GIVE — split column with Zeffy iframe + framing */
.donate-give{padding:clamp(70px,9vw,120px) var(--gutter);background:var(--paper)}

.donate-give-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:clamp(40px,5vw,72px);max-width:var(--maxw);margin:0 auto;align-items:start}

@media (max-width:880px){.donate-give-grid{grid-template-columns:1fr;gap:48px}}

.donate-frame h2{font-family:var(--slab);font-weight:800;font-size:clamp(34px,4.4vw,56px);line-height:1.05;letter-spacing:-0.02em;margin:14px 0 22px;color:var(--green-d);max-width:18ch;text-wrap:balance}

.donate-frame h2 span{color:var(--green-l)}

.donate-frame p.lede{font-size:18px;color:var(--ink-2);line-height:1.65;margin:0 0 24px;max-width:42ch}

.donate-toggle{display:inline-flex;background:var(--paper-2);padding:5px;border-radius:999px;margin-bottom:24px}

.donate-toggle button{padding:11px 22px;font:700 12px/1 var(--sans);letter-spacing:0.18em;text-transform:uppercase;color:var(--ink-2);background:transparent;border-radius:999px;cursor:pointer;transition:all .2s ease}

.donate-toggle button.on{background:var(--green-d);color:var(--paper);box-shadow:0 2px 8px rgba(31,43,29,0.18)}

/* Impact ladder */
.donate-ladder{display:grid;gap:14px;margin-bottom:28px}
.donate-ladder[hidden]{display:none}

.donate-rung{display:grid;grid-template-columns:80px 1fr;gap:18px;align-items:center;padding:14px 18px;background:var(--paper-2);border-radius:var(--r-md);border:1px solid transparent;transition:all .2s ease;cursor:pointer}

.donate-rung:hover{background:var(--paper);border-color:var(--gold);transform:translateX(2px)}

.donate-rung.on{background:var(--paper);border-color:var(--gold);box-shadow:0 4px 14px rgba(232,176,74,0.18)}

.donate-rung .amt{font-family:var(--slab);font-weight:800;font-size:30px;color:var(--gold-d);text-align:center;letter-spacing:-0.02em;line-height:1}

.donate-rung .amt small{font-size:13px;color:var(--muted);font-weight:600;display:block;margin-top:2px;letter-spacing:0.04em;text-transform:uppercase}

.donate-rung .desc{font-size:15px;color:var(--ink);line-height:1.5}

.donate-rung .desc strong{font-family:var(--slab);font-weight:700;color:var(--green-d);display:block;margin-bottom:2px;font-size:15px}

.donate-cta-row{display:flex;align-items:center;gap:18px;flex-wrap:wrap}

.donate-cta-row small{font-size:12px;color:var(--muted);max-width:30ch;line-height:1.5}

/* Zeffy iframe card */
.donate-iframe-card{background:#fff;border:1px solid var(--line-soft);border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow);position:relative}

.donate-iframe-head{padding:18px 26px;border-bottom:1px solid var(--line-soft);display:flex;align-items:center;justify-content:space-between;font:700 10px/1 var(--sans);letter-spacing:0.22em;text-transform:uppercase;background:var(--paper-2);color:var(--green-d)}

.donate-iframe-head .badge{display:inline-flex;align-items:center;gap:6px;color:var(--green);font:700 10px/1 var(--sans);letter-spacing:0.22em}

.donate-iframe-head .badge::before{content:"";width:7px;height:7px;border-radius:50%;background:#5a8b3e}

.donate-iframe-card iframe{display:block;width:100%;height:760px;border:0;background:#fff}

.donate-iframe-foot{padding:14px 26px;border-top:1px solid var(--line-soft);background:var(--paper-2);font:600 11px/1.4 var(--sans);letter-spacing:0.04em;color:var(--ink-2);display:flex;align-items:center;gap:10px;justify-content:space-between;flex-wrap:wrap}

.donate-iframe-foot a{color:var(--green-d);border-bottom:1.5px solid transparent;transition:border-color .2s ease}

.donate-iframe-foot a:hover{border-color:var(--gold)}

/* WHERE IT GOES — cost grid on dark fur */
.donate-where{padding:clamp(70px,10vw,140px) var(--gutter);color:#fbf6e7;position:relative;overflow:hidden;background:#0a1408;isolation:isolate}

.donate-where::before{content:"";position:absolute;inset:0;background:url('../images/donate-fur-bw.jpg') center/cover no-repeat;filter:brightness(0.55) contrast(1.05);z-index:-1}

.donate-where .container{max-width:1140px;position:relative;z-index:1}

.donate-where .heading{text-align:center;margin-bottom:42px}

.donate-where .heading .eyebrow{color:var(--gold-l);justify-content:center}

.donate-where .heading .eyebrow::before{background:var(--gold)}

.donate-where .heading h2{font-family:var(--slab);font-weight:800;font-size:clamp(34px,4.6vw,58px);line-height:1.08;letter-spacing:-0.02em;margin:18px 0 18px;color:#fbf6e7;text-wrap:balance}

.donate-where .heading h2 strong{color:var(--gold-l);font-weight:800;text-shadow:0 0 22px rgba(244,211,94,0.40),0 2px 6px rgba(31,43,29,0.30)}

.donate-where .heading p{font-size:17px;color:rgba(251,246,231,0.88);max-width:60ch;margin:0 auto;line-height:1.65}

.donate-cost-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:14px;margin-bottom:36px}

@media (max-width:1024px){.donate-cost-grid{grid-template-columns:repeat(3,1fr)}}

@media (max-width:640px){.donate-cost-grid{grid-template-columns:repeat(2,1fr)}}

.donate-cost-card{background:var(--paper);padding:26px 22px;border-radius:var(--r-md);border:1px solid rgba(176,122,20,0.18);box-shadow:0 6px 22px rgba(0,0,0,0.28);text-align:left;display:flex;flex-direction:column;gap:8px;transition:all .2s ease}

.donate-cost-card:hover{transform:translateY(-3px);background:#fbf6e7;border-color:var(--gold);box-shadow:0 10px 30px rgba(0,0,0,0.36)}

.donate-cost-card .pct{font-family:var(--slab);font-weight:800;font-size:38px;line-height:1;letter-spacing:-0.02em;color:var(--gold-d)}

.donate-cost-card h3{font-family:var(--slab);font-weight:800;font-size:17px;margin:0;letter-spacing:-0.01em;color:var(--green-d)}

.donate-cost-card p{font-size:13px;color:var(--ink-2);margin:0;line-height:1.55}

.donate-trust-line{margin-top:36px;padding:22px 28px;background:rgba(251,246,231,0.08);backdrop-filter:blur(4px);border-radius:var(--r-md);border:1px solid rgba(232,176,74,0.4);text-align:center;font-family:'Fraunces',Georgia,serif;font-style:italic;font-weight:600;font-size:18px;line-height:1.5;color:#fbf6e7;max-width:780px;margin-left:auto;margin-right:auto}

.donate-trust-line .src{display:block;margin-top:10px;font:600 10px/1.4 var(--sans);font-style:normal;letter-spacing:0.20em;text-transform:uppercase;color:var(--gold-l);opacity:0.85}

/* OTHER WAYS — pillar grid */
.donate-other{padding:clamp(70px,9vw,120px) var(--gutter);background:var(--paper-2)}

.donate-other .container{max-width:var(--maxw)}

.donate-other .heading{text-align:left;margin-bottom:48px;max-width:1080px}

.donate-other .heading .eyebrow{margin-bottom:18px}

.donate-other .heading h2{font-family:var(--slab);font-weight:800;font-size:clamp(36px,5.2vw,64px);line-height:1.05;letter-spacing:-0.025em;margin:0;color:var(--green-d);text-wrap:balance;max-width:22ch}

.donate-other .heading h2 span{color:var(--green-l)}

.donate-other .heading p{font-size:18px;color:var(--ink-2);max-width:54ch;margin:24px 0 0;line-height:1.6}

.donate-other-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:22px;max-width:1080px}

@media (max-width:560px){.donate-other-grid{grid-template-columns:1fr}}

.donate-other-card{position:relative;padding:36px 28px 32px;display:flex;flex-direction:column;min-height:340px;background:var(--paper);border-radius:var(--r-lg);box-shadow:0 1px 6px rgba(42,51,38,0.04);border:1px solid rgba(52,74,48,0.08);transition:all .25s ease;text-decoration:none;color:inherit}

.donate-other-card:hover{transform:translateY(-3px);box-shadow:var(--shadow);border-color:var(--gold)}

.donate-other-card .icon{margin-bottom:18px;display:inline-flex;width:60px;height:60px;align-items:center;justify-content:center;border-radius:50%;background:var(--green);color:var(--paper-w);align-self:flex-start;transition:transform .25s ease;box-shadow:0 4px 12px rgba(47,74,57,0.22)}
.donate-other-card .icon svg{width:28px;height:28px}
.donate-other-card:hover .icon{transform:scale(1.06) rotate(-3deg)}

/* All badges + all text share the green style (per the "What sponsors
   receive" reference). The Gift Aid card is the one green-gradient standout
   below and keeps its yellow title / light body. */

/* Gift Aid — featured green-gradient tile with a yellow title, so it stands out. */
.donate-other-card[href*="gift-aid"]{background:linear-gradient(155deg,var(--green) 0%,var(--green-d) 100%);border-color:transparent;box-shadow:0 10px 26px rgba(47,74,57,0.30)}
.donate-other-card[href*="gift-aid"]:hover{border-color:transparent;transform:translateY(-3px);box-shadow:0 16px 34px rgba(47,74,57,0.40)}
.donate-other-card[href*="gift-aid"] .icon{background:var(--yellow);color:var(--green-d);box-shadow:0 4px 12px rgba(0,0,0,0.18)}
.donate-other-card[href*="gift-aid"] .label{color:rgba(251,246,231,0.72)}
.donate-other-card[href*="gift-aid"] h3{color:var(--yellow)}
.donate-other-card[href*="gift-aid"] p{color:rgba(251,246,231,0.92)}

.donate-other-card .label{font-size:13px;color:var(--muted);letter-spacing:0.04em;line-height:1.4;text-transform:uppercase;font-weight:600}

.donate-other-card h3{font-family:var(--slab);font-weight:800;font-size:clamp(24px,2.2vw,30px);line-height:1.1;margin:14px 0 12px;letter-spacing:-0.02em;color:var(--green-d)}

.donate-other-card p{font-size:15px;color:var(--green);margin:0 0 18px;line-height:1.6}

.donate-other-card .arrow-link{margin-top:auto;align-self:flex-start;font:700 11px/1 var(--sans);letter-spacing:0.18em;text-transform:uppercase;color:var(--green-d);display:inline-flex;align-items:center;gap:8px;padding:10px 16px;border-radius:999px;background:var(--yellow);box-shadow:0 3px 10px rgba(244,211,94,0.32);transition:all .2s ease}

.donate-other-card:hover .arrow-link{background:var(--gold);box-shadow:0 4px 14px rgba(232,176,74,0.42)}

/* TRUST */
.donate-trust{padding:clamp(60px,7vw,90px) var(--gutter);background:var(--gold);border-top:1px solid rgba(31,43,29,0.12)}

.donate-trust .container{max-width:1100px;text-align:center}

.donate-trust .eyebrow{justify-content:center;margin-bottom:18px}

.donate-trust h2{font-family:var(--slab);font-weight:800;font-size:clamp(24px,2.8vw,36px);line-height:1.2;letter-spacing:-0.015em;margin:0 0 24px;color:var(--green-d)}

.donate-trust-row{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;margin-top:24px}

@media (max-width:780px){.donate-trust-row{grid-template-columns:repeat(2,1fr)}}

@media (max-width:480px){.donate-trust-row{grid-template-columns:1fr}}

.donate-trust-item{padding:18px 16px;background:#fff;border-radius:var(--r-md);border:1px solid var(--line-soft)}

.donate-trust-item .num{font-family:var(--slab);font-weight:800;font-size:24px;color:var(--gold-d);letter-spacing:-0.01em;line-height:1.1}

.donate-trust-item .num small{font-size:12px;color:var(--muted);font-weight:600;letter-spacing:0.04em;display:block;margin-top:6px;text-transform:uppercase}

.donate-hero-bg img{animation:kb-slow 24s ease-in-out infinite alternate;will-change:transform}

.donate-hero-actions .btn-primary{animation:cta-pulse 2.6s ease-in-out infinite}

.donate-hero-actions .btn-primary:hover{animation:none}

@media (prefers-reduced-motion:reduce){.r-up{transition:opacity 0.3s ease;transform:none !important}.r-up.in{transform:none !important}.donate-hero-bg img{animation:none !important}.donate-hero-actions .btn-primary{animation:none !important}html{scroll-behavior:auto}}

/* MOBILE FIXES — added 2026-05-30 for donate page audit at 360x780 */
@media (max-width:640px){
  /* Hero was ~93% of viewport on mobile, pushing Zeffy form below fold. Cap height. */
  .donate-hero{min-height:clamp(420px,58vh,560px);margin:12px}
  .donate-hero-content{min-height:clamp(420px,58vh,560px);padding:48px var(--gutter)}

  /* Bump sub-13px text to 14px minimum for readability */
  .donate-iframe-head,
  .donate-iframe-head .badge{font-size:11px}
  .donate-iframe-foot{font-size:13px;padding:14px 18px}
  .donate-toggle button{font-size:13px;padding:13px 20px;min-height:44px}
  .donate-trust-item .num small{font-size:12px}
  .donate-rung .amt small{font-size:12px}
  .donate-cost-card p{font-size:14px}

  /* Iframe is hard-coded to 760px — too tall on a phone; the Zeffy form scrolls internally */
  .donate-iframe-card iframe{height:640px}

  /* Tap targets: ensure interactive cards/buttons have >=44px hit area */
  .donate-rung{min-height:64px;padding:16px}
  .donate-rung .amt{font-size:26px}
  .donate-other-card .arrow-link{min-height:44px;padding:12px 18px}
  .donate-iframe-foot a{display:inline-block;min-height:32px;line-height:32px}

  /* Reduce massive padding so content actually breathes */
  .donate-give{padding:48px var(--gutter)}
  .donate-where{padding:56px var(--gutter)}
  .donate-other{padding:48px var(--gutter)}
  .donate-trust{padding:48px var(--gutter)}

  /* Prevent any iframe/card from overflowing the viewport */
  .donate-iframe-card{max-width:100%;box-sizing:border-box}
  .donate-give-grid{max-width:100%}
}


/* === PA hero mobile restructure (auto, 2026-05-31) === prefix:donate */
@media (max-width:980px){
  .donate-hero{
    display:flex; flex-direction:column;
    min-height:0 !important; height:auto !important;
    padding:0 !important; background:var(--paper);
    position:relative; overflow:hidden;
    align-items:stretch !important;
  }
  .donate-hero-bg{
    position:relative !important; inset:auto !important; z-index:auto !important;
    width:100%; aspect-ratio:4/3; height:auto !important;
    order:1; flex:0 0 auto;
  }
  .donate-hero-bg img{
    position:absolute !important; inset:0 !important;
    width:100%; height:100% !important;
    object-fit:cover; object-position:center 30%;
  }
  .donate-hero > .container,
  .donate-hero > .donate-hero-content,
  .donate-hero .donate-hero-content{
    position:static !important; inset:auto !important;
    padding:0 !important; max-width:100%; width:100%; margin:0;
    background:var(--paper); color:var(--ink);
    order:2; flex:1 1 auto;
    min-height:0 !important;
    display:block !important;
  }
  .donate-hero-eyebrow,
  .donate-hero .eyebrow{ display:none !important; }
  .donate-hero h1{
    position:absolute !important; top:37.5vw;
    left:0; right:0; transform:translateY(-50%);
    margin:0 !important; padding:0 24px; max-width:none;
    text-align:center; color:var(--paper-w);
    font-size:clamp(26px,7vw,38px); line-height:1.1;
    text-shadow:0 2px 14px rgba(0,0,0,.6), 0 1px 4px rgba(0,0,0,.5);
    z-index:3;
  }
  .donate-hero h1 .accent,
  .donate-hero h1 span{ color:var(--gold-l); }
  .donate-hero .lede,
  .donate-hero p.sub{
    margin:0 !important; padding:22px 22px 8px; max-width:none;
    background:var(--paper); color:#4a4a3d;
    font-size:14.5px; line-height:1.5; text-align:center;
  }
  .donate-hero .lede strong{ color:var(--ink); }
  .donate-hero .hero-actions,
  .donate-hero .actions,
  .donate-hero .donate-hero-actions{
    margin:0 !important; padding:0 22px 24px;
    background:var(--paper);
    display:flex; flex-direction:row; flex-wrap:wrap;
    gap:10px; align-items:center; justify-content:center; width:100%;
  }
  .donate-hero .btn-light{
    background:transparent;
    border:1.5px solid var(--green-d); color:var(--green-d);
  }
  .donate-hero .btn-light:hover{ background:var(--green-d); color:var(--paper-w); }
  .donate-hero .hero-meta,
  .donate-hero .meta,
  .donate-hero .donate-hero-meta{
    position:absolute; top:calc(75vw - 34px);
    left:50%; right:auto; bottom:auto; transform:translateX(-50%);
    margin:0 !important; padding:5px 14px;
    background:rgba(0,0,0,.34);
    backdrop-filter:blur(6px); -webkit-backdrop-filter:blur(6px);
    border-radius:999px;
    font-family:'Lora',Georgia,serif; font-style:italic; font-size:11px;
    color:rgba(251,246,231,.92); z-index:3;
    display:inline-flex; gap:5px; white-space:nowrap; text-align:center;
  }
  .donate-hero .who{ color:var(--gold-l); font-weight:600; }
}


/* === PA hero mobile contrast/meta fix (auto, 2026-05-31b) === prefix:donate */
@media (max-width:980px){
  /* Lede/quote dark on the cream band (global .X-hero p.lede sets a light
     colour with element-level specificity; override with !important). */
  .donate-hero .lede, .donate-hero p.lede,
  .donate-hero p.sub, .donate-hero .sub,
  .donate-hero blockquote, .donate-hero .quote{ color:#4a4a3d !important; }
  .donate-hero .lede strong, .donate-hero p.lede strong{ color:var(--ink) !important; }
  /* Attribution / credit lines readable on cream */
  .donate-hero .attrib, .donate-hero .attribution,
  .donate-hero .credit, .donate-hero .source{ color:var(--gold-d) !important; }
  /* Hide the decorative caption pill on mobile (overflows on longer metas). */
  .donate-hero .hero-meta, .donate-hero .meta, .donate-hero .donate-hero-meta{ display:none !important; }
}


/* ---- Bank transfer / direct giving ---- */
.donate-bank{padding:clamp(60px,8vw,110px) var(--gutter);background:var(--paper-2)}
.donate-bank .container{max-width:var(--maxw)}
.donate-bank .heading{text-align:center;margin-bottom:34px}
.donate-bank .heading .eyebrow{justify-content:center;margin-bottom:18px}
.donate-bank .heading h2{font-family:var(--slab);font-weight:800;font-size:clamp(30px,4vw,52px);line-height:1.06;letter-spacing:-0.02em;margin:0 0 14px;color:var(--green-d);text-wrap:balance}
.donate-bank .heading h2 span{color:var(--green-l)}
.donate-bank .heading p{font-size:17px;color:var(--ink-2);max-width:52ch;margin:0 auto;line-height:1.6}
.donate-bank-card{max-width:560px;margin:0 auto;background:var(--paper);border:1px solid rgba(176,122,20,0.20);border-radius:var(--r-lg);box-shadow:0 8px 28px rgba(0,0,0,0.10);padding:clamp(26px,4vw,40px)}
.donate-bank-details{margin:0}
.donate-bank-details > div{display:flex;justify-content:space-between;align-items:baseline;gap:18px;padding:14px 0;border-bottom:1px solid rgba(31,43,29,0.10)}
.donate-bank-details > div:last-child{border-bottom:0}
.donate-bank-details dt{font:600 12px/1.4 var(--sans);letter-spacing:0.16em;text-transform:uppercase;color:var(--ink-2);margin:0}
.donate-bank-details dd{margin:0;font-family:var(--slab);font-weight:800;font-size:clamp(18px,2.2vw,22px);color:var(--green-d)}
.donate-bank-note{margin:22px 0 0;font-size:14px;color:var(--ink-2);line-height:1.6;text-align:center}
.donate-bank-note a{color:var(--green-d);font-weight:600}
