/* ================================================================
   VIBRANT HEALTH ADVOCATES — ASCENT  |  style.css
   Warm & Human Community archetype
================================================================ */

/* --- Reset & base ------------------------------------------ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

:root{
  --cream:       #FAF6EF;
  --cream-dark:  #F2E8D9;
  --cream-bd:    #E8D5B0;
  --sand:        #E8D5B0;
  --terra:       #C4622D;
  --terra-lt:    #E8825A;
  --terra-pale:  #F7E4D8;
  --brand:       #7B2D8B;
  --brand-lt:    #F0D9F5;
  --brand-dk:    #5A1E68;
  --ink:         #2C1810;
  --ink-mid:     #6B4C35;
  --ink-soft:    #9B7A5E;
  --white:       #FFFFFF;
  --r-sm:12px; --r-md:24px; --r-lg:40px; --r-xl:60px;
  --font: ui-rounded, system-ui, -apple-system, 'Segoe UI', sans-serif;
}

html{scroll-behavior:smooth}
body{font-family:var(--font);background:var(--cream);color:var(--ink);line-height:1.78;font-size:1.0625rem}
img{max-width:100%;display:block}
a{color:var(--brand);text-decoration:none}
a:hover{text-decoration:underline}
h1,h2,h3,h4{font-weight:900;line-height:1.18;letter-spacing:-0.022em}
h1{font-size:clamp(2.2rem,5.2vw,3.8rem)}
h2{font-size:clamp(1.75rem,3.5vw,2.65rem)}
h3{font-size:clamp(1.15rem,2vw,1.45rem)}
p{line-height:1.8}

/* --- Layout ------------------------------------------------ */
.container{max-width:1160px;margin-inline:auto;padding-inline:28px}
.section{padding-block:80px}
.section--cream{background:var(--cream)}
.section--sand{background:#F5ECD9}
.section--terra-pale{background:var(--terra-pale)}
.section--brand-lt{background:var(--brand-lt)}

/* --- Navigation -------------------------------------------- */
.site-nav{
  position:sticky;top:0;z-index:200;
  background:var(--cream);
  border-bottom:2px dotted var(--cream-bd);
  padding:12px 28px;
}
.site-nav__inner{
  max-width:1160px;margin-inline:auto;
  display:flex;align-items:center;justify-content:space-between;gap:20px;
}
.site-nav__brand{
  display:flex;align-items:center;gap:10px;
  text-decoration:none;flex-shrink:0;
}
.site-nav__brand .logo-icon{height:42px;width:auto}
.site-nav__brand .wordmark{height:26px;width:auto}
.site-nav__links{
  display:flex;align-items:center;gap:2px;
  list-style:none;flex-wrap:wrap;
}
.site-nav__links a{
  color:var(--ink-mid);font-weight:700;font-size:0.92rem;
  padding:7px 13px;border-radius:999px;
  text-decoration:none;transition:background .2s,color .2s;
}
.site-nav__links a:hover,
.site-nav__links a.active{background:var(--brand-lt);color:var(--brand)}
.site-nav__links a.nav-cta{
  background:var(--terra);color:var(--white) !important;
  margin-left:6px;
}
.site-nav__links a.nav-cta:hover{background:var(--terra-lt)}
.nav-toggle{
  display:none;background:none;
  border:2px solid var(--cream-bd);border-radius:10px;
  padding:6px 11px;cursor:pointer;font-size:1.25rem;color:var(--ink-mid);
}

/* --- Hero -------------------------------------------------- */
.hero{
  position:relative;min-height:700px;
  display:flex;flex-direction:column;
  padding-bottom:160px;overflow:hidden;
}
.hero__img{
  position:absolute;inset:0;width:100%;height:100%;
  object-fit:cover;object-position:center 30%;z-index:0;
}
.hero__overlay{
  position:absolute;inset:0;z-index:1;
  background:linear-gradient(135deg,rgba(44,24,16,.72) 0%,rgba(44,24,16,.35) 55%,rgba(44,24,16,.1) 100%);
}
.hero__text{
  position:relative;z-index:2;
  padding:88px 28px 0;max-width:780px;margin-inline:auto;
  width:100%;
}
.hero__tag{
  display:inline-block;
  background:var(--brand);color:var(--white);
  font-size:.75rem;font-weight:900;letter-spacing:.14em;text-transform:uppercase;
  padding:5px 16px;border-radius:999px;margin-bottom:22px;
}
.hero__title{color:var(--white);margin-bottom:20px}
.hero__sub{
  color:rgba(255,255,255,.88);font-size:1.1rem;
  line-height:1.7;max-width:620px;
}

/* --- Hero overlap card ------------------------------------- */
.hero-overlap{
  position:relative;z-index:20;
  margin-top:-110px;
  padding-inline:28px;
}
.hero-overlap__card{
  background:var(--cream);border-radius:var(--r-lg);
  padding:44px 52px;
  box-shadow:0 28px 72px rgba(44,24,16,.18);
  max-width:860px;margin-inline:auto;
  border:3px solid var(--cream-bd);
  position:relative;
}
.hero-overlap__card::before{
  content:'';position:absolute;top:-3px;left:60px;right:60px;height:3px;
  background:repeating-linear-gradient(90deg,var(--terra) 0 10px,transparent 10px 18px);
}
.hero-overlap__card p{
  font-size:1.08rem;line-height:1.85;color:var(--ink-mid);margin-bottom:0;
}
.hero-overlap__read{
  display:inline-flex;align-items:center;gap:6px;
  color:var(--terra);font-weight:800;font-size:.95rem;
  margin-top:22px;text-decoration:none;
}
.hero-overlap__read::after{content:'→'}
.hero-overlap__read:hover{color:var(--brand);text-decoration:none}

/* --- Squiggle divider -------------------------------------- */
.squiggle-divider{
  display:block;width:100%;overflow:hidden;line-height:0;
  margin-block:-1px;padding:12px 0;
  text-align:center;
}
.squiggle-divider svg{display:block;width:100%;height:auto}

/* --- Section labels & titles ------------------------------- */
.sec-label{
  display:inline-block;color:var(--terra);
  font-size:.76rem;font-weight:900;letter-spacing:.14em;text-transform:uppercase;
  margin-bottom:12px;
}
.sec-title{margin-bottom:20px}
.sec-title--center{text-align:center}
.sec-intro{
  color:var(--ink-mid);font-size:1.05rem;line-height:1.8;
  max-width:700px;margin-bottom:0;
}
.sec-intro--center{margin-inline:auto;text-align:center}

/* --- Highlights / feature cards ---------------------------- */
.highlights-grid{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:28px;padding-top:16px;
}
.highlight-card{
  background:var(--white);border-radius:var(--r-md);
  padding:36px 30px;
  border:2px dotted var(--cream-bd);
  box-shadow:6px 6px 0 var(--sand);
  transition:transform .2s;
}
.highlight-card:hover{transform:translateY(-4px)}
.highlight-card:nth-child(2){margin-top:44px}
.highlight-card:nth-child(3){margin-top:22px}
.highlight-card__icon{font-size:2.2rem;margin-bottom:16px;display:block}
.highlight-card__title{
  font-size:1.1rem;font-weight:900;color:var(--ink);margin-bottom:12px;
}
.highlight-card__blurb{color:var(--ink-mid);font-size:.94rem;line-height:1.72}

/* --- Impact strip ------------------------------------------ */
.impact-strip{
  background:var(--terra);padding:64px 28px;overflow:hidden;
  position:relative;
}
.impact-strip::before{
  content:'';position:absolute;inset:0;
  background:radial-gradient(circle at 15% 50%,rgba(255,255,255,.07) 0%,transparent 60%);
}
.impact-inner{
  max-width:900px;margin-inline:auto;
  display:flex;justify-content:center;align-items:center;
  gap:64px;flex-wrap:wrap;position:relative;z-index:1;
}
.impact-stat{
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  width:160px;height:160px;position:relative;text-align:center;
}
.impact-stat::before{
  content:'';position:absolute;inset:0;
  border:3px dotted rgba(255,255,255,.35);border-radius:50%;
}
.impact-stat__num{
  font-size:clamp(2.2rem,4.5vw,3.6rem);font-weight:900;
  color:var(--white);line-height:1;display:block;
}
.impact-stat__lbl{
  color:rgba(255,255,255,.82);font-size:.82rem;font-weight:800;
  letter-spacing:.07em;text-transform:uppercase;margin-top:8px;display:block;
}

/* --- Stamp badge ------------------------------------------- */
.stamp{
  display:inline-flex;flex-direction:column;align-items:center;
  justify-content:center;width:148px;height:148px;border-radius:50%;
  border:4px dashed var(--brand);background:var(--brand-lt);
  text-align:center;padding:18px;transform:rotate(-7deg);flex-shrink:0;
}
.stamp__text{
  font-size:.7rem;font-weight:900;letter-spacing:.09em;
  text-transform:uppercase;color:var(--brand);line-height:1.5;
}

/* --- Polaroid cards ---------------------------------------- */
.polaroid{
  background:var(--white);border-radius:6px;
  padding:10px 10px 44px;
  box-shadow:4px 10px 36px rgba(44,24,16,.18);
  display:inline-block;
}
.polaroid img{
  border-radius:4px;width:100%;
  aspect-ratio:4/3;object-fit:cover;display:block;
}
.polaroid__caption{
  text-align:center;margin-top:8px;
  font-size:.8rem;color:var(--ink-soft);font-style:italic;
}
.pol-tl{transform:rotate(-3.5deg)}
.pol-tr{transform:rotate(2.8deg)}
.pol-ll{transform:rotate(-5.5deg)}
.pol-rr{transform:rotate(4.2deg)}

/* --- Polaroid gallery ------------------------------------- */
.polaroid-gallery{
  display:flex;gap:36px;align-items:flex-start;
  flex-wrap:wrap;justify-content:center;padding-block:20px;
}
.polaroid-gallery .polaroid{max-width:300px;width:100%}

/* --- Page banner (sub-pages) ------------------------------- */
.page-banner{position:relative;height:440px;overflow:hidden}
.page-banner__img{
  width:100%;height:100%;object-fit:cover;object-position:center 40%;
}
.page-banner__overlay{
  position:absolute;inset:0;
  background:linear-gradient(to right,rgba(44,24,16,.68) 0%,rgba(44,24,16,.22) 70%,transparent 100%);
}
.page-banner__content{
  position:absolute;inset:0;display:flex;flex-direction:column;
  justify-content:center;padding:60px 48px;max-width:720px;
}
.page-banner__label{
  display:inline-block;background:var(--terra);color:var(--white);
  font-size:.75rem;font-weight:900;letter-spacing:.14em;text-transform:uppercase;
  padding:5px 16px;border-radius:999px;margin-bottom:16px;width:fit-content;
}
.page-banner__title{color:var(--white);margin-bottom:14px}
.page-banner__sub{color:rgba(255,255,255,.86);font-size:1.08rem;line-height:1.65}

/* --- Programme cards --------------------------------------- */
.programme-grid{
  display:grid;grid-template-columns:repeat(2,1fr);gap:32px;
}
.programme-card{
  background:var(--white);border-radius:var(--r-md);
  overflow:hidden;border:2px solid var(--cream-bd);
  box-shadow:4px 4px 0 var(--sand);
  transition:transform .2s,box-shadow .2s;
}
.programme-card:hover{transform:translateY(-4px);box-shadow:8px 8px 0 var(--sand)}
.programme-card__head{background:var(--terra-pale);padding:28px 32px 20px}
.programme-card__icon{font-size:1.9rem;margin-bottom:10px;display:block}
.programme-card__title{font-size:1.15rem;font-weight:900;color:var(--ink)}
.programme-card__body{padding:24px 32px}
.programme-card__blurb{
  color:var(--ink-mid);font-size:.94rem;line-height:1.72;margin-bottom:16px;
  font-weight:600;
}
.programme-card__detail{color:var(--ink-soft);font-size:.9rem;line-height:1.78}

/* --- Ways / get-involved cards ----------------------------- */
.ways-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.way-card{
  background:var(--white);border-radius:var(--r-md);
  padding:40px 30px;border:2px solid var(--cream-bd);
  box-shadow:4px 4px 0 var(--sand);
  position:relative;overflow:hidden;
}
.way-card::before{
  content:'';position:absolute;top:0;left:0;
  width:100%;height:6px;
}
.way-card:nth-child(1)::before{background:var(--terra)}
.way-card:nth-child(2)::before{background:var(--brand)}
.way-card:nth-child(3)::before{background:var(--terra-lt)}
.way-card__icon{font-size:2.4rem;margin-bottom:16px;display:block}
.way-card__title{font-size:1.1rem;font-weight:900;color:var(--ink);margin-bottom:12px}
.way-card__blurb{color:var(--ink-mid);font-size:.94rem;line-height:1.72}

/* --- Blog cards -------------------------------------------- */
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:32px}
.blog-card{
  background:var(--white);border-radius:var(--r-md);
  overflow:hidden;border:2px solid var(--cream-bd);
  box-shadow:4px 6px 24px rgba(44,24,16,.09);
  display:flex;flex-direction:column;
  transition:transform .2s,box-shadow .2s;
}
.blog-card:hover{transform:translateY(-5px);box-shadow:4px 14px 40px rgba(44,24,16,.14)}
.blog-card__thumb{
  aspect-ratio:16/10;overflow:hidden;background:var(--sand);
}
.blog-card__thumb img{
  width:100%;height:100%;object-fit:cover;
  transition:transform .35s;display:block;
}
.blog-card:hover .blog-card__thumb img{transform:scale(1.05)}
.blog-card__body{padding:28px;flex:1;display:flex;flex-direction:column}
.blog-card__title{
  font-size:1.08rem;font-weight:900;color:var(--ink);
  margin-bottom:10px;line-height:1.35;
}
.blog-card__dek{
  color:var(--ink-mid);font-size:.9rem;line-height:1.65;
  flex:1;margin-bottom:20px;
}
.blog-card__cta{
  display:inline-flex;align-items:center;gap:5px;
  color:var(--terra);font-weight:900;font-size:.88rem;
  text-decoration:none;
}
.blog-card__cta::after{content:'→'}
.blog-card__cta:hover{color:var(--brand);text-decoration:none}

