/*
Theme Name:        Whole Word Hub
Theme URI:         https://wholewordtv.org
Author:            The Godhouse Centre
Author URI:        https://wholewordtv.org
Description:       Official website theme for Whole Word Hub — the ministry management platform of The Godhouse Centre. Features the homepage, privacy policy, terms of service, and terms of use pages.
Version:           1.0.0
Requires at least: 5.9
Tested up to:      6.5
Requires PHP:      7.4
License:           GNU General Public License v2 or later
License URI:       http://www.gnu.org/licenses/gpl-2.0.html
Text Domain:       whole-word-hub
Tags:              ministry, church, custom-colors, custom-logo, full-site-editing
*/

/* ─────────────────────────────────────────────────────────────
   MAIN PAGE STYLES (homepage)
───────────────────────────────────────────────────────────── */

/* ── RESET & BASE ── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:"DM Sans",system-ui,sans-serif;background:#fff;color:#111827;overflow-x:hidden;line-height:1.7;font-size:17px}

/* ── TOKENS ── */
:root{
  --white:#ffffff;
  --blue:#1A56DB;--blue-dark:#1244B8;--blue-mid:#2563EB;--blue-light:#EBF0FD;--blue-xlight:#F0F5FF;
  --red:#E53935;--red-dark:#C62828;--red-mid:#EF4444;--red-light:#FEF2F2;
  --yellow:#FDD835;--yellow-dark:#B8960A;
  --gray-50:#F9FAFB;--gray-100:#F3F4F6;--gray-200:#E5E7EB;--gray-300:#D1D5DB;
  --gray-400:#9CA3AF;--gray-500:#6B7280;--gray-600:#4B5563;--gray-700:#374151;--gray-800:#1F2937;--gray-900:#111827;
  --border:#E5E7EB;
  --r:12px;--r-lg:16px;--r-xl:24px;--r-pill:999px;
  --ease-out-quart:cubic-bezier(0.25,1,0.5,1);
  --ease-spring:cubic-bezier(0.34,1.56,0.64,1);
}

/* ── SCROLLBAR ── */
::-webkit-scrollbar{width:6px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--blue-light);border-radius:3px}

/* ── NAV ── */
#nav{position:fixed;top:0;left:0;right:0;z-index:200;
  padding:.75rem 2rem;
  display:flex;align-items:center;justify-content:space-between;gap:1rem;
  transition:background .3s,box-shadow .3s,backdrop-filter .3s}
#nav.scrolled{background:rgba(255,255,255,.92);backdrop-filter:blur(16px);
  box-shadow:0 1px 0 var(--border),0 4px 16px rgba(0,0,0,.06)}
.nav-brand{display:flex;align-items:center;gap:10px;text-decoration:none;flex-shrink:0}
.nav-logo{width:54px;height:54px;border-radius:12px;object-fit:cover}
.nav-brand-text{line-height:1.15}
.nav-name{display:block;font-family:"Plus Jakarta Sans",sans-serif;font-size:22px;font-weight:800;color:var(--gray-900);letter-spacing:-.02em}
.nav-org{display:block;font-size:12.5px;color:var(--gray-500);letter-spacing:.04em;margin-top:1px}
.nav-links{display:flex;align-items:center;gap:1.75rem}
.nav-links a{font-size:15px;font-weight:500;color:var(--gray-600);text-decoration:none;transition:color .2s}
.nav-links a:hover{color:var(--blue)}
.nav-btn{display:inline-flex;align-items:center;gap:6px;
  background:var(--blue);color:#fff;font-family:"Plus Jakarta Sans",sans-serif;
  font-size:14px;font-weight:600;padding:9px 20px;border-radius:8px;
  text-decoration:none;transition:background .2s,transform .15s,box-shadow .2s;
  box-shadow:0 2px 8px rgba(26,86,219,.3)}
.nav-btn:hover{background:var(--blue-dark);transform:translateY(-1px);box-shadow:0 4px 16px rgba(26,86,219,.4)}
.ham{display:none;flex-direction:column;gap:4px;cursor:pointer;padding:4px}
.ham span{display:block;width:22px;height:2px;background:var(--gray-700);border-radius:1px;transition:.3s}

