/* fundraise.css — page-specific styles for fundraise.html
   Extracted from inline <style> by tools/css-consolidate.py. */

/* ============================================
   FUNDRAISE — page-specific styles
   ============================================ */
/* Pennies Auction featured block — paper bg with big GOLD paw silhouette as the yellow accent */
.fr-auction{padding:clamp(80px,11vw,140px) var(--gutter);background:var(--paper);position:relative;overflow:hidden;color:var(--green-d)}

.fr-auction::before{content:"";position:absolute;top:-40px;right:-60px;width:240px;height:240px;background:var(--green-l);-webkit-mask:url('../images/paw-only.svg') no-repeat center/contain;mask:url('../images/paw-only.svg') no-repeat center/contain;opacity:0.12;pointer-events:none;transform:rotate(14deg);z-index:0}

.fr-auction::after{content:"";position:absolute;bottom:-110px;left:-120px;width:420px;height:420px;background:var(--gold);-webkit-mask:url('../images/paw-only.svg') no-repeat center/contain;mask:url('../images/paw-only.svg') no-repeat center/contain;opacity:0.16;pointer-events:none;transform:rotate(-14deg);z-index:0}

.fr-auction .container{max-width:1100px;position:relative;z-index:1;display:grid;grid-template-columns:minmax(280px,1fr) 1.35fr;gap:clamp(36px,5vw,72px);align-items:center}

@media (max-width:820px){.fr-auction .container{grid-template-columns:1fr;text-align:center}}

.fr-auction .auction-image{aspect-ratio:1/1;border-radius:var(--r-lg);overflow:hidden;background:var(--paper-3);box-shadow:0 14px 36px rgba(31,43,29,0.20),0 4px 12px rgba(31,43,29,0.12);border:1px solid rgba(31,43,29,0.10);transition:all .35s ease}

.fr-auction .auction-image:hover{transform:translateY(-3px);box-shadow:0 18px 44px rgba(31,43,29,0.24),0 6px 14px rgba(31,43,29,0.14)}

.fr-auction .auction-image img{width:100%;height:100%;object-fit:cover;display:block}

@media (max-width:820px){.fr-auction .auction-image{max-width:380px;margin:0 auto}}

.fr-auction .eyebrow{color:var(--green-d)}

.fr-auction .eyebrow::before{background:var(--green-d)}

.fr-auction h2{font-family:var(--slab);font-weight:800;font-size:clamp(36px,5vw,64px);line-height:1.05;letter-spacing:-0.025em;margin:14px 0 18px;color:var(--green-d);text-wrap:balance}

.fr-auction h2 span{font-family:'Fraunces',Georgia,serif;font-variation-settings:'opsz' 144,'SOFT' 100;font-style:italic;font-weight:700;color:var(--brown-d);letter-spacing:-0.005em}

.fr-auction p.lede{font-size:18px;line-height:1.65;margin:0 0 14px;color:var(--green-d)}

.fr-auction p.lede em{font-style:italic;color:var(--green-d);background:rgba(31,43,29,0.08);padding:0 8px;border-radius:6px}

.fr-auction .auction-meta{margin-top:24px;padding-top:18px;border-top:1px solid rgba(31,43,29,0.18);display:grid;grid-template-columns:1fr 1fr;gap:14px;font-size:14px;color:var(--green-d)}

@media (max-width:560px){.fr-auction .auction-meta{grid-template-columns:1fr}}

.fr-auction .auction-meta strong{display:block;font-family:var(--slab);font-weight:700;font-size:11px;letter-spacing:0.18em;text-transform:uppercase;color:var(--green-d);opacity:0.7;margin-bottom:4px}

.fr-auction-actions{margin-top:28px;display:flex;gap:12px;flex-wrap:wrap}

@media (max-width:820px){.fr-auction-actions{justify-content:center}}

.fr-auction-actions .btn-primary{background:var(--green-d);color:var(--paper);box-shadow:0 4px 14px rgba(31,43,29,0.30)}

.fr-auction-actions .btn-primary:hover{background:var(--green);color:var(--paper)}