/* --- Article layout ---------------------------------------- */
.article-banner{
  background:var(--cream-dark);
  padding:56px 28px 48px;
}
.article-banner__inner{max-width:840px;margin-inline:auto}
.article-banner__label{
  display:inline-block;background:var(--terra);color:var(--white);
  font-size:.73rem;font-weight:900;letter-spacing:.14em;text-transform:uppercase;
  padding:5px 14px;border-radius:999px;margin-bottom:16px;
}
.article-banner__title{font-size:clamp(1.8rem,3.5vw,2.6rem);margin-bottom:16px;color:var(--ink)}
.article-banner__dek{
  font-size:1.12rem;color:var(--ink-mid);line-height:1.7;
  max-width:640px;
}
.article-img-wrap{max-width:840px;margin:0 auto -28px;padding-inline:28px}
.article-img-wrap img{
  border-radius:var(--r-md);width:100%;
  aspect-ratio:16/7;object-fit:cover;
  box-shadow:0 12px 48px rgba(44,24,16,.14);
}
.article-body{
  max-width:740px;margin-inline:auto;
  padding:56px 28px 80px;
}
.article-body p{margin-bottom:1.5rem;color:var(--ink-mid);line-height:1.88}
.article-body h3{
  font-size:1.25rem;color:var(--terra);
  margin-top:2.4rem;margin-bottom:.9rem;
}
.article-body strong{color:var(--ink);font-weight:800}
.article-body blockquote{
  border-left:4px solid var(--brand);
  background:var(--brand-lt);
  margin:2rem 0;padding:22px 28px;
  border-radius:0 var(--r-sm) var(--r-sm) 0;
  font-style:italic;color:var(--brand-dk);
  font-size:1.02rem;line-height:1.8;
}
.article-body blockquote p{color:var(--brand-dk);margin-bottom:0}