/* ── HERO ── */
.hero{min-height:100vh;display:flex;flex-direction:column;align-items:center;
  justify-content:center;padding:7rem 2rem 4rem;position:relative;overflow:hidden;
  background:linear-gradient(160deg,#fff 0%,var(--blue-xlight) 50%,#fff 100%)}

/* Animated mesh background */
.hero-mesh{position:absolute;inset:0;pointer-events:none;overflow:hidden}
.mesh-circle{position:absolute;border-radius:50%;filter:blur(70px);opacity:.35;animation:meshFloat 8s ease-in-out infinite}
.mc1{width:600px;height:600px;background:var(--blue-light);top:-200px;left:-100px;animation-delay:0s}
.mc2{width:400px;height:400px;background:var(--red-light);top:100px;right:-80px;animation-delay:-3s}
.mc3{width:350px;height:350px;background:var(--blue-xlight);bottom:-100px;left:30%;animation-delay:-6s}
@keyframes meshFloat{0%,100%{transform:translate(0,0) scale(1)}33%{transform:translate(30px,-20px) scale(1.05)}66%{transform:translate(-20px,30px) scale(.95)}}

/* Grid overlay */
.hero-grid{position:absolute;inset:0;pointer-events:none;
  background-image:linear-gradient(rgba(26,86,219,.04) 1px,transparent 1px),
    linear-gradient(90deg,rgba(26,86,219,.04) 1px,transparent 1px);
  background-size:56px 56px;
  mask-image:radial-gradient(ellipse 80% 80% at 50% 50%,black 30%,transparent 100%)}

.hero-inner{position:relative;z-index:1;text-align:center;max-width:780px}

/* Logo with ring pulse */
.hero-logo-wrap{position:relative;width:96px;height:96px;margin:0 auto 1.75rem;display:flex;align-items:center;justify-content:center}
.hero-logo-wrap::before{content:"";position:absolute;inset:-8px;border-radius:22px;
  background:linear-gradient(135deg,var(--blue),var(--red));opacity:.12;
  animation:logoPulse 3s ease-in-out infinite}
.hero-logo-wrap::after{content:"";position:absolute;inset:-16px;border-radius:28px;
  background:linear-gradient(135deg,var(--blue),var(--red));opacity:.06;
  animation:logoPulse 3s ease-in-out infinite .5s}
@keyframes logoPulse{0%,100%{transform:scale(1)}50%{transform:scale(1.08)}}
.hero-logo{width:96px;height:96px;border-radius:20px;object-fit:cover;
  box-shadow:0 12px 40px rgba(26,86,219,.2);position:relative;z-index:1}

.hero-pill{display:inline-flex;align-items:center;gap:7px;
  background:#fff;border:1px solid var(--border);border-radius:var(--r-pill);
  padding:5px 14px 5px 8px;margin-bottom:1.5rem;
  box-shadow:0 2px 8px rgba(0,0,0,.06);
  animation:fadeSlideUp .6s var(--ease-out-quart) both}
.pill-dot{width:8px;height:8px;border-radius:50%;background:var(--blue);
  box-shadow:0 0 0 3px rgba(26,86,219,.2);animation:pillBlink 2s infinite}
@keyframes pillBlink{0%,100%{box-shadow:0 0 0 3px rgba(26,86,219,.2)}50%{box-shadow:0 0 0 6px rgba(26,86,219,.08)}}
.pill-text{font-size:13.5px;font-weight:600;color:var(--gray-600);letter-spacing:.03em}

h1{font-family:"Plus Jakarta Sans",sans-serif;font-size:clamp(2.8rem,6.5vw,4.6rem);
  font-weight:800;line-height:1.1;color:var(--gray-900);letter-spacing:-.03em;
  margin-bottom:1.25rem;
  animation:fadeSlideUp .6s .1s var(--ease-out-quart) both}
.word-blue{color:var(--blue)}
.word-red{color:var(--red)}

.hero-sub{font-size:1.2rem;color:var(--gray-500);max-width:540px;margin:0 auto 2.25rem;
  font-weight:300;line-height:1.7;
  animation:fadeSlideUp .6s .2s var(--ease-out-quart) both}

.hero-cta{display:flex;align-items:center;justify-content:center;gap:.875rem;flex-wrap:wrap;
  animation:fadeSlideUp .6s .3s var(--ease-out-quart) both}
.btn-hero{display:inline-flex;align-items:center;gap:8px;
  font-family:"Plus Jakarta Sans",sans-serif;font-weight:700;font-size:15px;
  padding:13px 28px;border-radius:var(--r);text-decoration:none;
  transition:transform .2s var(--ease-spring),box-shadow .2s}
.btn-hero-primary{background:var(--blue);color:#fff;
  box-shadow:0 4px 20px rgba(26,86,219,.35)}
.btn-hero-primary:hover{transform:translateY(-2px);box-shadow:0 8px 32px rgba(26,86,219,.45)}
.btn-hero-outline{background:#fff;color:var(--gray-800);border:1.5px solid var(--border)}
.btn-hero-outline:hover{border-color:var(--blue);color:var(--blue);transform:translateY(-2px);
  box-shadow:0 4px 16px rgba(26,86,219,.12)}

/* Floating badges */
.hero-float{position:absolute;z-index:2;pointer-events:none;animation:floatBadge 4s ease-in-out infinite}
.hero-float-1{top:25%;left:5%;animation-delay:0s}
.hero-float-2{top:35%;right:4%;animation-delay:-2s}
.hero-float-3{bottom:25%;left:8%;animation-delay:-1.5s}
.hero-float-4{bottom:30%;right:6%;animation-delay:-3s}
@keyframes floatBadge{0%,100%{transform:translateY(0)}50%{transform:translateY(-10px)}}
.float-badge{background:#fff;border:1px solid var(--border);border-radius:var(--r);
  padding:.5rem .875rem;box-shadow:0 4px 16px rgba(0,0,0,.08);
  display:flex;align-items:center;gap:8px;white-space:nowrap;
  font-size:12.5px;font-weight:600;color:var(--gray-700)}
.fb-icon{width:28px;height:28px;border-radius:7px;display:flex;align-items:center;justify-content:center}
.fb-blue{background:var(--blue-light)}
.fb-red{background:var(--red-light)}
.fb-icon svg{width:14px;height:14px}

@keyframes fadeSlideUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}

/* Hero scroll arrow */
.scroll-cue{position:absolute;bottom:2rem;left:50%;transform:translateX(-50%);
  display:flex;flex-direction:column;align-items:center;gap:6px;
  animation:fadeSlideUp .6s .6s var(--ease-out-quart) both;z-index:1}
.scroll-cue span{font-size:11px;color:var(--gray-400);letter-spacing:.1em;text-transform:uppercase;font-weight:500}
.scroll-arrow{width:20px;height:20px;border-right:2px solid var(--gray-300);
  border-bottom:2px solid var(--gray-300);transform:rotate(45deg);
  animation:arrowBounce 1.5s ease-in-out infinite}
@keyframes arrowBounce{0%,100%{transform:rotate(45deg) translateY(0);opacity:.5}
  50%{transform:rotate(45deg) translateY(5px);opacity:1}}

/* ── STATS ── */
.stats-strip{background:var(--blue);padding:2rem}
.stats-inner{max-width:800px;margin:0 auto;display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;text-align:center}
.stat-item{padding:.5rem 0;border-right:1px solid rgba(255,255,255,.15)}
.stat-item:last-child{border-right:none}
.stat-num{font-family:"Plus Jakarta Sans",sans-serif;font-size:2.6rem;font-weight:800;
  color:#fff;line-height:1;display:block}
.stat-num.counter{transition:none}
.stat-label{font-size:13px;color:rgba(255,255,255,.9);margin-top:.3rem;display:block;font-weight:500}

/* ── COLOUR STRIPE ── */
.stripe{height:4px;background:linear-gradient(90deg,var(--blue) 0%,var(--blue) 34%,var(--yellow) 34%,var(--yellow) 67%,var(--red) 67%)}

/* ── SECTION COMMONS ── */
.section{padding:5.5rem 2rem;max-width:1060px;margin:0 auto}
.section-label{font-size:12.5px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;
  margin-bottom:.5rem}
.section-label.blue{color:var(--blue)}
.section-label.red{color:var(--red)}
.section-title{font-family:"Plus Jakarta Sans",sans-serif;
  font-size:clamp(1.6rem,3.5vw,2.4rem);font-weight:800;
  letter-spacing:-.025em;line-height:1.15;margin-bottom:.75rem;color:var(--gray-900)}
.section-sub{font-size:17px;color:var(--gray-500);max-width:500px;
  font-weight:300;line-height:1.7;margin-bottom:2.75rem}

/* reveal animation */
.reveal{opacity:0;transform:translateY(30px);transition:opacity .65s var(--ease-out-quart),transform .65s var(--ease-out-quart)}
.reveal.revealed{opacity:1;transform:translateY(0)}
.reveal-delay-1{transition-delay:.1s}
.reveal-delay-2{transition-delay:.2s}
.reveal-delay-3{transition-delay:.3s}
.reveal-delay-4{transition-delay:.4s}

/* ── FEATURES ── */
.features-bg{background:var(--gray-50);border-top:1px solid var(--border);border-bottom:1px solid var(--border)}

/* Tab nav */
.feat-tabs{display:flex;gap:.5rem;background:#fff;border:1px solid var(--border);
  border-radius:var(--r-pill);padding:4px;width:fit-content;margin-bottom:2.5rem}
.feat-tab{font-family:"Plus Jakarta Sans",sans-serif;font-size:15px;font-weight:600;
  color:var(--gray-500);padding:7px 18px;border-radius:var(--r-pill);
  cursor:pointer;border:none;background:transparent;transition:all .25s;white-space:nowrap}
.feat-tab:hover{color:var(--gray-800)}
.feat-tab.active{background:var(--blue);color:#fff;box-shadow:0 2px 8px rgba(26,86,219,.3)}

.feat-panels{position:relative}
.feat-panel{display:none;animation:panelIn .35s var(--ease-out-quart)}
.feat-panel.active{display:grid;grid-template-columns:1fr 1fr;gap:1.25rem}
@keyframes panelIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}

.feat-card{background:#fff;border:1px solid var(--border);border-radius:var(--r-lg);
  padding:1.6rem;position:relative;overflow:hidden;
  transition:border-color .25s,box-shadow .25s,transform .25s}
.feat-card:hover{border-color:var(--blue-mid);box-shadow:0 8px 28px rgba(26,86,219,.1);transform:translateY(-2px)}
.feat-card.wide{grid-column:span 2}
.feat-card.red-accent:hover{border-color:var(--red-mid);box-shadow:0 8px 28px rgba(229,57,53,.1)}

/* card top-line accent */
.feat-card::before{content:"";position:absolute;top:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,var(--blue),var(--blue-mid));
  transform:scaleX(0);transform-origin:left;transition:transform .3s var(--ease-out-quart)}
.feat-card:hover::before{transform:scaleX(1)}
.feat-card.red-accent::before{background:linear-gradient(90deg,var(--red),var(--red-mid))}

.feat-icon{width:44px;height:44px;border-radius:11px;display:flex;align-items:center;
  justify-content:center;margin-bottom:1.1rem}
.feat-icon.blue{background:var(--blue-light)}
.feat-icon.red{background:var(--red-light)}
.feat-icon svg{width:20px;height:20px}
.feat-icon.blue svg{fill:var(--blue)}
.feat-icon.red svg{fill:var(--red)}

.feat-title{font-family:"Plus Jakarta Sans",sans-serif;font-size:1.1rem;font-weight:700;
  color:var(--gray-900);margin-bottom:.4rem}
.feat-desc{font-size:15px;color:var(--gray-500);line-height:1.7}
.feat-tags{display:flex;flex-wrap:wrap;gap:5px;margin-top:.9rem}
.tag{font-size:12px;font-weight:600;border-radius:5px;padding:3px 9px}
.tag-blue{background:var(--blue-light);color:var(--blue)}
.tag-red{background:var(--red-light);color:var(--red-dark)}

/* ── ANIMATED COUNTER STRIP ── */
.impact-strip{background:linear-gradient(135deg,var(--blue-dark) 0%,var(--blue-mid) 100%);padding:3rem 2rem;position:relative;overflow:hidden}
.impact-strip::before{content:"";position:absolute;top:-50%;right:-10%;
  width:500px;height:500px;border-radius:50%;
  background:rgba(255,255,255,.05);pointer-events:none}
.impact-inner{max-width:800px;margin:0 auto;display:grid;grid-template-columns:repeat(3,1fr);gap:2rem;text-align:center;position:relative;z-index:1}
.impact-item{}
.impact-num{font-family:"Plus Jakarta Sans",sans-serif;font-size:3.2rem;font-weight:800;
  color:#fff;line-height:1;display:block}
.impact-num span.suffix{font-size:1.8rem}
.impact-label{font-size:15px;color:rgba(255,255,255,.88);margin-top:.4rem;display:block;font-weight:500}

/* ── ROLES ── */
.roles-bg{background:#fff;border-top:1px solid var(--border)}
.roles-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:.75rem}
.role-card{background:var(--gray-50);border:1.5px solid var(--border);border-radius:var(--r);
  padding:1rem .75rem;text-align:center;cursor:default;
  transition:all .25s var(--ease-spring)}
.role-card:hover{background:#fff;border-color:var(--blue);transform:translateY(-3px);
  box-shadow:0 6px 20px rgba(26,86,219,.12)}
.role-level{font-size:9.5px;font-weight:700;color:var(--blue);letter-spacing:.1em;
  text-transform:uppercase;margin-bottom:.3rem;display:block}
.role-name{font-family:"Plus Jakarta Sans",sans-serif;font-size:12.5px;font-weight:700;color:var(--gray-800)}
.role-bar{height:3px;background:var(--gray-200);border-radius:2px;margin:.65rem 0 0;overflow:hidden}
.role-fill{height:100%;background:linear-gradient(90deg,var(--blue-light),var(--blue));
  border-radius:2px;transform:scaleX(0);transform-origin:left;
  transition:transform 1s var(--ease-out-quart)}
.role-fill.animated{transform:scaleX(1)}

/* ── CENTRES ── */
.centres-section{background:var(--gray-50);border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.centres-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.25rem}
.centre-card{background:#fff;border:1.5px solid var(--border);border-radius:var(--r-lg);
  padding:1.75rem;position:relative;overflow:hidden;
  transition:all .25s var(--ease-spring)}
.centre-card::after{content:"";position:absolute;bottom:0;left:0;right:0;height:3px;
  transform:scaleX(0);transform-origin:left;transition:transform .3s var(--ease-out-quart)}
.centre-card.ng::after{background:var(--blue)}
.centre-card.uk::after{background:var(--red)}
.centre-card.us::after{background:linear-gradient(90deg,var(--blue),var(--red))}
.centre-card:hover{transform:translateY(-4px);box-shadow:0 12px 36px rgba(0,0,0,.1)}
.centre-card:hover::after{transform:scaleX(1)}
.centre-flag{font-size:2.5rem;display:block;margin-bottom:.65rem}
.centre-name{font-family:"Plus Jakarta Sans",sans-serif;font-size:1.2rem;font-weight:800;
  color:var(--gray-900);margin-bottom:.35rem}
.centre-desc{font-size:15px;color:var(--gray-500);margin-bottom:.9rem;line-height:1.7}
.group-pills{display:flex;flex-wrap:wrap;gap:5px}
.gpill{font-size:12.5px;font-weight:600;background:var(--gray-100);color:var(--gray-600);
  border-radius:5px;padding:2px 8px;transition:all .2s}
.centre-card:hover .gpill{background:var(--blue-light);color:var(--blue)}
.centre-card.uk:hover .gpill{background:var(--red-light);color:var(--red-dark)}

/* ── SECURITY ── */
.sec-section{background:var(--gray-900);padding:5.5rem 2rem}
.sec-inner{max-width:1060px;margin:0 auto;display:grid;grid-template-columns:1fr 440px;gap:4rem;align-items:start}
.sec-title{font-family:"Plus Jakarta Sans",sans-serif;font-size:clamp(1.6rem,3.5vw,2.4rem);
  font-weight:800;letter-spacing:-.025em;line-height:1.15;color:#fff;margin-bottom:.75rem}
.sec-sub{font-size:15px;color:var(--gray-500);font-weight:300;line-height:1.7;margin-bottom:2rem;max-width:440px}
.sec-list{display:flex;flex-direction:column;gap:.875rem}
.sec-item{display:flex;align-items:flex-start;gap:12px;padding:1rem;
  background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.07);border-radius:var(--r);
  transition:background .2s,border-color .2s}
.sec-item:hover{background:rgba(255,255,255,.07);border-color:rgba(26,86,219,.4)}
.sec-check{width:24px;height:24px;border-radius:7px;background:rgba(34,197,94,.12);
  border:1px solid rgba(34,197,94,.25);display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:1px}
.sec-check svg{width:12px;height:12px}
.sec-item-title{font-family:"Plus Jakarta Sans",sans-serif;font-size:13.5px;font-weight:700;
  color:#fff;display:block;margin-bottom:.15rem}
.sec-item-desc{font-size:12.5px;color:var(--gray-400);line-height:1.55}

/* Score card */
.sec-score-card{background:linear-gradient(145deg,rgba(26,86,219,.25),rgba(26,86,219,.08));
  border:1px solid rgba(26,86,219,.3);border-radius:var(--r-xl);padding:2.5rem 2rem;text-align:center;
  position:sticky;top:120px}
.score-ring-wrap{position:relative;width:160px;height:160px;margin:0 auto 1.5rem}
.score-ring-wrap svg{width:160px;height:160px;transform:rotate(-90deg)}
.ring-track{fill:none;stroke:rgba(255,255,255,.08);stroke-width:10}
.ring-progress{fill:none;stroke:url(#scoreGrad);stroke-width:10;stroke-linecap:round;
  stroke-dasharray:408;stroke-dashoffset:408;transition:stroke-dashoffset 2s var(--ease-out-quart)}
.ring-progress.animated{stroke-dashoffset:115}
.ring-label{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center}
.ring-num{font-family:"Plus Jakarta Sans",sans-serif;font-size:2.4rem;font-weight:800;color:#fff;line-height:1}
.ring-of{font-size:12px;color:var(--gray-400);margin-top:.1rem}
.score-title{font-family:"Plus Jakarta Sans",sans-serif;font-size:1rem;font-weight:700;color:#fff;margin-bottom:.3rem}
.score-sub{font-size:12px;color:var(--gray-400);line-height:1.5}
.score-badges{display:flex;flex-wrap:wrap;gap:.4rem;justify-content:center;margin-top:1.25rem}
.sbadge{font-size:10.5px;font-weight:600;padding:3px 10px;border-radius:var(--r-pill);border:1px solid}
.sbadge-blue{background:rgba(26,86,219,.15);color:#93b4ff;border-color:rgba(26,86,219,.25)}
.sbadge-red{background:rgba(229,57,53,.15);color:#fca5a5;border-color:rgba(229,57,53,.2)}
.sbadge-green{background:rgba(34,197,94,.12);color:#86efac;border-color:rgba(34,197,94,.2)}

/* ── MARQUEE / SCROLL ── */
.marquee-wrap{background:var(--blue);padding:.75rem 0;overflow:hidden;border-top:1px solid var(--border)}
.marquee-track{display:flex;gap:3rem;animation:marquee 28s linear infinite;width:max-content}
.marquee-item{font-family:"Plus Jakarta Sans",sans-serif;font-size:14px;font-weight:600;
  color:rgba(255,255,255,.85);white-space:nowrap;display:flex;align-items:center;gap:.5rem}
.marquee-dot{width:4px;height:4px;border-radius:50%;background:rgba(255,255,255,.4)}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ── CTA ── */
.cta-section{padding:6rem 2rem;background:#fff;text-align:center;position:relative;overflow:hidden}
.cta-section::before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;
  background:radial-gradient(ellipse 80% 80% at 50% -20%,var(--blue-xlight) 0%,transparent 60%),
    radial-gradient(ellipse 50% 60% at 80% 120%,var(--red-light) 0%,transparent 60%)}
.cta-inner{max-width:600px;margin:0 auto;position:relative;z-index:1}
.cta-title{font-family:"Plus Jakarta Sans",sans-serif;font-size:clamp(1.75rem,4vw,2.8rem);
  font-weight:800;letter-spacing:-.025em;color:var(--gray-900);margin-bottom:.875rem;line-height:1.1}
.cta-title span.blue{color:var(--blue)}
.cta-sub{font-size:1.15rem;color:var(--gray-500);margin-bottom:2.25rem;font-weight:300}
.cta-btns{display:flex;align-items:center;justify-content:center;gap:.875rem;flex-wrap:wrap}
.btn-cta-primary{display:inline-flex;align-items:center;gap:8px;
  background:var(--blue);color:#fff;
  font-family:"Plus Jakarta Sans",sans-serif;font-weight:700;font-size:15px;
  padding:14px 30px;border-radius:var(--r-lg);text-decoration:none;
  box-shadow:0 4px 24px rgba(26,86,219,.35);
  transition:transform .2s var(--ease-spring),box-shadow .2s,background .2s}
.btn-cta-primary:hover{transform:translateY(-2px) scale(1.01);box-shadow:0 8px 36px rgba(26,86,219,.45);background:var(--blue-dark)}
.btn-cta-secondary{display:inline-flex;align-items:center;gap:8px;
  background:transparent;color:var(--gray-700);
  font-family:"Plus Jakarta Sans",sans-serif;font-weight:600;font-size:15px;
  padding:13px 28px;border-radius:var(--r-lg);text-decoration:none;
  border:1.5px solid var(--border);transition:all .2s}
.btn-cta-secondary:hover{border-color:var(--gray-400);background:var(--gray-50);transform:translateY(-1px)}
.cta-legal{font-size:13.5px;color:var(--gray-400);margin-top:1.5rem}
.cta-legal a{color:var(--gray-500);text-decoration:underline;text-underline-offset:2px}

/* ── FOOTER ── */
footer{background:var(--gray-900);padding:3.5rem 2rem 1.5rem}
.footer-inner{max-width:1060px;margin:0 auto}
.footer-top{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:2.5rem;padding-bottom:2.5rem;border-bottom:1px solid rgba(255,255,255,.07)}
.footer-brand-row{display:flex;align-items:center;gap:10px;margin-bottom:.75rem}
.footer-logo{width:36px;height:36px;border-radius:9px;object-fit:cover}
.footer-name{font-family:"Plus Jakarta Sans",sans-serif;font-size:16px;font-weight:800;color:#fff}
.footer-org{font-size:10.5px;color:var(--gray-500);letter-spacing:.05em}
.footer-desc{font-size:14.5px;color:var(--gray-500);line-height:1.7;max-width:260px}
.footer-col h4{font-family:"Plus Jakarta Sans",sans-serif;font-size:11px;font-weight:700;
  color:rgba(255,255,255,.9);letter-spacing:.1em;text-transform:uppercase;margin-bottom:.875rem}
.footer-col ul{list-style:none}
.footer-col ul li{margin-bottom:.45rem}
.footer-col ul a{font-size:14.5px;color:var(--gray-500);text-decoration:none;transition:color .2s}
.footer-col ul a:hover{color:var(--blue-light)}
.footer-bottom{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;
  gap:.75rem;padding-top:1.5rem}
.footer-bottom p{font-size:13.5px;color:var(--gray-500)}
.footer-bottom a{color:var(--gray-400);text-decoration:none;transition:color .2s}
.footer-bottom a:hover{color:#fff}

/* ── MOBILE ── */
.mobile-menu{display:none;position:fixed;top:64px;left:0;right:0;z-index:199;
  background:#fff;border-bottom:1px solid var(--border);
  flex-direction:column;padding:1.25rem 1.5rem;gap:.75rem;
  box-shadow:0 8px 24px rgba(0,0,0,.1)}
.mobile-menu.open{display:flex}
.mobile-menu a{font-size:16px;font-weight:500;color:var(--gray-700);text-decoration:none;
  padding:.5rem 0;border-bottom:1px solid var(--gray-100);transition:color .2s}
.mobile-menu a:hover{color:var(--blue)}
.mobile-menu a.mm-cta{background:var(--blue);color:#fff;padding:.65rem 1.25rem;
  border-radius:8px;border:none;text-align:center;font-weight:600;margin-top:.25rem}

@media(max-width:960px){
  .sec-inner{grid-template-columns:1fr}
  .sec-score-card{position:static}
  .feat-panel.active{grid-template-columns:1fr}
  .feat-card.wide{grid-column:span 1}
}
@media(max-width:760px){
  .roles-grid{grid-template-columns:repeat(3,1fr)}
  .centres-grid{grid-template-columns:1fr}
  .impact-inner{grid-template-columns:repeat(2,1fr)}
  .stats-inner{grid-template-columns:repeat(2,1fr)}
  .footer-top{grid-template-columns:1fr 1fr}
  .hero-float{display:none}
  .hero-cta{flex-direction:column;align-items:stretch;max-width:300px;margin:0 auto}
  .feat-tabs{flex-wrap:wrap}
  .nav-links{display:none}
  .ham{display:flex}
}
@media(max-width:480px){
  .roles-grid{grid-template-columns:repeat(2,1fr)}
  .footer-top{grid-template-columns:1fr}
  .footer-bottom{flex-direction:column;text-align:center}
}

/* ── TRUST SECTION ── */
.trust-section{background:var(--gray-900);padding:5.5rem 2rem}
.trust-inner{max-width:1060px;margin:0 auto;text-align:center}
.trust-label{font-size:12.5px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;
  color:var(--blue-light);margin-bottom:.6rem;opacity:.85}
.trust-title{font-family:"Plus Jakarta Sans",sans-serif;
  font-size:clamp(1.6rem,3.5vw,2.4rem);font-weight:800;
  letter-spacing:-.025em;line-height:1.15;color:#fff;margin-bottom:.75rem}
.trust-sub{font-size:17px;color:var(--gray-400);font-weight:300;
  line-height:1.7;max-width:500px;margin:0 auto 3rem}
.trust-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.25rem;text-align:left}
.trust-card{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.08);
  border-radius:var(--r-lg);padding:1.5rem;
  transition:background .25s,border-color .25s,transform .25s}
.trust-card:hover{background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.15);transform:translateY(-2px)}
.trust-icon{width:42px;height:42px;border-radius:11px;
  display:flex;align-items:center;justify-content:center;margin-bottom:1rem}
.trust-icon.blue{background:rgba(26,86,219,.2)}
.trust-icon.red{background:rgba(229,57,53,.18)}
.trust-icon.blue svg{width:20px;height:20px;color:var(--blue-light)}
.trust-icon.red svg{width:20px;height:20px;color:#fca5a5}
.trust-card-title{font-family:"Plus Jakarta Sans",sans-serif;
  font-size:1.05rem;font-weight:700;color:#fff;margin-bottom:.4rem}
.trust-card-desc{font-size:15px;color:var(--gray-400);line-height:1.7}
@media(max-width:760px){.trust-grid{grid-template-columns:1fr 1fr}}
@media(max-width:480px){.trust-grid{grid-template-columns:1fr}}



/* ─────────────────────────────────────────────────────────────
   LEGAL PAGE STYLES (privacy, terms of service, terms of use)
───────────────────────────────────────────────────────────── */
.legal-page {

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:"DM Sans",system-ui,sans-serif;background:#F9FAFB;color:#111827;font-size:15px;line-height:1.7;overflow-x:hidden}
:root{
  --blue:#1A56DB;--blue-dark:#1244B8;--blue-mid:#2563EB;--blue-light:#EBF0FD;--blue-xlight:#F0F5FF;
  --red:#E53935;--red-dark:#C62828;--red-light:#FEF2F2;
  --yellow:#FDD835;
  --gray-50:#F9FAFB;--gray-100:#F3F4F6;--gray-200:#E5E7EB;--gray-400:#9CA3AF;
  --gray-500:#6B7280;--gray-600:#4B5563;--gray-700:#374151;--gray-800:#1F2937;--gray-900:#111827;
  --border:#E5E7EB;--r:10px;--r-lg:14px;--r-pill:999px;
  --ease:cubic-bezier(0.25,1,0.5,1);
}
::-webkit-scrollbar{width:5px}::-webkit-scrollbar-thumb{background:var(--blue-light);border-radius:3px}

/* ── NAV ── */
nav{position:sticky;top:0;z-index:100;background:rgba(255,255,255,.95);
  backdrop-filter:blur(12px);border-bottom:1px solid var(--border);
  padding:.75rem 2rem;display:flex;align-items:center;justify-content:space-between;gap:1rem;
  box-shadow:0 1px 0 var(--border)}
.nav-brand{display:flex;align-items:center;gap:10px;text-decoration:none;flex-shrink:0}
.nav-logo{width:54px;height:54px;border-radius:12px;object-fit:cover}
.nav-brand-text{line-height:1.2}
.nav-name{display:block;font-family:"Plus Jakarta Sans",sans-serif;font-size:22px;font-weight:800;color:var(--gray-900);letter-spacing:-.02em}
.nav-org{display:block;font-size:12.5px;color:var(--gray-500);letter-spacing:.04em;margin-top:1px}
.nav-links{display:flex;align-items:center;gap:1.5rem}
.nav-links a{font-size:15px;font-weight:500;color:var(--gray-500);text-decoration:none;transition:color .2s}
.nav-links a:hover{color:var(--blue)}
.nav-btn{background:var(--blue);color:#fff!important;font-family:"Plus Jakarta Sans",sans-serif;
  font-size:14px!important;font-weight:600;padding:8px 18px;border-radius:7px;
  transition:background .2s!important;box-shadow:0 2px 8px rgba(26,86,219,.25)}
.nav-btn:hover{background:var(--blue-dark)!important}

/* ── PAGE HERO ── */
.page-hero{background:#fff;border-bottom:1px solid var(--border);padding:2.75rem 2rem 2.25rem;position:relative;overflow:hidden}
.page-hero::before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;
  background:radial-gradient(ellipse 60% 100% at 0% 50%,var(--blue-xlight) 0%,transparent 60%);
  pointer-events:none}
.page-hero-inner{max-width:1060px;margin:0 auto;position:relative;z-index:1}
.page-badge{display:inline-flex;align-items:center;gap:6px;margin-bottom:.75rem;
  background:var(--blue-light);color:var(--blue);font-size:11px;font-weight:700;
  letter-spacing:.1em;text-transform:uppercase;border-radius:var(--r-pill);padding:3px 12px}
.page-hero h1{font-family:"Plus Jakarta Sans",sans-serif;
  font-size:clamp(2rem,4.5vw,3rem);font-weight:800;
  letter-spacing:-.025em;line-height:1.1;color:var(--gray-900);margin-bottom:.5rem}
.page-meta{font-size:14px;color:var(--gray-400);display:flex;gap:1.5rem;flex-wrap:wrap;margin-top:.35rem}
.page-meta span{display:flex;align-items:center;gap:5px}

/* ── LAYOUT ── */
.layout{max-width:1060px;margin:0 auto;display:grid;
  grid-template-columns:210px 1fr;gap:3rem;padding:2.75rem 2rem 5rem}

/* ── TOC ── */
.toc{position:sticky;top:80px;align-self:start;height:fit-content}
.toc-head{font-size:11px;font-weight:700;color:var(--gray-400);
  letter-spacing:.12em;text-transform:uppercase;margin-bottom:.7rem;
  padding-left:9px}
.toc-list{list-style:none}
.toc-list li{margin-bottom:1px}
.toc-list a{display:flex;align-items:center;gap:6px;padding:6px 9px;
  font-size:14px;color:var(--gray-500);text-decoration:none;border-radius:7px;
  border-left:2px solid transparent;transition:all .18s var(--ease)}
.toc-list a::before{content:"";width:5px;height:5px;border-radius:50%;
  background:var(--gray-300);flex-shrink:0;transition:background .18s}
.toc-list a:hover{color:var(--blue);border-left-color:var(--blue);
  background:var(--blue-xlight);padding-left:13px}
.toc-list a:hover::before{background:var(--blue)}
.toc-list a.active-toc{color:var(--blue);border-left-color:var(--blue);
  background:var(--blue-light);padding-left:13px}
.toc-list a.active-toc::before{background:var(--blue)}

/* ── CONTENT ── */
.content section{margin-bottom:2.5rem;padding-bottom:2.5rem;
  border-bottom:1px solid var(--gray-100)}
.content section:last-child{border-bottom:none;margin-bottom:0}
h2{font-family:"Plus Jakarta Sans",sans-serif;font-size:1.3rem;font-weight:800;
  color:var(--gray-900);margin-bottom:.75rem;
  display:flex;align-items:center;gap:9px}
h2::before{content:"";display:block;width:3px;height:18px;flex-shrink:0;
  background:linear-gradient(to bottom,var(--blue),var(--red));border-radius:2px}
h3{font-family:"Plus Jakarta Sans",sans-serif;font-size:.95rem;font-weight:700;
  color:var(--gray-500);text-transform:uppercase;letter-spacing:.08em;
  margin:1.25rem 0 .4rem}
p{color:var(--gray-600);font-size:16px;margin-bottom:.85rem}
p:last-child{margin-bottom:0}
ul,ol{padding-left:1.3rem;margin-bottom:.75rem}
li{color:var(--gray-600);font-size:16px;margin-bottom:.35rem;padding-left:.2rem}
strong{font-weight:600;color:var(--gray-800)}
code{font-size:12px;background:var(--blue-light);color:var(--blue);
  padding:1px 6px;border-radius:5px;font-family:monospace}

/* ── CALLOUTS ── */
.callout{border-left:3px solid var(--blue);background:var(--blue-xlight);
  border-radius:0 var(--r) var(--r) 0;padding:.9rem 1.1rem;margin:1rem 0}
.callout p{margin:0;font-size:15.5px;color:var(--blue-dark)}
.callout a{color:var(--blue);font-weight:600}
.callout-warning{border-left-color:var(--red);background:var(--red-light)}
.callout-warning p{color:var(--red-dark)}

/* ── RULE GRID ── */
.rule-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin:1rem 0}
.rule-card{background:#fff;border:1px solid var(--border);border-radius:var(--r-lg);padding:1.15rem}
.rule-card.ok{border-top:3px solid #22C55E}
.rule-card.no{border-top:3px solid var(--red)}
.rule-label{font-family:"Plus Jakarta Sans",sans-serif;font-size:11px;font-weight:700;
  letter-spacing:.1em;text-transform:uppercase;margin-bottom:.6rem;display:flex;align-items:center;gap:5px}
.rule-card.ok .rule-label{color:#16A34A}
.rule-card.no .rule-label{color:var(--red)}
.rule-card ul{padding-left:1.1rem;margin:0}
.rule-card li{font-size:14px;margin-bottom:.3rem}

/* ── CONTACT BOX ── */
.contact-box{background:#fff;border:1.5px solid var(--border);border-radius:var(--r-lg);
  padding:1.1rem 1.3rem;margin-top:.75rem;display:flex;flex-direction:column;gap:.2rem}
.contact-box p{margin:0;font-size:13px}
.contact-box a{color:var(--blue);text-decoration:none;font-weight:500}
.contact-box a:hover{text-decoration:underline}

/* ── FOOTER ── */
footer{background:var(--gray-900);padding:2rem;text-align:center}
footer p{font-size:14.5px;color:var(--gray-500)}
footer a{color:var(--gray-400);text-decoration:none;transition:color .2s}
footer a:hover{color:var(--blue-light)}
.stripe{height:3px;background:linear-gradient(90deg,var(--blue),var(--blue) 34%,var(--yellow) 34%,var(--yellow) 67%,var(--red) 67%)}

@media(max-width:768px){
  .layout{grid-template-columns:1fr;gap:1.5rem}.toc{display:none}
  .rule-grid{grid-template-columns:1fr}
  .nav-links a:not(.nav-btn){display:none}
}

}
