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

/* ============================================
   CONTACT PAGE — page-specific styles (.contact- namespace)
   ============================================ */
.contact-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 */
.contact-hero{position:relative;min-height:clamp(420px,56vh,540px);overflow:hidden;background:#0a1408;margin:clamp(16px,2vw,28px);border-radius:var(--r-xl)}

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

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

.contact-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%);}

.contact-hero-content{position:relative;z-index:2;max-width:var(--maxw);margin:0 auto;padding:clamp(56px,9vh,100px) var(--gutter);color:#fbf6e7;display:flex;flex-direction:column;justify-content:center;min-height:clamp(420px,56vh,540px)}

.contact-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}

.contact-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)}

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

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

.contact-hero p.lede{font-size:clamp(17px,1.6vw,21px);max-width:54ch;margin:0;color:rgba(255,255,255,0.92);line-height:1.5;font-family:var(--slab);font-weight:500}

/* DETAILS + FORM */
.contact-main{padding:clamp(70px,9vw,120px) var(--gutter);background:var(--paper)}

.contact-grid{display:grid;grid-template-columns:1fr 1.4fr;gap:clamp(40px,5vw,72px);max-width:1180px;margin:0 auto;align-items:start}

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

.contact-info h2{font-family:var(--slab);font-weight:800;font-size:clamp(28px,3.2vw,42px);line-height:1.1;letter-spacing:-0.02em;margin:14px 0 28px;color:var(--green-d);max-width:18ch;text-wrap:balance}

.contact-info h2 span{color:var(--green-l)}

.contact-info > p{font-size:17px;color:var(--ink-2);line-height:1.65;margin:0 0 36px;max-width:36ch}

.contact-blocks{display:grid;gap:24px}

.contact-block{display:grid;grid-template-columns:52px 1fr;gap:20px;align-items:start}

/* Brand icon style: yellow disc + green-d glyph, matches the primary button
   pattern and the arrow-link disc on the route cards. */
.contact-block .icon{
  width:52px; height:52px; border-radius:50%;
  background:var(--yellow); color:var(--green-d);
  display:inline-flex; align-items:center; justify-content:center;
  flex-shrink:0; border:0;
  box-shadow:0 4px 12px rgba(237,202,102,.40);
  transition:transform .25s ease, background .2s ease;
}
.contact-block:hover .icon{ transform:scale(1.06); background:var(--gold); }
.contact-block .icon svg{ width:22px; height:22px; }

.contact-block .label{font:700 11px/1 var(--sans);letter-spacing:0.20em;text-transform:uppercase;color:var(--muted);margin:6px 0 6px}

.contact-block .value{font-family:var(--slab);font-weight:600;font-size:18px;color:var(--green-d);line-height:1.4}

.contact-block .value a{color:var(--green-d);border-bottom:1.5px solid transparent;transition:border-color .2s ease}

.contact-block .value a:hover{border-color:var(--gold)}

.contact-block .sub{font-size:14px;color:var(--ink-2);margin-top:4px;line-height:1.5}

.contact-right{display:flex;flex-direction:column;gap:22px}

.contact-charity{padding:22px 24px;background:var(--paper-2);border-radius:var(--r-md);font-size:14px;color:var(--ink-2);line-height:1.6}

/* FORM CARD */
.contact-form-card{background:#fff;border:1px solid var(--line-soft);border-radius:var(--r-lg);padding:clamp(28px,3vw,42px);box-shadow:var(--shadow);position:relative;overflow:hidden}

.contact-form-card::before{content:"";position:absolute;top:-30px;right:-50px;width:200px;height:200px;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);z-index:0}

.contact-form-card > *{position:relative;z-index:1}

.contact-form-card h3{font-family:var(--slab);font-weight:800;font-size:clamp(22px,2.4vw,30px);line-height:1.15;letter-spacing:-0.015em;margin:0 0 8px;color:var(--green-d)}

.contact-form-card .form-sub{font-size:15px;color:var(--ink-2);margin:0 0 28px;line-height:1.55}

.contact-form{display:grid;gap:18px}

.contact-field{display:grid;gap:6px}

.contact-field label{font:700 11px/1 var(--sans);letter-spacing:0.18em;text-transform:uppercase;color:var(--muted)}

.contact-field input,.contact-field select,.contact-field textarea{width:100%;padding:14px 16px;font:500 15px var(--sans);color:var(--ink);background:var(--paper);border:1.5px solid var(--line-soft);border-radius:var(--r-sm);outline:0;transition:border-color .2s ease,background .2s ease}

.contact-field input:focus,.contact-field select:focus,.contact-field textarea:focus{border-color:var(--gold);background:#fff}

.contact-field textarea{min-height:130px;resize:vertical;font-family:var(--sans)}

.contact-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}

@media (max-width:600px){.contact-row{grid-template-columns:1fr}}

.contact-form-actions{display:flex;align-items:center;gap:14px;margin-top:8px;flex-wrap:wrap}

.contact-form-actions small{font-size:12px;color:var(--muted)}

