/* foster-to-forever.css — page-specific styles for foster-to-forever.html
   Extracted from inline <style> by tools/css-consolidate.py. */

/* Remove the dark gradient overlay on this page's hero */
.ftf-hero .wr-hero-bg::after{display:none}

.ftf-hero .wr-hero-bg img{object-position:center 50%;object-fit:cover}

.ftf-hero .wr-hero-content h1, .ftf-hero .wr-hero-content p.lede{text-shadow:0 2px 18px rgba(0,0,0,0.55)}

/* FOSTER-TO-FOREVER — long-read editorial */
.ftf-intro{text-align:center}

.ftf-intro .ornament{width:54px;height:54px;margin:0 auto 28px;border-radius:50%;background:var(--gold);display:flex;align-items:center;justify-content:center;color:var(--green-d);box-shadow:0 4px 18px rgba(232,176,74,0.4)}

.ftf-intro .ornament svg{display:block}

.ftf-intro .heading{margin-bottom:28px;text-align:center}

.ftf-intro .heading .eyebrow{justify-content:center}

.ftf-intro h2 span{font-family:'Fraunces',Georgia,serif;font-variation-settings:'opsz' 144,'SOFT' 100;font-style:italic;font-weight:700;letter-spacing:-0.005em}

.ftf-intro .body{max-width:62ch;margin:0 auto;text-align:left}