/* --- Mission block ----------------------------------------- */
.mission-block{
  background:var(--brand);border-radius:var(--r-lg);
  padding:56px 60px;color:var(--white);
  position:relative;overflow:hidden;
}
.mission-block::before{
  content:'\201C';position:absolute;
  top:-30px;left:24px;font-size:14rem;
  color:rgba(255,255,255,.07);
  font-family:Georgia,serif;line-height:1;pointer-events:none;
}
.mission-block p{
  font-size:1.1rem;line-height:1.85;position:relative;z-index:1;
}

/* --- Story layout ------------------------------------------ */
.story-layout{
  display:grid;grid-template-columns:1fr 1fr;
  gap:64px;align-items:start;
}
.story-text p{color:var(--ink-mid);line-height:1.88;margin-bottom:1.3rem}

/* --- Trustees --------------------------------------------- */
.trustees-row{
  display:flex;gap:24px;flex-wrap:wrap;justify-content:center;
}
.trustee-card{
  background:var(--white);border-radius:var(--r-md);
  padding:28px 24px;border:2px dotted var(--cream-bd);
  text-align:center;flex:1;min-width:180px;max-width:270px;
}
.trustee-card__avatar{
  width:68px;height:68px;border-radius:50%;
  background:var(--brand-lt);border:3px solid var(--brand);
  margin:0 auto 14px;display:flex;align-items:center;
  justify-content:center;font-size:1.7rem;
}
.trustee-card__name{font-weight:900;font-size:.98rem;color:var(--ink);margin-bottom:4px}
.trustee-card__role{
  font-size:.82rem;color:var(--terra);font-weight:800;
  letter-spacing:.07em;text-transform:uppercase;
}

