/*
Theme Name: Spring Together
Theme URI: https://springtogether.org
Author: Spring Together CIC
Description: Official WordPress theme for Spring Together CIC. UK GDPR compliant, WCAG 2.1 AA, fully responsive, truly full-width.
Version: 3.3.0
Requires at least: 5.9
Tested up to: 6.7
Requires PHP: 7.2
License: GNU General Public License v2 or later
Text Domain: spring-together
*/

/* ============================================================
   DESIGN TOKENS
   ============================================================ */
:root {
  --st-teal:#4B9696;--st-teal-dark:#3A7878;--st-teal-light:#EAF4F4;
  --st-green:#4B9678;--st-green-dark:#3A7860;--st-green-light:#EAF4EF;
  --st-amber:#F0A54B;--st-amber-dark:#D48B30;--st-amber-light:#FDF3E3;
  --st-slate:#2D3B45;--st-white:#FFFFFF;--st-cream:#F7FAFA;
  --st-grey:#6B7F88;--st-grey-light:#F0F4F5;--st-border:#DDE7E8;
  --font-head:'Nunito','Segoe UI',Arial,sans-serif;
  --font-body:'Nunito','Helvetica Neue',Arial,sans-serif;
  --container:1200px;--radius:10px;--radius-lg:20px;
  --shadow-xs:0 1px 4px rgba(45,59,69,.07);
  --shadow-sm:0 2px 12px rgba(45,59,69,.09);
  --shadow-md:0 8px 32px rgba(45,59,69,.11);
  --shadow-lg:0 20px 60px rgba(45,59,69,.15);
  --ease:cubic-bezier(.4,0,.2,1);
}

/* ============================================================
   HARD RESET — truly full width, no browser gaps
   ============================================================ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

html{
  width:100%;height:100%;font-size:16px;
  scroll-behavior:smooth;-webkit-text-size-adjust:100%;overflow-x:hidden;
}

body{
  width:100%;min-height:100%;margin:0;padding:0;overflow-x:hidden;
  font-family:var(--font-body);font-size:1rem;line-height:1.75;
  color:var(--st-slate);background:var(--st-cream);
  -webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;
}

/* WordPress wrappers — must be full width */
#page,.site,#content,.site-content,.wp-site-blocks{
  width:100%;max-width:100%;
}

img{max-width:100%;height:auto;display:block;}
ul{list-style:none;}
a{color:var(--st-teal-dark);text-decoration:underline;text-underline-offset:3px;transition:color .2s;}
a:hover{color:var(--st-teal);}
nav a,.btn,.service-link,.footer-col a,.social-link,.donate-btn,.site-logo a,.partner-link,.footer-contact-link{text-decoration:none;}
h1,h2,h3,h4,h5,h6{font-family:var(--font-head);line-height:1.2;font-weight:800;color:var(--st-slate);}

/* ============================================================
   ACCESSIBILITY
   ============================================================ */
*:focus-visible{outline:3px solid var(--st-teal);outline-offset:3px;border-radius:4px;}
.skip-link{position:absolute;top:-120px;left:16px;padding:12px 20px;background:var(--st-teal);color:#fff;font-weight:700;border-radius:0 0 10px 10px;z-index:99999;text-decoration:none;transition:top .2s;}
.skip-link:focus{top:0;}
.screen-reader-text{clip:rect(1px,1px,1px,1px);clip-path:inset(50%);height:1px;width:1px;overflow:hidden;position:absolute;word-wrap:normal;}

@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms!important;transition-duration:.01ms!important;scroll-behavior:auto!important;}
}

/* ============================================================
   LAYOUT
   ============================================================ */
.container{width:100%;max-width:var(--container);margin-left:auto;margin-right:auto;padding-left:24px;padding-right:24px;}
.section-pad{padding:90px 0;}
.text-center{text-align:center;}

.section-label{display:inline-flex;align-items:center;gap:8px;font-size:.72rem;font-weight:800;letter-spacing:.14em;text-transform:uppercase;color:var(--st-teal);margin-bottom:12px;}
.section-label::before{content:'';display:inline-block;width:22px;height:2px;background:var(--st-teal);border-radius:2px;flex-shrink:0;}
.section-title{font-size:clamp(1.8rem,3.5vw,2.8rem);margin-bottom:16px;}
.section-subtitle{font-size:1.05rem;color:var(--st-grey);max-width:620px;margin:0 auto 52px;line-height:1.85;}

.bg-white{background:#fff;}.bg-cream{background:var(--st-cream);}
.bg-teal-light{background:var(--st-teal-light);}.bg-slate{background:var(--st-slate);}

/* ============================================================
   BUTTONS
   ============================================================ */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:14px 32px;border-radius:50px;font-family:var(--font-body);font-size:.95rem;font-weight:700;cursor:pointer;border:2px solid transparent;transition:all .25s var(--ease);text-decoration:none;min-height:48px;white-space:nowrap;line-height:1.3;}
