/*
Theme Name: Intentionally Blank
Theme URI: https://www.nilovelez.com/blank/
Author: Nilo Velez
Author URI: https://www.nilovelez.com/
Description: This theme was intentionally left blank.
Version: 3.2
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Tags: featured-images, custom-background, theme-options, translation-ready
Text Domain: intentionally-blank
Requires at least: 4.6
Tested up to: 6.9
Requires PHP: 7.4
*/

/* ==============================================
   SEAVIEW SAILING TRUST — CORE STYLESHEET
   ============================================== */

@import url('https://fonts.googleapis.com/css2?family=Cinzel:wght@400;600;700;900&family=Cabin:wght@400;500;600;700&family=EB+Garamond:ital,wght@0,400;0,500;1,400;1,500&display=swap');

:root {
  --navy:      #1a2d5a;
  --navy-dark: #101d3d;
  --red:       #c0392b;
  --red-hover: #a93226;
  --green:     #27ae60;
  --green-lt:  #2ecc71;
  --cream:     #f6f4ef;
  --white:     #ffffff;
  --text:      #2a2a28;
  --muted:     #64635e;
}

/* ── BASE ── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; overflow: auto !important; }
body { font-family: 'EB Garamond', Georgia, serif; font-size: 18px; color: var(--text); background: var(--cream); overflow: auto !important; }
img  { display: block; max-width: 100%; }
a    { color: inherit; text-decoration: none; }

/* ── NAV ── */
.nav { background: var(--navy-dark); position: sticky; top: 0; z-index: 100; padding: 0 52px; display: flex; align-items: center; justify-content: space-between; height: 66px; border-bottom: 3px solid var(--red); }
.nav-brand { display: flex; align-items: center; gap: 13px; }
.nav-brand img { height: 38px; width: auto; }
.nav-title { font-family: 'Cinzel', Georgia, serif; font-size: 14px; font-weight: 600; color: white; letter-spacing: 2.5px; }
.nav-links { display: flex; gap: 30px; }
.nav-links a { font-family: 'Cabin', sans-serif; font-size: 11px; font-weight: 600; letter-spacing: 1.8px; text-transform: uppercase; color: rgba(255,255,255,0.60); transition: color 0.2s; }
.nav-links a:hover, .nav-links a.active { color: white; }
.nav-donate { font-family: 'Cabin', sans-serif; font-size: 11px; font-weight: 700; letter-spacing: 2px; text-transform: uppercase; background: var(--red); color: white; padding: 10px 26px; border: none; cursor: pointer; transition: background 0.2s; }
.nav-donate:hover { background: var(--red-hover); }

/* ── LAYOUT ── */
.container { max-width: 1100px; margin: 0 auto; padding: 0 64px; }