.fr-auction-actions .btn-secondary{background:transparent;color:var(--green-d);border:1.5px solid var(--green-d);font-family:var(--slab);font-weight:700;font-size:13px;letter-spacing:0.16em;text-transform:uppercase;padding:14px 24px;border-radius:999px;display:inline-flex;align-items:center;gap:10px;transition:all .22s ease}

.fr-auction-actions .btn-secondary:hover{background:var(--green-d);color:var(--paper)}

/* Real fundraisers — vertical stack of 2-col features (photos + text), alternating sides */
.fr-stories{padding:clamp(80px,10vw,120px) var(--gutter);background:#fff}

.fr-stories .container{max-width:1140px}

.fr-stories .heading{text-align:center;margin-bottom:64px}

.fr-stories .heading .eyebrow{justify-content:center}

.fr-stories .heading h2{font-family:var(--slab);font-weight:800;font-size:clamp(32px,4.4vw,52px);line-height:1.1;letter-spacing:-0.02em;margin:14px 0 14px;color:var(--green-d);text-wrap:balance}

.fr-stories .heading h2 span{color:var(--green-l)}

.fr-stories .heading p{font-size:17px;color:var(--ink-2);max-width:54ch;margin:0 auto;line-height:1.65}

.fr-stories-list{display:flex;flex-direction:column;gap:clamp(56px,7vw,96px)}

.fr-feature{display:grid;grid-template-columns:1fr 1.1fr;gap:clamp(28px,4vw,64px);align-items:stretch}

.fr-feature.reverse{grid-template-columns:1.1fr 1fr}

.fr-feature.reverse .fr-feature-hero{order:2}

.fr-feature.reverse .fr-feature-side{order:1}

@media (max-width:820px){.fr-feature,.fr-feature.reverse{grid-template-columns:1fr;gap:28px}.fr-feature.reverse .fr-feature-hero,.fr-feature.reverse .fr-feature-side{order:initial}.fr-feature-hero{min-height:0!important;aspect-ratio:4/5}}

/* Hero photo — single tall portrait, stretches to match the side column */
.fr-feature-hero{position:relative;border-radius:var(--r-lg);overflow:hidden;background:var(--paper-3);border:1px solid rgba(52,74,48,0.08);min-height:520px;transition:all .25s ease}

.fr-feature-hero:hover{transform:translateY(-2px);box-shadow:var(--shadow);border-color:var(--gold)}

.fr-feature-hero > img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block;transition:transform .6s ease}

.fr-feature-hero:hover > img{transform:scale(1.04)}

/* Placeholder hero — for features with no photo */
.fr-feature-hero.placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;background:linear-gradient(160deg,var(--paper-2),var(--paper-3));padding:48px 32px;text-align:center}

.fr-feature-hero.placeholder:hover{transform:none;box-shadow:none;border-color:rgba(52,74,48,0.08)}

.fr-feature-hero.placeholder .ph-label{font-family:'Fraunces',Georgia,serif;font-variation-settings:'opsz' 144,'SOFT' 100;font-weight:700;font-style:italic;line-height:1.05;letter-spacing:-0.02em;color:var(--green-d);text-wrap:balance;font-size:clamp(56px,7vw,84px);margin:0}

.fr-feature-hero.placeholder .ph-label.md{font-size:clamp(32px,4vw,46px);line-height:1.1}

.fr-feature-hero.placeholder .ph-sub{font:600 11px/1.5 var(--sans);letter-spacing:0.22em;text-transform:uppercase;color:var(--muted);margin:20px 0 0;display:block;max-width:24ch}

/* Side column — text on top, optional thumb row beneath */
.fr-feature-side{display:flex;flex-direction:column;gap:clamp(20px,2.5vw,32px);justify-content:center}

.fr-feature-text{display:flex;flex-direction:column}

.fr-feature-text .raised{font-family:var(--slab);font-weight:800;font-size:clamp(48px,6.5vw,84px);line-height:0.95;letter-spacing:-0.03em;color:var(--gold-d);margin:0 0 6px}