.btn-primary{background:var(--st-teal);color:#fff;border-color:var(--st-teal);}
.btn-primary:hover{background:var(--st-teal-dark);border-color:var(--st-teal-dark);color:#fff;transform:translateY(-2px);box-shadow:var(--shadow-md);}
.btn-amber{background:var(--st-amber);color:var(--st-slate);border-color:var(--st-amber);}
.btn-amber:hover{background:var(--st-amber-dark);border-color:var(--st-amber-dark);color:var(--st-slate);transform:translateY(-2px);}
.btn-outline{background:transparent;color:#fff;border-color:rgba(255,255,255,.65);}
.btn-outline:hover{background:#fff;color:var(--st-teal-dark);border-color:#fff;}
.btn-outline-teal{background:transparent;color:var(--st-teal);border-color:var(--st-teal);}
.btn-outline-teal:hover{background:var(--st-teal);color:#fff;}

/* ============================================================
   COOKIE BANNER
   ============================================================ */
.cookie-banner{position:fixed;bottom:0;left:0;width:100%;z-index:9990;background:var(--st-slate);color:rgba(255,255,255,.9);padding:18px 0;transform:translateY(110%);transition:transform .4s var(--ease);border-top:3px solid var(--st-teal);}
.cookie-banner.visible{transform:translateY(0);}
.cookie-inner{display:flex;align-items:center;gap:24px;flex-wrap:wrap;}
.cookie-text{flex:1;font-size:.875rem;line-height:1.65;min-width:240px;}
.cookie-text a{color:var(--st-amber);}
.cookie-actions{display:flex;gap:10px;flex-wrap:wrap;flex-shrink:0;}
.cookie-btn{padding:10px 20px;border-radius:50px;font-size:.85rem;font-weight:700;cursor:pointer;min-height:44px;font-family:var(--font-body);border:none;transition:all .2s;}
.cookie-btn.accept{background:var(--st-teal);color:#fff;}
.cookie-btn.accept:hover{background:var(--st-teal-dark);}
.cookie-btn.decline{background:transparent;color:rgba(255,255,255,.7);border:1px solid rgba(255,255,255,.3);}
.cookie-btn.decline:hover{background:rgba(255,255,255,.1);color:#fff;}

/* ============================================================
   HEADER — fixed, full width
   ============================================================ */
.site-header{position:fixed;top:0;left:0;width:100%;z-index:1000;background:rgba(255,255,255,.97);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-bottom:1px solid var(--st-border);transition:box-shadow .3s var(--ease);}
.site-header.scrolled{box-shadow:var(--shadow-md);}
.header-inner{display:flex;align-items:center;justify-content:space-between;height:80px;gap:20px;}
.site-logo a{display:flex;align-items:center;text-decoration:none;}
.site-logo img{height:54px;max-width:230px;width:auto;object-fit:contain;display:block;background:transparent!important;}
.primary-nav ul{display:flex;align-items:center;gap:2px;flex-wrap:nowrap;}
.primary-nav ul li a{display:flex;align-items:center;padding:8px 13px;font-size:.85rem;font-weight:600;color:var(--st-slate);border-radius:8px;transition:all .2s;min-height:44px;text-decoration:none;white-space:nowrap;}
.primary-nav ul li a:hover,.primary-nav ul li.current-menu-item>a{color:var(--st-teal);background:var(--st-teal-light);}
.header-cta{display:flex;align-items:center;gap:10px;flex-shrink:0;}
.donate-btn{background:var(--st-amber);color:var(--st-slate);padding:10px 22px;border-radius:50px;font-size:.875rem;font-weight:700;display:flex;align-items:center;gap:6px;min-height:44px;transition:all .25s;text-decoration:none;white-space:nowrap;}
.donate-btn:hover{background:var(--st-amber-dark);color:var(--st-slate);transform:translateY(-1px);box-shadow:0 4px 16px rgba(240,165,75,.3);}
.menu-toggle{display:none;flex-direction:column;justify-content:center;gap:5px;background:none;border:1px solid var(--st-border);border-radius:8px;cursor:pointer;padding:10px;min-width:44px;min-height:44px;flex-shrink:0;}
.menu-toggle span{display:block;width:22px;height:2px;background:var(--st-slate);border-radius:2px;transition:all .3s var(--ease);}
.menu-toggle[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg);}
.menu-toggle[aria-expanded="true"] span:nth-child(2){opacity:0;transform:scaleX(0);}
.menu-toggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg);}

/* ============================================================
   HERO — truly full screen
   ============================================================ */
.hero{width:100%;min-height:100vh;min-height:100svh;display:flex;align-items:center;position:relative;overflow:hidden;padding-top:80px;background:linear-gradient(145deg,#2A5F5F 0%,var(--st-teal) 45%,var(--st-green) 100%);}
.hero::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 10% 60%,rgba(240,165,75,.18) 0%,transparent 55%),radial-gradient(ellipse at 90% 20%,rgba(255,255,255,.07) 0%,transparent 45%);pointer-events:none;}
.hero-pattern{position:absolute;inset:0;background-image:radial-gradient(rgba(255,255,255,.1) 1px,transparent 1px);background-size:30px 30px;pointer-events:none;}
.hero-bg-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.2;pointer-events:none;}
.hero .container{position:relative;z-index:2;width:100%;}
.hero-grid{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center;}
.hero-badge{display:inline-flex;align-items:center;gap:8px;background:rgba(255,255,255,.15);border:1px solid rgba(255,255,255,.3);color:#fff;padding:7px 18px;border-radius:50px;font-size:.78rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;margin-bottom:24px;}
.hero-dot{width:7px;height:7px;background:var(--st-amber);border-radius:50%;animation:heroBlink 2s ease-in-out infinite;}
@keyframes heroBlink{0%,100%{opacity:1;transform:scale(1);}50%{opacity:.6;transform:scale(1.3);}}
.hero h1{font-size:clamp(2.2rem,5vw,4rem);color:#fff;line-height:1.1;margin-bottom:20px;}
.hero h1 em{font-style:normal;color:var(--st-amber);}
.hero-desc{font-size:1.1rem;color:rgba(255,255,255,.88);margin-bottom:36px;line-height:1.85;max-width:540px;}
.hero-btns{display:flex;gap:14px;flex-wrap:wrap;}
.hero-trust{display:flex;gap:36px;margin-top:52px;padding-top:32px;border-top:1px solid rgba(255,255,255,.2);flex-wrap:wrap;}
.trust-num{font-size:1.8rem;font-weight:800;color:var(--st-amber);display:block;line-height:1;}
.trust-label{font-size:.72rem;color:rgba(255,255,255,.7);text-transform:uppercase;letter-spacing:.08em;margin-top:4px;display:block;}
.hero-visual{position:relative;display:flex;align-items:center;justify-content:center;}
.hero-flower{width:100%;max-width:420px;}
.hero-card-float{position:absolute;background:#fff;border-radius:var(--radius);padding:14px 18px;box-shadow:var(--shadow-lg);display:flex;align-items:center;gap:12px;min-width:170px;animation:floatCard 4s ease-in-out infinite;}
.hero-card-float.card-1{bottom:10%;left:-5%;animation-delay:0s;}
.hero-card-float.card-2{top:15%;right:-5%;animation-delay:2s;}
@keyframes floatCard{0%,100%{transform:translateY(0);}50%{transform:translateY(-8px);}}
.float-icon{width:42px;height:42px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:1.3rem;flex-shrink:0;}
.float-icon.teal{background:var(--st-teal-light);}
.float-icon.amber{background:var(--st-amber-light);}
.float-card-text strong{display:block;font-size:1rem;font-weight:800;color:var(--st-teal);}
.float-card-text span{font-size:.72rem;color:var(--st-grey);}

/* ============================================================
   PARTNER STRIP
   ============================================================ */
.partner-strip{width:100%;background:#fff;border-bottom:1px solid var(--st-border);}
.partner-strip-inner{display:flex;align-items:stretch;flex-wrap:wrap;}
.partner-item{display:flex;align-items:center;gap:10px;padding:16px 28px;font-size:.875rem;font-weight:600;color:var(--st-slate);border-right:1px solid var(--st-border);flex:1;justify-content:center;min-width:160px;}
.partner-item:last-child{border-right:none;}
.partner-icon{font-size:1.2rem;}

/* ============================================================
   ABOUT
   ============================================================ */
.about-section{background:#fff;}
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:72px;align-items:center;}
.about-img-wrap{position:relative;}
.about-img{border-radius:var(--radius-lg);width:100%;aspect-ratio:4/3;object-fit:cover;box-shadow:var(--shadow-lg);display:block;}
.about-img-placeholder{border-radius:var(--radius-lg);width:100%;aspect-ratio:4/3;background:linear-gradient(135deg,var(--st-teal-light),var(--st-green-light));display:flex;align-items:center;justify-content:center;font-size:5rem;box-shadow:var(--shadow-lg);}
.about-float{position:absolute;bottom:-20px;right:-20px;background:#fff;border-radius:var(--radius);padding:16px 20px;box-shadow:var(--shadow-md);border:1px solid var(--st-border);display:flex;align-items:center;gap:12px;}
.about-float-icon{width:44px;height:44px;background:var(--st-amber-light);border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:1.4rem;flex-shrink:0;}
.about-float strong{display:block;font-size:1.3rem;font-weight:800;color:var(--st-amber);}
.about-float span{font-size:.72rem;color:var(--st-grey);}
.about-content p{color:var(--st-grey);line-height:1.85;margin-bottom:14px;}
.pillars{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin:24px 0;}
.pillar{display:flex;align-items:flex-start;gap:12px;padding:14px;background:var(--st-cream);border-radius:var(--radius);border:1px solid var(--st-border);}
.pillar-icon{width:38px;height:38px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:1.1rem;flex-shrink:0;background:var(--st-teal-light);}
.pillar h4{font-size:.875rem;font-weight:700;color:var(--st-slate);margin-bottom:2px;}
.pillar p{font-size:.78rem;color:var(--st-grey);line-height:1.55;}

/* ============================================================
   SERVICES
   ============================================================ */
.services-section{background:var(--st-cream);}
.services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:52px;}
.service-card{background:#fff;border-radius:var(--radius-lg);padding:36px 28px;border:1.5px solid var(--st-border);transition:all .3s var(--ease);position:relative;overflow:hidden;}
.service-card::after{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:var(--card-color,var(--st-teal));transform:scaleX(0);transform-origin:left;transition:transform .35s var(--ease);}
.service-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg);border-color:transparent;}
.service-card:hover::after{transform:scaleX(1);}
.service-icon{width:58px;height:58px;border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:1.6rem;margin-bottom:20px;}
.service-card h3{font-size:1.1rem;margin-bottom:10px;}
.service-card p{font-size:.875rem;color:var(--st-grey);line-height:1.75;margin-bottom:20px;}
.service-link{font-size:.85rem;font-weight:700;color:var(--card-color,var(--st-teal));display:inline-flex;align-items:center;gap:6px;text-decoration:none;transition:gap .2s;}
.service-link:hover{gap:10px;}

/* ============================================================
   PARTNERS
   ============================================================ */
.partners-section{background:#fff;}
.partners-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:52px;}
.partner-card{background:var(--st-cream);border-radius:var(--radius-lg);padding:32px 24px;text-align:center;border:1.5px solid var(--st-border);transition:all .3s var(--ease);display:flex;flex-direction:column;align-items:center;}
.partner-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:var(--st-teal);}
.partner-logo-wrap{width:140px;height:80px;display:flex;align-items:center;justify-content:center;margin-bottom:20px;overflow:hidden;}
.partner-logo-wrap img{max-width:100%;max-height:100%;object-fit:contain;}
.partner-logo-placeholder{width:80px;height:80px;border-radius:50%;background:var(--st-teal-light);display:flex;align-items:center;justify-content:center;font-size:2.5rem;}
.partner-card h3{font-size:1.05rem;margin-bottom:6px;}
.partner-role{font-size:.75rem;font-weight:700;color:var(--st-teal);text-transform:uppercase;letter-spacing:.08em;margin-bottom:12px;display:block;}
.partner-card p{font-size:.875rem;color:var(--st-grey);line-height:1.7;flex:1;}
.partner-link{display:inline-flex;align-items:center;gap:5px;margin-top:16px;font-size:.85rem;font-weight:700;color:var(--st-teal);text-decoration:none;transition:gap .2s;}
.partner-link:hover{gap:8px;}

/* ============================================================
   PROJECTS
   ============================================================ */
.projects-section{background:#fff;}
.projects-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px;margin-top:52px;}
.project-card{border-radius:var(--radius-lg);overflow:hidden;border:1.5px solid var(--st-border);background:#fff;transition:all .3s var(--ease);}
.project-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:transparent;}
.project-img{aspect-ratio:16/9;background:linear-gradient(135deg,var(--st-teal),var(--st-green));display:flex;align-items:center;justify-content:center;font-size:3rem;position:relative;overflow:hidden;}
.project-img img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;}
.project-tag{position:absolute;top:14px;left:14px;background:var(--st-amber);color:var(--st-slate);padding:3px 12px;border-radius:50px;font-size:.72rem;font-weight:800;text-transform:uppercase;letter-spacing:.06em;}
.project-body{padding:26px;}
.project-body h3{font-size:1.1rem;margin-bottom:8px;}
.project-body p{font-size:.875rem;color:var(--st-grey);line-height:1.75;}

/* ============================================================
   EVENTS
   ============================================================ */
.events-section{background:var(--st-cream);}
.events-list{margin-top:48px;display:flex;flex-direction:column;gap:16px;}
.event-card{display:flex;gap:22px;background:#fff;border-radius:var(--radius);padding:24px;border:1.5px solid var(--st-border);align-items:flex-start;transition:all .25s var(--ease);}
.event-card:hover{box-shadow:var(--shadow-md);border-color:var(--st-teal);}
.event-date{flex-shrink:0;width:62px;text-align:center;background:var(--st-teal);color:#fff;border-radius:10px;padding:10px 6px;}
.event-date .day{display:block;font-size:1.5rem;font-weight:800;line-height:1;}
.event-date .month{display:block;font-size:.65rem;text-transform:uppercase;letter-spacing:.1em;opacity:.85;margin-top:2px;}
.event-info h3{font-size:1rem;margin-bottom:5px;}
.event-info>p{font-size:.85rem;color:var(--st-grey);margin-bottom:8px;}
.event-meta{display:flex;gap:16px;flex-wrap:wrap;font-size:.78rem;color:var(--st-grey);}

/* ============================================================
   GALLERY
   ============================================================ */
.gallery-section{width:100%;background:var(--st-slate);}
.gallery-section .section-title{color:#fff;}
.gallery-section .section-label{color:var(--st-amber);}
.gallery-section .section-label::before{background:var(--st-amber);}
.gallery-section .section-subtitle{color:rgba(255,255,255,.65);}
.gallery-grid{display:grid;grid-template-columns:repeat(4,1fr);grid-template-rows:repeat(2,200px);gap:10px;margin-top:44px;}
.gallery-item{border-radius:var(--radius);overflow:hidden;position:relative;cursor:pointer;background:rgba(255,255,255,.06);display:flex;align-items:center;justify-content:center;font-size:2.5rem;}
.gallery-item:first-child{grid-column:span 2;grid-row:span 2;font-size:4rem;}
.gallery-item:nth-child(4){grid-column:span 2;}
.gallery-item img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .45s var(--ease);}
.gallery-overlay{position:absolute;inset:0;background:rgba(75,150,150,0);transition:background .3s;display:flex;align-items:center;justify-content:center;}
.gallery-overlay svg{color:#fff;opacity:0;transform:scale(.8);transition:all .3s;}
.gallery-item:hover img{transform:scale(1.06);}
.gallery-item:hover .gallery-overlay{background:rgba(75,150,150,.55);}
.gallery-item:hover .gallery-overlay svg{opacity:1;transform:scale(1);}

/* ============================================================
   VOLUNTEER
   ============================================================ */
.volunteer-section{width:100%;background:linear-gradient(145deg,#2A5F5F,var(--st-teal));position:relative;overflow:hidden;}
.volunteer-section::before{content:'';position:absolute;inset:0;background-image:radial-gradient(rgba(255,255,255,.07) 1px,transparent 1px);background-size:28px 28px;pointer-events:none;}
.volunteer-inner{position:relative;z-index:2;display:grid;grid-template-columns:1fr 1fr;gap:72px;align-items:start;}
.volunteer-content .section-label{color:var(--st-amber);}
.volunteer-content .section-label::before{background:var(--st-amber);}
.volunteer-content .section-title{color:#fff;}
.volunteer-content p{color:rgba(255,255,255,.88);margin-bottom:14px;}
.vol-perks{margin:28px 0;display:flex;flex-direction:column;gap:12px;}
.vol-perk{display:flex;align-items:center;gap:12px;color:rgba(255,255,255,.9);font-size:.9rem;}
.vol-perk-icon{width:36px;height:36px;background:rgba(255,255,255,.15);border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:1rem;flex-shrink:0;}

/* ============================================================
   FORMS
   ============================================================ */
.form-box{background:#fff;border-radius:var(--radius-lg);padding:40px;box-shadow:var(--shadow-lg);}
.form-box h3{font-size:1.25rem;margin-bottom:24px;}
.form-group{margin-bottom:18px;}
.form-group label{display:block;font-size:.85rem;font-weight:700;color:var(--st-slate);margin-bottom:6px;}
.form-group label .req{color:var(--st-amber-dark);margin-left:2px;}
.form-group input,.form-group select,.form-group textarea{width:100%;padding:12px 16px;border:1.5px solid var(--st-border);border-radius:8px;font-family:var(--font-body);font-size:.9rem;color:var(--st-slate);background:var(--st-cream);transition:border-color .2s,box-shadow .2s;outline:none;min-height:48px;appearance:auto;}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--st-teal);background:#fff;box-shadow:0 0 0 3px rgba(75,150,150,.18);}
.form-group textarea{resize:vertical;min-height:110px;}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;}
.form-consent{display:flex;align-items:flex-start;gap:10px;font-size:.8rem;color:var(--st-grey);line-height:1.6;cursor:pointer;}
.form-consent input[type="checkbox"]{width:18px;height:18px;min-height:auto;flex-shrink:0;margin-top:2px;accent-color:var(--st-teal);cursor:pointer;}
.form-consent a{color:var(--st-teal);}
.form-msg{display:none;margin-top:14px;padding:12px 16px;border-radius:8px;font-size:.875rem;font-weight:600;}
.form-msg.success{background:var(--st-teal-light);color:var(--st-teal-dark);border:1px solid var(--st-teal);}
.form-msg.error{background:#FDE8EA;color:#B91C1C;border:1px solid #F9A8B0;}
.honeypot{position:absolute;left:-9999px;top:-9999px;}
input.invalid,select.invalid,textarea.invalid{border-color:#E8394A;box-shadow:0 0 0 3px rgba(232,57,74,.12);}

/* ============================================================
   FAQ
   ============================================================ */
.faq-section{background:#fff;}
.faq-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:52px;}
.faq-item{border:1.5px solid var(--st-border);border-radius:var(--radius);overflow:hidden;transition:border-color .2s;}
.faq-item.active{border-color:var(--st-teal);}
.faq-question{width:100%;display:flex;justify-content:space-between;align-items:center;padding:18px 22px;background:none;border:none;cursor:pointer;font-family:var(--font-body);font-size:.9rem;font-weight:700;color:var(--st-slate);text-align:left;gap:12px;transition:background .2s;min-height:56px;}
.faq-question:hover{background:var(--st-teal-light);}
.faq-icon{flex-shrink:0;width:28px;height:28px;background:var(--st-teal-light);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--st-teal);font-size:1.2rem;transition:all .3s;}
.faq-item.active .faq-icon{background:var(--st-teal);color:#fff;transform:rotate(45deg);}
.faq-answer{max-height:0;overflow:hidden;transition:max-height .4s var(--ease);}
.faq-item.active .faq-answer{max-height:400px;}
.faq-answer-inner{padding:0 22px 18px;font-size:.875rem;color:var(--st-grey);line-height:1.85;}

/* ============================================================
   SAFEGUARDING
   ============================================================ */
.safeguarding-section{width:100%;background:var(--st-teal-light);border-top:3px solid var(--st-teal);border-bottom:3px solid var(--st-teal);}
.safeguarding-inner{display:grid;grid-template-columns:auto 1fr;gap:56px;align-items:start;}
.sg-icon{width:100px;height:100px;background:var(--st-teal);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:3rem;flex-shrink:0;box-shadow:var(--shadow-md);}
.sg-content h2{font-size:2rem;margin-bottom:14px;}
.sg-content p{color:var(--st-grey);line-height:1.85;margin-bottom:14px;}
.sg-points{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin:20px 0;}
.sg-point{display:flex;align-items:flex-start;gap:8px;font-size:.875rem;color:var(--st-slate);}
.sg-check{color:var(--st-teal);font-weight:800;font-size:1rem;flex-shrink:0;margin-top:1px;}
.dsl-card{background:#fff;border-radius:var(--radius);padding:18px 22px;margin-top:20px;border-left:4px solid var(--st-teal);box-shadow:var(--shadow-xs);}
.dsl-label{font-size:.7rem;font-weight:800;text-transform:uppercase;letter-spacing:.1em;color:var(--st-teal);display:block;margin-bottom:3px;}
.dsl-name{font-weight:700;font-size:.95rem;color:var(--st-slate);}
.dsl-info{font-size:.83rem;color:var(--st-grey);margin-top:4px;}
.dsl-info a{color:var(--st-teal);}

/* ============================================================
   CONTACT
   ============================================================ */
.contact-section{background:var(--st-cream);}
.contact-grid{display:grid;grid-template-columns:1fr 1.6fr;gap:60px;margin-top:52px;}
.contact-block{margin-bottom:28px;}
.contact-block h4{font-size:.72rem;font-weight:800;text-transform:uppercase;letter-spacing:.12em;color:var(--st-teal);margin-bottom:7px;display:flex;align-items:center;gap:6px;}
.contact-block h4::before{content:'';width:14px;height:2px;background:var(--st-teal);border-radius:2px;}
.contact-block p,.contact-block a{font-size:.9rem;color:var(--st-slate);line-height:1.75;}
.contact-socials{display:flex;gap:10px;margin-top:28px;}
.social-link{width:44px;height:44px;background:#fff;border:1.5px solid var(--st-border);border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:1.1rem;text-decoration:none;transition:all .2s;}
.social-link:hover{background:var(--st-teal);color:#fff;border-color:var(--st-teal);transform:translateY(-2px);}

/* ============================================================
   CTA
   ============================================================ */
.cta-section{width:100%;background:linear-gradient(145deg,#2A5F5F,var(--st-teal));position:relative;overflow:hidden;}
.cta-section::before{content:'';position:absolute;inset:0;background-image:radial-gradient(rgba(255,255,255,.07) 1px,transparent 1px);background-size:28px 28px;pointer-events:none;}
.cta-section .container{position:relative;z-index:2;}
.cta-section h2{color:#fff;font-size:clamp(1.8rem,3.5vw,2.6rem);margin-bottom:14px;}

/* ============================================================
   PAGE HERO (inner pages)
   ============================================================ */
.page-hero{width:100%;padding:calc(80px + 60px) 0 60px;background:linear-gradient(145deg,#2A5F5F 0%,var(--st-teal) 45%,var(--st-green) 100%);background-size:cover;background-position:center;position:relative;overflow:hidden;}
.page-hero::before{content:'';position:absolute;inset:0;background:rgba(45,59,69,.5);pointer-events:none;}
.page-hero .container{position:relative;z-index:2;}
.page-hero h1{font-size:clamp(2rem,4.5vw,3.2rem);color:#fff;margin-bottom:12px;line-height:1.15;}
.page-hero>.container>p{font-size:1.1rem;color:rgba(255,255,255,.88);max-width:640px;line-height:1.75;margin-bottom:20px;}
.page-breadcrumb{display:flex;align-items:center;gap:8px;font-size:.85rem;color:rgba(255,255,255,.7);}
.page-breadcrumb a{color:var(--st-amber);text-decoration:none;}
.page-breadcrumb a:hover{text-decoration:underline;}
.page-breadcrumb span{color:rgba(255,255,255,.5);}

/* ============================================================
   ABOUT PAGE INTERNALS
   ============================================================ */
.mv-grid{display:grid;grid-template-columns:1fr 1fr;gap:28px;}
.mv-card{border-radius:var(--radius-lg);padding:40px 36px;text-align:center;}
.mv-card.mv-teal{background:var(--st-teal-light);border:2px solid var(--st-teal);}
.mv-card.mv-green{background:var(--st-green-light);border:2px solid var(--st-green);}
.mv-icon{font-size:2.8rem;margin-bottom:16px;}
.mv-card h2{font-size:1.4rem;margin-bottom:12px;}
.mv-card p{color:var(--st-grey);line-height:1.8;}
.story-grid{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center;}
.story-image{border-radius:var(--radius-lg);width:100%;aspect-ratio:4/3;object-fit:cover;box-shadow:var(--shadow-lg);}
.placeholder-img{background:var(--st-teal-light);display:flex;align-items:center;justify-content:center;font-size:4rem;border-radius:var(--radius-lg);aspect-ratio:4/3;}
.about-stats-row{display:flex;gap:32px;margin-top:32px;padding-top:24px;border-top:1px solid var(--st-border);flex-wrap:wrap;}
.about-stat strong{display:block;font-size:1.6rem;font-weight:800;color:var(--st-teal);line-height:1;}
.about-stat span{font-size:.75rem;color:var(--st-grey);text-transform:uppercase;letter-spacing:.07em;margin-top:4px;display:block;}
.team-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px;margin-top:52px;}
.team-card{background:var(--st-cream);border-radius:var(--radius-lg);padding:32px 24px;text-align:center;border:1.5px solid var(--st-border);transition:all .3s var(--ease);}
.team-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);border-color:var(--st-teal);}
.team-photo{width:110px;height:110px;border-radius:50%;overflow:hidden;margin:0 auto 20px;border:3px solid var(--st-teal);}
.team-photo img{width:100%;height:100%;object-fit:cover;}
.team-photo-placeholder{width:100%;height:100%;background:var(--st-teal-light);display:flex;align-items:center;justify-content:center;font-size:2.5rem;}
.team-role{font-size:.8rem;font-weight:700;color:var(--st-teal);text-transform:uppercase;letter-spacing:.08em;margin-bottom:10px;display:block;}
.team-bio{font-size:.875rem;color:var(--st-grey);line-height:1.7;}
.values-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-top:48px;}
.value-card{background:#fff;border-radius:var(--radius);padding:28px 20px;border:1.5px solid var(--st-border);transition:all .3s;}
.value-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-md);border-color:var(--st-teal);}
.value-icon{font-size:2.2rem;margin-bottom:14px;}
.value-card h3{font-size:1rem;margin-bottom:8px;}
.value-card p{font-size:.85rem;color:var(--st-grey);line-height:1.7;}

/* GALLERY PAGE */
.full-gallery-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;}
.full-gallery-grid .gallery-item{height:220px;}

/* POLICY */
.policy-content h2{font-size:1.4rem;margin:28px 0 12px;}
.policy-content h3{font-size:1.1rem;margin:20px 0 8px;}
.policy-content p{color:var(--st-grey);margin-bottom:14px;line-height:1.85;}
.policy-content ul{list-style:disc;padding-left:24px;margin-bottom:14px;}
.policy-content ul li{color:var(--st-grey);margin-bottom:6px;line-height:1.75;}

/* ============================================================
   LIGHTBOX
   ============================================================ */
.lightbox-overlay{position:fixed;inset:0;background:rgba(0,0,0,.94);z-index:9999;display:none;align-items:center;justify-content:center;}
.lightbox-overlay.active{display:flex;}
.lightbox-close{position:absolute;top:20px;right:20px;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.2);color:#fff;width:44px;height:44px;border-radius:50%;font-size:1.2rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s;}
.lightbox-close:hover{background:rgba(255,255,255,.25);}
.lightbox-img{max-width:92vw;max-height:88vh;border-radius:8px;}

/* ============================================================
   CHAT WIDGET
   ============================================================ */
.ai-chat-bubble{position:fixed;bottom:24px;right:24px;z-index:8000;}
.chat-toggle-btn{width:58px;height:58px;background:linear-gradient(135deg,var(--st-teal),var(--st-green));border:none;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 24px rgba(75,150,150,.4);transition:all .3s;position:relative;}
.chat-toggle-btn:hover{transform:scale(1.08);}
.chat-notification{position:absolute;top:-3px;right:-3px;width:16px;height:16px;background:var(--st-amber);border-radius:50%;border:2px solid #fff;animation:heroBlink 2s ease-in-out infinite;}
.chat-window{position:absolute;bottom:72px;right:0;width:360px;background:#fff;border-radius:20px;box-shadow:0 20px 64px rgba(0,0,0,.18);display:none;flex-direction:column;overflow:hidden;border:1px solid var(--st-border);}
.chat-window.open{display:flex;}
.chat-header{background:linear-gradient(135deg,var(--st-teal-dark),var(--st-teal));padding:14px 18px;display:flex;align-items:center;gap:12px;}
.chat-avatar{width:40px;height:40px;background:rgba(255,255,255,.2);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.2rem;flex-shrink:0;}
.chat-header-info .chat-name{color:#fff;font-weight:700;font-size:.9rem;display:block;}
.chat-header-info .chat-status{color:rgba(255,255,255,.75);font-size:.72rem;display:flex;align-items:center;gap:4px;}
.online-dot{width:6px;height:6px;background:var(--st-amber);border-radius:50%;}
.chat-messages{flex:1;padding:16px;overflow-y:auto;max-height:300px;display:flex;flex-direction:column;gap:10px;background:var(--st-cream);}
.chat-msg{max-width:82%;padding:10px 14px;border-radius:14px;font-size:.85rem;line-height:1.6;}
.chat-msg.bot{background:#fff;color:var(--st-slate);border:1px solid var(--st-border);align-self:flex-start;border-bottom-left-radius:3px;}
.chat-msg.user{background:var(--st-teal);color:#fff;align-self:flex-end;border-bottom-right-radius:3px;}
.chat-quick-btns{display:flex;flex-wrap:wrap;gap:5px;padding:0 16px 10px;background:var(--st-cream);}
.quick-btn{background:#fff;border:1.5px solid var(--st-teal);color:var(--st-teal);padding:4px 11px;border-radius:50px;font-size:.73rem;font-weight:700;cursor:pointer;transition:all .2s;font-family:var(--font-body);}
.quick-btn:hover{background:var(--st-teal);color:#fff;}
.chat-input-row{padding:10px 14px;border-top:1px solid var(--st-border);display:flex;gap:8px;align-items:center;}
.chat-input-field{flex:1;border:1.5px solid var(--st-border);border-radius:50px;padding:9px 16px;font-family:var(--font-body);font-size:.85rem;outline:none;color:var(--st-slate);background:var(--st-cream);min-height:42px;}
.chat-input-field:focus{border-color:var(--st-teal);box-shadow:0 0 0 3px rgba(75,150,150,.18);}
.chat-send-btn{width:36px;height:36px;background:var(--st-teal);border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s;flex-shrink:0;}
.chat-send-btn:hover{background:var(--st-teal-dark);}
.chat-gdpr-note{padding:6px 16px 10px;font-size:.7rem;color:var(--st-grey);text-align:center;background:var(--st-cream);border-top:1px solid var(--st-border);}
.chat-gdpr-note a{color:var(--st-teal);}

/* ============================================================
   FOOTER — full width
   ============================================================ */
.site-footer{width:100%;background:var(--st-slate);color:rgba(255,255,255,.7);}
.footer-top{padding:72px 0 52px;display:grid;grid-template-columns:2.2fr 1fr 1fr 1fr;gap:44px;border-bottom:1px solid rgba(255,255,255,.08);}
.footer-brand p{font-size:.875rem;line-height:1.85;color:rgba(255,255,255,.6);margin:16px 0 22px;max-width:280px;}
.footer-reg{font-size:.75rem;color:rgba(255,255,255,.4);line-height:1.75;}
.footer-logo-img{height:44px;width:auto;filter:brightness(0) invert(1);opacity:.9;display:block;margin-bottom:4px;}
.footer-col h5{font-size:.72rem;font-weight:800;text-transform:uppercase;letter-spacing:.12em;color:rgba(255,255,255,.9);margin-bottom:18px;}
.footer-col ul{display:flex;flex-direction:column;gap:9px;}
.footer-col ul li a{font-size:.875rem;color:rgba(255,255,255,.55);text-decoration:none;transition:color .2s;}
.footer-col ul li a:hover{color:var(--st-amber);}
.footer-contact-link{font-size:.875rem;color:rgba(255,255,255,.55);text-decoration:none;display:block;margin-bottom:8px;transition:color .2s;}
.footer-contact-link:hover{color:var(--st-amber);}
.footer-socials{display:flex;gap:10px;margin-top:20px;}
.footer-social{width:38px;height:38px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.15);border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:1rem;text-decoration:none;transition:all .2s;}
.footer-social:hover{background:var(--st-teal);border-color:var(--st-teal);}
.footer-bottom{padding:22px 0;display:flex;justify-content:space-between;align-items:center;font-size:.78rem;color:rgba(255,255,255,.35);flex-wrap:wrap;gap:10px;}
.footer-bottom a{color:rgba(255,255,255,.35);text-decoration:none;}
.footer-bottom a:hover{color:var(--st-amber);}


/* ============================================================
   FULL SCREEN + RESPONSIVE FIX v3.2.0
   Removes theme/page boxed layouts and forces full browser-width
   sections while keeping readable inner content.
   ============================================================ */
html, body {
  width: 100% !important;
  max-width: 100% !important;
  margin: 0 !important;
  padding: 0 !important;
  overflow-x: clip;
}
#page, .site, #content, .site-content, .content-area, main, .site-main, .wp-site-blocks {
  width: 100% !important;
  max-width: none !important;
  margin: 0 !important;
  padding: 0 !important;
}
.site-header, .hero, .partner-strip, .about-section, .services-section, .partners-section, .projects-section,
.events-section, .gallery-section, .volunteer-section, .faq-section, .safeguarding-section, .contact-section,
.cta-section, .page-hero, .site-footer {
  width: 100vw !important;
  max-width: 100vw !important;
  margin-left: calc(50% - 50vw) !important;
  margin-right: calc(50% - 50vw) !important;
}
.container {
  width: min(100%, var(--container)) !important;
  max-width: var(--container) !important;
  margin-left: auto !important;
  margin-right: auto !important;
}
.hero {
  min-height: 100vh;
  min-height: 100dvh;
}
.hero .container {
  min-height: calc(100dvh - 80px);
  display: flex;
  align-items: center;
}
.hero-grid { width: 100%; }
.header-inner { width: 100%; }
@supports not (overflow-x: clip) {
  html, body { overflow-x: hidden; }
}
@media (min-width: 1400px) {
  :root { --container: 1320px; }
}
@media (max-width: 1100px) {
  .header-inner { gap: 12px; }
  .primary-nav ul li a { padding: 8px 9px; font-size: .8rem; }
  .donate-btn { padding: 9px 16px; }
}
@media (max-width: 900px) {
  .site-header { position: sticky; }
  .hero { min-height: auto; padding: 120px 0 70px; }
  .hero .container { min-height: 0; display: block; }
}
@media (max-width: 768px) {
  .container { padding-left: 18px !important; padding-right: 18px !important; }
  .hero { padding-top: 112px; padding-bottom: 58px; }
  .hero h1 { font-size: clamp(2rem, 11vw, 3rem); }
  .hero-desc { font-size: 1rem; max-width: 100%; }
  .hero-trust { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 18px; }
  .primary-nav { top: 80px; }
  .service-card, .partner-card, .project-card { width: 100%; }
}
@media (max-width: 480px) {
  .container { padding-left: 14px !important; padding-right: 14px !important; }
  .hero { padding-top: 104px; }
  .hero-trust { grid-template-columns: 1fr; }
  .hero-badge { font-size: .68rem; padding: 7px 12px; }
}

/* ============================================================
   RESPONSIVE — TABLET ≤1024px
   ============================================================ */
@media(max-width:1024px){
  .hero-grid{grid-template-columns:1fr;gap:40px;}
  .hero-visual{display:none;}
  .services-grid{grid-template-columns:repeat(2,1fr);}
  .partners-grid{grid-template-columns:repeat(2,1fr);}
  .footer-top{grid-template-columns:1fr 1fr;gap:32px;}
  .values-grid{grid-template-columns:repeat(2,1fr);}
  .team-grid{grid-template-columns:repeat(2,1fr);}
  .full-gallery-grid{grid-template-columns:repeat(3,1fr);}
}

/* ============================================================
   RESPONSIVE — MOBILE ≤768px
   ============================================================ */
@media(max-width:768px){
  .container{padding-left:18px;padding-right:18px;}
  .section-pad{padding:60px 0;}

  .primary-nav{display:none;position:fixed;top:80px;left:0;right:0;bottom:0;width:100%;background:#fff;padding:24px 18px;overflow-y:auto;z-index:999;border-top:1px solid var(--st-border);}
  .primary-nav.open{display:block;}
  .primary-nav.open ul{flex-direction:column;gap:4px;}
  .primary-nav.open ul li a{font-size:1rem;padding:14px 16px;min-height:54px;border-radius:10px;display:flex;align-items:center;}
  .menu-toggle{display:flex;}

  .about-grid,.volunteer-inner,.contact-grid,.safeguarding-inner,.story-grid,.mv-grid{grid-template-columns:1fr;gap:36px;}
  .pillars,.sg-points,.faq-grid{grid-template-columns:1fr;}
  .projects-grid,.services-grid,.team-grid,.partners-grid{grid-template-columns:1fr;}
  .values-grid{grid-template-columns:1fr 1fr;}
  .footer-top{grid-template-columns:1fr;gap:28px;}
  .footer-bottom{flex-direction:column;text-align:center;}
  .form-row{grid-template-columns:1fr;}

  .gallery-grid{display:grid;grid-template-columns:repeat(2,1fr);grid-template-rows:auto;}
  .gallery-item:first-child{grid-column:span 2;grid-row:span 1;}
  .gallery-item:nth-child(4){grid-column:span 1;}
  .full-gallery-grid{grid-template-columns:repeat(2,1fr);}

  .hero-trust{gap:20px;}
  .hero-btns{flex-direction:column;align-items:flex-start;}
  .hero-btns .btn{width:100%;justify-content:center;}

  .partner-strip-inner{flex-direction:column;}
  .partner-item{border-right:none;border-bottom:1px solid var(--st-border);width:100%;}
  .partner-item:last-child{border-bottom:none;}

  .about-float{position:static;margin-top:16px;}
  .chat-window{width:calc(100vw - 48px);max-width:340px;right:0;}
  .sg-icon{width:72px;height:72px;font-size:2.2rem;}
  .form-box{padding:24px 18px;}
}

/* ============================================================
   RESPONSIVE — SMALL MOBILE ≤480px
   ============================================================ */
@media(max-width:480px){
  .hero h1{font-size:1.9rem;}
  .section-title{font-size:1.7rem;}
  .page-hero h1{font-size:1.8rem;}
  .values-grid{grid-template-columns:1fr;}
  .full-gallery-grid{grid-template-columns:1fr;}
  .gallery-grid{grid-template-columns:1fr;}
  .gallery-item:first-child,.gallery-item:nth-child(4){grid-column:span 1;}
  .header-cta .donate-btn{padding:8px 14px;font-size:.8rem;}
  .btn{padding:13px 24px;font-size:.875rem;}
  .hero-trust{gap:16px;}
  .about-stats-row{gap:20px;}
}

/* PRINT */
@media print{
  .site-header,.ai-chat-bubble,.cookie-banner,.lightbox-overlay,.menu-toggle{display:none!important;}
  body{font-size:11pt;color:#000;background:#fff;}
  a[href]::after{content:" ("attr(href)")";font-size:9pt;}
}

/* WordPress */
.alignleft{float:left;margin:0 24px 16px 0;}
.alignright{float:right;margin:0 0 16px 24px;}
.aligncenter{display:block;margin:0 auto 24px;}
.wp-caption-text{font-size:.8rem;color:var(--st-grey);text-align:center;margin-top:6px;}

/* ============================================================
   v3.3.0 VISUAL REFRESH — attractive, editable, responsive
   ============================================================ */
:root{
  --st-gradient-main:linear-gradient(135deg,var(--st-teal) 0%,var(--st-green) 58%,var(--st-amber) 140%);
  --st-gradient-soft:linear-gradient(135deg,rgba(75,150,150,.12),rgba(75,150,120,.08),rgba(240,165,75,.14));
  --st-glass:rgba(255,255,255,.82);
}

/* Remove old screenshot-style partner/company strip under hero */
.partner-strip{display:none!important;}

body{background:linear-gradient(180deg,#f9fcfc 0%,#f2f8f7 48%,#fff 100%);}
.site-header{box-shadow:0 8px 28px rgba(45,59,69,.07);}
.site-logo img,.custom-logo{max-height:72px;width:auto;object-fit:contain;filter:drop-shadow(0 6px 12px rgba(45,59,69,.10));}

.hero{min-height:100vh;display:flex;align-items:center;position:relative;overflow:hidden;background:radial-gradient(circle at 12% 20%,rgba(240,165,75,.38),transparent 28%),radial-gradient(circle at 86% 18%,rgba(255,255,255,.22),transparent 30%),linear-gradient(135deg,#2e7778 0%,#3fa785 60%,#f0a54b 155%);padding-top:120px;padding-bottom:80px;}
.hero::after{content:"";position:absolute;inset:auto -10% -18% -10%;height:34%;background:rgba(255,255,255,.92);clip-path:ellipse(58% 42% at 50% 100%);pointer-events:none;}
.hero-content{position:relative;z-index:2;max-width:880px;margin:0 auto;text-align:center;padding:clamp(26px,4vw,56px);border:1px solid rgba(255,255,255,.24);border-radius:34px;background:linear-gradient(135deg,rgba(255,255,255,.18),rgba(255,255,255,.07));backdrop-filter:blur(10px);box-shadow:0 30px 80px rgba(0,0,0,.18);}
.hero-badge{display:inline-flex;align-items:center;gap:10px;padding:10px 18px;border-radius:999px;background:rgba(255,255,255,.94);color:var(--st-teal-dark);font-weight:900;box-shadow:0 10px 30px rgba(0,0,0,.14);}
.hero h1{color:#fff;font-size:clamp(2.45rem,7vw,5.8rem);letter-spacing:-.055em;line-height:.98;margin:26px 0 22px;text-shadow:0 8px 26px rgba(0,0,0,.18);}
.hero h1 em{font-style:normal;color:var(--st-amber);text-shadow:0 5px 18px rgba(0,0,0,.18);}
.hero-desc{color:rgba(255,255,255,.96);font-size:clamp(1.05rem,2vw,1.34rem);max-width:760px;margin:0 auto 34px;line-height:1.8;font-weight:600;}
.hero-actions{display:flex;justify-content:center;gap:16px;flex-wrap:wrap;margin-top:28px;}
.hero-trust-bar{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-top:34px;}
.hero-trust-bar>div{background:rgba(255,255,255,.94);border-radius:18px;padding:16px 12px;box-shadow:0 16px 40px rgba(0,0,0,.12);}
.trust-num{display:block;color:var(--st-amber);font-size:1.6rem;font-weight:900;line-height:1;}
.trust-label{display:block;color:var(--st-slate);font-size:.78rem;text-transform:uppercase;letter-spacing:.08em;font-weight:800;margin-top:6px;}

.btn{border-radius:999px;padding:15px 30px;font-weight:900;letter-spacing:.01em;box-shadow:0 12px 28px rgba(45,59,69,.13);position:relative;overflow:hidden;}
.btn::before{content:"";position:absolute;inset:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.28),transparent);transform:translateX(-120%);transition:transform .55s var(--ease);}
.btn:hover::before{transform:translateX(120%);}
.btn-primary{background:var(--st-gradient-main);border:none;color:#fff;}
.btn-primary:hover{filter:saturate(1.08) brightness(1.02);transform:translateY(-3px);box-shadow:0 18px 38px rgba(75,150,150,.28);}
.btn-amber{background:linear-gradient(135deg,#ffc15f,var(--st-amber));border:none;color:#253440;}
.btn-amber:hover{transform:translateY(-3px);box-shadow:0 18px 38px rgba(240,165,75,.32);}
.btn-outline-white{background:rgba(255,255,255,.12);color:#fff;border:2px solid rgba(255,255,255,.78);backdrop-filter:blur(8px);}
.btn-outline-white:hover{background:#fff;color:var(--st-teal-dark);border-color:#fff;transform:translateY(-3px);}
.btn-outline-teal{background:#fff;color:var(--st-teal-dark);border:2px solid var(--st-teal);}
.btn-outline-teal:hover{background:var(--st-teal);color:#fff;transform:translateY(-3px);}

.section-pad{padding:clamp(64px,8vw,110px) 0;}
.section-title{letter-spacing:-.035em;}
.section-subtitle{font-size:1.12rem;}
.about-section,.services-section,.projects-section,.events-section,.gallery-section,.partners-section,.faq-section,.contact-section{position:relative;overflow:hidden;}
.about-section::before,.services-section::before,.partners-section::before,.events-section::before{content:"";position:absolute;width:420px;height:420px;border-radius:50%;background:var(--st-gradient-soft);filter:blur(4px);opacity:.9;right:-180px;top:-160px;pointer-events:none;}
.service-card,.project-card,.event-card,.partner-card,.faq-item,.contact-card{border:1px solid rgba(75,150,150,.14)!important;box-shadow:0 14px 40px rgba(45,59,69,.08);}
.service-card:hover,.project-card:hover,.event-card:hover,.partner-card:hover{transform:translateY(-7px);box-shadow:0 24px 60px rgba(45,59,69,.14)!important;}

/* Partner cards with replaceable images/logos */
.partners-section{background:linear-gradient(180deg,#fff 0%,#f6fbfb 100%);}
.partners-grid-enhanced{grid-template-columns:repeat(4,minmax(0,1fr));gap:26px;align-items:stretch;}
.partner-card-enhanced{padding:0;background:#fff;border-radius:28px;overflow:hidden;text-align:left;display:flex;flex-direction:column;min-height:100%;}
.partner-photo-wrap{width:100%;height:190px;margin:0;background:var(--st-gradient-soft);border-radius:0;}
.partner-photo-wrap img{width:100%;height:100%;object-fit:cover;}
.partner-card-body{padding:24px;display:flex;flex-direction:column;gap:8px;flex:1;}
.partner-card h3{font-size:1.18rem;margin:0;color:var(--st-slate);}
.partner-role{align-self:flex-start;padding:6px 10px;border-radius:999px;background:var(--st-amber-light);color:#935c16;font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;font-weight:900;}
.partner-card p{color:var(--st-grey);font-size:.95rem;line-height:1.72;margin:0;}
.partner-link{margin-top:auto;color:var(--st-teal-dark);font-weight:900;}
.partner-logo-placeholder{width:100%;height:100%;border-radius:0;background:var(--st-gradient-soft);font-size:3rem;}
.partners-admin-note{margin-top:38px;}
.empty-card{background:#fff;border:1px solid var(--st-border);border-radius:24px;padding:36px;text-align:center;box-shadow:var(--shadow-sm);}

/* Events — clearer, easier to update from Admin → Events */
.events-section{background:linear-gradient(180deg,#f7fbfb,#eef7f5);}
.events-list{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:22px;}
.event-card{height:100%;border-radius:24px;padding:26px;background:rgba(255,255,255,.92);backdrop-filter:blur(8px);}
.event-date{background:var(--st-gradient-main);border-radius:18px;width:76px;padding:14px 8px;box-shadow:0 14px 30px rgba(75,150,150,.22);}
.event-date .day{font-size:1.85rem;}.event-date .month{font-weight:900;}
.event-info h3{font-size:1.18rem;letter-spacing:-.02em;}
.event-meta span{background:var(--st-grey-light);border-radius:999px;padding:6px 10px;color:var(--st-slate);font-weight:700;}

/* Responsive */
@media(max-width:1024px){
  .partners-grid-enhanced{grid-template-columns:repeat(2,minmax(0,1fr));}
  .hero-trust-bar{grid-template-columns:repeat(2,1fr);}
}
@media(max-width:720px){
  .container{padding-left:18px;padding-right:18px;}
  .hero{min-height:calc(100vh - 0px);padding-top:105px;padding-bottom:54px;}
  .hero-content{padding:24px 18px;border-radius:26px;}
  .hero h1{font-size:clamp(2.2rem,13vw,3.8rem);}
  .hero-desc{font-size:1rem;}
  .hero-actions{flex-direction:column;align-items:stretch;}
  .hero-actions .btn{width:100%;}
  .hero-trust-bar{grid-template-columns:1fr;}
  .events-list,.partners-grid-enhanced{grid-template-columns:1fr;}
  .event-card{flex-direction:column;}
  .event-date{width:100%;display:flex;align-items:center;justify-content:center;gap:8px;}
  .partner-photo-wrap{height:210px;}
  .site-logo img,.custom-logo{max-height:58px;}
}


/* v3.3.1 footer/menu fixes */
.site-logo, .site-logo a, .site-logo img,
.footer-logo, .footer-logo a, .footer-logo img { background: transparent !important; }
.footer-menu { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 9px; }
.footer-menu li { margin: 0; padding: 0; }
.footer-menu a { color: rgba(255,255,255,.62); font-size: .92rem; line-height: 1.65; }
.footer-menu a:hover { color: var(--st-amber); }
body.mobile-menu-open { overflow: hidden; }
@media (max-width: 768px) {
  .header-inner { min-height: 78px; height: auto; padding: 12px 0; }
  .site-logo img { height: 58px; max-width: 230px; }
  .primary-nav {
    display: none;
    position: fixed;
    top: 82px;
    left: 0;
    right: 0;
    bottom: 0;
    width: 100%;
    height: calc(100vh - 82px);
    background: #fff;
    padding: 22px 18px 40px;
    overflow-y: auto;
    z-index: 2000;
    border-top: 1px solid var(--st-border);
    box-shadow: 0 18px 50px rgba(45,59,69,.16);
  }
  .primary-nav.open { display: block !important; }
  .primary-nav.open ul { display: flex; flex-direction: column; align-items: stretch; gap: 6px; margin: 0; padding: 0; }
  .primary-nav.open li { width: 100%; }
  .primary-nav.open a { width: 100%; justify-content: flex-start; font-size: 1rem; padding: 15px 16px; min-height: 52px; }
  .menu-toggle { display: flex !important; position: relative; z-index: 2100; background: #fff; }
  .menu-toggle.active span:nth-child(1){transform:translateY(7px) rotate(45deg);}
  .menu-toggle.active span:nth-child(2){opacity:0;transform:scaleX(0);}
  .menu-toggle.active span:nth-child(3){transform:translateY(-7px) rotate(-45deg);}
}
@media (max-width: 420px) {
  .site-logo img { height: 48px; max-width: 210px; }
  .donate-btn { padding: 9px 15px; font-size: .84rem; }
  .header-cta { gap: 8px; }
}