/* ── SHARED LABELS & HEADINGS ── */
.tag { display: inline-block; font-family: 'Cabin', sans-serif; font-size: 10px; font-weight: 700; letter-spacing: 3px; text-transform: uppercase; color: var(--red); background: #fdf0ee; padding: 6px 12px; margin-bottom: 22px; border-left: 3px solid var(--red); }
.section-h2 { font-family: 'Cinzel', Georgia, serif; font-size: 34px; font-weight: 700; line-height: 1.2; color: var(--navy); margin-bottom: 22px; letter-spacing: 0.5px; }
.body-p { font-family: 'EB Garamond', Georgia, serif; font-size: 18px; line-height: 1.82; color: #585854; margin-bottom: 14px; }

/* ── BUTTONS ── */
.btn-red { font-family: 'Cabin', sans-serif; font-size: 11px; font-weight: 700; letter-spacing: 2px; text-transform: uppercase; background: var(--red); color: white; padding: 14px 36px; border: none; cursor: pointer; transition: background 0.2s; }
.btn-red:hover { background: var(--red-hover); }
.btn-ghost { font-family: 'Cabin', sans-serif; font-size: 11px; font-weight: 600; letter-spacing: 2px; text-transform: uppercase; background: transparent; color: white; padding: 13px 36px; border: 1.5px solid rgba(255,255,255,0.4); cursor: pointer; transition: border-color 0.2s; }
.btn-ghost:hover { border-color: rgba(255,255,255,0.85); }
.btn-white { font-family: 'Cabin', sans-serif; font-size: 11px; font-weight: 700; letter-spacing: 2px; text-transform: uppercase; background: white; color: var(--red); padding: 15px 38px; border: none; cursor: pointer; transition: opacity 0.2s; }
.btn-white:hover { opacity: 0.9; }
.btn-outline-wh { font-family: 'Cabin', sans-serif; font-size: 11px; font-weight: 600; letter-spacing: 2px; text-transform: uppercase; background: transparent; color: white; padding: 14px 38px; border: 1.5px solid rgba(255,255,255,0.55); cursor: pointer; transition: border-color 0.2s; }
.btn-outline-wh:hover { border-color: white; }
.text-link { font-family: 'Cabin', sans-serif; font-size: 11px; font-weight: 700; letter-spacing: 1.8px; text-transform: uppercase; color: var(--red); display: inline-flex; align-items: center; gap: 8px; margin-top: 10px; }

/* ── HOMEPAGE HERO ── */
.hero { position: relative; height: 610px; overflow: hidden; }
.hero-img { width: 100%; height: 100%; object-fit: cover; object-position: center 28%; }
.hero-overlay { position: absolute; inset: 0; background: linear-gradient(108deg, rgba(16,29,61,0.93) 0%, rgba(16,29,61,0.68) 48%, rgba(16,29,61,0.12) 100%); }
.hero-content { position: absolute; left: 68px; top: 50%; transform: translateY(-50%); max-width: 560px; }
.hero-eyebrow { font-family: 'Cabin', sans-serif; font-size: 11px; font-weight: 600; letter-spacing: 3px; text-transform: uppercase; color: var(--green-lt); margin-bottom: 20px; }
.hero-h1 { font-family: 'Cinzel', Georgia, serif; font-size: 58px; font-weight: 700; line-height: 1.08; color: white; letter-spacing: 1px; margin-bottom: 22px; }
.hero-h1 em { display: block; font-family: 'EB Garamond', Georgia, serif; font-style: italic; font-size: 64px; font-weight: 400; color: var(--green-lt); letter-spacing: 0; line-height: 1.05; }
.hero-sub { font-family: 'EB Garamond', Georgia, serif; font-size: 19px; line-height: 1.75; color: rgba(255,255,255,0.80); max-width: 430px; margin-bottom: 34px; }
.hero-btns { display: flex; gap: 14px; }

/* ── PAGE HERO (inner pages) ── */
.page-hero { position: relative; height: 460px; overflow: hidden; }
.page-hero img { width: 100%; height: 100%; object-fit: cover; object-position: center 35%; }
.page-hero-overlay { position: absolute; inset: 0; background: linear-gradient(108deg, rgba(16,29,61,0.92) 0%, rgba(16,29,61,0.65) 55%, rgba(16,29,61,0.15) 100%); display: flex; flex-direction: column; justify-content: flex-end; padding: 52px 68px; }
.page-eyebrow { font-family: 'Cabin', sans-serif; font-size: 11px; font-weight: 600; letter-spacing: 3px; text-transform: uppercase; color: var(--green-lt); margin-bottom: 14px; }
.page-title { font-family: 'Cinzel', Georgia, serif; font-size: 52px; font-weight: 700; color: white; letter-spacing: 1px; line-height: 1.1; }
.page-title em { display: block; font-family: 'EB Garamond', Georgia, serif; font-style: italic; font-size: 26px; font-weight: 400; color: rgba(255,255,255,0.72); letter-spacing: 0; margin-top: 12px; }
.page-subtitle { font-family: 'EB Garamond', Georgia, serif; font-size: 21px; font-style: italic; color: rgba(255,255,255,0.60); max-width: 580px; line-height: 1.6; }

/* ── ARTICLE HERO (news/reports) ── */
.article-hero { position: relative; height: 480px; overflow: hidden; }
.article-hero img { width: 100%; height: 100%; object-fit: cover; object-position: center 30%; }
.article-hero-overlay { position: absolute; inset: 0; background: linear-gradient(108deg, rgba(16,29,61,0.92) 0%, rgba(16,29,61,0.65) 50%, rgba(16,29,61,0.15) 100%); display: flex; flex-direction: column; justify-content: flex-end; padding: 52px 68px; }
.hero-breadcrumb { font-family: 'Cabin', sans-serif; font-size: 11px; font-weight: 600; letter-spacing: 2.5px; text-transform: uppercase; color: rgba(255,255,255,0.50); margin-bottom: 14px; }
.hero-breadcrumb a { color: var(--green-lt); }
.hero-year { font-family: 'Cabin', sans-serif; font-size: 11px; font-weight: 600; letter-spacing: 3px; text-transform: uppercase; color: var(--green-lt); margin-bottom: 12px; }
.hero-title { font-family: 'Cinzel', Georgia, serif; font-size: 46px; font-weight: 700; color: white; letter-spacing: 1px; line-height: 1.1; max-width: 700px; }
.hero-meta { display: flex; align-items: center; gap: 16px; margin-bottom: 16px; flex-wrap: wrap; }
.hero-tag { font-family: 'Cabin', sans-serif; font-size: 10px; font-weight: 700; letter-spacing: 2.5px; text-transform: uppercase; color: var(--navy-dark); background: var(--green-lt); padding: 5px 12px; }
.hero-date { font-family: 'Cabin', sans-serif; font-size: 11px; font-weight: 600; letter-spacing: 2px; text-transform: uppercase; color: rgba(255,255,255,0.55); }

/* ── STATS STRIP ── */
.stats { background: var(--navy); display: grid; grid-template-columns: repeat(3,1fr); border-top: 3px solid var(--green); }
.stat { padding: 30px 36px; text-align: center; border-right: 1px solid rgba(255,255,255,0.07); }
.stat:last-child { border-right: none; }
.stat-num { font-family: 'Cinzel', Georgia, serif; font-size: 50px; font-weight: 700; color: var(--green-lt); line-height: 1; }
.stat-label { font-family: 'Cabin', sans-serif; font-size: 11px; font-weight: 600; letter-spacing: 1.8px; text-transform: uppercase; color: rgba(255,255,255,0.48); margin-top: 7px; }

/* ── HOMEPAGE SECTIONS ── */
.mission { display: grid; grid-template-columns: 1fr 1fr; background: var(--white); }
.mission-img { height: 500px; overflow: hidden; }
.mission-img img { width: 100%; height: 100%; object-fit: cover; }
.mission-text { padding: 68px 56px; display: flex; flex-direction: column; justify-content: center; }

.quote-band { background: var(--navy-dark); padding: 72px 80px; text-align: center; border-top: 4px solid var(--green); border-bottom: 4px solid var(--green); }
.quote-open { font-family: 'EB Garamond', Georgia, serif; font-size: 90px; line-height: 0.5; color: var(--green); margin-bottom: 20px; }
.quote-text { font-family: 'EB Garamond', Georgia, serif; font-size: 32px; font-style: italic; font-weight: 400; line-height: 1.5; color: white; max-width: 800px; margin: 0 auto 22px; }
.quote-attr { font-family: 'Cabin', sans-serif; font-size: 11px; font-weight: 600; letter-spacing: 2.5px; text-transform: uppercase; color: var(--green-lt); }

.impact { background: var(--cream); padding: 76px 64px; }
.impact-hdr { display: flex; justify-content: space-between; align-items: flex-end; margin-bottom: 44px; padding-bottom: 20px; border-bottom: 1px solid rgba(26,45,90,0.14); }
.impact-hdr h2 { font-family: 'Cinzel', Georgia, serif; font-size: 36px; font-weight: 700; color: var(--navy); letter-spacing: 0.5px; }
.impact-hdr p { font-family: 'EB Garamond', Georgia, serif; font-size: 18px; font-style: italic; color: var(--muted); max-width: 380px; text-align: right; line-height: 1.5; }
.impact-grid { display: grid; grid-template-columns: repeat(4,1fr); gap: 3px; background: rgba(26,45,90,0.10); }
.tile { background: white; padding: 36px 24px; text-align: center; }
.tile-num { font-family: 'Cinzel', Georgia, serif; font-size: 44px; font-weight: 700; color: var(--navy); line-height: 1; margin-bottom: 10px; }
.tile-label { font-family: 'Cabin', sans-serif; font-size: 11px; font-weight: 600; letter-spacing: 1.5px; text-transform: uppercase; color: var(--muted); }
.tile-accent { width: 28px; height: 3px; background: var(--red); margin: 12px auto 0; }

.news { background: var(--navy-dark); padding: 76px 64px; }
.news-hdr { display: flex; justify-content: space-between; align-items: baseline; margin-bottom: 32px; }
.news-hdr h2 { font-family: 'Cinzel', Georgia, serif; font-size: 34px; font-weight: 700; color: white; letter-spacing: 0.5px; }
.news-hdr a { font-family: 'Cabin', sans-serif; font-size: 11px; font-weight: 600; letter-spacing: 2px; text-transform: uppercase; color: var(--green-lt); }
.news-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 20px; }
.card { background: rgba(255,255,255,0.04); border: 1px solid rgba(255,255,255,0.07); overflow: hidden; transition: background 0.25s, border-color 0.25s; display: block; }
.card:hover { background: rgba(255,255,255,0.09); border-color: rgba(255,255,255,0.18); }
.card-img { height: 195px; overflow: hidden; }
.card-img img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.4s; }
.card:hover .card-img img { transform: scale(1.04); }
.card-body { padding: 20px 24px 24px; }
.card-date { font-family: 'Cabin', sans-serif; font-size: 10px; font-weight: 700; letter-spacing: 2.5px; text-transform: uppercase; color: var(--green-lt); margin-bottom: 9px; }
.card-title { font-family: 'EB Garamond', Georgia, serif; font-size: 21px; font-weight: 500; line-height: 1.35; color: white; }

.support { background: var(--red); padding: 88px 64px; text-align: center; }
.support h2 { font-family: 'Cinzel', Georgia, serif; font-size: 42px; font-weight: 700; color: white; letter-spacing: 1px; margin-bottom: 18px; }
.support p { font-family: 'EB Garamond', Georgia, serif; font-size: 21px; font-style: italic; line-height: 1.65; color: rgba(255,255,255,0.88); max-width: 560px; margin: 0 auto 38px; }
.support-btns { display: flex; gap: 18px; justify-content: center; }

/* ── CTA BAND ── */
.cta { background: var(--red); padding: 80px 0; text-align: center; }
.cta h2 { font-family: 'Cinzel', Georgia, serif; font-size: 38px; font-weight: 700; color: white; margin-bottom: 16px; letter-spacing: 0.5px; }
.cta p { font-family: 'EB Garamond', Georgia, serif; font-size: 20px; line-height: 1.65; color: rgba(255,255,255,0.85); max-width: 540px; margin: 0 auto 36px; }
.cta-cost { font-family: 'Cinzel', Georgia, serif; font-size: 52px; font-weight: 700; color: white; margin-bottom: 6px; }
.cta-cost-label { font-family: 'Cabin', sans-serif; font-size: 11px; font-weight: 600; letter-spacing: 2px; text-transform: uppercase; color: rgba(255,255,255,0.60); margin-bottom: 32px; }
.cta-btns { display: flex; gap: 16px; justify-content: center; flex-wrap: wrap; }