/* --- CTA block --------------------------------------------- */
.cta-block{
  background:var(--terra);padding:72px 28px;
  text-align:center;position:relative;overflow:hidden;
}
.cta-block::before{
  content:'';position:absolute;inset:0;
  background:radial-gradient(circle at 80% 30%,rgba(255,255,255,.08),transparent 55%);
}
.cta-block > *{position:relative;z-index:1}
.cta-block__label{
  display:inline-block;background:rgba(255,255,255,.18);color:var(--white);
  font-size:.75rem;font-weight:900;letter-spacing:.14em;text-transform:uppercase;
  padding:5px 16px;border-radius:999px;margin-bottom:18px;
}
.cta-block__title{color:var(--white);margin-bottom:32px;max-width:640px;margin-inline:auto}

/* --- Buttons ----------------------------------------------- */
.btn{
  display:inline-flex;align-items:center;gap:8px;
  padding:15px 36px;border-radius:999px;
  font-family:var(--font);font-weight:900;font-size:.98rem;
  text-decoration:none;border:none;cursor:pointer;
  transition:all .2s;
}
.btn--white{background:var(--white);color:var(--terra)}
.btn--white:hover{background:var(--cream);text-decoration:none;color:var(--terra)}
.btn--brand{background:var(--brand);color:var(--white)}
.btn--brand:hover{background:var(--brand-dk);text-decoration:none}
.btn--terra{background:var(--terra);color:var(--white)}
.btn--terra:hover{background:var(--terra-lt);text-decoration:none}

