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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

/* Stacked variant — intro paragraph sits BELOW the heading (single column) */
.vu-section-head--stacked{grid-template-columns:1fr;gap:18px;align-items:start}

.vu-section-head--stacked p.lede{max-width:60ch}

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

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

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

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

/* ============================================
   HONEST, TWO-WAY COMMITMENT — sponsor-style
   centered heading + row of 4 numbered cream cards
   (mirrors sponsor.css .sponsor-promises / .promise)
   ============================================ */
.vu-ask-head{text-align:center;max-width:46ch;margin:0 auto clamp(40px,5vw,56px)}

.vu-ask-head .eyebrow{display:inline-flex;margin:0 0 16px}

.vu-ask-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 0 16px;color:var(--green-d);text-wrap:balance}

.vu-ask-head h2 .vu-heading-accent{display:block;color:var(--green-l);font-weight:700;font-style:italic}

.vu-ask-head p.lede{font-size:18px;color:var(--ink-2);margin:0 auto;line-height:1.6;max-width:48ch}

.vu-ask-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(18px,2vw,28px)}

@media (max-width:920px){.vu-ask-grid{grid-template-columns:repeat(2,1fr)}}

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

.vu-ask-card{background:var(--paper-3,var(--paper));border-radius:28px;padding:28px 26px 26px;border:1px solid transparent;transition:transform .25s ease, box-shadow .25s ease, background .25s ease, border-color .25s ease}

.vu-section.bg-paper-2 .vu-ask-card{background:var(--paper)}

.vu-ask-card:hover{transform:translateY(-3px);box-shadow:0 14px 28px rgba(0,0,0,0.14);border-color:var(--gold)}

.vu-ask-card .num{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:20px;letter-spacing:-.02em;margin-bottom:18px}

.vu-ask-card h3{font-family:var(--slab);font-weight:800;font-size:19px;line-height:1.18;margin:0 0 8px;color:var(--green-d)}

.vu-ask-card p{font-family:'Lora',Georgia,serif;font-style:italic;font-size:14px;line-height:1.55;color:var(--ink-2);margin:0}

/* "What we'll always do" — full-width panel below the 4 cards.
   Spans the whole container (site wide). The four promises flow in
   two columns at wide widths so the panel doesn't read sparse. */
.vu-ask-return{margin-top:clamp(28px,3vw,40px)}

.vu-ask-return .vu-aside-card{position:relative;padding:clamp(28px,3vw,44px)}

.vu-ask-return .vu-aside-card p{font-size:15px}

@media (min-width:760px){
  .vu-ask-return .vu-aside-card .vu-return-points{column-count:2;column-gap:clamp(36px,5vw,72px)}
  .vu-ask-return .vu-aside-card .vu-return-points p{break-inside:avoid;margin-bottom:16px}
}

/* TWO-COL BODY GRID */
.vu-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){.vu-body-grid{grid-template-columns:1fr;gap:36px}}

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

.vu-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 */
.vu-aside{display:flex;flex-direction:column;gap:18px;position:sticky;top:24px}

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

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

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

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

.vu-section.bg-paper-2 .vu-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}

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

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

/* GIFT AID aside cards — dark forest gradient with light text */
.vu-section.bg-white .vu-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)}

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

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

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

.vu-section.bg-white .vu-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}

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

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

.vu-section.bg-white .vu-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)}

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

/* CALLOUT */
.vu-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}

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

/* ============================================
   ROLE CARDS — home-style "help-card" photo cards in a
   non-uniform grid. Photo + forest-green band + gold Fraunces
   italic title + light description + gold round arrow.
   Adapted from get-involved.css / index.css.
   ============================================ */
.vu-help-grid{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:clamp(290px,28vw,380px);gap:18px;margin:0}

/* Feature card (Foster a dog) spans two columns */
.vu-help-grid > .vu-role-card.is-feature{grid-column:span 2}

@media (max-width:1024px){
  .vu-help-grid{grid-template-columns:repeat(2,1fr)}
  .vu-help-grid > .vu-role-card.is-feature{grid-column:span 2}
}

@media (max-width:540px){
  .vu-help-grid{grid-template-columns:1fr;grid-auto-rows:clamp(220px,62vw,300px)}
  .vu-help-grid > .vu-role-card.is-feature{grid-column:span 1}
}

.vu-role-card{position:relative;display:block;padding:0;border:0;border-radius:14px;overflow:hidden;text-decoration:none;color:inherit;isolation:isolate;background:transparent;aspect-ratio:auto;height:100%;min-height:0;box-shadow:0 6px 22px rgba(40,40,30,.14);transition:transform .25s ease, box-shadow .25s ease}

.vu-role-card:hover{transform:translateY(-3px);box-shadow:0 18px 38px rgba(40,40,30,.22);border-color:transparent}

/* Static info cards (roles with no destination page) — no pointer, no hover lift */
.vu-role-card.is-static{cursor:default}

.vu-role-card.is-static:hover{transform:none;box-shadow:0 6px 22px rgba(40,40,30,.14)}

.vu-role-card.is-static:hover .img{transform:none}

.vu-role-card .img{position:absolute;inset:0;background-size:cover;background-position:center;transition:transform .55s ease;z-index:0}

.vu-role-card:hover .img{transform:scale(1.04)}