.ftf-flagship{padding:clamp(80px,11vw,140px) var(--gutter);background:#fff;position:relative;overflow:hidden}

.ftf-flagship::before{content:"";position:absolute;top:-30px;right:-50px;width:280px;height:280px;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.10;pointer-events:none;transform:rotate(14deg)}

.ftf-flagship .container{max-width:1180px;position:relative;z-index:1}

/* LEAD — heading-only block, the cast strip below carries the imagery */
.ftf-lead{max-width:880px;margin:0 auto clamp(48px,6vw,80px);text-align:center}

.ftf-lead .ftf-eyebrow{justify-content:center}

.ftf-eyebrow{font:600 12px/1 var(--sans);letter-spacing:0.22em;text-transform:uppercase;color:var(--gold-d);margin-bottom:16px;display:inline-flex;align-items:center;gap:10px}

.ftf-eyebrow::before{content:"";width:24px;height:2px;background:var(--gold);border-radius:2px}

.ftf-flagship h2{font-family:var(--slab);font-weight:800;font-size:clamp(40px,5.6vw,80px);line-height:0.98;letter-spacing:-0.025em;margin:8px 0 22px;color:var(--green-d);text-wrap:balance}

.ftf-flagship h2 span{font-family:'Fraunces',Georgia,serif;font-variation-settings:'opsz' 144,'SOFT' 100;font-style:italic;font-weight:700;letter-spacing:-0.005em;color:var(--green-l)}

.ftf-lede{font-family:'Fraunces',Georgia,serif;font-variation-settings:'opsz' 144,'SOFT' 80;font-style:italic;font-weight:500;font-size:clamp(19px,2vw,24px);max-width:48ch;margin:18px auto 0;color:var(--ink-2);line-height:1.45;text-align:center}

/* CAST — 4-up portrait strip introducing each sibling */
.ftf-cast{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(16px,2vw,24px);margin-bottom:clamp(60px,7vw,96px)}

@media (max-width:780px){.ftf-cast{grid-template-columns:repeat(2,1fr);gap:18px}}

.ftf-cast-card{margin:0;background:var(--paper);border-radius:var(--r-lg);overflow:hidden;border:1px solid rgba(52,74,48,0.10);box-shadow:0 1px 6px rgba(42,51,38,0.04);transition:all .25s ease}

.ftf-cast-card:hover{transform:translateY(-3px);box-shadow:var(--shadow);border-color:var(--gold)}

.ftf-cast-card img{width:100%;aspect-ratio:1/1;object-fit:cover;display:block;background:var(--paper-3)}

.ftf-cast-card figcaption{padding:14px 16px 16px;display:flex;flex-direction:column;gap:4px}

.ftf-cast-card figcaption strong{font-family:var(--slab);font-weight:800;font-size:20px;letter-spacing:-0.01em;color:var(--green-d)}

.ftf-cast-card figcaption span{font:600 11px/1.4 var(--sans);letter-spacing:0.10em;text-transform:uppercase;color:var(--gold-d)}

.ftf-arc{display:grid;gap:clamp(28px,4vw,48px);position:relative}

.ftf-arc::before{content:"";position:absolute;left:24px;top:14px;bottom:14px;width:2px;background:linear-gradient(180deg,var(--gold) 0%,var(--paper-3) 100%);opacity:0.5}

@media (max-width:680px){.ftf-arc::before{left:18px}}

/* Center-timeline arc — text on one side, image on the other, number circles in the middle */
.ftf-arc{position:relative;display:grid;gap:clamp(36px,5vw,72px)}

.ftf-arc::before{content:"";position:absolute;left:50%;top:30px;bottom:30px;width:2px;background:linear-gradient(180deg,var(--gold) 0%,var(--paper-3) 50%,var(--gold) 100%);opacity:0.5;transform:translateX(-50%);pointer-events:none;z-index:0}

@media (max-width:880px){.ftf-arc::before{left:24px;transform:none}}

.ftf-step{display:grid;grid-template-columns:1fr 80px 1fr;gap:clamp(20px,3vw,40px);align-items:center;position:relative;z-index:1}

@media (max-width:880px){.ftf-step{grid-template-columns:50px 1fr;gap:18px}}

@media (max-width:680px){.ftf-step{grid-template-columns:38px 1fr;gap:14px}}

.ftf-step-num{width:64px;height:64px;display:flex;align-items:center;justify-content:center;background:var(--gold);border-radius:50%;color:var(--green-d);box-shadow:0 4px 14px rgba(232,176,74,0.32);font-family:var(--slab);font-weight:800;font-size:22px;letter-spacing:-0.01em;justify-self:center;z-index:2}

@media (max-width:880px){.ftf-step-num{width:50px;height:50px;font-size:18px;justify-self:start}}

@media (max-width:680px){.ftf-step-num{width:38px;height:38px;font-size:14px}}

.ftf-step-text h3{font-family:var(--slab);font-weight:800;font-size:clamp(22px,2.4vw,28px);letter-spacing:-0.015em;margin:0 0 12px;color:var(--green-d)}

.ftf-step-text p{font-size:17px;line-height:1.7;color:var(--ink-2);margin:0 0 12px}

.ftf-step-text p:last-child{margin-bottom:0}

.ftf-step-photo{margin:0;width:100%;aspect-ratio:4/3;overflow:hidden;background:var(--paper-3);border-radius:var(--r-lg);box-shadow:var(--shadow)}

.ftf-step-photo img{width:100%;height:100%;object-fit:cover;display:block}

/* Alternating sides — text-left places text in column 1, photo in column 3 (default) */
.ftf-step--text-left .ftf-step-text{grid-column:1;text-align:right}

.ftf-step--text-left .ftf-step-photo{grid-column:3}

/* text-right places photo in column 1, text in column 3 */
.ftf-step--text-right .ftf-step-photo{grid-column:1}

.ftf-step--text-right .ftf-step-text{grid-column:3;text-align:left}

@media (max-width:880px){
  .ftf-step--text-left .ftf-step-text,
  .ftf-step--text-right .ftf-step-text{grid-column:2;text-align:left}
  .ftf-step--text-left .ftf-step-photo,
  .ftf-step--text-right .ftf-step-photo{grid-column:1 / -1;margin-top:14px;aspect-ratio:16/10}
  .ftf-step{grid-template-rows:auto auto;align-items:start}
  .ftf-step-num{grid-row:1}
  .ftf-step-text{grid-row:1}
}

/* Step 04 climax — pull-quote treatment instead of body card */
.ftf-step-climax .ftf-quote{font-family:'Fraunces',Georgia,serif;font-variation-settings:'opsz' 144,'SOFT' 100;font-style:italic;font-weight:700;font-size:clamp(20px,2.4vw,28px);line-height:1.3;color:var(--green-d);margin:14px 0 18px;padding:6px 0 6px 20px;border-left:4px solid var(--gold);letter-spacing:-0.01em;text-wrap:balance}

.ftf-quote{font-family:'Fraunces',Georgia,serif;font-variation-settings:'opsz' 144,'SOFT' 100;font-style:italic;font-weight:600;font-size:clamp(20px,2.4vw,28px);line-height:1.4;color:var(--green-d);margin:18px 0;padding:0;text-wrap:balance}

.ftf-pullquote{margin:clamp(48px,6vw,72px) 0 0;padding:32px 36px;background:linear-gradient(160deg,var(--green-d) 0%,var(--green) 100%);color:#fbf6e7;border-radius:var(--r-lg);box-shadow:var(--shadow);position:relative}

.ftf-pullquote p{font-family:'Fraunces',Georgia,serif;font-variation-settings:'opsz' 144,'SOFT' 100;font-style:italic;font-weight:600;font-size:clamp(20px,2.4vw,28px);line-height:1.4;margin:0 0 14px;color:#fbf6e7;text-wrap:balance}

.ftf-pullquote cite{display:block;font:600 11px/1.4 var(--sans);font-style:normal;letter-spacing:0.22em;text-transform:uppercase;color:var(--gold-l);opacity:0.85}

.ftf-pattern{background:var(--paper-2);color:var(--green-d);padding:clamp(80px,11vw,140px) var(--gutter);position:relative;overflow:hidden}

.ftf-pattern::before{display:none}

.ftf-pattern .container{max-width:1100px;position:relative;z-index:1}

/* Block 1 — heading on the left, full width container, large headline */
.ftf-pattern-head{max-width:780px;margin-bottom:clamp(40px,5vw,64px)}

.ftf-pattern-head .eyebrow{color:var(--gold-d);margin-bottom:18px}

.ftf-pattern-head .eyebrow::before{background:var(--gold)}

.ftf-pattern-head h2{font-family:var(--slab);font-weight:800;font-size:clamp(36px,4.6vw,60px);line-height:1.05;letter-spacing:-0.02em;margin:8px 0 0;color:var(--green-d);text-wrap:balance}

.ftf-pattern-head h2 span{font-family:'Fraunces',Georgia,serif;font-variation-settings:'opsz' 144,'SOFT' 100;font-style:italic;font-weight:700;color:var(--gold-d)}

/* Block 2 — photo left, body text right (the "with image" block) */
.ftf-pattern-mid{display:grid;grid-template-columns:minmax(0,1.2fr) minmax(0,1fr);gap:clamp(40px,5vw,72px);align-items:start;margin-bottom:clamp(40px,5vw,64px)}

@media (max-width:820px){.ftf-pattern-mid{grid-template-columns:1fr;gap:clamp(28px,4vw,40px)}}

.ftf-pattern-photo{order:2;margin:0;width:100%;aspect-ratio:4/5;overflow:hidden;background:var(--paper-3);border-radius:var(--r-lg);box-shadow:var(--shadow)}

.ftf-pattern-mid-text{order:1}

@media (max-width:820px){.ftf-pattern-photo{order:0}.ftf-pattern-mid-text{order:0}}

.ftf-pattern-photo img{width:100%;height:100%;object-fit:cover;display:block}

.ftf-pattern-mid-text p{font-size:17px;line-height:1.8;color:var(--ink-2);margin:0 0 18px}

.ftf-pattern-mid-text p:first-child{margin-top:6px}

.ftf-pattern-mid-text p:last-child{margin-bottom:0}

/* Block 3 — payoff text below, full width but constrained reading column */
.ftf-pattern-payoff{max-width:760px}

.ftf-pattern-payoff p{font-size:17px;line-height:1.8;color:var(--ink-2);margin:0 0 22px}

.ftf-payoff-line{font-family:var(--slab);font-size:clamp(20px,2.4vw,26px);line-height:1.45;color:var(--green-d)}

.ftf-payoff-line strong{font-weight:700;color:var(--green-d)}

.ftf-payoff-line span{font-family:'Fraunces',Georgia,serif;font-variation-settings:'opsz' 144,'SOFT' 100;font-style:italic;font-weight:700;color:var(--gold-d)}

.newsletter{background:#3a2516 url('../images/donate-fur-bw.jpg') center center/cover no-repeat;position:relative;isolation:isolate}


/* === PA hero mobile restructure (auto, 2026-05-31) === prefix:wr */
@media (max-width:980px){
  .wr-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;
  }
  .wr-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;
  }
  .wr-hero-bg img{
    position:absolute !important; inset:0 !important;
    width:100%; height:100% !important;
    object-fit:cover; object-position:center 30%;
  }
  .wr-hero > .container,
  .wr-hero > .wr-hero-content,
  .wr-hero .wr-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;
  }
  .wr-hero-eyebrow,
  .wr-hero .eyebrow{ display:none !important; }
  .wr-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;
  }
  .wr-hero h1 .accent,
  .wr-hero h1 span{ color:var(--gold-l); }
  .wr-hero .lede,
  .wr-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;
  }
  .wr-hero .lede strong{ color:var(--ink); }
  .wr-hero .hero-actions,
  .wr-hero .actions,
  .wr-hero .wr-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%;
  }
  .wr-hero .btn-light{
    background:transparent;
    border:1.5px solid var(--green-d); color:var(--green-d);
  }
  .wr-hero .btn-light:hover{ background:var(--green-d); color:var(--paper-w); }
  .wr-hero .hero-meta,
  .wr-hero .meta,
  .wr-hero .wr-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;
  }
  .wr-hero .who{ color:var(--gold-l); font-weight:600; }
}


/* === PA hero mobile contrast/meta fix (auto, 2026-05-31b) === prefix:wr */
@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). */
  .wr-hero .lede, .wr-hero p.lede,
  .wr-hero p.sub, .wr-hero .sub,
  .wr-hero blockquote, .wr-hero .quote{ color:#4a4a3d !important; }
  .wr-hero .lede strong, .wr-hero p.lede strong{ color:var(--ink) !important; }
  /* Attribution / credit lines readable on cream */
  .wr-hero .attrib, .wr-hero .attribution,
  .wr-hero .credit, .wr-hero .source{ color:var(--gold-d) !important; }
  /* Hide the decorative caption pill on mobile (overflows on longer metas). */
  .wr-hero .hero-meta, .wr-hero .meta, .wr-hero .wr-hero-meta{ display:none !important; }
}