/* ── WHAT WE DO ── */
.story { background: var(--white); padding: 72px 0; }
.story .container { display: grid; grid-template-columns: 1fr 420px; gap: 72px; align-items: start; }
.story-aside { background: var(--cream); padding: 36px; border-top: 4px solid var(--navy); margin-top: 4px; }
.aside-label { font-family: 'Cabin', sans-serif; font-size: 10px; font-weight: 700; letter-spacing: 2.5px; text-transform: uppercase; color: var(--muted); margin-bottom: 16px; }
.aside-stat { margin-bottom: 20px; padding-bottom: 20px; border-bottom: 1px solid rgba(26,45,90,0.12); }
.aside-stat:last-child { border-bottom: none; margin-bottom: 0; padding-bottom: 0; }
.aside-num { font-family: 'Cinzel', Georgia, serif; font-size: 40px; font-weight: 700; color: var(--navy); line-height: 1; }
.aside-desc { font-family: 'Cabin', sans-serif; font-size: 11px; font-weight: 600; letter-spacing: 1.5px; text-transform: uppercase; color: var(--muted); margin-top: 5px; }

.ambition { background: var(--navy); padding: 60px 0; border-top: 3px solid var(--green); border-bottom: 3px solid var(--green); }
.ambition .container { display: grid; grid-template-columns: 1fr 1fr; gap: 64px; align-items: center; }
.ambition-label { font-family: 'Cabin', sans-serif; font-size: 10px; font-weight: 700; letter-spacing: 3px; text-transform: uppercase; color: var(--green-lt); margin-bottom: 14px; }
.ambition-h2 { font-family: 'Cinzel', Georgia, serif; font-size: 32px; font-weight: 700; color: white; line-height: 1.2; margin-bottom: 20px; }
.ambition-p { font-family: 'EB Garamond', Georgia, serif; font-size: 18px; line-height: 1.75; color: rgba(255,255,255,0.75); }
.ambition-milestone { display: flex; align-items: flex-start; gap: 20px; padding: 20px 0; border-bottom: 1px solid rgba(255,255,255,0.08); }
.ambition-milestone:first-child { border-top: 1px solid rgba(255,255,255,0.08); }
.milestone-year { font-family: 'Cinzel', Georgia, serif; font-size: 22px; font-weight: 700; color: var(--green-lt); min-width: 56px; }
.milestone-text { font-family: 'Cabin', sans-serif; font-size: 12px; font-weight: 600; letter-spacing: 1px; text-transform: uppercase; color: rgba(255,255,255,0.60); line-height: 1.6; padding-top: 4px; }

.programme { background: var(--cream); padding: 76px 0; }
.programme .container { display: grid; grid-template-columns: 1fr 1fr; gap: 64px; align-items: center; }
.prog-img { overflow: hidden; height: 420px; }
.prog-img img { width: 100%; height: 100%; object-fit: cover; }

.partners { background: var(--white); padding: 72px 0; }
.partners-intro { text-align: center; max-width: 640px; margin: 0 auto 52px; }
.partner-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 3px; background: rgba(26,45,90,0.08); }
.partner-card { background: white; padding: 42px 36px; }
.partner-name { font-family: 'Cinzel', Georgia, serif; font-size: 20px; font-weight: 700; color: var(--navy); margin-bottom: 4px; }
.partner-loc { font-family: 'Cabin', sans-serif; font-size: 10px; font-weight: 600; letter-spacing: 2px; text-transform: uppercase; color: var(--green); margin-bottom: 16px; }
.partner-desc { font-family: 'EB Garamond', Georgia, serif; font-size: 17px; line-height: 1.75; color: var(--muted); }

.saturday { background: var(--navy-dark); padding: 72px 0; }
.saturday .container { display: grid; grid-template-columns: 1fr 1fr; gap: 72px; align-items: center; }
.saturday-img { overflow: hidden; height: 380px; }
.saturday-img img { width: 100%; height: 100%; object-fit: cover; }
.sat-tag { display: inline-block; font-family: 'Cabin', sans-serif; font-size: 10px; font-weight: 700; letter-spacing: 3px; text-transform: uppercase; color: var(--green-lt); background: rgba(46,204,113,0.12); padding: 6px 12px; margin-bottom: 22px; border-left: 3px solid var(--green-lt); }
.saturday .body-p { color: rgba(255,255,255,0.70); }
.saturday .body-p strong { color: var(--green-lt); }

.inclusion { background: var(--cream); padding: 72px 0; }
.inclusion .container { display: grid; grid-template-columns: 420px 1fr; gap: 72px; align-items: center; }
.inclusion-quote { background: var(--navy); padding: 44px 40px; }
.iq-open { font-family: 'EB Garamond', Georgia, serif; font-size: 80px; line-height: 0.6; color: var(--green); margin-bottom: 20px; }
.iq-text { font-family: 'EB Garamond', Georgia, serif; font-size: 22px; font-style: italic; line-height: 1.55; color: white; margin-bottom: 18px; }
.iq-attr { font-family: 'Cabin', sans-serif; font-size: 10px; font-weight: 600; letter-spacing: 2px; text-transform: uppercase; color: var(--green-lt); }

/* ── IMPACT PAGE ── */
.context { background: var(--white); padding: 76px 0; }
.context .container { display: grid; grid-template-columns: 1fr 1fr; gap: 72px; align-items: center; }
.context-img { overflow: hidden; height: 440px; }
.context-img img { width: 100%; height: 100%; object-fit: cover; }

.contrast { background: var(--navy); padding: 64px 0; border-top: 3px solid var(--green); border-bottom: 3px solid var(--green); }
.contrast-label { font-family: 'Cabin', sans-serif; font-size: 10px; font-weight: 700; letter-spacing: 3px; text-transform: uppercase; color: var(--green-lt); text-align: center; margin-bottom: 44px; }
.contrast-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 3px; background: rgba(255,255,255,0.06); }
.contrast-tile { background: rgba(255,255,255,0.04); padding: 36px 24px; text-align: center; }
.ct-num { font-family: 'Cinzel', Georgia, serif; font-size: 44px; font-weight: 700; color: var(--green-lt); line-height: 1; margin-bottom: 10px; }
.ct-label { font-family: 'Cabin', sans-serif; font-size: 11px; font-weight: 600; letter-spacing: 1.5px; text-transform: uppercase; color: rgba(255,255,255,0.45); line-height: 1.5; }

.freedom { background: var(--cream); padding: 76px 0; }
.freedom .container { display: grid; grid-template-columns: 1fr 1fr; gap: 72px; align-items: center; }
.freedom-img { overflow: hidden; height: 480px; }
.freedom-img img { width: 100%; height: 100%; object-fit: cover; }

.pullquote { background: var(--navy-dark); padding: 80px 0; text-align: center; border-top: 4px solid var(--green); border-bottom: 4px solid var(--green); }
.pq-open { font-family: 'EB Garamond', Georgia, serif; font-size: 90px; line-height: 0.5; color: var(--green); margin-bottom: 20px; }
.pq-text { font-family: 'EB Garamond', Georgia, serif; font-size: 28px; font-style: italic; line-height: 1.55; color: white; max-width: 760px; margin: 0 auto 24px; }
.pq-attr { font-family: 'Cabin', sans-serif; font-size: 11px; font-weight: 600; letter-spacing: 2.5px; text-transform: uppercase; color: var(--green-lt); }