.vu-role-card .band{position:absolute;left:0;right:0;bottom:0;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);z-index:1}

.vu-role-card h3{font-family:var(--serif-accent);font-weight:600;font-size:26px;line-height:1.08;margin:0 0 8px;padding-right:48px;color:var(--paper-w);letter-spacing:0}

.vu-role-card h3 em{font-style:italic;color:var(--gold-l);font-weight:500}

.vu-role-card p{font-family:var(--serif-body);font-style:italic;font-size:13px;line-height:1.5;margin:0;padding-right:54px;max-width:34ch;color:rgba(251,246,231,.92);display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:3;overflow:hidden}

/* Feature card gets a touch more room for its longer copy */
.vu-role-card.is-feature h3{font-size:30px}
.vu-role-card.is-feature p{-webkit-line-clamp:4;max-width:52ch}

.vu-role-card .arrow-link{position:absolute;right:18px;bottom:18px;width:36px;height:36px;border-radius:50%;background:var(--yellow);color:var(--green-d);display:inline-flex;align-items:center;justify-content:center;padding:0;font-size:0;gap:0;margin-top:0;box-shadow:0 4px 12px rgba(30,58,42,.30);transition:background .2s ease, transform .25s ease;z-index:2}

.vu-role-card .arrow-link::after{content:"\203A";font-size:18px;font-weight:700}

.vu-role-card:hover .arrow-link{background:var(--gold);transform:translateX(3px);color:var(--green-d)}

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

.vu-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) */
.vu-routes{padding:clamp(70px,9vw,120px) var(--gutter);background:#fff;border-top:1px solid var(--line-soft);position:relative;overflow:hidden}

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

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

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

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

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

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

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

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

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

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

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

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

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

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

.vu-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 */
.vu-route-grid > .vu-route:nth-child(1) .icon,
.vu-route-grid > .vu-route:nth-child(1) h3{color:var(--red)}

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

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

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

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

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

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

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

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

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

/* NEWSLETTER — uses the standard site-wide .newsletter component
   (gold panel + cream pill form + green button) defined in global.css,
   identical to the other pages. No page-specific overrides needed. */

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

/* ============================================
   MOBILE RESPONSIVENESS — tap targets & readability
   Applied conservatively for narrow viewports only.
   ============================================ */
@media (max-width:640px){
  /* Role-card arrow CTA: bump to 44x44 minimum tap target */
  .vu-role-card .arrow-link{width:44px;height:44px;right:14px;bottom:14px}
  .vu-role-card .arrow-link::after{font-size:20px}

  /* Partner cards inside aside — ensure comfortable tap target */
  .vu-aside-card .partner{padding:16px 18px;min-height:44px}

  /* Aside CTA buttons — keep readable size on mobile */
  .vu-aside-card .btn,.vu-cta-row .btn{font-size:14px;padding:14px 22px;min-height:44px}

  /* CTA-row small print — readability minimum */
  .vu-cta-row small{font-size:13px}

  /* Numbered step body & defs descriptions — keep at 14px+ */
  .vu-steps li .step-body{font-size:15px}
  .vu-defs li .desc{font-size:14px}

  /* Ensure role card band copy remains legible */
  .vu-role-card p{font-size:14px}
}


/* === PA hero mobile restructure (auto, 2026-05-31) === prefix:vu */
@media (max-width:980px){
  .vu-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;
  }
  .vu-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;
  }
  .vu-hero-bg img{
    position:absolute !important; inset:0 !important;
    width:100%; height:100% !important;
    object-fit:cover; object-position:center 30%;
  }
  .vu-hero > .container,
  .vu-hero > .vu-hero-content,
  .vu-hero .vu-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;
  }
  .vu-hero-eyebrow,
  .vu-hero .eyebrow{ display:none !important; }
  .vu-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;
  }
  .vu-hero h1 .accent,
  .vu-hero h1 span{ color:var(--gold-l); }
  .vu-hero .lede,
  .vu-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;
  }
  .vu-hero .lede strong{ color:var(--ink); }
  .vu-hero .hero-actions,
  .vu-hero .actions,
  .vu-hero .vu-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%;
  }
  .vu-hero .btn-light{
    background:transparent;
    border:1.5px solid var(--green-d); color:var(--green-d);
  }
  .vu-hero .btn-light:hover{ background:var(--green-d); color:var(--paper-w); }
  .vu-hero .hero-meta,
  .vu-hero .meta,
  .vu-hero .vu-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;
  }
  .vu-hero .who{ color:var(--gold-l); font-weight:600; }
}


/* === PA hero mobile contrast/meta fix (auto, 2026-05-31b) === prefix:vu */
@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). */
  .vu-hero .lede, .vu-hero p.lede,
  .vu-hero p.sub, .vu-hero .sub,
  .vu-hero blockquote, .vu-hero .quote{ color:#4a4a3d !important; }
  .vu-hero .lede strong, .vu-hero p.lede strong{ color:var(--ink) !important; }
  /* Attribution / credit lines readable on cream */
  .vu-hero .attrib, .vu-hero .attribution,
  .vu-hero .credit, .vu-hero .source{ color:var(--gold-d) !important; }
  /* Hide the decorative caption pill on mobile (overflows on longer metas). */
  .vu-hero .hero-meta, .vu-hero .meta, .vu-hero .vu-hero-meta{ display:none !important; }
}