/* --- Contact form ------------------------------------------ */
.contact-form{
  background:var(--white);border-radius:var(--r-md);
  padding:48px;border:2px solid var(--cream-bd);
  box-shadow:4px 8px 32px rgba(44,24,16,.08);
}
.contact-layout{
  display:grid;grid-template-columns:1fr 1.5fr;
  gap:64px;align-items:start;
}
.contact-info h3{font-size:1.3rem;margin-bottom:16px;color:var(--ink)}
.contact-info p{color:var(--ink-mid);font-size:.95rem;line-height:1.8;margin-bottom:16px}
.contact-info a{color:var(--terra);font-weight:700;word-break:break-all}
.contact-info a:hover{color:var(--brand)}
.contact-detail{
  background:var(--terra-pale);border-radius:var(--r-md);
  padding:28px;margin-top:28px;
  border:2px dotted var(--cream-bd);
}
.contact-detail h4{font-size:.85rem;font-weight:900;letter-spacing:.1em;text-transform:uppercase;color:var(--terra);margin-bottom:12px}
.contact-detail p{font-size:.9rem;color:var(--ink-mid);margin-bottom:8px}
.form-row{margin-bottom:22px}
.form-row label{
  display:block;font-weight:800;font-size:.88rem;
  color:var(--ink);margin-bottom:7px;
}
.form-row input,
.form-row textarea,
.form-row select{
  width:100%;padding:13px 18px;
  border:2px solid var(--cream-bd);border-radius:var(--r-sm);
  background:var(--cream);font-family:var(--font);
  font-size:.95rem;color:var(--ink);
  transition:border-color .2s,background .2s;
  appearance:none;
}
.form-row input:focus,
.form-row textarea:focus,
.form-row select:focus{
  outline:none;border-color:var(--brand);background:var(--brand-lt);
}
.form-row textarea{resize:vertical;min-height:150px}
.form-2col{display:grid;grid-template-columns:1fr 1fr;gap:20px}

