/* ==========================================================================
   GAMSME Institutional — theme.css
   Colours, fonts and sizes arrive as CSS custom properties from
   inc/dynamic-css.php (Website Settings). This file is the design system.
   ========================================================================== */

/* ----------------------------------------------------------- Reset / base */
*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
body{
	margin:0;
	font-family:var(--font-body);
	font-size:var(--fs-body);
	line-height:var(--lh-body);
	color:var(--c-body);
	background:var(--page-bg);
	-webkit-font-smoothing:antialiased;
	text-rendering:optimizeLegibility;
}
body.lang-hi{font-family:var(--font-body-hi)}
img{max-width:100%;height:auto;display:block}
a{color:var(--c-link);text-decoration:none;transition:color .2s}
a:hover{color:var(--c-link-hover)}
h1,h2,h3,h4,h5,h6{
	font-family:var(--font-display);
	color:var(--c-heading);
	line-height:var(--lh-heading);
	font-weight:var(--fw-heading);
	margin:0 0 .5em;
	letter-spacing:-.01em;
}
.lang-hi h1,.lang-hi h2,.lang-hi h3,.lang-hi h4{font-family:var(--font-display-hi)}
h1{font-size:var(--fs-h1)}
h2{font-size:var(--fs-h2)}
h3{font-size:var(--fs-h3)}
h4{font-size:var(--fs-h4)}
p{margin:0 0 1.1em}
ul,ol{margin:0 0 1.1em;padding-left:1.25em}
hr{border:0;border-top:1px solid var(--c-border);margin:2em 0}
:focus-visible{outline:3px solid var(--c-accent);outline-offset:2px;border-radius:3px}