.fr-feature-text .raised small{font-size:0.42em;letter-spacing:0.04em;font-weight:600;color:var(--muted);margin-left:4px}

.fr-feature-text h3{font-family:var(--slab);font-weight:800;font-size:clamp(26px,3vw,38px);letter-spacing:-0.015em;margin:8px 0 6px;color:var(--green-d);line-height:1.15}

.fr-feature-text .who{font:600 12px/1.4 var(--sans);letter-spacing:0.20em;text-transform:uppercase;color:var(--muted);margin:0 0 14px}

.fr-feature-text p{font-size:16px;color:var(--ink-2);margin:0;line-height:1.7;max-width:54ch}

/* Thumbnail strip beneath text (1-2 small supporting photos) */
.fr-feature-thumbs{display:grid;gap:10px;max-width:480px}

.fr-feature-thumbs.count-1{grid-template-columns:1fr;max-width:280px}

.fr-feature-thumbs.count-2{grid-template-columns:1fr 1fr}

.fr-feature-thumb{aspect-ratio:4/3;overflow:hidden;border-radius:var(--r-md);background:var(--paper-3);border:1px solid rgba(52,74,48,0.08);transition:all .25s ease}

.fr-feature-thumb:hover{transform:translateY(-2px);box-shadow:var(--shadow);border-color:var(--gold)}

.fr-feature-thumb img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .6s ease}

.fr-feature-thumb:hover img{transform:scale(1.04)}

/* Per-feature accent for the raised number */
.fr-stories-list > .fr-feature:nth-child(1) .raised{color:var(--red)}

.fr-stories-list > .fr-feature:nth-child(2) .raised{color:var(--gold-d)}

.fr-stories-list > .fr-feature:nth-child(3) .raised{color:var(--blue-d)}

.fr-stories-list > .fr-feature:nth-child(4) .raised{color:var(--green)}

/* Per-dog appeals — 4 small status cards on paper */
.fr-appeals{padding:clamp(70px,9vw,110px) var(--gutter);background:var(--paper)}

.fr-appeals .container{max-width:1140px}

.fr-appeals .heading{text-align:center;margin-bottom:40px}

.fr-appeals .heading .eyebrow{justify-content:center}

.fr-appeals .heading h2{font-family:var(--slab);font-weight:800;font-size:clamp(28px,3.6vw,44px);line-height:1.1;letter-spacing:-0.02em;margin:14px 0 14px;color:var(--green-d);text-wrap:balance}

.fr-appeals .heading h2 span{color:var(--green-l)}

.fr-appeals .heading p{font-size:16px;color:var(--ink-2);max-width:60ch;margin:0 auto;line-height:1.6}

.fr-appeals-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(16px,1.6vw,22px);margin-top:8px}

@media (max-width:920px){.fr-appeals-grid{grid-template-columns:repeat(2,1fr)}}

@media (max-width:540px){.fr-appeals-grid{grid-template-columns:1fr}}

/* Help-card pattern: full-bleed photo + dark forest gradient band overlay */
.fr-appeal{
  position:relative; display:block; aspect-ratio:4/5;
  border-radius:14px; overflow:hidden; isolation:isolate;
  background:transparent; border:0; padding:0;
  box-shadow:0 6px 22px rgba(40,40,30,.14);
  transition:transform .25s ease, box-shadow .25s ease;
}
.fr-appeal:hover{ transform:translateY(-3px); box-shadow:0 18px 38px rgba(40,40,30,.22); }

.fr-appeal-photo{
  position:absolute; inset:0; z-index:0;
  aspect-ratio:auto; background:var(--paper-3);
  border:0; overflow:hidden;
}
.fr-appeal-photo img{ width:100%; height:100%; object-fit:cover; display:block; transition:transform .55s ease; }
.fr-appeal:hover .fr-appeal-photo img{ transform:scale(1.04); }