/* QUICK ROUTES — pillar-style grid (matches homepage .pillar pattern) */
.contact-routes{padding:clamp(70px,9vw,120px) var(--gutter);background:var(--paper-2);position:relative;overflow:hidden}

.contact-routes::before{content:"";position:absolute;top:-30px;left:-50px;width:240px;height:240px;background:var(--green-ll);-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}

.contact-routes .container{max-width:var(--maxw);position:relative;z-index:1}

.contact-routes .heading{display:grid;grid-template-columns:1.5fr 1fr;gap:clamp(36px,5vw,90px);align-items:end;margin-bottom:clamp(40px,5vw,60px);max-width:1240px}

@media (max-width:820px){.contact-routes .heading{grid-template-columns:1fr;gap:18px;align-items:start}}

.contact-routes .heading-meta{display:flex;flex-direction:column;gap:18px}

.contact-routes .heading .eyebrow{margin:0}

.contact-routes .heading h2{font-family:var(--slab);font-weight:800;font-size:clamp(44px,6.4vw,84px);line-height:1.02;letter-spacing:-0.025em;margin:0;color:var(--green-d);text-wrap:balance;max-width:14ch}

.contact-routes .heading h2 span{color:var(--green-l);font-style:italic;font-weight:600;font-family:'Fraunces',Georgia,serif}

.contact-routes .heading p{font-size:17px;color:var(--ink-2);max-width:42ch;margin:0;line-height:1.6}

.contact-route-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:clamp(20px,2vw,28px);max-width:1080px;margin:0 auto}

@media (max-width:540px){.contact-route-grid{grid-template-columns:1fr}}

/* Card layout: full-bleed image at top + dark forest band overlay at bottom.
   Same visual language as the help-cards from get-involved. */
.contact-route{
  position:relative; display:block; aspect-ratio:5/4;
  border-radius:14px; overflow:hidden; isolation:isolate;
  text-decoration:none; color:inherit;
  background:transparent;
  box-shadow:0 6px 22px rgba(40,40,30,.14);
  transition:transform .25s ease, box-shadow .25s ease;
}
.contact-route:hover{ transform:translateY(-3px); box-shadow:0 18px 38px rgba(40,40,30,.22); }

.contact-route .img{
  position:absolute; inset:0;
  background-size:cover; background-position:center;
  transition:transform .55s ease;
  z-index:0;
}
.contact-route:hover .img{ transform:scale(1.04); }

.contact-route .band{
  position:absolute; left:0; right:0; bottom:0; z-index:1;
  padding:74px 24px 22px;
  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);
}
.contact-route .label{
  display:block;
  font:700 10.5px/1 var(--sans);
  letter-spacing:.20em; text-transform:uppercase;
  color:var(--gold-l);
  margin:0 0 8px;
}
.contact-route h3{
  font-family:'Fraunces', Georgia, serif;
  font-weight:600; font-style:italic;
  font-size:26px; line-height:1.08; letter-spacing:0;
  color:var(--paper-w);
  margin:0 0 8px;
  padding-right:48px;
}
.contact-route p{
  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:54px;
  max-width:34ch;
  display:-webkit-box; -webkit-box-orient:vertical; -webkit-line-clamp:3; overflow:hidden;
}
.contact-route .arrow-link{
  position:absolute; right:18px; bottom:18px; z-index:2;
  width:36px; height:36px; border-radius:50%;
  background:var(--yellow); color:var(--green-d);
  display:inline-flex; align-items:center; justify-content:center;
  font-size:0; gap:0; padding:0; margin:0;
  letter-spacing:0; text-transform:none;
  box-shadow:0 4px 12px rgba(30,58,42,.30);
  transition:background .2s ease, transform .25s ease;
}
.contact-route .arrow-link svg{ width:14px; height:14px; }
.contact-route:hover .arrow-link{ background:var(--gold); transform:translateX(3px); }

/* NEWSLETTER (mirrors homepage .newsletter pattern) */
.contact-newsletter{background:var(--paper);padding:clamp(70px,9vw,120px) var(--gutter);position:relative;overflow:hidden}

.contact-newsletter .container{max-width:var(--maxw);background:var(--gold);border-radius:var(--r-xl);padding:clamp(40px,5vw,72px);border:1px solid rgba(176,122,20,0.20);box-shadow:0 8px 32px rgba(232,176,74,0.22);position:relative;overflow:hidden}

.contact-newsletter .container::before{content:"";position:absolute;top:-40px;right:-50px;width:260px;height:260px;background:var(--green-d);-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(18deg);z-index:0}

.contact-newsletter .container > *{position:relative;z-index:1}

.contact-newsletter-grid{display:grid;grid-template-columns:1fr 1.2fr;gap:clamp(40px,6vw,72px);align-items:center}

@media (max-width:820px){.contact-newsletter-grid{grid-template-columns:1fr}}

.contact-newsletter .eyebrow{color:var(--green-d)}

.contact-newsletter .eyebrow::before{background:var(--green-d)}

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

