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

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

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

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

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

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

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

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

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

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

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

/* INTRO — three routes (mirrors contact-routes pillar pattern on white bg) */
.vs-intro{padding:clamp(70px,9vw,120px) var(--gutter);background:#fff;border-top:1px solid var(--line-soft);position:relative;overflow:hidden}

.vs-intro::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}

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

.vs-intro .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){.vs-intro .heading{grid-template-columns:1fr;gap:18px;align-items:start}}

.vs-intro .heading-meta{display:flex;flex-direction:column;gap:18px}

.vs-intro .heading .eyebrow{margin:0}

.vs-intro .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}

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

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

/* 3-card grid override (intro has 3 routes, not 4) */
.vs-intro .vs-route-grid{grid-template-columns:repeat(3,1fr);max-width:1180px}

@media (max-width:980px){.vs-intro .vs-route-grid{grid-template-columns:repeat(2,1fr)}}

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

/* GENERIC LARGE SECTION (legacy / gift-aid / corporate) */
.vs-section{padding:clamp(70px,9vw,120px) var(--gutter);position:relative;overflow:hidden;scroll-margin-top:90px}

.vs-section.bg-paper{background:var(--paper)}

.vs-section.bg-white{background:#fff}

.vs-section.bg-paper-2{background:var(--paper-2)}

.vs-section::before{content:"";position:absolute;top:-30px;right:-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.12;pointer-events:none;transform:rotate(14deg);z-index:0}

.vs-section.bg-paper-2::before{background:var(--gold)}

.vs-section .container{max-width:1180px;position:relative;z-index:1}

.vs-section-head{display:grid;grid-template-columns:1.4fr 1fr;gap:clamp(36px,5vw,80px);align-items:end;margin-bottom:clamp(40px,5vw,56px)}

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

.vs-section-head-meta{display:flex;flex-direction:column;gap:18px}

.vs-section-head h2{font-family:var(--slab);font-weight:800;font-size:clamp(40px,5.4vw,68px);line-height:1.02;letter-spacing:-0.025em;margin:0;color:var(--green-d);text-wrap:balance;max-width:16ch}

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

.vs-section-head p.lede{font-size:18px;color:var(--ink-2);max-width:46ch;margin:0;line-height:1.6}

/* TWO-COL BODY GRID */
.vs-body-grid{display:grid;grid-template-columns:1.3fr 1fr;gap:clamp(36px,5vw,72px);align-items:start;max-width:1180px}

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

.vs-body{font-size:17px;line-height:1.7;color:var(--ink)}

.vs-body p{margin:0 0 16px}

.vs-body p strong{color:var(--green-d);font-weight:700}

.vs-body h3{font-family:var(--slab);font-weight:800;font-size:clamp(22px,2.2vw,28px);line-height:1.2;letter-spacing:-0.015em;color:var(--green-d);margin:32px 0 14px}

.vs-body h3:first-child{margin-top:0}

/* DEFINED LIST */
.vs-defs{display:grid;gap:14px;margin:18px 0 22px;padding:0;list-style:none}

.vs-defs li{padding:16px 20px;background:var(--paper-2);border-radius:var(--r-md);line-height:1.55;border:1px solid transparent}

.vs-section.bg-paper-2 .vs-defs li{background:var(--paper);border-color:rgba(176,122,20,0.14)}

.vs-defs li .k{display:inline-block;font:700 11px/1 var(--sans);letter-spacing:0.16em;text-transform:uppercase;color:var(--muted);margin-right:14px;vertical-align:middle;padding-top:1px}

.vs-defs li .v{display:inline-block;font-family:var(--slab);font-weight:700;font-size:16px;color:var(--green-d);vertical-align:middle}

.vs-defs li .desc{display:block;font-size:14px;color:var(--ink-2);line-height:1.6;margin:8px 0 0}

/* NUMBERED STEPS */
.vs-steps{display:grid;gap:16px;margin:18px 0 24px;counter-reset:step;padding:0;list-style:none}

.vs-steps li{display:grid;grid-template-columns:48px 1fr;gap:18px;align-items:start}

.vs-steps li::before{counter-increment:step;content:counter(step,decimal-leading-zero);font-family:var(--slab);font-weight:800;font-size:18px;letter-spacing:-0.01em;color:var(--gold-d);width:48px;height:48px;background:var(--paper-2);border-radius:999px;display:inline-flex;align-items:center;justify-content:center;border:1.5px solid var(--gold)}

.vs-section.bg-paper-2 .vs-steps li::before{background:var(--paper)}

.vs-steps li .step-body{padding-top:8px;font-size:15px;line-height:1.6;color:var(--ink-2)}

.vs-steps li .step-body strong{display:block;font-family:var(--slab);font-weight:800;font-size:16px;color:var(--green-d);margin-bottom:4px}

/* SIDEBAR ASIDE CARD */
.vs-aside{display:flex;flex-direction:column;gap:18px;position:sticky;top:24px}

@media (max-width:880px){.vs-aside{position:static}}

.vs-aside-card{background:#fff;border:1px solid var(--line-soft);border-radius:var(--r-lg);padding:clamp(24px,2.6vw,32px);box-shadow:var(--shadow);position:relative;overflow:hidden}

.vs-section.bg-paper-2 .vs-aside-card{background:var(--paper);border-color:rgba(176,122,20,0.18)}

.vs-section.bg-paper-2 .vs-aside-card .partner{background:var(--paper-2);border:1px solid rgba(31,43,29,0.12);position:relative;padding-right:64px}

.vs-section.bg-paper-2 .vs-aside-card .partner::after{content:"FREE";position:absolute;top:14px;right:14px;padding:5px 10px;background:var(--leaf);color:#fbf6e7;font:700 9px/1.2 var(--sans);letter-spacing:0.16em;border-radius:999px;transition:all .2s ease}

.vs-section.bg-paper-2 .vs-aside-card .partner:hover{background:#fff;border-color:var(--gold)}

.vs-section.bg-paper-2 .vs-aside-card .partner:hover::after{background:var(--green-d)}

/* GIFT AID aside cards — dark forest gradient with light text */
.vs-section.bg-white .vs-aside-card{background:linear-gradient(160deg,var(--green-d) 0%,var(--green) 100%);border:1px solid rgba(255,255,255,0.08);color:#fbf6e7;box-shadow:0 8px 28px rgba(31,43,29,0.22)}

.vs-section.bg-white .vs-aside-card .label{color:var(--gold-l)}

.vs-section.bg-white .vs-aside-card h4{color:#fff}

.vs-section.bg-white .vs-aside-card p{color:rgba(251,246,231,0.86)}

.vs-section.bg-white .vs-aside-card a:not(.btn):not(.partner){color:var(--gold-l);border-bottom:1.5px solid rgba(244,211,94,0.45);transition:border-color .2s ease}

.vs-section.bg-white .vs-aside-card a:not(.btn):not(.partner):hover{border-color:var(--gold-l)}

.vs-section.bg-white .vs-aside-card .partner{background:rgba(251,246,231,0.08);border:1px solid rgba(251,246,231,0.16);color:#fbf6e7}

.vs-section.bg-white .vs-aside-card .partner:hover{background:rgba(251,246,231,0.14);border-color:var(--gold);transform:translateY(-1px);box-shadow:0 4px 14px rgba(0,0,0,0.18)}

.vs-section.bg-white .vs-aside-card .partner strong{color:#fbf6e7}

.vs-section.bg-white .vs-aside-card .partner span{color:rgba(251,246,231,0.78)}

.vs-section.bg-white .vs-aside-card input{background:rgba(251,246,231,0.92) !important;color:var(--ink) !important;border-color:rgba(251,246,231,0.30) !important}

.vs-section.bg-white .vs-aside-card input:focus{background:#fff !important;border-color:var(--gold) !important}

.vs-section.bg-white .vs-aside-card label{color:rgba(251,246,231,0.85) !important}

.vs-section.bg-white .vs-aside-card .btn-primary{background:var(--gold);color:var(--green-d);box-shadow:0 4px 14px rgba(232,176,74,0.36)}

.vs-section.bg-white .vs-aside-card .btn-primary:hover{background:var(--gold-l);transform:translateY(-1px)}

.vs-aside-card .label{font:700 11px/1 var(--sans);letter-spacing:0.20em;text-transform:uppercase;color:var(--muted);margin-bottom:10px;display:block}

.vs-aside-card h4{font-family:var(--slab);font-weight:800;font-size:clamp(20px,2vw,24px);line-height:1.2;color:var(--green-d);margin:0 0 14px;letter-spacing:-0.01em}

.vs-aside-card p{font-size:14px;color:var(--ink-2);line-height:1.6;margin:0 0 14px}

.vs-aside-card p:last-of-type{margin-bottom:18px}

.vs-aside-card .partner-row{display:flex;flex-direction:column;gap:10px}

.vs-aside-card .partner{padding:14px 16px;background:var(--paper);border-radius:var(--r-sm);border:1px solid var(--line-soft);transition:all .2s ease;display:block;text-decoration:none;color:inherit}

.vs-aside-card .partner:hover{border-color:var(--gold);background:#fff;transform:translateY(-1px);box-shadow:0 4px 14px rgba(232,176,74,0.18)}

.vs-aside-card .partner strong{font-family:var(--slab);font-weight:800;font-size:15px;color:var(--green-d);display:block;margin-bottom:3px}

.vs-aside-card .partner span{font-size:13px;color:var(--ink-2);line-height:1.5}

.vs-aside-card .btn,.vs-cta-row .btn{font-size:12px;padding:14px 22px}

/* CALLOUT */
.vs-callout{margin-top:14px;padding:18px 22px;background:rgba(31,43,29,0.05);border-radius:var(--r-md);font-size:14px;color:var(--ink-2);line-height:1.6}

.vs-callout strong{font-family:var(--slab);font-weight:700;color:var(--green-d);font-size:14px;display:block;margin-bottom:4px}

/* OPTION CARDS — "Three ways to leave a gift" pattern, mirrors .vs-route accent rotation */
.vs-option-grid{display:grid;grid-template-columns:1fr;gap:14px;margin:18px 0 24px}

.vs-option{padding:24px 26px;background:var(--paper);border-radius:var(--r-md);border:1px solid rgba(176,122,20,0.18);transition:all .25s ease;display:grid;grid-template-columns:auto 1fr;gap:22px;align-items:start}

@media (max-width:600px){.vs-option{grid-template-columns:1fr;gap:14px}}

.vs-section.bg-paper-2 .vs-option{background:var(--paper);border-color:rgba(176,122,20,0.18)}

.vs-section.bg-white .vs-option{background:var(--paper-2);border-color:rgba(176,122,20,0.18)}

.vs-option:hover{border-color:var(--gold)}

.vs-option .icon{width:54px;height:54px;border-radius:50%;background:var(--paper-2);border:1.5px solid var(--gold);display:inline-flex;align-items:center;justify-content:center;color:var(--gold-d);align-self:start;flex-shrink:0;transition:all .25s ease}

.vs-section.bg-paper-2 .vs-option .icon{background:var(--paper-2)}

.vs-section.bg-white .vs-option .icon{background:#fff}

.vs-option-body{display:flex;flex-direction:column;min-width:0}

.vs-option .label{font:700 11px/1 var(--sans);letter-spacing:0.20em;text-transform:uppercase;color:var(--muted);display:block;margin-bottom:10px}

.vs-option h4{font-family:var(--slab);font-weight:800;font-size:clamp(20px,2.2vw,26px);line-height:1.15;letter-spacing:-0.02em;color:var(--green-d);margin:0 0 10px}

.vs-option p{font-size:15px;color:var(--ink-2);line-height:1.6;margin:0;max-width:60ch}

/* Per-card accent rotation — matches .vs-route + homepage Pillars system */
.vs-option-grid > .vs-option:nth-child(1) .icon,
.vs-option-grid > .vs-option:nth-child(1) h4{color:var(--red)}

.vs-option-grid > .vs-option:nth-child(2) .icon,
.vs-option-grid > .vs-option:nth-child(2) h4{color:var(--gold-d)}

.vs-option-grid > .vs-option:nth-child(3) .icon,
.vs-option-grid > .vs-option:nth-child(3) h4{color:var(--blue-d)}

/* CORPORATE 4-card route grid */
.vs-routes-inner{display:grid;grid-template-columns:repeat(2,1fr);gap:18px;margin:24px 0 28px}

@media (max-width:680px){.vs-routes-inner{grid-template-columns:1fr}}

.vs-route-inner{padding:24px 26px;background:var(--paper);border-radius:var(--r-md);border:1px solid rgba(176,122,20,0.18);transition:all .25s ease;display:flex;flex-direction:column}

.vs-section.bg-white .vs-route-inner{background:var(--paper-2);border-color:rgba(176,122,20,0.18)}

.vs-section.bg-paper-2 .vs-route-inner{background:var(--paper);border-color:rgba(176,122,20,0.18)}

.vs-route-inner:hover{border-color:var(--gold)}

.vs-route-inner .icon{width:48px;height:48px;border-radius:50%;background:var(--paper-2);border:1.5px solid var(--gold);display:inline-flex;align-items:center;justify-content:center;color:var(--gold-d);align-self:flex-start;margin-bottom:16px;transition:all .25s ease}

.vs-section.bg-white .vs-route-inner .icon{background:#fff}

.vs-section.bg-paper-2 .vs-route-inner .icon{background:var(--paper-2)}

.vs-route-inner .label{font:700 11px/1 var(--sans);letter-spacing:0.18em;text-transform:uppercase;color:var(--gold-d);margin-bottom:8px;display:block}

.vs-route-inner h4{font-family:var(--slab);font-weight:800;font-size:18px;line-height:1.2;color:var(--green-d);margin:0 0 8px}

.vs-route-inner p{font-size:14px;color:var(--ink-2);line-height:1.55;margin:0}

.vs-route-inner p strong{color:var(--green-d);font-weight:700}

/* Per-card accent rotation — matches .vs-option + homepage Pillars */
.vs-routes-inner > .vs-route-inner:nth-child(1) .icon,
.vs-routes-inner > .vs-route-inner:nth-child(1) h4{color:var(--red)}

.vs-routes-inner > .vs-route-inner:nth-child(2) .icon,
.vs-routes-inner > .vs-route-inner:nth-child(2) h4{color:var(--gold-d)}

.vs-routes-inner > .vs-route-inner:nth-child(3) .icon,
.vs-routes-inner > .vs-route-inner:nth-child(3) h4{color:var(--blue-d)}

.vs-routes-inner > .vs-route-inner:nth-child(4) .icon,
.vs-routes-inner > .vs-route-inner:nth-child(4) h4{color:var(--green)}

/* CTA ROW */
.vs-cta-row{display:flex;align-items:center;gap:16px;flex-wrap:wrap;margin-top:8px}

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

/* QUICK ROUTES — pillar-style grid (matches homepage .pillar pattern) */
.vs-routes{padding:clamp(70px,9vw,120px) var(--gutter);background:#fff;border-top:1px solid var(--line-soft);position:relative;overflow:hidden}

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

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

.vs-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){.vs-routes .heading{grid-template-columns:1fr;gap:18px;align-items:start}}

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

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

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

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

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

.vs-route-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;max-width:1180px;margin:0 auto}

@media (max-width:980px){.vs-route-grid{grid-template-columns:repeat(2,1fr)}}

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

.vs-route{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}

.vs-route:hover{transform:translateY(-3px);box-shadow:var(--shadow);border-color:var(--gold)}

.vs-route .icon{margin-bottom:18px;display:inline-flex;width:62px;height:62px;align-items:center;justify-content:center;border:1.5px solid var(--gold);border-radius:50%;background:var(--paper-2);color:var(--green);align-self:flex-start;transition:all .25s ease}

.vs-route:hover .icon{background:var(--gold);border-color:var(--gold);color:var(--green-d)}

/* Per-child accent rotation — matches homepage Pillars system 4-colour sequence */
.vs-route-grid > .vs-route:nth-child(1) .icon,
.vs-route-grid > .vs-route:nth-child(1) h3{color:var(--red)}

.vs-route-grid > .vs-route:nth-child(2) .icon,
.vs-route-grid > .vs-route:nth-child(2) h3{color:var(--gold-d)}

.vs-route-grid > .vs-route:nth-child(3) .icon,
.vs-route-grid > .vs-route:nth-child(3) h3{color:var(--blue-d)}

.vs-route-grid > .vs-route:nth-child(4) .icon,
.vs-route-grid > .vs-route:nth-child(4) h3{color:var(--green)}

.vs-route-grid > .vs-route:nth-child(1):hover .icon,
.vs-route-grid > .vs-route:nth-child(2):hover .icon,
.vs-route-grid > .vs-route:nth-child(3):hover .icon,
.vs-route-grid > .vs-route:nth-child(4):hover .icon{color:var(--green-d)}

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

.vs-route 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}

.vs-route p{font-size:15px;color:var(--ink-2);margin:0 0 18px;line-height:1.6;flex:1}

.vs-route .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}

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

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

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

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

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

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

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

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

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

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

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

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

.vs-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){.vs-newsletter form{grid-template-columns:1fr;border-radius:var(--r-lg)}}

.vs-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){.vs-newsletter input{background:var(--paper);border-radius:var(--r-md)}}

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

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

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

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

.vs-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}.vs-hero-bg img{animation:none !important}html{scroll-behavior:auto}}

/* ============================================
   "5 WAYS TO COME AND HELP" — numbered horizontal cards
   (added 2026-05-29, mirrors legacy promise-card pattern)
   ============================================ */

/* When a card has a .num-circle inside, hide the legacy SVG icon
   and the inline label + CTA; restyle as a soft cream pill card. */
.vs-option:has(.num-circle){
  background:var(--paper-3);
  border:1px solid transparent;
  border-radius:18px;
  padding:22px 28px;
  gap:20px;
  align-items:center;
  transition:background .25s ease, border-color .25s ease, box-shadow .25s ease, transform .25s ease;
}
.vs-section.bg-paper-2 .vs-option:has(.num-circle){background:var(--paper-3)}
.vs-option:has(.num-circle):hover{
  background:var(--paper);
  border-color:var(--gold);
  box-shadow:0 8px 22px rgba(0,0,0,.10);
  transform:translateY(-1px);
}
.vs-option:has(.num-circle) > .icon{display:none}
.vs-option:has(.num-circle) .label{display:none}
.vs-option:has(.num-circle) .arrow-link{display:none}

.vs-option .num-circle{
  flex-shrink:0;
  display:inline-flex; align-items:center; justify-content:center;
  width:46px; height:46px; border-radius:50%;
  background:var(--green-d); color:var(--gold-l);
  font-family:'Fraunces',Georgia,serif; font-style:italic; font-weight:500;
  font-size:18px; letter-spacing:-.02em;
}
.vs-option:has(.num-circle) h4{
  font-family:var(--slab); font-weight:800;
  font-size:18px; line-height:1.2; letter-spacing:-.01em;
  color:var(--green-d); margin:0 0 4px;
}
.vs-option:has(.num-circle) p{
  font-family:'Lora',Georgia,serif; font-style:italic;
  font-size:14px; line-height:1.55;
  color:var(--ink-2); margin:0;
}

/* Stacked heading + intro (left-aligned, no 2-col split) */
.vs-section.full-body .vs-section-head{
  grid-template-columns:1fr; text-align:left; max-width:880px; gap:24px;
}
.vs-section.full-body .vs-section-head h2{ max-width:none }
.vs-section.full-body .vs-section-head p,
.vs-section.full-body .vs-section-head p.lede{ max-width:62ch; margin:0 }

/* Forest-green section variant */
.vs-section.bg-forest{ background:var(--green-d); color:var(--paper-w) }
.vs-section.bg-forest::before{ background:var(--gold); opacity:0.10 }
.vs-section.bg-forest .vs-section-head h2{ color:var(--paper-w); max-width:14ch }
.vs-section.bg-forest .vs-section-head h2 span{
  color:var(--gold-l);
  font-family:'Fraunces',Georgia,serif; font-style:italic; font-weight:500;
}
.vs-section.bg-forest .vs-section-head p,
.vs-section.bg-forest .vs-section-head p.lede{ color:rgba(251,246,231,0.86) }
/* Shorter padding-bottom on the forest heading section so it sits closer
   to the cards section that follows */
.vs-section.bg-forest.full-body{ padding-bottom:clamp(40px,5vw,64px) }

/* Deepest-cream section variant — cards become paper-w for contrast */
.vs-section.bg-paper-3{ background:var(--paper-3) }
.vs-section.bg-paper-3::before{ background:var(--green-l); opacity:0.10 }
.vs-section.bg-paper-3 .vs-option:has(.num-circle){ background:var(--paper-w) }
.vs-section.bg-paper-3 .vs-option:has(.num-circle):hover{ background:#fff }
/* Less top padding when cards section follows a heading-only section */
.vs-section.bg-paper-3{ padding-top:clamp(40px,5vw,64px) }

/* Cards on the forest-green section — paper-w cards pop against green */
.vs-section.bg-forest .vs-option:has(.num-circle){ background:var(--paper-w); border-color:transparent }
.vs-section.bg-forest .vs-option:has(.num-circle):hover{ background:#fff; border-color:var(--gold) }

/* Lightest-cream section variant (paper-w) — used for "What to expect" */
.vs-section.bg-paper-w{ background:var(--paper-w) }
.vs-section.bg-paper-w::before{ background:var(--green-l); opacity:0.12 }


/* === PA hero mobile restructure (auto, 2026-05-31) === prefix:vs */
@media (max-width:980px){
  .vs-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;
  }
  .vs-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;
  }
  .vs-hero-bg img{
    position:absolute !important; inset:0 !important;
    width:100%; height:100% !important; object-fit:cover; object-position:center 30%;
  }
  .vs-hero > .container,
  .vs-hero > .vs-hero-content,
  .vs-hero .vs-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;
  }
  .vs-hero-eyebrow, .vs-hero .eyebrow{ display:none !important; }
  .vs-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;
  }
  .vs-hero h1 .accent, .vs-hero h1 span{ color:var(--gold-l); }
  .vs-hero .lede, .vs-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;
  }
  .vs-hero .lede strong{ color:var(--ink); }
  .vs-hero .hero-actions, .vs-hero .actions, .vs-hero .vs-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%;
  }
  .vs-hero .btn-light{ background:transparent; border:1.5px solid var(--green-d); color:var(--green-d); }
  .vs-hero .btn-light:hover{ background:var(--green-d); color:var(--paper-w); }
  .vs-hero .hero-meta, .vs-hero .meta, .vs-hero .vs-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;
  }
  .vs-hero .who{ color:var(--gold-l); font-weight:600; }
}

/* === PA hero mobile contrast/meta fix (auto, 2026-05-31b) === prefix:vs */
@media (max-width:980px){
  .vs-hero .lede, .vs-hero p.lede,
  .vs-hero p.sub, .vs-hero .sub,
  .vs-hero blockquote, .vs-hero .quote{ color:#4a4a3d !important; }
  .vs-hero .lede strong, .vs-hero p.lede strong{ color:var(--ink) !important; }
  .vs-hero .attrib, .vs-hero .attribution,
  .vs-hero .credit, .vs-hero .source{ color:var(--gold-d) !important; }
  .vs-hero .hero-meta, .vs-hero .meta, .vs-hero .vs-hero-meta{ display:none !important; }
}