.fr-appeal-content{
  position:absolute; left:0; right:0; bottom:0; z-index:1;
  padding:60px 22px 20px;
  background:linear-gradient(180deg, rgba(30,58,42,0) 0%, rgba(30,58,42,.45) 30%, rgba(30,58,42,.92) 65%, var(--green-d) 82%, var(--green-d) 100%);
  color:var(--paper-w);
  display:flex; flex-direction:column; gap:4px;
}
.fr-appeal .name{
  font:700 10.5px/1 var(--sans);
  letter-spacing:.22em; text-transform:uppercase;
  color:var(--gold-l);
  margin:0;
}
.fr-appeal .ask{
  font-family:'Fraunces', Georgia, serif; font-style:italic; font-weight:600;
  font-size:34px; line-height:1; letter-spacing:0;
  color:var(--paper-w);
  margin:4px 0 6px;
}
.fr-appeal .what{
  font-family:'Lora', Georgia, serif; font-style:italic;
  font-size:13px; line-height:1.5;
  color:rgba(251,246,231,.92);
  margin:0;
  padding-right:60px;
  display:-webkit-box; -webkit-box-orient:vertical; -webkit-line-clamp:2; overflow:hidden;
}
.fr-appeal .status{
  position:absolute; right:18px; bottom:18px; z-index:2;
  font:700 10px/1 var(--sans); letter-spacing:.18em; text-transform:uppercase;
  padding:6px 12px; border-radius:999px;
  margin:0; align-self:auto;
  display:inline-flex; align-items:center; gap:6px;
}
.fr-appeal .status{ display:none !important; }

/* Start your own — 3-step CTA section */
.fr-start{padding:clamp(80px,10vw,140px) var(--gutter);background:var(--green);color:var(--paper-w)}

.fr-start .container{max-width:980px;text-align:center}

.fr-start .heading{margin-bottom:48px}

.fr-start .heading .eyebrow{justify-content:center}

.fr-start .heading h2{font-family:var(--slab);font-weight:800;font-size:clamp(32px,4.2vw,52px);line-height:1.1;letter-spacing:-0.02em;margin:14px 0 18px;color:var(--paper-w);text-wrap:balance}

.fr-start .heading h2 span{font-family:'Fraunces',Georgia,serif;font-style:italic;font-weight:600;color:var(--gold-l)}

.fr-start .heading p{font-size:17px;color:rgba(251,246,231,0.88);max-width:54ch;margin:0 auto;line-height:1.65}

.fr-start-steps{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-bottom:36px}

@media (max-width:780px){.fr-start-steps{grid-template-columns:1fr}}

.fr-start-step{background:var(--paper-2);padding:28px 24px;border-radius:var(--r-md);border:1px solid rgba(52,74,48,0.08);text-align:left}

.fr-start-step .num{font-family:var(--slab);font-weight:800;font-size:13px;letter-spacing:0.18em;text-transform:uppercase;color:var(--gold-d);background:var(--paper);padding:5px 12px;border-radius:999px;display:inline-block;margin-bottom:14px}

.fr-start-step h3{font-family:var(--slab);font-weight:800;font-size:18px;letter-spacing:-0.005em;margin:0 0 6px;color:var(--green-d);line-height:1.2}

.fr-start-step p{font-size:14px;color:var(--ink-2);margin:0;line-height:1.55}

.fr-start-cta{display:inline-flex;align-items:center;gap:10px;padding:18px 32px;background:var(--yellow);color:var(--green-d);font-family:var(--slab);font-weight:700;font-size:14px;letter-spacing:0.12em;text-transform:uppercase;border-radius:999px;box-shadow:0 4px 14px rgba(244,211,94,0.36);transition:all .22s ease}

.fr-start-cta:hover{background:var(--gold);transform:translateY(-1px);box-shadow:0 6px 22px rgba(232,176,74,0.46)}

.fr-start-note{margin-top:18px;font-size:13px;color:rgba(251,246,231,0.72)}

/* Newsletter section — homepage Newsletter pattern: cream outer with fur photo bg + gold inner box + glow heading */
/* Newsletter — uses the .newsletter rules from the homepage block below
   (single source of truth — no fr-newsletter override). */

/* ============================================
   GET INVOLVED HUB — page-specific styles
   ============================================ */