.contact-newsletter h2 span{color:#fff;font-style:italic;font-weight:600;text-shadow:0 0 24px rgba(255,255,255,0.65),0 0 48px rgba(255,255,255,0.35),0 2px 4px rgba(176,122,20,0.20);font-family:'Fraunces',Georgia,serif}

.contact-newsletter p{font-size:17px;color:var(--green-d);opacity:0.85;max-width:46ch;margin:0;line-height:1.6}

.contact-newsletter form{display:grid;grid-template-columns:1fr 1.4fr auto;gap:8px;background:var(--paper-2);padding:8px;border-radius:999px}

@media (max-width:720px){.contact-newsletter form{grid-template-columns:1fr;border-radius:var(--r-lg)}}

.contact-newsletter input{border:0;outline:0;background:transparent;padding:18px 22px;font-family:var(--sans);font-size:15px;color:var(--ink);border-radius:999px}

@media (max-width:720px){.contact-newsletter input{background:var(--paper);border-radius:var(--r-md)}}

.contact-newsletter input::placeholder{color:var(--muted)}

.contact-newsletter input:focus{background:var(--paper);box-shadow:0 0 0 1.5px var(--gold)}

.contact-newsletter button[type="submit"]{background:var(--green);color:#fbf6e7;padding:14px 28px;font-family:var(--slab);font-weight:700;font-size:13px;letter-spacing:0.16em;text-transform:uppercase;border-radius:999px;display:inline-flex;align-items:center;gap:10px;justify-content:center;transition:all .2s ease;border:0;cursor:pointer}

.contact-newsletter button[type="submit"]:hover{background:var(--green-d);transform:translateY(-1px);box-shadow:0 6px 20px rgba(52,74,48,0.22)}

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

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

/* MOBILE READABILITY + TAP TARGETS (audit 2026-05-30) */
@media (max-width:640px){
  /* Bump too-small text up to a 13-14px readable floor where this file owns the rule */
  .contact-hero-eyebrow{font-size:13px}
  .contact-block .label{font-size:13px;letter-spacing:0.18em}
  .contact-field label{font-size:13px;letter-spacing:0.16em}
  .contact-form-actions small{font-size:13px}
  .contact-route .label{font-size:13px;letter-spacing:0.18em}
  .contact-route p{font-size:14px}
  .contact-newsletter button[type="submit"]{font-size:14px}

  /* Tap-target minimums for interactive elements styled in this file */
  .contact-field input,
  .contact-field select,
  .contact-field textarea{min-height:44px}
  .contact-newsletter input{min-height:44px}
  .contact-newsletter button[type="submit"]{min-height:44px;min-width:44px}
  .contact-route .arrow-link{width:44px;height:44px}
  .contact-route .arrow-link svg{width:16px;height:16px}
  .contact-block .icon{width:48px;height:48px}
}


/* === PA hero mobile restructure (auto, 2026-05-31) === prefix:contact */
@media (max-width:980px){
  .contact-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;
  }
  .contact-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;
  }
  .contact-hero-bg img{
    position:absolute !important; inset:0 !important;
    width:100%; height:100% !important;
    object-fit:cover; object-position:center 30%;
  }
  .contact-hero > .container,
  .contact-hero > .contact-hero-content,
  .contact-hero .contact-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;
  }
  .contact-hero-eyebrow,
  .contact-hero .eyebrow{ display:none !important; }
  .contact-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;
  }
  .contact-hero h1 .accent,
  .contact-hero h1 span{ color:var(--gold-l); }
  .contact-hero .lede,
  .contact-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;
  }
  .contact-hero .lede strong{ color:var(--ink); }
  .contact-hero .hero-actions,
  .contact-hero .actions,
  .contact-hero .contact-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%;
  }
  .contact-hero .btn-light{
    background:transparent;
    border:1.5px solid var(--green-d); color:var(--green-d);
  }
  .contact-hero .btn-light:hover{ background:var(--green-d); color:var(--paper-w); }
  .contact-hero .hero-meta,
  .contact-hero .meta,
  .contact-hero .contact-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;
  }
  .contact-hero .who{ color:var(--gold-l); font-weight:600; }
}


/* === PA hero mobile contrast/meta fix (auto, 2026-05-31b) === prefix:contact */
@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). */
  .contact-hero .lede, .contact-hero p.lede,
  .contact-hero p.sub, .contact-hero .sub,
  .contact-hero blockquote, .contact-hero .quote{ color:#4a4a3d !important; }
  .contact-hero .lede strong, .contact-hero p.lede strong{ color:var(--ink) !important; }
  /* Attribution / credit lines readable on cream */
  .contact-hero .attrib, .contact-hero .attribution,
  .contact-hero .credit, .contact-hero .source{ color:var(--gold-d) !important; }
  /* Hide the decorative caption pill on mobile (overflows on longer metas). */
  .contact-hero .hero-meta, .contact-hero .meta, .contact-hero .contact-hero-meta{ display:none !important; }
}