.container{width:min(100% - 40px,var(--container));margin-inline:auto}
.content-narrow{max-width:var(--content);margin-inline:auto}
.section{padding-block:var(--section-pad)}
.section--alt{background:var(--c-section-bg)}
.screen-reader-text{position:absolute!important;clip:rect(1px,1px,1px,1px);width:1px;height:1px;overflow:hidden}
.skip-link{position:absolute;left:-999px;top:0;background:var(--c-primary);color:#fff;padding:10px 16px;z-index:200;border-radius:0 0 8px 0}
.skip-link:focus{left:0}

/* ----------------------------------------------------------- Buttons */
.btn{
	display:inline-flex;align-items:center;gap:.5em;
	font-family:var(--font-body);
	font-size:var(--fs-button);
	font-weight:var(--btn-weight);
	line-height:1;
	padding:var(--btn-pad-y) var(--btn-pad-x);
	border-radius:var(--btn-radius);
	border:2px solid transparent;
	cursor:pointer;
	transition:transform .15s ease,background .2s,color .2s,border-color .2s,box-shadow .2s;
	text-align:center;
}
.btn:hover{transform:translateY(-2px)}
.btn--primary,.btn--header.filled{background:var(--c-btn-bg);color:var(--c-btn-text);box-shadow:0 8px 20px -10px var(--c-btn-bg)}
.btn--primary:hover,.btn--header.filled:hover{background:var(--c-btn-hover-bg);color:var(--c-btn-hover-text)}
.btn--ghost{background:transparent;color:#fff;border-color:rgba(255,255,255,.55)}
.btn--ghost:hover{background:rgba(255,255,255,.12);color:#fff}
.btn--ghost-dark,.btn--header.outline{background:transparent;color:var(--c-primary);border-color:var(--c-primary)}
.btn--ghost-dark:hover,.btn--header.outline:hover{background:var(--c-primary);color:#fff}
.btn--ghost-light{background:transparent;color:#fff;border-color:rgba(255,255,255,.6)}
.btn--ghost-light:hover{background:#fff;color:var(--c-primary)}
.btn--light{background:#fff;color:var(--c-primary)}
.btn--light:hover{background:#fff;color:var(--c-primary-dark)}
.btn--text{background:transparent;color:var(--c-primary);padding-inline:0;border:0;font-weight:600}
.btn--text:hover{color:var(--c-accent-dark);transform:none}
.btn--header.rounded{background:var(--c-btn-bg);color:var(--c-btn-text);border-radius:10px}

/* ----------------------------------------------------------- Advertising bar (no Sponsored label) */
.adbar{background:linear-gradient(90deg,var(--c-primary),var(--c-primary-dark));color:#fff}
.adbar-inner{display:flex;align-items:center;justify-content:center;gap:14px;min-height:42px;position:relative}
.adbar-link{color:#fff;font-size:14px;font-weight:600;display:inline-flex;align-items:center;gap:8px}
.adbar-link:hover{color:#fff;opacity:.9}
.adbar-link .icon{transition:transform .2s}
.adbar-link:hover .icon{transform:translateX(4px)}
.adbar-close{position:absolute;right:0;background:none;border:0;color:#fff;opacity:.7;cursor:pointer;padding:6px}
.adbar-close:hover{opacity:1}

/* ----------------------------------------------------------- Top bar */
.topbar{background:var(--c-topbar-bg);color:var(--c-topbar-text);font-size:13.5px}
.topbar-inner{display:flex;align-items:center;justify-content:space-between;min-height:40px;gap:18px}
.topbar a{color:var(--c-topbar-text);display:inline-flex;align-items:center;gap:6px}
.topbar a:hover{opacity:.8;color:var(--c-topbar-text)}
.topbar-left{display:flex;gap:20px;align-items:center;flex-wrap:wrap}
.topbar-right{display:flex;gap:16px;align-items:center}
.topbar-note{opacity:.85}
.topbar-menu{display:flex;gap:14px;list-style:none;margin:0;padding:0}
@media(max-width:900px){.topbar--desktop{display:none}}

/* ----------------------------------------------------------- Announcement */
.announce{font-size:14.5px}
.announce-inner{display:flex;align-items:center;gap:16px;min-height:46px;position:relative}
.announce--center .announce-inner{justify-content:center}
.announce--right .announce-inner{justify-content:flex-end}
.announce-text{font-weight:600}
.announce-btn{background:rgba(255,255,255,.18);color:inherit;padding:5px 14px;border-radius:999px;font-weight:600;font-size:13px}
.announce-btn:hover{background:rgba(255,255,255,.3);color:inherit}
.announce-close{background:none;border:0;color:inherit;opacity:.7;cursor:pointer;position:absolute;right:0}
.announce-close:hover{opacity:1}

/* ----------------------------------------------------------- Header */
.site-header{background:var(--c-header-bg);position:relative;z-index:50;transition:padding .25s,box-shadow .25s,background .25s}
.header-inner{display:flex;align-items:center;gap:28px;min-height:var(--logo-h);padding-block:var(--logo-pad-y)}
.header--logo-center .header-inner{flex-direction:column;gap:10px}
body.has-sticky-header .site-header{position:sticky;top:0}
.site-header.is-stuck{box-shadow:0 6px 24px -14px rgba(13,40,60,.4)}
.site-header.is-shrunk .header-inner{min-height:54px;padding-block:2px}
.site-header.is-shrunk .brand-logo{max-height:42px}

/* transparent header over hero */
body.has-transparent-header .site-header{background:transparent;position:absolute;left:0;right:0}
body.has-transparent-header .site-header:not(.is-stuck) .nav-menu>.menu-item>.menu-link{color:#fff}
body.has-transparent-header .site-header:not(.is-stuck) .brand-logo--dark{display:none}
body.has-transparent-header .site-header:not(.is-stuck) .brand-logo--light{display:block}
body.has-transparent-header .site-header.is-stuck{background:var(--c-header-bg);position:fixed;left:0;right:0;top:0}

.brand{display:inline-flex;align-items:center}
.brand-logo{max-height:var(--logo-h);width:auto;padding:0 var(--logo-pad-x)}
.brand-logo--light{display:none}
.brand-text{font-family:var(--font-display);font-size:22px;font-weight:700;color:var(--c-heading)}
.brand-meta{display:flex;flex-direction:column;margin-left:12px}
.brand-meta-title{font-family:var(--font-display);font-weight:700;color:var(--c-heading);font-size:18px;line-height:1.1}
.brand-meta-tag{font-size:12.5px;color:var(--c-muted)}
.header-brand{margin-right:auto}
.header--logo-center .header-brand{margin-right:0}

.primary-nav{margin-left:auto}
.nav-menu{display:flex;list-style:none;margin:0;padding:0;gap:4px;align-items:center}
.nav-menu .menu-item{position:relative}
.nav-menu .menu-link{
	display:inline-flex;align-items:center;gap:5px;
	padding:10px 14px;border-radius:8px;
	color:var(--c-menu-text);font-size:var(--fs-menu);font-weight:600;
}
.nav-menu .menu-link:hover,.nav-menu .current-menu-item>.menu-link{color:var(--c-menu-hover);background:color-mix(in srgb,var(--c-menu-hover) 8%,transparent)}
.caret{width:7px;height:7px;border-right:2px solid currentColor;border-bottom:2px solid currentColor;transform:rotate(45deg);margin-top:-3px;transition:transform .2s}
.menu-item-has-children:hover>.menu-link .caret{transform:rotate(225deg);margin-top:2px}

/* dropdowns */
.nav-menu .sub-menu{
	position:absolute;top:calc(100% + 6px);left:0;min-width:230px;
	background:#fff;border:1px solid var(--c-border);border-radius:14px;
	box-shadow:0 24px 48px -24px rgba(13,40,60,.4);
	padding:8px;list-style:none;margin:0;
	opacity:0;visibility:hidden;transform:translateY(8px);transition:all .2s;z-index:60;
}
.nav-menu .menu-item:hover>.sub-menu{opacity:1;visibility:visible;transform:translateY(0)}
.nav-menu .sub-menu .menu-link{padding:9px 12px;border-radius:8px;width:100%;color:var(--c-body);font-weight:500}
.nav-menu .sub-menu .menu-link:hover{background:var(--c-section-bg);color:var(--c-primary)}
.menu-desc{display:block;font-size:12px;color:var(--c-muted);padding:0 12px 6px}

/* mega menu */
.nav-menu .has-mega{position:static}
.nav-menu .has-mega>.sub-menu{
	left:50%;transform:translate(-50%,8px);width:min(960px,92vw);
	display:grid;grid-template-columns:repeat(4,1fr);gap:4px;padding:22px;
}
.nav-menu .has-mega:hover>.sub-menu{transform:translate(-50%,0)}
.nav-menu .has-mega>.sub-menu>.menu-item>.menu-link{font-weight:700;color:var(--c-primary);text-transform:uppercase;font-size:12px;letter-spacing:.04em}
.nav-menu .has-mega .sub-menu--nested{position:static;opacity:1;visibility:visible;transform:none;box-shadow:none;border:0;padding:0;background:none;min-width:0}

.header-actions{display:flex;align-items:center;gap:10px}
.icon-btn{background:none;border:0;cursor:pointer;color:var(--c-heading);padding:8px;border-radius:10px;display:inline-flex;line-height:0}
.icon-btn:hover{background:var(--c-section-bg);color:var(--c-primary)}
.menu-toggle{display:none}

/* language switch */
.lang-switch{display:inline-flex;gap:2px;border:1px solid var(--c-border);border-radius:999px;padding:3px;background:#fff}
.lang-switch--topbar{border-color:rgba(255,255,255,.3);background:transparent}
.lang-opt{background:none;border:0;cursor:pointer;font:inherit;font-size:12.5px;font-weight:600;color:var(--c-muted);padding:4px 10px;border-radius:999px;line-height:1}
.lang-switch--topbar .lang-opt{color:var(--c-topbar-text)}
.lang-opt.is-active,.lang-opt:hover{background:var(--c-primary);color:#fff}

/* ----------------------------------------------------------- Mobile drawer */
.mobile-drawer{position:fixed;inset:0;z-index:120;visibility:hidden;pointer-events:none}
.mobile-drawer.is-open{visibility:visible;pointer-events:auto}
.mobile-drawer-scrim{position:absolute;inset:0;background:rgba(12,42,62,.5);opacity:0;transition:opacity .3s}
.mobile-drawer.is-open .mobile-drawer-scrim{opacity:1}
.mobile-drawer-panel{
	position:absolute;top:0;right:0;height:100%;width:min(360px,86vw);background:#fff;
	transform:translateX(100%);transition:transform .3s ease;display:flex;flex-direction:column;
	box-shadow:-20px 0 50px -30px rgba(13,40,60,.6);overflow-y:auto;
}
.mobile-drawer.is-open .mobile-drawer-panel{transform:translateX(0)}
.mobile-drawer-head{display:flex;align-items:center;justify-content:space-between;padding:18px 20px;border-bottom:1px solid var(--c-border)}
.mobile-drawer-head .brand-logo{max-height:42px}
.mobile-nav{padding:12px 8px;flex:1}
.mobile-menu,.mobile-menu .sub-menu{list-style:none;margin:0;padding:0}
.mobile-menu .menu-link{display:block;padding:13px 16px;border-radius:10px;color:var(--c-heading);font-weight:600;font-size:16px}
.mobile-menu .menu-link:hover{background:var(--c-section-bg);color:var(--c-primary)}
.mobile-menu .sub-menu{padding-left:14px}
.mobile-menu .sub-menu .menu-link{font-weight:500;font-size:15px;color:var(--c-body)}
.mobile-drawer-foot{padding:18px 20px;border-top:1px solid var(--c-border);display:flex;flex-direction:column;gap:14px}

/* ----------------------------------------------------------- Search overlay */
.search-overlay{position:fixed;inset:0;z-index:130;background:rgba(12,42,62,.96);display:grid;place-items:center;opacity:0;visibility:hidden;transition:opacity .25s}
.search-overlay.is-open{opacity:1;visibility:visible}
.search-overlay-inner{width:min(680px,90vw);position:relative}
.search-close{position:absolute;top:-56px;right:0;color:#fff}
.search-overlay .search-form{display:flex;gap:10px}
.search-overlay .search-field{flex:1;font-size:20px;padding:16px 20px;border-radius:12px;border:0}
.search-form{display:flex;gap:10px}
.search-field{border:1px solid var(--c-border);border-radius:10px;padding:12px 16px;font:inherit;flex:1;background:#fff;color:var(--c-body)}

/* ----------------------------------------------------------- Hero */
.hero{position:relative;display:flex;align-items:center;min-height:var(--hero-h);color:var(--hero-text);overflow:hidden;background:var(--c-primary-dark)}
.hero--color{background:linear-gradient(135deg,var(--c-primary-dark),var(--c-primary))}
.hero--image{background-size:cover;background-position:center}
.hero-overlay{position:absolute;inset:0;background:var(--hero-overlay)}
.hero-inner{position:relative;z-index:2;padding-block:clamp(48px,9vh,110px)}
.hero-content{max-width:760px}
.hero--center .hero-content{margin-inline:auto;text-align:center}
.hero-title{color:var(--hero-text);font-size:clamp(34px,5.2vw,var(--fs-h1));margin-bottom:.35em;letter-spacing:-.02em}
.hero-sub{color:var(--hero-text);opacity:.92;font-size:clamp(17px,2.1vw,21px);max-width:620px;margin-bottom:1.6em}
.hero--center .hero-sub{margin-inline:auto}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap}
.hero--center .hero-actions{justify-content:center}
/* hero decorative gear motif */
.hero::after{content:"";position:absolute;right:-120px;top:50%;transform:translateY(-50%);width:420px;height:420px;border:44px solid rgba(241,149,40,.12);border-radius:50%;z-index:1;pointer-events:none}
.hero.is-animated .hero-title,.hero.is-animated .hero-sub,.hero.is-animated .hero-actions{opacity:0;animation:gam-rise .7s ease forwards}
.hero.is-animated .hero-sub{animation-delay:.12s}
.hero.is-animated .hero-actions{animation-delay:.24s}
@keyframes gam-rise{from{opacity:0;transform:translateY(18px)}to{opacity:1;transform:translateY(0)}}

/* ----------------------------------------------------------- Section heads */
.section-head{max-width:680px;margin-bottom:48px}
.section--center .section-head,.section-head.center{margin-inline:auto;text-align:center}
.eyebrow{display:inline-block;font-size:13px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--c-accent-dark);margin-bottom:12px;position:relative;padding-left:30px}
.eyebrow::before{content:"";position:absolute;left:0;top:50%;width:22px;height:2px;background:var(--c-accent)}
.section-title{font-size:var(--fs-h2);margin:0}
.section-sub{color:var(--c-muted);margin-top:10px;font-size:18px}
.section-foot{margin-top:34px;text-align:center}

/* ----------------------------------------------------------- Grids & cards */
.cards{display:grid;gap:var(--card-gap)}
.cols-2{grid-template-columns:repeat(2,1fr)}
.cols-3{grid-template-columns:repeat(3,1fr)}
.cols-4{grid-template-columns:repeat(4,1fr)}
.grid{display:grid;gap:24px}
.grid--2{grid-template-columns:repeat(2,1fr)}
.grid--4{grid-template-columns:repeat(4,1fr)}

.card{background:var(--c-card-bg);border:1px solid var(--c-border);border-radius:var(--card-radius);overflow:hidden;display:flex;flex-direction:column;box-shadow:0 18px 40px -30px rgba(13,40,60,.5);transition:transform .25s,box-shadow .25s}
.card:hover{transform:translateY(-6px);box-shadow:0 26px 50px -28px rgba(13,40,60,.55)}
.card-media{display:block;aspect-ratio:3/2;overflow:hidden;background:var(--c-section-bg)}
.card-media img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.card:hover .card-media img{transform:scale(1.05)}
.card-body{padding:24px;display:flex;flex-direction:column;gap:10px;flex:1}
.card-tag{align-self:flex-start;font-size:11.5px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--c-primary);background:color-mix(in srgb,var(--c-primary) 10%,transparent);padding:4px 10px;border-radius:999px}
.card-title{font-size:var(--fs-h4);margin:0;line-height:1.25}
.card-title a{color:var(--c-heading)}
.card-title a:hover{color:var(--c-primary)}
.card-excerpt{color:var(--c-muted);font-size:15.5px;margin:0}
.card-meta{font-size:13px;color:var(--c-muted);display:flex;align-items:center;gap:6px;margin:0}
.card-more{margin-top:auto;font-weight:600;color:var(--c-primary);display:inline-flex;align-items:center;gap:6px}
.card-more .icon{transition:transform .2s}
.card-more:hover .icon{transform:translateX(4px)}
.card--interv .card-body{padding:28px}
.card--interv{border-top:4px solid var(--c-accent)}

.mini-card{background:var(--c-card-bg);border:1px solid var(--c-border);border-radius:var(--card-radius);padding:28px}
.mini-card h3{font-size:20px;color:var(--c-primary)}
.mini-card p{margin:0;color:var(--c-muted)}

.feature{text-align:left}
.feature-ic{width:54px;height:54px;border-radius:14px;display:grid;place-items:center;background:color-mix(in srgb,var(--c-primary) 10%,transparent);color:var(--c-primary);margin-bottom:16px}
.feature h3{font-size:19px;margin-bottom:6px}
.feature p{color:var(--c-muted);margin:0;font-size:15.5px}

/* ----------------------------------------------------------- Impact numbers */
.impact-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.impact-card{background:var(--c-card-bg);border:1px solid var(--c-border);border-radius:var(--card-radius);padding:30px 24px;text-align:center;position:relative;overflow:hidden}
.impact-card::before{content:"";position:absolute;left:0;top:0;width:100%;height:4px;background:linear-gradient(90deg,var(--c-primary),var(--c-accent))}
.impact-num{font-family:var(--font-display);font-size:clamp(34px,4vw,46px);font-weight:700;color:var(--c-primary);line-height:1;display:flex;align-items:baseline;justify-content:center;gap:2px}
.impact-prefix,.impact-suffix{font-size:.55em;color:var(--c-accent-dark)}
.impact-label{margin-top:10px;font-weight:600;color:var(--c-heading)}
.impact-note{margin-top:4px;font-size:13px;color:var(--c-muted)}

/* ----------------------------------------------------------- About */
.about-grid{display:grid;grid-template-columns:1.3fr .9fr;gap:56px;align-items:center}
.ticks{list-style:none;padding:0;margin:0 0 28px}
.ticks li{display:flex;gap:12px;align-items:flex-start;margin-bottom:12px}
.ticks .icon{color:var(--c-accent-dark);flex:none;margin-top:3px}
.about-card{background:linear-gradient(155deg,var(--c-primary),var(--c-primary-dark));color:#fff;border-radius:22px;padding:38px}
.about-card h3{color:#fff}
.about-card p{opacity:.9}
.about-card-foot{display:flex;align-items:center;gap:14px;margin-top:26px;padding-top:22px;border-top:1px solid rgba(255,255,255,.18);font-family:var(--font-display);font-style:italic}
.about-card-foot .icon{color:var(--c-accent)}

/* ----------------------------------------------------------- Membership */
.membership-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}
.membership-tiers{display:grid;gap:16px}
.tier{background:var(--c-card-bg);border:1px solid var(--c-border);border-left:4px solid var(--c-accent);border-radius:14px;padding:22px 24px}
.tier h3{margin:0 0 4px;font-size:18px;color:var(--c-primary)}
.tier p{margin:0;color:var(--c-muted);font-size:15px}

/* ----------------------------------------------------------- Banner / promo zone */
.section--banner{padding-block:36px}
.promo{display:block;border-radius:18px;overflow:hidden;border:1px dashed var(--c-border)}
.promo img{width:100%}
.promo-fallback{display:flex;align-items:center;justify-content:center;gap:12px;padding:30px;background:color-mix(in srgb,var(--c-primary) 6%,transparent);color:var(--c-primary);font-weight:600;font-size:18px}

/* ----------------------------------------------------------- Partners */
.partner-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:18px}
.partner{display:grid;place-items:center;background:var(--c-card-bg);border:1px solid var(--c-border);border-radius:14px;padding:22px;min-height:96px;filter:grayscale(1);opacity:.75;transition:all .25s}
.partner:hover{filter:none;opacity:1}
.partner img{max-height:54px;width:auto;object-fit:contain}
.partner span{font-weight:600;color:var(--c-muted);text-align:center;font-size:14px}

/* ----------------------------------------------------------- CTA */
.section--cta{background:linear-gradient(135deg,var(--c-primary),var(--c-primary-dark));color:#fff;text-align:center}
.cta-inner{max-width:720px;margin-inline:auto}
.section--cta h2{color:#fff;font-size:clamp(28px,3.6vw,40px)}
.section--cta p{opacity:.92;font-size:19px;margin-bottom:1.6em}

/* ----------------------------------------------------------- Newsletter */
.newsletter-inner{display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:center;background:var(--c-section-bg);border:1px solid var(--c-border);border-radius:24px;padding:44px}
.newsletter-copy h2{margin:0 0 8px}
.newsletter-copy p{margin:0;color:var(--c-muted)}
.nl-form{display:flex;gap:10px}
.nl-form input{flex:1;border:1px solid var(--c-border);border-radius:999px;padding:13px 18px;font:inherit;background:#fff}
.nl-note{font-size:12.5px;color:var(--c-muted);margin-top:10px}

/* ----------------------------------------------------------- Page banner */
.page-banner{background:var(--c-section-bg);padding-block:54px;--banner-ov:rgba(12,42,62,.55)}
.page-banner.has-image{background-size:cover;background-position:center;color:#fff}
.page-banner.has-image .page-banner-title,.page-banner.has-image .breadcrumbs,.page-banner.has-image .breadcrumbs a{color:#fff}
.page-banner.align-center{text-align:center}
.page-banner-title{font-size:clamp(30px,4.4vw,var(--fs-h1));margin:8px 0 0}
.page-banner-sub{color:var(--c-muted);margin-top:10px;max-width:680px;font-size:18px}
.page-banner.align-center .page-banner-sub{margin-inline:auto}

/* ----------------------------------------------------------- Breadcrumbs */
.breadcrumbs ol{list-style:none;display:flex;flex-wrap:wrap;gap:8px;margin:0;padding:0;font-size:14px;color:var(--c-muted)}
.breadcrumbs li+li::before{content:"/";margin-right:8px;opacity:.5}
.breadcrumbs a{color:var(--c-muted)}
.breadcrumbs a:hover{color:var(--c-primary)}

/* ----------------------------------------------------------- Layout / single */
.layout{display:grid;gap:48px}
.layout.has-sidebar{grid-template-columns:1fr 320px}
.entry-content{font-size:var(--fs-body)}
.entry-content h2{margin-top:1.6em}
.entry-content h3{margin-top:1.4em}
.entry-content img{border-radius:14px;margin-block:1.4em}
.entry-content blockquote{border-left:4px solid var(--c-accent);background:var(--c-section-bg);margin:1.6em 0;padding:18px 24px;border-radius:0 12px 12px 0;font-family:var(--font-display);font-style:italic;color:var(--c-heading)}
.entry-content a{text-decoration:underline;text-decoration-color:color-mix(in srgb,var(--c-link) 40%,transparent);text-underline-offset:3px}
.single-meta{color:var(--c-muted);font-size:14.5px;text-transform:uppercase;letter-spacing:.04em}
.single-feature{margin:0 0 28px}
.single-feature img{width:100%;border-radius:18px}
.fact-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:var(--c-border);border:1px solid var(--c-border);border-radius:14px;overflow:hidden;margin:0 0 28px}
.fact{background:#fff;padding:16px 20px}
.fact dt{font-size:12px;text-transform:uppercase;letter-spacing:.05em;color:var(--c-muted);margin-bottom:4px;display:flex;align-items:center;gap:6px}
.fact dd{margin:0;font-weight:600;color:var(--c-heading)}

.share{display:flex;align-items:center;gap:10px;margin-top:36px;padding-top:24px;border-top:1px solid var(--c-border)}
.share-label{font-weight:600;color:var(--c-muted);font-size:14px}
.share a{width:38px;height:38px;border-radius:50%;display:grid;place-items:center;background:var(--c-section-bg);color:var(--c-primary)}
.share a:hover{background:var(--c-primary);color:#fff}

/* ----------------------------------------------------------- Search results */
.search-results{display:flex;flex-direction:column;gap:20px}
.search-item{display:flex;gap:20px;padding-bottom:20px;border-bottom:1px solid var(--c-border)}
.search-thumb{flex:none;width:140px}
.search-thumb img{border-radius:12px;aspect-ratio:3/2;object-fit:cover}
.search-type{font-size:12px;text-transform:uppercase;letter-spacing:.05em;color:var(--c-accent-dark);font-weight:700}
.search-title{font-size:21px;margin:4px 0 6px}
.search-count{color:var(--c-muted);margin-bottom:28px}

/* ----------------------------------------------------------- Filter chips / accordion */
.filter-chips{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:36px}
.chip{padding:8px 16px;border-radius:999px;border:1px solid var(--c-border);font-size:14px;font-weight:600;color:var(--c-muted)}
.chip:hover,.chip.is-active{background:var(--c-primary);color:#fff;border-color:var(--c-primary)}
.accordion{display:flex;flex-direction:column;gap:12px;margin-top:24px}
.accordion-item{border:1px solid var(--c-border);border-radius:14px;overflow:hidden;background:#fff}
.accordion-q{width:100%;display:flex;align-items:center;justify-content:space-between;gap:16px;padding:20px 24px;background:none;border:0;cursor:pointer;font:inherit;font-weight:600;font-size:17px;color:var(--c-heading);text-align:left}
.accordion-ic{width:14px;height:14px;flex:none;position:relative}
.accordion-ic::before,.accordion-ic::after{content:"";position:absolute;background:var(--c-primary);transition:transform .25s}
.accordion-ic::before{top:6px;left:0;width:14px;height:2px}
.accordion-ic::after{left:6px;top:0;width:2px;height:14px}
.accordion-q[aria-expanded="true"] .accordion-ic::after{transform:scaleY(0)}
.accordion-a{max-height:0;overflow:hidden;transition:max-height .3s ease}
.accordion-a-inner{padding:0 24px 22px;color:var(--c-muted)}

/* ----------------------------------------------------------- Contact / involve */
.contact-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:48px}
.contact-list{margin-top:20px}
.form-placeholder{background:var(--c-section-bg);border:1px dashed var(--c-border);border-radius:16px;padding:40px;color:var(--c-muted)}
.card--involve .feature-ic{margin-bottom:14px}

/* ----------------------------------------------------------- Footer */
.site-footer{margin-top:0}
.footer-top{display:grid;gap:40px;padding-block:64px}
.footer-cols-2{grid-template-columns:repeat(2,1fr)}
.footer-cols-3{grid-template-columns:1.6fr 1fr 1fr}
.footer-cols-4{grid-template-columns:1.8fr 1fr 1fr 1.2fr}
.footer-cols-5{grid-template-columns:1.8fr 1fr 1fr 1fr 1.2fr}
.footer-logo{margin-bottom:18px}
.footer-brand-text{font-family:var(--font-display);font-size:22px;font-weight:700;color:var(--c-footer-heading);display:block;margin-bottom:14px}
.footer-about{color:var(--c-footer-text);opacity:.85;font-size:15px;max-width:36ch}
.footer-heading{color:var(--c-footer-heading);font-size:16px;margin-bottom:16px}
.footer-menu,.footer-contact,.legal-menu{list-style:none;margin:0;padding:0}
.footer-menu li,.footer-contact li{margin-bottom:10px}
.footer-menu a,.footer-contact a,.footer-contact span{color:var(--c-footer-text);opacity:.85;font-size:15px}
.footer-menu a:hover,.footer-contact a:hover{opacity:1;color:#fff}
.footer-contact li{display:flex;gap:10px;align-items:flex-start}
.footer-contact .icon{color:var(--c-accent);flex:none;margin-top:3px}
.footer-bottom{border-top:1px solid rgba(255,255,255,.12)}
.footer-bottom-inner{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;padding-block:22px}
.footer-copy,.footer-dev{margin:0;font-size:13.5px;opacity:.8}
.legal-menu{display:flex;gap:18px}
.legal-menu a{color:var(--c-footer-text);opacity:.8;font-size:13.5px}

.social{display:flex;gap:10px}
.social a{width:38px;height:38px;border-radius:50%;display:grid;place-items:center;border:1px solid var(--c-border);color:var(--c-primary);transition:all .2s}
.social a:hover{background:var(--c-primary);color:#fff;border-color:var(--c-primary);transform:translateY(-3px)}
.social--footer a,.social--drawer a{margin-top:18px}
.social--footer a{border-color:rgba(255,255,255,.2);color:var(--c-footer-text)}
.social--footer a:hover{background:var(--c-accent);color:#12283A;border-color:var(--c-accent)}
.social--topbar a{width:auto;height:auto;border:0;color:var(--c-topbar-text)}

/* ----------------------------------------------------------- Floating buttons */
.float-wa{position:fixed;right:22px;bottom:22px;z-index:90;width:56px;height:56px;border-radius:50%;background:#25D366;color:#fff;display:grid;place-items:center;box-shadow:0 12px 28px -10px rgba(37,211,102,.7)}
.float-wa:hover{color:#fff;transform:scale(1.06)}
.back-to-top{position:fixed;right:22px;bottom:22px;z-index:80;width:48px;height:48px;border-radius:50%;background:var(--c-primary);color:#fff;border:0;cursor:pointer;display:grid;place-items:center;opacity:0;visibility:hidden;transform:translateY(12px);transition:all .25s;box-shadow:0 12px 28px -12px var(--c-primary)}
.back-to-top.is-visible{opacity:1;visibility:visible;transform:translateY(0)}
.float-wa ~ .back-to-top{bottom:88px}

/* ----------------------------------------------------------- Pagination */
.pagination,.nav-links{display:flex;gap:8px;justify-content:center;margin-top:48px;flex-wrap:wrap}
.page-numbers{display:grid;place-items:center;min-width:42px;height:42px;padding:0 12px;border-radius:10px;border:1px solid var(--c-border);color:var(--c-body);font-weight:600}
.page-numbers.current,.page-numbers:hover{background:var(--c-primary);color:#fff;border-color:var(--c-primary)}

/* ----------------------------------------------------------- Forms (plugin friendly) */
.contact-form-wrap input[type=text],.contact-form-wrap input[type=email],.contact-form-wrap input[type=tel],
.contact-form-wrap textarea,.contact-form-wrap select,
.wpcf7 input,.wpcf7 textarea,.fluentform input,.fluentform textarea,.wpforms-field input,.wpforms-field textarea{
	width:100%;border:1px solid var(--c-border);border-radius:10px;padding:12px 14px;font:inherit;background:#fff;color:var(--c-body)
}
.wpcf7 input[type=submit],.fluentform button,.wpforms-submit{background:var(--c-btn-bg)!important;color:var(--c-btn-text)!important;border:0;border-radius:var(--btn-radius);padding:13px 26px;font-weight:600;cursor:pointer}

/* ----------------------------------------------------------- Responsive */
@media(max-width:1024px){
	.about-grid,.membership-grid,.newsletter-inner,.contact-grid{grid-template-columns:1fr}
	.cols-4,.grid--4{grid-template-columns:repeat(2,1fr)}
	.impact-grid{grid-template-columns:repeat(2,1fr)}
	.partner-grid{grid-template-columns:repeat(4,1fr)}
	.footer-cols-4,.footer-cols-5{grid-template-columns:1fr 1fr}
}
@media(max-width:900px){
	.primary-nav{display:none}
	.menu-toggle{display:inline-flex}
	.layout.has-sidebar{grid-template-columns:1fr}
	.fact-grid{grid-template-columns:1fr}
}
@media(max-width:640px){
	:root{--section-pad:56px}
	.cols-2,.cols-3,.grid--2{grid-template-columns:1fr}
	.impact-grid{grid-template-columns:repeat(2,1fr);gap:12px}
	.partner-grid{grid-template-columns:repeat(2,1fr)}
	.footer-top,.footer-cols-3,.footer-cols-4,.footer-cols-5{grid-template-columns:1fr}
	.hero::after{display:none}
	.search-item{flex-direction:column}
	.search-thumb{width:100%}
	.footer-bottom-inner{flex-direction:column;align-items:flex-start}
	.legal-menu{flex-wrap:wrap}
	.nl-form{flex-direction:column}
	.nl-form input{border-radius:12px}
}

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

/* ==========================================================================
   v1.1 additions — blueprint pages, sections, prominent logo, Action Updates
   ========================================================================== */

/* ---- Prominent homepage logo ---- */
.home .site-header:not(.is-shrunk) .brand-logo{max-height:var(--logo-h-home)}
.home .header-inner{min-height:calc(var(--logo-h-home) + 24px)}
@media(max-width:900px){
	.home .site-header:not(.is-shrunk) .brand-logo{max-height:calc(var(--logo-h-home) * .7)}
	.home .header-inner{min-height:auto}
}

/* ---- Header login link (beside Join Now) ---- */
.header-login{display:inline-flex;align-items:center;gap:6px;font-size:14px;font-weight:600;color:var(--c-heading);padding:8px 12px;border-radius:10px}
.header-login:hover{color:var(--c-primary);background:var(--c-section-bg)}
body.has-transparent-header .site-header:not(.is-stuck) .header-login{color:#fff}
@media(max-width:1100px){.header-login span{display:none}}

/* ---- Lead paragraph + inner-page content rhythm ---- */
.is-lead{font-size:1.18em;color:var(--c-heading);line-height:1.6}
.page-article .entry-content>h2:first-child,.section .entry-content>p:first-child{margin-top:0}
.entry-content .wp-block-buttons{margin-top:1.6em}
.entry-content .wp-block-button__link{display:inline-flex;align-items:center;background:var(--c-btn-bg);color:var(--c-btn-text);border-radius:var(--btn-radius);padding:13px 26px;font-weight:600;font-family:var(--font-body)}
.entry-content .wp-block-button.is-style-outline .wp-block-button__link,.entry-content .wp-block-buttons .wp-block-button:nth-child(2) .wp-block-button__link{background:transparent;color:var(--c-primary);border:2px solid var(--c-primary)}

/* ---- Tables (block + seeded) ---- */
.wp-block-table{margin:1.6em 0}
.wp-block-table table{border-collapse:separate;border-spacing:0;width:100%;border:1px solid var(--c-border);border-radius:14px;overflow:hidden}
.wp-block-table th{background:var(--c-primary);color:#fff;font-family:var(--font-display);font-weight:600;text-align:left;padding:14px 18px;font-size:15px}
.wp-block-table td{padding:13px 18px;border-top:1px solid var(--c-border);font-size:15.5px;vertical-align:top}
.wp-block-table.is-style-stripes tbody tr:nth-child(odd){background:var(--c-section-bg)}
.gamsme-table table{box-shadow:0 18px 40px -32px rgba(13,40,60,.5)}

/* ---- Impact band: navy strip, white numerals (blueprint) ---- */
.section--impact{background:linear-gradient(135deg,var(--c-primary),var(--c-primary-dark));color:#fff}
.section--impact .eyebrow{color:var(--c-accent)}
.section--impact .eyebrow::before{background:var(--c-accent)}
.section--impact .section-title{color:#fff}
.section--impact .section-sub{color:rgba(255,255,255,.85)}
.impact-grid--6{grid-template-columns:repeat(6,1fr)}
.section--impact .impact-card{background:rgba(255,255,255,.06);border-color:rgba(255,255,255,.14)}
.section--impact .impact-card::before{background:var(--c-accent)}
.section--impact .impact-num{color:#fff}
.section--impact .impact-prefix,.section--impact .impact-suffix{color:var(--c-accent)}
.section--impact .impact-label{color:rgba(255,255,255,.92)}
@media(max-width:1024px){.impact-grid--6{grid-template-columns:repeat(3,1fr)}}
@media(max-width:640px){.impact-grid--6{grid-template-columns:repeat(2,1fr)}}

/* ---- Challenges We Solve ---- */
.challenge-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}
.challenge-card{display:grid;grid-template-columns:1fr 1fr;background:var(--c-card-bg);border:1px solid var(--c-border);border-radius:var(--card-radius);overflow:hidden;box-shadow:0 18px 40px -32px rgba(13,40,60,.5)}
.challenge-problem{padding:24px;background:var(--c-section-bg)}
.challenge-response{padding:24px;border-left:1px solid var(--c-border)}
.challenge-tag{display:inline-flex;align-items:center;gap:5px;font-size:11px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:var(--c-muted);margin-bottom:8px}
.challenge-tag--ok{color:var(--c-accent-dark)}
.challenge-problem h3{font-size:18px;margin:0 0 8px;color:var(--c-heading)}
.challenge-problem p,.challenge-response p{margin:0;font-size:14.5px;color:var(--c-muted)}
@media(max-width:900px){.challenge-grid{grid-template-columns:1fr}}
@media(max-width:560px){.challenge-card{grid-template-columns:1fr}.challenge-response{border-left:0;border-top:1px solid var(--c-border)}}

/* ---- Sector tiles ---- */
.sector-tiles{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.sector-tiles--page{grid-template-columns:repeat(3,1fr)}
.sector-tile{display:flex;align-items:center;gap:12px;background:var(--c-card-bg);border:1px solid var(--c-border);border-radius:14px;padding:18px 20px;font-weight:600;color:var(--c-heading);transition:transform .2s,box-shadow .2s}
.sector-tile:hover{transform:translateY(-3px);box-shadow:0 16px 32px -24px rgba(13,40,60,.5)}
.sector-tile .icon{color:var(--c-accent-dark);flex:none}
@media(max-width:900px){.sector-tiles,.sector-tiles--page{grid-template-columns:repeat(2,1fr)}}
@media(max-width:480px){.sector-tiles,.sector-tiles--page{grid-template-columns:1fr}}

/* ---- Focus areas (8 compact pillars) ---- */
.focus-grid .card--interv{border-top:4px solid var(--c-accent)}
.focus-grid .card-body{gap:12px}
.feature-ic--sm{width:44px;height:44px;border-radius:11px;margin-bottom:2px}

/* ---- Vision / Mission ---- */
.vm-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin:1.4em 0}
.vm-card{border-radius:18px;padding:32px;color:#fff}
.vm-card--vision{background:linear-gradient(150deg,var(--c-primary),var(--c-primary-dark))}
.vm-card--mission{background:linear-gradient(150deg,var(--c-accent-dark),#b5660f)}
.vm-eyebrow{display:block;font-size:12px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;opacity:.85;margin-bottom:10px}
.vm-card p{font-family:var(--font-display);font-size:20px;line-height:1.5;margin:0}
@media(max-width:768px){.vm-grid{grid-template-columns:1fr}}

/* ---- Why-join benefit grid ---- */
.benefit-grid{margin:1.4em 0}
.benefit-grid .feature{background:var(--c-card-bg);border:1px solid var(--c-border);border-radius:16px;padding:26px}

/* ---- Fee cards ---- */
.fee-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin:1.4em 0}
.fee-card{background:var(--c-card-bg);border:1px solid var(--c-border);border-radius:18px;padding:28px;text-align:center;display:flex;flex-direction:column;gap:8px}
.fee-card h3{margin:0;font-size:19px;color:var(--c-primary)}
.fee-for{color:var(--c-muted);font-size:14px;margin:0;min-height:38px}
.fee-amount{font-family:var(--font-display);font-size:30px;font-weight:700;color:var(--c-heading);margin:6px 0 14px}
.fee-amount span{font-size:14px;font-weight:400;color:var(--c-muted)}
.fee-card .btn{margin-top:auto;justify-content:center}
@media(max-width:900px){.fee-cards{grid-template-columns:1fr}}

/* ---- Action Updates ---- */
.card--action{border-top:4px solid var(--c-primary)}
.card--action .card-meta{color:var(--c-accent-dark);font-weight:600}
.seed-note{display:inline-flex;align-items:center;gap:8px;background:color-mix(in srgb,var(--c-primary) 8%,transparent);color:var(--c-primary);border:1px dashed color-mix(in srgb,var(--c-primary) 35%,transparent);border-radius:999px;padding:10px 18px;font-size:14px;font-weight:600}
.seed-note a{text-decoration:underline}
.seed-note--block{display:flex;margin-top:24px;border-radius:14px;justify-content:flex-start}

/* ---- Team / Advisory board ---- */
.team-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.team-card{background:var(--c-card-bg);border:1px solid var(--c-border);border-radius:18px;overflow:hidden;transition:transform .25s,box-shadow .25s}
.team-card:hover{transform:translateY(-5px);box-shadow:0 24px 48px -30px rgba(13,40,60,.5)}
.team-photo{aspect-ratio:1/1;background:linear-gradient(150deg,var(--c-primary),var(--c-primary-dark));display:grid;place-items:center;overflow:hidden}
.team-photo img{width:100%;height:100%;object-fit:cover}
.team-initials{font-family:var(--font-display);font-size:48px;font-weight:700;color:rgba(255,255,255,.5)}
.team-info{padding:20px}
.team-info h3{margin:0 0 2px;font-size:18px}
.team-role{margin:0 0 8px;color:var(--c-accent-dark);font-weight:600;font-size:14px}
.team-bio{color:var(--c-muted);font-size:14.5px}
@media(max-width:1024px){.team-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.team-grid{grid-template-columns:1fr}}

/* ---- Partners page ---- */
.partner-group{margin-bottom:40px}
.partner-group-title{font-size:20px;color:var(--c-primary);margin-bottom:18px;padding-bottom:10px;border-bottom:2px solid var(--c-border)}

/* ---- Events page ---- */
.event-grid .event-date{display:inline-flex;flex-direction:column;line-height:1;background:var(--c-primary);color:#fff;border-radius:12px;padding:10px 14px;margin-bottom:6px;align-items:center;align-self:flex-start}
.event-grid .event-day{font-family:var(--font-display);font-size:24px;font-weight:700}
.event-grid .event-mon{font-size:11px;text-transform:uppercase;letter-spacing:.06em;margin-top:3px}

/* ---- Resources page ---- */
.card--resource{border-left:4px solid var(--c-accent)}

/* ---- Register (stepper) ---- */
.stepper{display:flex;list-style:none;counter-reset:step;padding:0;margin:0 0 30px;gap:8px;flex-wrap:wrap}
.stepper li{display:flex;align-items:center;gap:10px;color:var(--c-muted);font-weight:600;font-size:14px;flex:1;min-width:160px}
.stepper li span{width:30px;height:30px;border-radius:50%;display:grid;place-items:center;background:var(--c-section-bg);border:1px solid var(--c-border);color:var(--c-muted);flex:none}
.stepper li.is-active{color:var(--c-primary)}
.stepper li.is-active span{background:var(--c-primary);color:#fff;border-color:var(--c-primary)}
.register-selected{display:inline-flex;align-items:center;gap:8px;background:color-mix(in srgb,var(--c-accent) 16%,transparent);color:var(--c-accent-dark);padding:10px 18px;border-radius:999px;font-weight:600;margin-bottom:24px}
.register-grid{display:grid;grid-template-columns:1.6fr .9fr;gap:36px;align-items:start}
.register-card{background:var(--c-section-bg);border:1px solid var(--c-border);border-radius:18px;padding:28px;position:sticky;top:100px}
.register-card h3{font-size:18px;margin-bottom:14px}
.register-note{margin:16px 0 0;font-size:14px;color:var(--c-muted)}
.register-reference{margin-top:48px;padding-top:36px;border-top:1px solid var(--c-border)}
.chips{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px}
.chip--static{background:var(--c-section-bg);color:var(--c-body);border:1px solid var(--c-border);cursor:default}
.chip--static:hover{background:var(--c-section-bg);color:var(--c-body);border-color:var(--c-border)}
@media(max-width:900px){.register-grid{grid-template-columns:1fr}.register-card{position:static}}

/* ---- Login ---- */
.login-wrap{max-width:420px}
.login-card{background:var(--c-card-bg);border:1px solid var(--c-border);border-radius:18px;padding:32px;max-width:420px;box-shadow:0 22px 48px -34px rgba(13,40,60,.5)}
.login-card label{display:block;font-weight:600;margin-bottom:6px;font-size:14px;color:var(--c-heading)}
.login-card input[type=text],.login-card input[type=password]{width:100%;border:1px solid var(--c-border);border-radius:10px;padding:12px 14px;font:inherit;margin-bottom:16px;background:#fff}
.login-card .login-remember{font-weight:400;display:flex;align-items:center;gap:8px}
.login-card .button,.login-card .wp-element-button{background:var(--c-btn-bg);color:var(--c-btn-text);border:0;border-radius:var(--btn-radius);padding:13px 26px;font-weight:600;cursor:pointer;width:100%}
.login-links{margin:16px 0 0;font-size:14px;color:var(--c-muted)}
.login-card--in p{margin:0 0 14px}
.login-actions{display:flex;gap:12px;flex-wrap:wrap}