.classroom { background: var(--white); padding: 76px 0; }
.classroom .container { display: grid; grid-template-columns: 1fr 1fr; gap: 72px; align-items: center; }
.classroom-img { overflow: hidden; height: 420px; order: 2; }
.classroom-img img { width: 100%; height: 100%; object-fit: cover; }
.classroom-text { order: 1; }
.impact-list { list-style: none; margin-top: 8px; }
.impact-list li { font-family: 'EB Garamond', Georgia, serif; font-size: 18px; line-height: 1.65; color: #585854; padding: 14px 0 14px 28px; border-bottom: 1px solid rgba(26,45,90,0.08); position: relative; }
.impact-list li::before { content: ''; position: absolute; left: 0; top: 22px; width: 10px; height: 3px; background: var(--green); }

.testimony { background: var(--cream); padding: 76px 0; }
.testimony .container { max-width: 900px; }
.test-tag { display: inline-block; font-family: 'Cabin', sans-serif; font-size: 10px; font-weight: 700; letter-spacing: 3px; text-transform: uppercase; color: var(--red); background: #fdf0ee; padding: 6px 12px; margin-bottom: 28px; border-left: 3px solid var(--red); }
.test-open { font-family: 'EB Garamond', Georgia, serif; font-size: 120px; line-height: 0.4; color: rgba(26,45,90,0.10); margin-bottom: 12px; }
.test-text { font-family: 'EB Garamond', Georgia, serif; font-size: 26px; font-style: italic; line-height: 1.65; color: var(--navy); margin-bottom: 28px; }
.test-attr-name { font-family: 'Cinzel', Georgia, serif; font-size: 15px; font-weight: 600; color: var(--navy); letter-spacing: 1px; }
.test-attr-role { font-family: 'Cabin', sans-serif; font-size: 11px; font-weight: 600; letter-spacing: 1.8px; text-transform: uppercase; color: var(--muted); margin-top: 5px; }

.reports { background: var(--navy); padding: 72px 0; }
.reports .container { display: grid; grid-template-columns: 1fr 1fr; gap: 64px; align-items: center; }
.reports-label { font-family: 'Cabin', sans-serif; font-size: 10px; font-weight: 700; letter-spacing: 3px; text-transform: uppercase; color: var(--green-lt); margin-bottom: 16px; }
.report-links { display: flex; flex-direction: column; gap: 3px; }
.report-link { display: flex; align-items: center; justify-content: space-between; background: rgba(255,255,255,0.05); border: 1px solid rgba(255,255,255,0.07); padding: 20px 24px; transition: background 0.2s, border-color 0.2s; }
.report-link:hover { background: rgba(255,255,255,0.10); border-color: rgba(255,255,255,0.16); }
.rl-title { font-family: 'EB Garamond', Georgia, serif; font-size: 18px; font-weight: 500; color: white; }
.rl-date { font-family: 'Cabin', sans-serif; font-size: 10px; font-weight: 600; letter-spacing: 2px; text-transform: uppercase; color: var(--green-lt); margin-top: 4px; }
.rl-arrow { font-size: 20px; color: rgba(255,255,255,0.30); }

/* ── GOVERNANCE ── */
.gov-hero { background: var(--navy-dark); padding: 72px 68px 60px; border-bottom: 3px solid var(--green); }
.about { background: var(--white); padding: 76px 0; }
.about .container { display: grid; grid-template-columns: 1fr 340px; gap: 72px; align-items: start; }
.purpose-block { background: var(--navy); padding: 36px 32px; border-top: 4px solid var(--green); }
.purpose-label { font-family: 'Cabin', sans-serif; font-size: 10px; font-weight: 700; letter-spacing: 2.5px; text-transform: uppercase; color: var(--green-lt); margin-bottom: 16px; }
.purpose-text { font-family: 'EB Garamond', Georgia, serif; font-size: 17px; font-style: italic; line-height: 1.78; color: rgba(255,255,255,0.82); }
.charity-card { background: var(--cream); border-top: 4px solid var(--navy); padding: 32px; margin-top: 20px; }
.cc-label { font-family: 'Cabin', sans-serif; font-size: 10px; font-weight: 700; letter-spacing: 2.5px; text-transform: uppercase; color: var(--muted); margin-bottom: 20px; }
.cc-row { padding: 12px 0; border-bottom: 1px solid rgba(26,45,90,0.10); }
.cc-row:last-child { border-bottom: none; }
.cc-field { font-family: 'Cabin', sans-serif; font-size: 10px; font-weight: 600; letter-spacing: 1.5px; text-transform: uppercase; color: var(--muted); margin-bottom: 4px; }
.cc-value { font-family: 'EB Garamond', Georgia, serif; font-size: 17px; color: var(--navy); }
.cc-link { color: var(--navy); border-bottom: 1px solid rgba(26,45,90,0.40); }
.trustees { background: var(--cream); padding: 76px 0; }
.trustees-intro { margin-bottom: 44px; }
.trustee-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 3px; background: rgba(26,45,90,0.08); }
.trustee-card { background: var(--white); padding: 28px 22px; }
.trustee-card.lead { border-top: 3px solid var(--green); }
.t-circle { width: 48px; height: 48px; border-radius: 50%; background: var(--navy); display: flex; align-items: center; justify-content: center; margin-bottom: 14px; }
.t-initials { font-family: 'Cinzel', Georgia, serif; font-size: 13px; font-weight: 700; color: white; letter-spacing: 1px; }
.t-name { font-family: 'Cinzel', Georgia, serif; font-size: 14px; font-weight: 600; color: var(--navy); line-height: 1.35; margin-bottom: 6px; }
.t-role { font-family: 'Cabin', sans-serif; font-size: 10px; font-weight: 600; letter-spacing: 1.8px; text-transform: uppercase; color: var(--green); }
.t-role.plain { color: var(--muted); opacity: 0.7; }
.accounts { background: var(--navy); padding: 72px 0; }
.accounts .container { display: grid; grid-template-columns: 1fr 1fr; gap: 64px; align-items: start; }
.accounts-label { font-family: 'Cabin', sans-serif; font-size: 10px; font-weight: 700; letter-spacing: 3px; text-transform: uppercase; color: var(--green-lt); margin-bottom: 16px; }
.doc-list { display: flex; flex-direction: column; gap: 3px; }
.doc-item { display: flex; align-items: center; justify-content: space-between; gap: 16px; background: rgba(255,255,255,0.04); border: 1px solid rgba(255,255,255,0.07); padding: 20px 24px; }
a.doc-item { transition: background 0.2s, border-color 0.2s; }
a.doc-item:hover { background: rgba(255,255,255,0.09); border-color: rgba(255,255,255,0.18); }
.doc-title { font-family: 'EB Garamond', Georgia, serif; font-size: 18px; font-weight: 500; color: white; }
.doc-sub { font-family: 'Cabin', sans-serif; font-size: 10px; font-weight: 600; letter-spacing: 1.5px; text-transform: uppercase; color: rgba(255,255,255,0.35); margin-top: 4px; }
.doc-badge { font-family: 'Cabin', sans-serif; font-size: 10px; font-weight: 600; letter-spacing: 1.5px; text-transform: uppercase; color: rgba(255,255,255,0.25); border: 1px solid rgba(255,255,255,0.12); padding: 5px 12px; white-space: nowrap; flex-shrink: 0; }
.doc-arrow { font-size: 18px; color: rgba(255,255,255,0.35); flex-shrink: 0; }
.contact { background: var(--navy-dark); padding: 64px 0; border-top: 4px solid var(--green); }
.contact .container { display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 32px; }
.contact-text h3 { font-family: 'Cinzel', Georgia, serif; font-size: 26px; font-weight: 700; color: white; margin-bottom: 8px; }
.contact-text p { font-family: 'EB Garamond', Georgia, serif; font-size: 18px; color: rgba(255,255,255,0.55); }
.contact-email { font-family: 'Cabin', sans-serif; font-size: 13px; font-weight: 600; letter-spacing: 1px; color: var(--green-lt); border: 1.5px solid rgba(46,204,113,0.40); padding: 14px 32px; transition: border-color 0.2s; display: inline-block; }
.contact-email:hover { border-color: var(--green-lt); }

/* ── ARTICLE PAGES ── */
.article { background: var(--white); padding: 72px 0; }
.article-inner { max-width: 780px; margin: 0 auto; padding: 0 40px; }
.article-tag { display: inline-block; font-family: 'Cabin', sans-serif; font-size: 10px; font-weight: 700; letter-spacing: 3px; text-transform: uppercase; color: var(--red); background: #fdf0ee; padding: 6px 12px; margin-bottom: 28px; border-left: 3px solid var(--red); }
.article h2 { font-family: 'Cinzel', Georgia, serif; font-size: 30px; font-weight: 700; color: var(--navy); line-height: 1.25; margin: 40px 0 18px; letter-spacing: 0.3px; }
.article h2:first-of-type { margin-top: 0; }
.article p { font-family: 'EB Garamond', Georgia, serif; font-size: 19px; line-height: 1.82; color: #585854; margin-bottom: 18px; }
.article p.lead { font-size: 21px; color: #3a3a38; line-height: 1.7; }
.article-img { margin: 36px 0; overflow: hidden; }
.article-img img { width: 100%; height: 340px; object-fit: cover; }
.article-img-caption { font-family: 'Cabin', sans-serif; font-size: 10px; font-weight: 600; letter-spacing: 1.5px; text-transform: uppercase; color: var(--muted); margin-top: 8px; }
.article-img-pair { display: grid; grid-template-columns: 1fr 1fr; gap: 3px; margin: 36px 0; }
.article-img-pair img { width: 100%; height: 260px; object-fit: cover; display: block; }
.article-img-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 3px; margin: 36px 0; }
.article-img-grid img { width: 100%; height: 200px; object-fit: cover; display: block; }
.article-img-trio { display: grid; grid-template-columns: repeat(3, 1fr); gap: 3px; margin: 36px 0; }
.article-img-trio img { width: 100%; height: 220px; object-fit: cover; display: block; }
.infographic { margin: 36px 0; }
.infographic img { width: 100%; }
.dateline { font-family: 'Cabin', sans-serif; font-size: 11px; font-weight: 600; letter-spacing: 2px; text-transform: uppercase; color: var(--muted); margin-bottom: 28px; padding-bottom: 20px; border-bottom: 1px solid rgba(26,45,90,0.12); }

.pull-quote { background: var(--navy-dark); margin: 48px 0; padding: 48px 44px; border-left: 4px solid var(--green); }
.pull-quote p { font-family: 'EB Garamond', Georgia, serif; font-size: 22px; font-style: italic; line-height: 1.65; color: rgba(255,255,255,0.88); margin-bottom: 16px; }
.pull-quote cite { font-family: 'Cabin', sans-serif; font-size: 10px; font-weight: 600; letter-spacing: 2px; text-transform: uppercase; color: var(--green-lt); font-style: normal; }

.spokesperson { margin: 32px 0; padding: 28px 32px; border-left: 4px solid rgba(26,45,90,0.15); background: var(--cream); }
.spokesperson p { font-family: 'EB Garamond', Georgia, serif; font-size: 18px; font-style: italic; line-height: 1.75; color: var(--navy); margin-bottom: 12px; }
.spokesperson cite { font-family: 'Cabin', sans-serif; font-size: 10px; font-weight: 700; letter-spacing: 1.8px; text-transform: uppercase; color: var(--muted); font-style: normal; }

.royal-band { background: var(--navy-dark); margin: 44px 0; padding: 52px 48px; border-top: 4px solid var(--green); border-bottom: 4px solid var(--green); text-align: center; }
.royal-eyebrow { font-family: 'Cabin', sans-serif; font-size: 10px; font-weight: 700; letter-spacing: 3px; text-transform: uppercase; color: var(--green-lt); margin-bottom: 20px; }
.royal-quote { font-family: 'Cinzel', Georgia, serif; font-size: 26px; font-weight: 700; color: white; line-height: 1.3; margin-bottom: 12px; letter-spacing: 0.5px; }
.royal-attr { font-family: 'Cabin', sans-serif; font-size: 10px; font-weight: 600; letter-spacing: 2.5px; text-transform: uppercase; color: rgba(255,255,255,0.45); }

.rya-quote { background: var(--navy); margin: 48px 0; padding: 44px 40px; border-left: 4px solid var(--green); }
.rya-quote p { font-family: 'EB Garamond', Georgia, serif; font-size: 19px; font-style: italic; line-height: 1.75; color: rgba(255,255,255,0.80); margin-bottom: 16px; }
.rya-quote cite { font-family: 'Cabin', sans-serif; font-size: 10px; font-weight: 600; letter-spacing: 2px; text-transform: uppercase; color: var(--green-lt); font-style: normal; }

.horizon-quote { background: var(--navy-dark); margin: 52px 0; padding: 60px 52px; border-top: 4px solid var(--green); border-bottom: 4px solid var(--green); }
.hq-open { font-family: 'EB Garamond', Georgia, serif; font-size: 80px; line-height: 0.5; color: var(--green); margin-bottom: 20px; }
.hq-text { font-family: 'EB Garamond', Georgia, serif; font-size: 24px; font-style: italic; line-height: 1.65; color: white; margin-bottom: 22px; }
.hq-attr { font-family: 'Cabin', sans-serif; font-size: 10px; font-weight: 600; letter-spacing: 2.5px; text-transform: uppercase; color: var(--green-lt); }

.funding-highlight { background: var(--navy); margin: 48px 0; padding: 40px 44px; display: flex; align-items: center; gap: 40px; flex-wrap: wrap; }
.fh-num { font-family: 'Cinzel', Georgia, serif; font-size: 56px; font-weight: 700; color: var(--green-lt); line-height: 1; flex-shrink: 0; }
.fh-text { font-family: 'EB Garamond', Georgia, serif; font-size: 20px; line-height: 1.6; color: rgba(255,255,255,0.75); }

.key-fact { background: var(--navy); margin: 44px 0; padding: 40px 44px; display: flex; align-items: center; gap: 36px; flex-wrap: wrap; border-top: 4px solid var(--green); }
.kf-num { font-family: 'Cinzel', Georgia, serif; font-size: 52px; font-weight: 700; color: var(--green-lt); line-height: 1; flex-shrink: 0; }
.kf-text { font-family: 'EB Garamond', Georgia, serif; font-size: 20px; line-height: 1.6; color: rgba(255,255,255,0.78); }

/* ── PDF & REPORT NAV ── */
.pdf-band { background: var(--cream); border-top: 1px solid rgba(26,45,90,0.12); padding: 52px 0; }
.pdf-band .article-inner { display: flex; align-items: center; justify-content: space-between; gap: 32px; flex-wrap: wrap; }
.pdf-text h3 { font-family: 'Cinzel', Georgia, serif; font-size: 22px; font-weight: 700; color: var(--navy); margin-bottom: 6px; }
.pdf-text p { font-family: 'EB Garamond', Georgia, serif; font-size: 16px; color: var(--muted); }
.pdf-btn { font-family: 'Cabin', sans-serif; font-size: 11px; font-weight: 700; letter-spacing: 2px; text-transform: uppercase; background: var(--navy); color: white; padding: 15px 32px; display: inline-block; white-space: nowrap; transition: background 0.2s; }
.pdf-btn:hover { background: var(--navy-dark); }
.report-nav { background: var(--navy-dark); padding: 36px 0; border-top: 3px solid var(--green); }
.report-nav-inner { max-width: 780px; margin: 0 auto; padding: 0 40px; display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 16px; }
.report-nav-label { font-family: 'Cabin', sans-serif; font-size: 10px; font-weight: 700; letter-spacing: 2px; text-transform: uppercase; color: rgba(255,255,255,0.35); margin-bottom: 6px; }
.report-nav-link { font-family: 'Cinzel', Georgia, serif; font-size: 16px; font-weight: 600; color: white; }
.report-nav-link:hover { color: var(--green-lt); }
.report-nav-next { text-align: right; }

/* ── PRESS RELEASES ── */
.pr-footer { margin-top: 52px; padding-top: 28px; border-top: 2px solid rgba(26,45,90,0.12); }
.pr-footer-label { font-family: 'Cabin', sans-serif; font-size: 10px; font-weight: 700; letter-spacing: 2.5px; text-transform: uppercase; color: var(--muted); margin-bottom: 10px; }
.pr-footer p { font-family: 'Cabin', sans-serif; font-size: 13px; color: var(--muted); line-height: 1.7; margin-bottom: 6px; }
.pr-footer a { color: var(--navy); border-bottom: 1px solid rgba(26,45,90,0.30); }
.pr-credit { font-family: 'Cabin', sans-serif; font-size: 11px; font-weight: 600; letter-spacing: 1px; text-transform: uppercase; color: rgba(100,99,94,0.55); margin-top: 16px; }
.photo-captions { margin-top: 24px; }
.photo-captions h5 { font-family: 'Cabin', sans-serif; font-size: 10px; font-weight: 700; letter-spacing: 2px; text-transform: uppercase; color: var(--muted); margin-bottom: 10px; }
.photo-captions ol { font-family: 'Cabin', sans-serif; font-size: 12px; color: var(--muted); line-height: 1.8; padding-left: 18px; }

.schools-section { background: var(--cream); padding: 60px 0; border-top: 1px solid rgba(26,45,90,0.10); }
.schools-inner { max-width: 780px; margin: 0 auto; padding: 0 40px; }
.schools-label { display: inline-block; font-family: 'Cabin', sans-serif; font-size: 10px; font-weight: 700; letter-spacing: 3px; text-transform: uppercase; color: var(--red); background: #fdf0ee; padding: 6px 12px; margin-bottom: 28px; border-left: 3px solid var(--red); }
.schools-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 32px; }
.schools-col h4 { font-family: 'Cabin', sans-serif; font-size: 11px; font-weight: 700; letter-spacing: 2px; text-transform: uppercase; color: var(--navy); margin-bottom: 16px; padding-bottom: 10px; border-bottom: 2px solid var(--navy); }
.schools-col ul { list-style: none; }
.schools-col li { font-family: 'EB Garamond', Georgia, serif; font-size: 16px; color: var(--muted); padding: 7px 0 7px 16px; border-bottom: 1px solid rgba(26,45,90,0.07); position: relative; }
.schools-col li::before { content: ''; position: absolute; left: 0; top: 15px; width: 6px; height: 2px; background: var(--green); }

/* ── FOOTER ── */
.footer { background: var(--navy-dark); padding: 60px 64px 32px; display: grid; grid-template-columns: 2.2fr 1fr 1fr; gap: 56px; }
.footer-logo { display: flex; align-items: center; gap: 12px; margin-bottom: 14px; }
.footer-logo img { height: 40px; }
.footer-name { font-family: 'Cinzel', Georgia, serif; font-size: 14px; font-weight: 600; color: white; letter-spacing: 2px; }
.footer-tagline { font-family: 'EB Garamond', Georgia, serif; font-size: 18px; font-style: italic; line-height: 1.65; color: rgba(255,255,255,0.42); max-width: 270px; margin-bottom: 16px; }
.footer-charity { font-family: 'Cabin', sans-serif; font-size: 10px; letter-spacing: 1.5px; text-transform: uppercase; color: rgba(255,255,255,0.18); }
.footer-col h4 { font-family: 'Cabin', sans-serif; font-size: 10px; font-weight: 700; letter-spacing: 3px; text-transform: uppercase; color: var(--green-lt); margin-bottom: 18px; padding-bottom: 10px; border-bottom: 1px solid rgba(255,255,255,0.07); }
.footer-col a { display: block; font-family: 'EB Garamond', Georgia, serif; font-size: 17px; color: rgba(255,255,255,0.45); margin-bottom: 9px; transition: color 0.2s; }
.footer-col a:hover { color: white; }
.footer-bottom { background: rgba(0,0,0,0.38); padding: 14px 64px; display: flex; justify-content: space-between; align-items: center; }
.footer-bottom span { font-family: 'Cabin', sans-serif; font-size: 10px; letter-spacing: 1px; color: rgba(255,255,255,0.22); }

/* ── HOMEPAGE DYNAMIC NEWS ── */
.hp-news { background: var(--navy-dark); padding: 76px 64px; }
.hp-news-hdr { display: flex; justify-content: space-between; align-items: baseline; margin-bottom: 32px; }
.hp-news-hdr h2 { font-family: 'Cinzel', Georgia, serif; font-size: 34px; font-weight: 700; color: white; letter-spacing: 0.5px; }
.hp-news-hdr a { font-family: 'Cabin', sans-serif; font-size: 11px; font-weight: 600; letter-spacing: 2px; text-transform: uppercase; color: var(--green-lt); text-decoration: none; }
.hp-news-grid .wp-block-query { width: 100%; }
.hp-news-grid ul.wp-block-post-template { display: grid; grid-template-columns: repeat(3,1fr); gap: 20px; list-style: none; margin: 0; padding: 0; }
.hp-news-grid .wp-block-post { background: rgba(255,255,255,0.04); border: 1px solid rgba(255,255,255,0.07); overflow: hidden; transition: background 0.25s, border-color 0.25s; }
.hp-news-grid .wp-block-post:hover { background: rgba(255,255,255,0.09); border-color: rgba(255,255,255,0.18); }
.hp-news-grid .wp-block-post-featured-image { height: 195px; overflow: hidden; margin: 0; }
.hp-news-grid .wp-block-post-featured-image img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.4s; display: block; }
.hp-news-grid .wp-block-post:hover .wp-block-post-featured-image img { transform: scale(1.04); }
.hp-card-body { padding: 20px 24px 24px; }
.hp-news-grid .wp-block-post-date { font-family: 'Cabin', sans-serif; font-size: 10px; font-weight: 700; letter-spacing: 2.5px; text-transform: uppercase; color: var(--green-lt); margin-bottom: 9px; display: block; text-decoration: none; }
.hp-news-grid .wp-block-post-title { font-family: 'EB Garamond', Georgia, serif; font-size: 21px; font-weight: 500; line-height: 1.35; margin: 0; }
.hp-news-grid .wp-block-post-title a { color: white; text-decoration: none; }

/* ── RESPONSIVE — all breakpoints consolidated ── */
@media (max-width: 920px) {

  /* Nav */
  .nav { height: auto; padding: 14px 20px; flex-wrap: wrap; gap: 12px; }
  .nav-links { display: none; }
  .nav-brand { flex: 1; }
  .nav-donate { font-size: 10px; padding: 8px 16px; }

  /* Hero */
  .hero { height: auto; min-height: 400px; }
  .hero-content { position: relative; left: auto; top: auto; transform: none; padding: 32px 28px; max-width: 100%; }
  .hero-h1 { font-size: 38px; line-height: 1.15; margin-bottom: 16px; }
  .hero-h1 em { font-size: 42px; line-height: 1.1; }
  .hero-sub { font-size: 17px; max-width: 100%; }

  /* Page & article heroes */
  .page-hero { height: 320px; }
  .page-hero-overlay { padding: 28px 24px; }
  .page-title { font-size: 28px; line-height: 1.2; }
  .article-hero { height: 320px; }
  .article-hero-overlay { padding: 28px 24px; }
  .hero-title { font-size: 26px; line-height: 1.2; }

  /* Governance hero */
  .gov-hero { padding: 48px 24px 40px; }

  /* Headings */
  .section-h2 { font-size: 26px; line-height: 1.3; margin-bottom: 18px; }
  .ambition-h2 { font-size: 24px; line-height: 1.3; }
  .quote-text { font-size: 22px; line-height: 1.5; }
  .test-text { font-size: 20px; line-height: 1.5; }
  .support h2 { font-size: 30px; }
  .impact-hdr h2 { font-size: 26px; }

  /* Layout */
  .container { padding: 0 24px; }
  .stats { grid-template-columns: repeat(3, 1fr); }
  .stat { padding: 20px 12px; }
  .stat-num { font-size: 32px; }

  /* Grids → single column */
  .mission, .story .container, .ambition .container,
  .programme .container, .saturday .container, .inclusion .container,
  .context .container, .freedom .container, .classroom .container,
  .reports .container, .about .container, .accounts .container,
  .partner-grid { grid-template-columns: 1fr; gap: 36px; }

  /* Images */
  .mission-img, .prog-img, .saturday-img,
  .context-img, .freedom-img, .classroom-img { height: 260px; order: 0; }
  .mission-text { padding: 36px 28px; }

  /* Impact & news sections */
  .impact { padding: 48px 24px; }
  .impact-grid { grid-template-columns: repeat(2, 1fr); }
  .impact-hdr { flex-direction: column; gap: 8px; }
  .impact-hdr p { text-align: left; }
  .news, .support, .cta { padding-left: 24px; padding-right: 24px; }
  .news-grid { grid-template-columns: 1fr; }
  .hp-news { padding: 48px 24px; }
  .hp-news-grid ul.wp-block-post-template { grid-template-columns: 1fr; }

  /* Quote band */
  .quote-band { padding: 48px 24px; }
  .pullquote { padding: 48px 24px; }
  .pq-text { font-size: 22px; }

  /* Contrast */
  .contrast-grid { grid-template-columns: repeat(2, 1fr); }

  /* Trustees */
  .trustee-grid { grid-template-columns: repeat(2, 1fr); }

  /* Article */
  .article-inner { padding: 0 20px; }
  .article-img-pair, .article-img-grid, .article-img-trio { grid-template-columns: 1fr; }
  .funding-highlight, .key-fact { flex-direction: column; gap: 12px; }

  /* Press */
  .schools-grid { grid-template-columns: 1fr; gap: 28px; }
  .schools-inner { padding: 0 20px; }

  /* Footer */
  .footer { grid-template-columns: 1fr; gap: 32px; padding: 48px 24px 24px; }
  .footer-bottom { padding: 14px 24px; flex-direction: column; gap: 6px; text-align: center; }
}

@media (max-width: 480px) {
  .trustee-grid { grid-template-columns: 1fr; }
  .stats { grid-template-columns: 1fr; }
  .stat { border-right: none; border-bottom: 1px solid rgba(255,255,255,0.07); }
}

/* ── CTA HEADING MOBILE ── */
@media (max-width: 920px) {
  .support h2,
  .cta h2 {
    font-size: 26px;
    line-height: 1.4;
    letter-spacing: 0;
    padding: 0 16px;
  }
  .support p,
  .cta p {
    padding: 0 8px;
  }
  .support-btns,
  .cta-btns {
    flex-direction: column;
    align-items: center;
    gap: 12px;
  }
}

/* ==============================================
   SST DONATION PAGE & CHARITABLE FORM STYLES
   Add to bottom of style.css
   ============================================== */

/* ── DONATE HERO ── */
.donate-hero { position: relative; height: 480px; overflow: hidden; }
.donate-hero img { width: 100%; height: 100%; object-fit: cover; object-position: center 30%; }
.donate-hero-overlay { position: absolute; inset: 0; background: linear-gradient(108deg, rgba(16,29,61,0.92) 0%, rgba(16,29,61,0.70) 50%, rgba(16,29,61,0.20) 100%); display: flex; flex-direction: column; justify-content: flex-end; padding: 52px 68px; }
.donate-hero-label { font-family: 'Cabin', sans-serif; font-size: 11px; font-weight: 600; letter-spacing: 3px; text-transform: uppercase; color: var(--green-lt); margin-bottom: 14px; }
.donate-hero-title { font-family: 'Cinzel', Georgia, serif; font-size: 52px; font-weight: 700; color: white; line-height: 1.1; margin-bottom: 16px; }
.donate-hero-sub { font-family: 'EB Garamond', Georgia, serif; font-size: 20px; color: rgba(255,255,255,0.80); max-width: 520px; line-height: 1.6; }

/* ── IMPACT STRIP ── */
.donate-impact-strip { background: var(--navy); display: grid; grid-template-columns: repeat(3,1fr); border-top: 3px solid var(--green); }
.donate-impact-item { padding: 24px 32px; text-align: center; border-right: 1px solid rgba(255,255,255,0.07); display: flex; flex-direction: column; gap: 6px; }
.donate-impact-item:last-child { border-right: none; }
.donate-impact-num { font-family: 'Cinzel', Georgia, serif; font-size: 36px; font-weight: 700; color: var(--green-lt); line-height: 1; }
.donate-impact-label { font-family: 'Cabin', sans-serif; font-size: 10px; font-weight: 600; letter-spacing: 1.8px; text-transform: uppercase; color: rgba(255,255,255,0.48); }

/* ── DONATE WRAP ── */
.donate-wrap { background: var(--cream); }
.donate-form-wrap { max-width: 680px; margin: 0 auto; padding: 56px 40px 64px; }
.donate-form-intro { margin-bottom: 36px; border-left: 4px solid var(--green); padding-left: 20px; }
.donate-form-intro-text { font-family: 'EB Garamond', Georgia, serif; font-size: 19px; line-height: 1.75; color: #585854; }

/* ── OTHER WAYS ── */
.donate-other-ways { margin-top: 48px; padding-top: 32px; border-top: 1px solid rgba(26,45,90,0.12); }
.donate-other-label { font-family: 'Cabin', sans-serif; font-size: 10px; font-weight: 700; letter-spacing: 2.5px; text-transform: uppercase; color: var(--muted); margin-bottom: 16px; }
.donate-other-links { display: flex; flex-direction: column; gap: 2px; }
.donate-other-link { font-family: 'Cabin', sans-serif; font-size: 11px; font-weight: 600; letter-spacing: 1px; color: var(--navy); padding: 14px 0; border-bottom: 1px solid rgba(26,45,90,0.08); transition: color 0.2s; }
.donate-other-link:hover { color: var(--red); }

/* ══════════════════════════════════════════
   CHARITABLE FORM — FULL OVERRIDE
   ══════════════════════════════════════════ */

/* Container reset */
body .charitable-campaign-container { background: transparent; box-shadow: none; border: none; border-radius: 0; }
body .charitable-campaign-row { padding: 0; margin: 0; max-width: 100%; }
body .charitable-campaign-column { padding: 0; }
body .charitable-field-section { padding: 0; }
body .charitable-campaign-field { padding: 0; }
body .charitable-campaign-field-inner { padding: 0; width: 100% !important; }

/* Form wrapper */
body #charitable-donation-form,
body .charitable-donation-form { background: white; padding: 36px; border-top: 4px solid var(--red); font-family: 'EB Garamond', Georgia, serif; }

/* Section headers */
body .charitable-form-header { font-family: 'Cabin', sans-serif; font-size: 10px; font-weight: 700; letter-spacing: 3px; text-transform: uppercase; color: var(--red); background: #fdf0ee; padding: 6px 12px; margin-bottom: 24px; border-left: 3px solid var(--red); display: inline-block; border-radius: 0; }

/* ── ONE TIME / RECURRING TOGGLE ── */
body ul.recurring-donation-options { list-style: none; display: grid; grid-template-columns: 1fr 1fr; gap: 3px; margin: 0 0 28px; padding: 0; background: rgba(26,45,90,0.08); }
body .recurring-donation-option { margin: 0; }
body .recurring-donation-option label { display: block; text-align: center; padding: 14px 12px; font-family: 'Cabin', sans-serif; font-size: 11px; font-weight: 700; letter-spacing: 2px; text-transform: uppercase; color: var(--muted); cursor: pointer; margin: 0; background: transparent; transition: background 0.2s, color 0.2s; }
body .recurring-donation-option input[type="radio"] { display: none; }
body .recurring-donation-option.selected label,
body .recurring-donation-option input[type="radio"]:checked ~ label { background: var(--navy); color: white; }

/* ── AMOUNT BUTTONS ── */
body ul.donation-amounts { list-style: none; display: grid; grid-template-columns: repeat(3, 1fr); gap: 3px; margin: 0 0 4px; padding: 0; }
body ul.donation-suggested-amount { margin-bottom: 24px; }
body .donation-amount { margin: 0; }
body .donation-amount label { display: block; text-align: center; padding: 20px 8px; font-family: 'Cinzel', Georgia, serif; font-size: 22px; font-weight: 700; color: var(--navy); background: var(--cream); border: 2px solid transparent; cursor: pointer; transition: all 0.15s; margin: 0; border-radius: 0; }
body .donation-amount label:hover { background: rgba(26,45,90,0.08); border-color: var(--navy); }
body .donation-amount input[type="radio"] { display: none; }
body .donation-amount.selected label,
body .donation-amount input[type="radio"]:checked + span { background: var(--navy) !important; color: var(--green-lt) !important; border-color: var(--navy) !important; }
body .donation-amount .description { display: none; }
body .recurring-details { display: none; }

/* Custom amount */
body .donation-amounts.donation-suggested-amount { grid-template-columns: 1fr; }
body .custom-donation-amount label { font-family: 'Cabin', sans-serif; font-size: 10px; font-weight: 700; letter-spacing: 2px; text-transform: uppercase; color: var(--muted); padding: 12px 0; background: transparent; border: none; text-align: left; font-size: 10px; }
body .custom-donation-input { width: 100%; padding: 14px 16px; font-family: 'EB Garamond', Georgia, serif; font-size: 20px; border: 1px solid rgba(26,45,90,0.20); background: white; color: var(--text); border-radius: 0; margin-top: 6px; outline: none; box-shadow: none; }
body .custom-donation-input:focus { border-color: var(--navy); }

/* Fieldsets */
body .charitable-fieldset { border: none; padding: 0; margin: 0 0 28px; }
body .charitable-fieldset:last-of-type { margin-bottom: 0; }

/* Donor details */
body .charitable-donor-details { background: var(--cream); padding: 18px 20px; border-left: 3px solid var(--green); margin-bottom: 12px; }
body .donor-address { display: none; }
body .donor-contact-details { font-family: 'EB Garamond', Georgia, serif; font-size: 17px; color: var(--muted); margin: 0 0 8px; }
body .charitable-change-user-details { margin: 0; }
body .charitable-change-user-details a { font-family: 'Cabin', sans-serif; font-size: 10px; font-weight: 700; letter-spacing: 1.5px; text-transform: uppercase; color: var(--red); }

/* Form fields */
body .charitable-form-field { margin-bottom: 18px; }
body .charitable-form-field label { font-family: 'Cabin', sans-serif; font-size: 10px; font-weight: 700; letter-spacing: 2px; text-transform: uppercase; color: var(--muted); display: block; margin-bottom: 8px; }
body .charitable-form-field label .required { color: var(--red); font-style: normal; }
body .charitable-form-field input[type="text"],
body .charitable-form-field input[type="email"] { width: 100%; padding: 14px 16px; font-family: 'EB Garamond', Georgia, serif; font-size: 18px; border: 1px solid rgba(26,45,90,0.20); background: white; color: var(--text); border-radius: 0; outline: none; box-shadow: none; }
body .charitable-form-field input[type="text"]:focus,
body .charitable-form-field input[type="email"]:focus { border-color: var(--navy); }

/* Stripe card */
body .StripeElement { border: 1px solid rgba(26,45,90,0.20) !important; padding: 14px 16px !important; background: white !important; border-radius: 0 !important; }

/* Gift Aid checkbox */
body .charitable-gift-aid-field { background: var(--cream); padding: 20px; border-left: 3px solid var(--green); margin: 20px 0; }
body .charitable-gift-aid-field label { font-family: 'EB Garamond', Georgia, serif; font-size: 16px; line-height: 1.65; color: #585854; display: flex; gap: 12px; align-items: flex-start; cursor: pointer; }
body .charitable-gift-aid-field input[type="checkbox"] { flex-shrink: 0; width: 18px; height: 18px; margin-top: 3px; accent-color: var(--navy); }

/* Submit button */
body .charitable-submit-field { margin-top: 28px; }
body button.donate-button,
body .charitable-button.donate-button { font-family: 'Cabin', sans-serif !important; font-size: 13px !important; font-weight: 700 !important; letter-spacing: 2.5px !important; text-transform: uppercase !important; background: var(--red) !important; color: white !important; padding: 20px !important; border: none !important; cursor: pointer !important; width: 100% !important; border-radius: 0 !important; transition: background 0.2s !important; display: block !important; }
body button.donate-button:hover,
body .charitable-button.donate-button:hover { background: var(--red-hover) !important; }

/* Error notices */
body .charitable-notice { background: #fdf0ee; border-left: 3px solid var(--red); padding: 14px 18px; margin-bottom: 20px; border-radius: 0; }
body .charitable-notice-errors { list-style: none; padding: 0; margin: 0; }
body .charitable-notice-errors li { font-family: 'Cabin', sans-serif; font-size: 12px; color: var(--red); margin-bottom: 4px; }
body .charitable-notice-errors li:last-child { margin-bottom: 0; }
body .charitable-notice-errors a { color: var(--red); text-decoration: underline; }

/* Hide campaign template chrome */
body .charitable-campaign-row.no-padding { display: none; }
body .charitable-template-tabs { display: none; }

/* ── DONATE PAGE RESPONSIVE ── */
@media (max-width: 920px) {
  .donate-hero { height: 360px; }
  .donate-hero-overlay { padding: 28px 24px; }
  .donate-hero-title { font-size: 36px; }
  .donate-impact-strip { grid-template-columns: repeat(3,1fr); }
  .donate-impact-item { padding: 16px 12px; }
  .donate-impact-num { font-size: 26px; }
  .donate-form-wrap { padding: 36px 20px 48px; }
  body #charitable-donation-form { padding: 24px 20px; }
  body ul.donation-amounts { grid-template-columns: repeat(2,1fr); }
}

/* Hide Charitable honeypot field */
input.charitable-hidden,
.charitable-hidden { 
  display: none !important; 
  visibility: hidden !important; 
  position: absolute !important; 
  left: -9999px !important; 
}

/* ── DONATION RECEIPT ── */
.campaign-donation-receipt body { background: var(--cream); }

.campaign-donation-receipt #page { max-width: 640px; margin: 0 auto; padding: 56px 40px 80px; }

.donation-summary {
  background: white;
  border-top: 4px solid var(--green);
  padding: 32px 36px;
  margin-bottom: 36px;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0;
}
.donation-summary dt {
  font-family: 'Cabin', sans-serif;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--muted);
  padding: 12px 0;
  border-bottom: 1px solid rgba(26,45,90,0.08);
}
.donation-summary dd {
  font-family: 'EB Garamond', Georgia, serif;
  font-size: 18px;
  color: var(--navy);
  padding: 10px 0;
  border-bottom: 1px solid rgba(26,45,90,0.08);
  margin: 0;
}
.donation-summary .donation-total { color: var(--text); font-weight: 700; }
.donation-summary .donation-summary-value:last-child,
.donation-summary dt:last-of-type { border-bottom: none; }

.charitable-header {
  font-family: 'Cabin', sans-serif;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 3px;
  text-transform: uppercase;
  color: var(--red);
  background: #fdf0ee;
  padding: 6px 12px;
  margin-bottom: 16px;
  border-left: 3px solid var(--red);
  display: inline-block;
}

.charitable-table {
  width: 100%;
  border-collapse: collapse;
  margin-bottom: 36px;
  font-family: 'EB Garamond', Georgia, serif;
}
.charitable-table thead tr {
  background: var(--navy);
}
.charitable-table thead th {
  font-family: 'Cabin', sans-serif;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: rgba(255,255,255,0.70);
  padding: 12px 16px;
  text-align: left;
}
.charitable-table tbody td {
  padding: 14px 16px;
  font-size: 18px;
  color: var(--text);
  border-bottom: 1px solid rgba(26,45,90,0.08);
  background: white;
}
.charitable-table tfoot td {
  padding: 14px 16px;
  font-family: 'Cabin', sans-serif;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  color: var(--navy);
  background: var(--cream);
  border-top: 2px solid var(--navy);
}

.charitable-donation-options input.custom-donation-input { width: 100%; }