/* --- Scrapbook band ---------------------------------------- */
.scrapbook-band{
  background:var(--brand-lt);padding:52px 28px;
  position:relative;
}
.scrapbook-band::before,
.scrapbook-band::after{
  content:'';position:absolute;left:0;right:0;height:5px;
  background:repeating-linear-gradient(90deg,var(--brand) 0 10px,transparent 10px 18px);
}
.scrapbook-band::before{top:0}
.scrapbook-band::after{bottom:0}

/* --- What we do text section ------------------------------- */
.what-we-do p{
  color:var(--ink-mid);line-height:1.9;margin-bottom:1.4rem;font-size:1.02rem;
}
.what-we-do p:last-child{margin-bottom:0}

/* --- Blog header ------------------------------------------- */
.blog-header{
  background:var(--cream-dark);
  padding:72px 28px 56px;
  border-bottom:2px dotted var(--cream-bd);
  position:relative;overflow:hidden;
}
.blog-header::after{
  content:'';position:absolute;
  top:-60px;right:-60px;
  width:280px;height:280px;
  border-radius:50%;
  background:var(--brand-lt);opacity:.5;
}
.blog-header .container{position:relative;z-index:1}

/* --- Simple page header ------------------------------------ */
.plain-header{
  background:var(--cream-dark);
  padding:72px 28px 56px;
  border-bottom:2px dotted var(--cream-bd);
}

/* --- Inline accent strip ----------------------------------- */
.accent-row{
  display:flex;align-items:center;gap:32px;
  flex-wrap:wrap;margin-top:28px;
}
.accent-pill{
  display:inline-flex;align-items:center;gap:8px;
  background:var(--white);border:2px solid var(--cream-bd);
  border-radius:999px;padding:8px 20px;
  font-size:.88rem;font-weight:700;color:var(--ink-mid);
}
.accent-pill span{font-size:1.1rem}