/* Universal Fraunces accent — all h2 italic spans on the page,
   matching the homepage's heading-accent treatment exactly. */
.gi-intro h2 span,
.gi-dogs-head h2 span,
.gi-pillar-head h2 span,
.gi-section .heading h2 span,
.gi-newsletter h2 span,
.gi-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;
}

.gi-hero{position:relative;min-height:clamp(420px,55vh,560px);overflow:hidden;background:#0a1408;margin:0;border-radius:var(--r-xl)}

.gi-hero-bg img{width:100%;height:100%;object-fit:cover;object-position:center 65%;filter:saturate(0.96) contrast(1.04)}

.gi-hero-content{position:relative;z-index:2;max-width:var(--maxw);margin:0 auto;padding:clamp(56px,8vh,90px) var(--gutter);color:#fbf6e7;display:flex;flex-direction:column;justify-content:center;min-height:clamp(420px,55vh,560px)}

/* ============================================
   FUNDRAISE — mobile readability + tap-target fixes
   ============================================ */
@media (max-width:640px){
  /* Bump small text up to >=14px for mobile legibility */
  .fr-appeal .name{font-size:14px;letter-spacing:.20em}
  .fr-appeal .what{font-size:14px;line-height:1.5;padding-right:48px;-webkit-line-clamp:3}
  .fr-appeal .status{font-size:14px;padding:8px 14px}
  .fr-start-step .num{font-size:14px}
  .fr-start-step p{font-size:14px}
  .fr-start-note{font-size:14px}
  .fr-auction .auction-meta{font-size:14px}
  .fr-auction .auction-meta strong{font-size:14px;letter-spacing:.14em}

  /* Ensure interactive elements meet 44px tap-target minimum */
  .fr-auction-actions .btn-primary,
  .fr-auction-actions .btn-secondary,
  .fr-start-cta{min-height:44px;min-width:44px;padding-top:14px;padding-bottom:14px}
  .fr-appeal{min-height:44px}
}


/* === PA hero mobile restructure (auto, 2026-05-31) === prefix:gi */
@media (max-width:980px){
  .gi-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;
  }
  .gi-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;
  }
  .gi-hero-bg img{
    position:absolute !important; inset:0 !important;
    width:100%; height:100% !important;
    object-fit:cover; object-position:center 30%;
  }
  .gi-hero > .container,
  .gi-hero > .gi-hero-content,
  .gi-hero .gi-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;
  }
  .gi-hero-eyebrow,
  .gi-hero .eyebrow{ display:none !important; }
  .gi-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;
  }
  .gi-hero h1 .accent,
  .gi-hero h1 span{ color:var(--gold-l); }
  .gi-hero .lede,
  .gi-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;
  }
  .gi-hero .lede strong{ color:var(--ink); }
  .gi-hero .hero-actions,
  .gi-hero .actions,
  .gi-hero .gi-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%;
  }
  .gi-hero .btn-light{
    background:transparent;
    border:1.5px solid var(--green-d); color:var(--green-d);
  }
  .gi-hero .btn-light:hover{ background:var(--green-d); color:var(--paper-w); }
  .gi-hero .hero-meta,
  .gi-hero .meta,
  .gi-hero .gi-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;
  }
  .gi-hero .who{ color:var(--gold-l); font-weight:600; }
}


/* === PA hero mobile contrast/meta fix (auto, 2026-05-31b) === prefix:gi */
@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). */
  .gi-hero .lede, .gi-hero p.lede,
  .gi-hero p.sub, .gi-hero .sub,
  .gi-hero blockquote, .gi-hero .quote{ color:#4a4a3d !important; }
  .gi-hero .lede strong, .gi-hero p.lede strong{ color:var(--ink) !important; }
  /* Attribution / credit lines readable on cream */
  .gi-hero .attrib, .gi-hero .attribution,
  .gi-hero .credit, .gi-hero .source{ color:var(--gold-d) !important; }
  /* Hide the decorative caption pill on mobile (overflows on longer metas). */
  .gi-hero .hero-meta, .gi-hero .meta, .gi-hero .gi-hero-meta{ display:none !important; }
}