/* --- Footer ----------------------------------------------- */
.site-footer{background:var(--ink);color:rgba(255,255,255,.78);padding:64px 28px 36px}
.footer-inner{max-width:1160px;margin-inline:auto}
.footer-top{
  display:grid;grid-template-columns:2fr 1fr 1fr 1.6fr;
  gap:48px;margin-bottom:48px;
}
.footer-brand .brand-lockup{
  display:flex;align-items:center;gap:10px;margin-bottom:18px;
}
.footer-brand .brand-lockup .logo-icon{height:38px}
.footer-brand .brand-lockup .wordmark{
  height:24px;
  filter:invert(1) brightness(2.5);
}
.footer-brand p{font-size:.88rem;line-height:1.72;color:rgba(255,255,255,.65)}
.footer-col h4{
  color:var(--white);font-size:.8rem;font-weight:900;
  letter-spacing:.12em;text-transform:uppercase;margin-bottom:16px;
}
.footer-col ul{list-style:none}
.footer-col ul li{margin-bottom:9px}
.footer-col ul li a{
  color:rgba(255,255,255,.65);font-size:.88rem;
  text-decoration:none;transition:color .2s;
}
.footer-col ul li a:hover{color:var(--terra-lt)}
.footer-contact p{font-size:.88rem;line-height:1.72;margin-bottom:8px}
.footer-contact a{color:var(--terra-lt);word-break:break-all;font-weight:600}
.footer-contact a:hover{color:var(--white)}
.footer-bottom{
  border-top:1px solid rgba(255,255,255,.1);
  padding-top:24px;display:flex;align-items:center;
  justify-content:space-between;flex-wrap:wrap;gap:12px;
}
.footer-bottom p{font-size:.8rem;color:rgba(255,255,255,.45)}

/* --- Responsive ------------------------------------------- */
@media(max-width:960px){
  .footer-top{grid-template-columns:1fr 1fr;gap:32px}
  .highlights-grid{grid-template-columns:1fr 1fr}
  .highlight-card:nth-child(2){margin-top:0}
  .highlight-card:nth-child(3){margin-top:0}
  .programme-grid{grid-template-columns:1fr}
  .ways-grid{grid-template-columns:1fr 1fr}
  .blog-grid{grid-template-columns:1fr 1fr}
  .story-layout{grid-template-columns:1fr;gap:36px}
  .contact-layout{grid-template-columns:1fr;gap:40px}
  .form-2col{grid-template-columns:1fr}
}
@media(max-width:680px){
  .site-nav__links{
    display:none;position:absolute;top:68px;left:0;right:0;
    background:var(--cream);border-bottom:2px solid var(--cream-bd);
    padding:16px 24px;flex-direction:column;align-items:flex-start;gap:4px;z-index:199;
  }
  .site-nav__links.open{display:flex}
  .nav-toggle{display:block}
  .hero{min-height:540px;padding-bottom:120px}
  .hero__text{padding:64px 20px 0}
  .hero-overlap{margin-top:-90px;padding-inline:16px}
  .hero-overlap__card{padding:28px 24px}
  .hero-overlap__card::before{left:30px;right:30px}
  .page-banner{height:360px}
  .page-banner__content{padding:40px 24px}
  .highlights-grid{grid-template-columns:1fr}
  .ways-grid{grid-template-columns:1fr}
  .blog-grid{grid-template-columns:1fr}
  .footer-top{grid-template-columns:1fr}
  .impact-inner{gap:36px}
  .mission-block{padding:36px 28px}
  .contact-form{padding:28px 20px}
  .polaroid-gallery{gap:20px}
  .polaroid-gallery .polaroid{max-width:260px}
  .trustees-row{flex-direction:column;align-items:center}
  .trustee-card{max-width:100%;width:100%}
}
