/* ==========================================================================
   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 social bar (right-aligned, engaging) ---- */
.adbar--social{background:linear-gradient(90deg,var(--c-primary),var(--c-primary-dark))}
.adbar-inner--social{justify-content:space-between;gap:14px;min-height:44px}
.adbar-social-label{color:#fff;font-size:13.5px;font-weight:600;letter-spacing:.02em;display:inline-flex;align-items:center;gap:9px;opacity:.96}
.adbar-social-label::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--c-accent);animation:gam-pulse 2.2s ease-out infinite}
@keyframes gam-pulse{0%{box-shadow:0 0 0 0 rgba(238,155,18,.55)}70%{box-shadow:0 0 0 9px rgba(238,155,18,0)}100%{box-shadow:0 0 0 0 rgba(238,155,18,0)}}
/* NOTE: use .social.social--adbar (two classes) so these beat the base .social a
   rule regardless of source order — otherwise the icons render navy-on-navy. */
.social.social--adbar{gap:9px;margin-left:auto}
.social.social--adbar a{width:32px;height:32px;border:1px solid rgba(255,255,255,.45);background:rgba(255,255,255,.14);color:#fff;border-radius:50%;display:grid;place-items:center;transition:transform .2s ease, background .2s ease, border-color .2s ease, box-shadow .2s ease}
.social.social--adbar a .icon{color:#fff;transition:color .2s ease}
.social.social--adbar a:hover{background:#fff;border-color:#fff;color:var(--c-primary);transform:translateY(-2px) scale(1.1);box-shadow:0 8px 18px -8px rgba(0,0,0,.45)}
.social.social--adbar a:hover .icon{color:var(--c-primary)}
.social.social--adbar a:hover .icon-linkedin{color:#0A66C2}
.social.social--adbar a:hover .icon-facebook{color:#1877F2}
.social.social--adbar a:hover .icon-instagram{color:#E1306C}
.social.social--adbar a:hover .icon-youtube{color:#FF0000}
.social.social--adbar a:hover .icon-twitter{color:#1DA1F2}
@media(max-width:480px){
	.adbar-social-label{font-size:12px}
	.adbar-social-label::before{display:none}
	.social.social--adbar a{width:30px;height:30px}
}

/* ----------------------------------------------------------- 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:18px;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:11px;max-width:172px;flex:none}
.brand-meta-title{font-family:var(--font-display);font-weight:800;color:var(--c-heading);font-size:16px;line-height:1.14;text-decoration:none}
a.brand-meta-title:hover{color:var(--c-menu-hover)}
.brand-meta-tag{font-size:12.5px;color:var(--c-muted)}
.header-brand{margin-right:auto;display:flex;align-items:center;gap:2px}
@media(max-width:900px){.brand-meta{max-width:180px}.brand-meta-title{font-size:15px}}
@media(max-width:480px){.brand-meta{max-width:130px;margin-left:8px}.brand-meta-title{font-size:12.5px}}
.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:2px;align-items:center;flex-wrap:nowrap}
.nav-menu .menu-item{position:relative}
.nav-menu .menu-link{
	display:inline-flex;align-items:center;gap:5px;white-space:nowrap;
	padding:9px 11px;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;align-items:center;gap:6px;border:1px solid var(--c-border);border-radius:999px;padding:4px 6px 4px 12px;background:#fff;color:var(--c-muted)}
.lang-switch .icon{color:var(--c-primary);flex:none}
.lang-switch--topbar{border-color:rgba(255,255,255,.3);background:transparent;color:var(--c-topbar-text)}
.lang-switch--topbar .icon{color:var(--c-topbar-text);opacity:.9}
.lang-select{appearance:none;-webkit-appearance:none;background:none;border:0;cursor:pointer;font:inherit;font-size:13px;font-weight:600;color:inherit;line-height:1;padding:3px 22px 3px 2px;border-radius:999px;
	background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23788696' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");
	background-repeat:no-repeat;background-position:right 4px center}
.lang-switch--topbar .lang-select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23EAF2F8' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E")}
.lang-select:focus{outline:2px solid var(--c-accent);outline-offset:2px}
.lang-select option{color:#12283A;background:#fff;font-weight:500}

/* When a translation plugin (Google Language Translator / GTranslate) renders
   its own widget, keep our wrapper minimal so the widget sits inline cleanly. */
.lang-switch--plugin{padding:0;border:0;background:none;display:inline-flex;align-items:center}
.lang-switch--plugin .goog-te-gadget,.lang-switch--plugin .gtranslate_wrapper{margin:0;line-height:1;font-size:0}
.lang-switch--plugin select{font:inherit;font-size:13px;font-weight:600;border:1px solid var(--c-border);border-radius:999px;padding:5px 10px;background:#fff;color:var(--c-heading);cursor:pointer}
.lang-switch--topbar.lang-switch--plugin select{border-color:rgba(255,255,255,.3);background:transparent;color:var(--c-topbar-text)}
/* Google Translate injects a top banner + body offset; neutralise it. */
/* Google Translate Element: keep the injected gadget hidden (we drive it from
   our own dropdown) and stop Google shifting the page down by its banner. */
.goog-te-banner-frame,.goog-te-gadget-icon{display:none!important}
.goog-te-gadget{font-size:0!important;color:transparent!important}
#google_translate_element{position:absolute!important;left:-9999px!important;top:0!important;height:0!important;overflow:hidden!important}
body{top:0!important}
.skiptranslate{line-height:normal}
iframe.skiptranslate,.goog-te-balloon-frame{display:none!important}
#goog-gt-tt,.goog-tooltip,.goog-text-highlight{display:none!important;background:none!important;box-shadow:none!important}
font[style]{background:none!important;box-shadow:none!important}

/* ----------------------------------------------------------- Mobile drawer */
.mobile-drawer{position:fixed;inset:0;z-index:120;visibility:hidden;pointer-events:none;overflow:hidden}
.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(238,155,18,.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--3{grid-template-columns:repeat(3,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:1;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}
/* Office blocks on the light Contact page: use dark, high-contrast text. */
.contact-list.footer-contact a,.contact-list.footer-contact span{color:var(--c-heading);opacity:1}
.contact-list.footer-contact a:hover{color:var(--c-primary)}
.contact-list .footer-office .office-address span,.contact-list .footer-office .office-phone a,.contact-list .footer-office .office-email a{color:var(--c-body)}
.contact-list .footer-office .office-label{color:var(--c-primary)}
.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)}
	.grid--3{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}
	.primary-nav{display:none}
	.menu-toggle{display:inline-flex}
}
@media(max-width:900px){
	.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--3{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)}
/* Prominent login button (logged-out state) */
.header-login--btn{border:1.5px solid var(--c-primary);color:var(--c-primary);padding:9px 18px;border-radius:999px}
.header-login--btn:hover{background:var(--c-primary);color:#fff}
.header-login--out{font-weight:500;color:var(--c-muted);font-size:13px}
.header-login--out:hover{color:var(--c-primary);background:transparent;text-decoration:underline}
body.has-transparent-header .site-header:not(.is-stuck) .header-login{color:#fff}
body.has-transparent-header .site-header:not(.is-stuck) .header-login--btn{border-color:rgba(255,255,255,.6);color:#fff}
body.has-transparent-header .site-header:not(.is-stuck) .header-login--btn:hover{background:#fff;color:var(--c-primary)}
@media(max-width:1100px){.header-login--in span,.header-login--out span{display:none}}
@media(max-width:1100px){.header-login--btn span{display:inline}}

/* ---- 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}

/* ==========================================================================
   v1.2 — homepage refinement: tighter rhythm, defined sections, catchy heads
   ========================================================================== */

/* ---- Section rhythm: tighter, with a clear top accent on alternating bands ---- */
.section{padding-block:var(--section-pad)}
.section--alt{
	background:
		radial-gradient(circle at 1px 1px, color-mix(in srgb, var(--c-primary) 7%, transparent) 1px, transparent 0) 0 0/24px 24px,
		var(--c-section-bg);
}

/* ---- Section heads: pill eyebrow + punchy title + accent rule ---- */
.section-head{margin-bottom:36px}
.section-head--center{margin-inline:auto;text-align:center;max-width:720px}
.eyebrow{
	display:inline-flex;align-items:center;gap:8px;
	padding:6px 14px 6px 12px;border-radius:999px;
	background:color-mix(in srgb, var(--c-accent) 15%, transparent);
	color:var(--c-accent-dark);font-size:12px;font-weight:700;
	letter-spacing:.14em;text-transform:uppercase;margin-bottom:16px;
}
.eyebrow::before{content:"";position:static;width:6px;height:6px;border-radius:50%;background:var(--c-accent);padding:0}
.section-head--center .eyebrow{margin-inline:auto}
.section-title{font-size:var(--fs-h2);line-height:1.12;letter-spacing:-.02em;font-weight:600}
.section-head--center .section-title{position:relative;padding-bottom:20px}
.section-head--center .section-title::after{
	content:"";position:absolute;left:50%;bottom:0;transform:translateX(-50%);
	width:56px;height:3px;border-radius:3px;
	background:linear-gradient(90deg,var(--c-accent),var(--c-accent-dark));
}
.section-sub{font-size:17.5px;line-height:1.62;color:var(--c-muted)}
.section-head--center .section-sub{margin-inline:auto}
.section-foot{margin-top:38px;text-align:center}

/* ---- Hero: dramatic scrim, bolder headline, lifted buttons ---- */
.hero--image .hero-overlay{
	background:linear-gradient(105deg, rgba(8,30,46,.93) 0%, rgba(8,30,46,.74) 44%, rgba(8,30,46,.30) 100%);
}
.hero-title{font-weight:700;line-height:1.04}
.hero-sub{max-width:600px}
.hero-actions .btn--primary{box-shadow:0 16px 34px -16px rgba(238,155,18,.7)}
.hero::after{opacity:.9}

/* ---- Buttons: subtle lift for catchiness ---- */
.btn{transition:transform .2s ease, box-shadow .2s ease, background .2s ease, color .2s ease}
.btn--primary:hover{transform:translateY(-2px)}

/* ---- Cards: defined edges + hover lift everywhere ---- */
.card{box-shadow:0 1px 2px rgba(13,40,60,.05);transition:transform .25s ease, box-shadow .25s ease, border-color .25s ease}
.card:hover{transform:translateY(-5px);box-shadow:0 26px 50px -30px rgba(13,40,60,.5);border-color:color-mix(in srgb, var(--c-primary) 22%, var(--c-border))}
.card-title a{transition:color .2s}
.card-title a:hover{color:var(--c-accent-dark)}
.mini-card{transition:transform .25s, box-shadow .25s, border-color .25s}
.mini-card:hover{transform:translateY(-4px);box-shadow:0 22px 44px -30px rgba(13,40,60,.45)}

/* ---- Why / benefit tiles → defined cards with an animated accent edge ---- */
.section--why .grid--3{gap:22px}
.section--why .feature,.benefit-grid .feature{
	background:var(--c-card-bg);border:1px solid var(--c-border);border-radius:18px;
	padding:28px 26px;position:relative;overflow:hidden;
	transition:transform .25s ease, box-shadow .25s ease, border-color .25s ease;
}
.section--why .feature::after,.benefit-grid .feature::after{
	content:"";position:absolute;left:0;top:0;height:3px;width:0;
	background:linear-gradient(90deg,var(--c-accent),var(--c-accent-dark));transition:width .35s ease;
}
.section--why .feature:hover,.benefit-grid .feature:hover{
	transform:translateY(-5px);box-shadow:0 26px 50px -30px rgba(13,40,60,.45);
	border-color:color-mix(in srgb, var(--c-primary) 22%, var(--c-border));
}
.section--why .feature:hover::after,.benefit-grid .feature:hover::after{width:100%}
.feature-ic{background:linear-gradient(150deg, color-mix(in srgb,var(--c-primary) 14%,transparent), color-mix(in srgb,var(--c-accent) 16%,transparent));color:var(--c-primary);transition:transform .25s ease}
.section--why .feature:hover .feature-ic,.benefit-grid .feature:hover .feature-ic{transform:scale(1.08) rotate(-4deg)}

/* ---- Focus pillars: gradient icon chips + hover ---- */
.focus-grid .card--interv{transition:transform .25s ease, box-shadow .25s ease}
.focus-grid .card--interv:hover{transform:translateY(-5px);box-shadow:0 24px 46px -30px rgba(13,40,60,.45)}
.feature-ic--sm{background:linear-gradient(150deg, color-mix(in srgb,var(--c-primary) 16%,transparent), color-mix(in srgb,var(--c-accent) 18%,transparent));color:var(--c-primary)}

/* ---- Impact band: bigger numerals, tighter cards ---- */
.section--impact{padding-block:calc(var(--section-pad) * .92)}
.section--impact .impact-num{font-size:clamp(36px,4.2vw,48px);font-weight:700;letter-spacing:-.02em}
.section--impact .impact-card{padding:20px 16px}

/* ---- Challenge cards: hover definition ---- */
.challenge-card{transition:transform .25s ease, box-shadow .25s ease}
.challenge-card:hover{transform:translateY(-3px);box-shadow:0 28px 54px -32px rgba(13,40,60,.5)}

/* ---- About: tighter + striking promise card ---- */
.about-grid{gap:48px}
.about-card{box-shadow:0 34px 64px -34px rgba(10,44,66,.7);position:relative;overflow:hidden}
.about-card::before{content:"";position:absolute;right:-60px;bottom:-60px;width:200px;height:200px;border:36px solid rgba(238,155,18,.16);border-radius:50%}
.ticks li{align-items:flex-start}
.ticks li .icon{color:var(--c-accent-dark);background:color-mix(in srgb,var(--c-accent) 16%,transparent);border-radius:50%;padding:4px;flex:none}

/* ---- Membership: bold navy band with glassy tiers ---- */
.section--membership{background:linear-gradient(135deg,var(--c-primary),var(--c-primary-dark));color:#fff;position:relative;overflow:hidden}
.section--membership::after{content:"";position:absolute;left:-80px;top:-80px;width:280px;height:280px;border:40px solid rgba(238,155,18,.12);border-radius:50%;pointer-events:none}
.section--membership .eyebrow{background:rgba(238,155,18,.22);color:#ffd9a8}
.section--membership .section-title{color:#fff}
.section--membership .section-sub,.section--membership .membership-copy p{color:rgba(255,255,255,.86)}
.section--membership .tier{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.16);border-left:4px solid var(--c-accent);backdrop-filter:blur(4px);transition:transform .25s, background .25s}
.section--membership .tier:hover{transform:translateX(4px);background:rgba(255,255,255,.13)}
.section--membership .tier h3{color:#fff}
.section--membership .tier p{color:rgba(255,255,255,.8)}

/* ---- Sector tiles: gradient icon, firmer hover ---- */
.sector-tile{transition:transform .22s ease, box-shadow .22s ease, border-color .22s ease}
.sector-tile:hover{border-color:color-mix(in srgb,var(--c-accent) 45%,var(--c-border))}
.sector-tile .icon{background:color-mix(in srgb,var(--c-accent) 14%,transparent);color:var(--c-accent-dark);border-radius:10px;padding:7px;box-sizing:content-box;width:22px;height:22px}

/* ---- Partners: lift on hover (already grayscale→color) ---- */
.partner{transition:transform .25s, box-shadow .25s, filter .25s, opacity .25s}
.partner:hover{transform:translateY(-3px);box-shadow:0 18px 36px -26px rgba(13,40,60,.4)}

/* ---- CTA band: add depth ---- */
.section--cta{position:relative;overflow:hidden}
.section--cta::after{content:"";position:absolute;right:-100px;top:50%;transform:translateY(-50%);width:360px;height:360px;border:48px solid rgba(238,155,18,.12);border-radius:50%;pointer-events:none}
.section--cta .cta-inner{position:relative;z-index:1}

/* Scroll-reveal animation removed: it started from opacity:0 on elements that
   were already visible, causing a flash/flicker as each card scrolled into view.
   Cards now stay visible with no entrance animation. */

@media(max-width:782px){
	.section-head{margin-bottom:26px}
	.section--membership .membership-grid{gap:30px}
}

/* ==========================================================================
   Latest at GAMSME — homepage news band, archive grid, single news page
   ========================================================================== */

/* ---- Homepage band: a clean, slightly tinted strip right after the hero ---- */
.section--latest{
	background:
		radial-gradient(circle at 1px 1px, color-mix(in srgb, var(--c-primary) 6%, transparent) 1px, transparent 0) 0 0/24px 24px,
		linear-gradient(180deg, color-mix(in srgb, var(--c-primary) 5%, var(--c-section-bg)), var(--c-section-bg));
}
.section--latest .eyebrow{background:color-mix(in srgb,var(--c-accent) 16%,transparent)}
.card--news .card-title{font-size:20px;line-height:1.25}
.card--news .card-excerpt{color:var(--c-muted)}

/* ---- Single news page ---- */
.single-news .news-feature{margin:0 0 26px;border-radius:16px;overflow:hidden;box-shadow:0 26px 50px -34px rgba(13,40,60,.5)}
.single-news .news-feature img{width:100%;height:auto;display:block}
.single-news .news-lead{
	font-size:19px;line-height:1.6;font-weight:500;color:var(--c-heading,#13314f);
	border-left:4px solid var(--c-accent);padding:2px 0 2px 18px;margin:0 0 26px;
}
.single-news .news-back{margin-top:32px}

/* ---- News gallery ---- */
.news-gallery{margin:38px 0 0}
.news-gallery-title{font-size:22px;margin:0 0 16px}
.news-gallery-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.news-gallery-item{display:block;aspect-ratio:3/2;overflow:hidden;border-radius:12px;background:var(--c-section-bg)}
.news-gallery-item img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.news-gallery-item:hover img{transform:scale(1.06)}
@media(max-width:640px){.news-gallery-grid{grid-template-columns:repeat(2,1fr)}}

/* ---- Homepage "Stories + GAMSME in News" two-column row (below hero) ---- */
.news-duo{display:grid;grid-template-columns:1fr 1fr;gap:40px}
.news-duo-col{min-width:0}
.news-duo-head{display:flex;align-items:baseline;justify-content:space-between;gap:14px;flex-wrap:wrap;margin:0 0 18px;padding-bottom:12px;border-bottom:2px solid color-mix(in srgb,var(--c-primary) 14%,var(--c-border))}
.news-duo-title{font-size:clamp(19px,2vw,23px);line-height:1.2;letter-spacing:-.01em;font-weight:600;margin:0}
.news-duo-viewall{display:inline-flex;align-items:center;gap:5px;font-size:13.5px;font-weight:600;color:var(--c-accent-dark);white-space:nowrap}
.news-duo-viewall:hover{color:var(--c-primary)}
.news-duo-viewall .icon{transition:transform .2s}
.news-duo-viewall:hover .icon{transform:translateX(3px)}
.news-duo-list{display:grid;grid-template-columns:1fr 1fr;gap:14px}

.duo-card{display:flex;flex-direction:column;background:var(--c-card-bg);border:1px solid var(--c-border);border-radius:12px;overflow:hidden;transition:transform .22s ease, box-shadow .22s ease, border-color .22s ease}
.duo-card:hover{transform:translateY(-3px);box-shadow:0 20px 40px -28px rgba(13,40,60,.45);border-color:color-mix(in srgb,var(--c-primary) 22%,var(--c-border))}
.duo-card-media{display:block;aspect-ratio:3/2;overflow:hidden;background:var(--c-section-bg)}
.duo-card-media img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.duo-card:hover .duo-card-media img{transform:scale(1.06)}
.duo-card-media--ph{display:grid;place-items:center;color:color-mix(in srgb,var(--c-primary) 32%,transparent)}
.duo-card-body{padding:12px 14px;flex:1}
.duo-card-title{font-size:14.5px;line-height:1.3;font-weight:600;margin:0}
.duo-card-title a{color:var(--c-heading,#13314f)}
.duo-card-title a:hover{color:var(--c-accent-dark)}
.duo-empty,.news-duo-list .seed-note--block{grid-column:1/-1}
.duo-empty{color:var(--c-muted);font-size:14px;padding:8px 0}
@media(max-width:860px){
	.news-duo{grid-template-columns:1fr;gap:32px}
}
@media(max-width:420px){
	.news-duo-list{grid-template-columns:1fr}
}

/* ==========================================================================
   Knowledge Bank — submitter/approver forms, dashboard, public lists
   ========================================================================== */

/* ---- Dashboard ---- */
.kb-dash{margin-bottom:40px}
.kb-dash-head{display:flex;justify-content:space-between;align-items:flex-end;gap:20px;flex-wrap:wrap;padding-bottom:20px;border-bottom:1px solid var(--c-border);margin-bottom:24px}
.kb-dash-head h2{margin:6px 0 4px;font-size:26px}
.kb-role{color:var(--c-muted);margin:0;font-size:14.5px}
.kb-dash-sub{font-size:18px;margin:30px 0 14px;display:flex;align-items:center;gap:10px}
.kb-count{background:var(--c-accent);color:#fff;font-size:13px;font-weight:700;border-radius:999px;padding:2px 10px}
.kb-type-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.kb-type-card{display:flex;flex-direction:column;gap:10px;padding:18px;border:1px solid var(--c-border);border-radius:14px;background:var(--c-card-bg);transition:transform .2s,box-shadow .2s,border-color .2s}
.kb-type-card:hover{transform:translateY(-3px);box-shadow:0 18px 36px -26px rgba(13,40,60,.45);border-color:color-mix(in srgb,var(--c-primary) 30%,var(--c-border))}
.kb-type-ic{width:42px;height:42px;border-radius:11px;display:grid;place-items:center;background:linear-gradient(150deg,color-mix(in srgb,var(--c-primary) 14%,transparent),color-mix(in srgb,var(--c-accent) 16%,transparent));color:var(--c-primary)}
.kb-type-name{font-weight:600;color:var(--c-heading);font-size:15px}
.kb-type-go{font-size:13px;color:var(--c-accent-dark);font-weight:600;display:inline-flex;align-items:center;gap:5px;margin-top:auto}
@media(max-width:900px){.kb-type-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.kb-type-grid{grid-template-columns:1fr}}

/* ---- Entry tables ---- */
.kb-table{width:100%;border-collapse:collapse;font-size:14.5px;margin-top:8px}
.kb-table th{text-align:left;padding:10px 12px;border-bottom:2px solid var(--c-border);color:var(--c-muted);font-size:12px;text-transform:uppercase;letter-spacing:.05em}
.kb-table td{padding:11px 12px;border-bottom:1px solid var(--c-border);vertical-align:middle}
.kb-table code{background:var(--c-section-bg);padding:2px 7px;border-radius:5px;font-size:12.5px}
.kb-edit{font-weight:600;color:var(--c-primary)}
.kb-empty{color:var(--c-muted);font-style:italic;padding:14px 0}
.kb-badge{display:inline-block;font-size:12px;font-weight:600;padding:3px 10px;border-radius:999px}
.kb-badge--draft{background:#eceae3;color:#7a8a82}
.kb-badge--pending{background:#f6e9d8;color:#c9742a}
.kb-badge--gamsme_revise{background:#f7dada;color:#b23b3b}
.kb-badge--publish{background:#e4efe9;color:#0d5c4f}

/* ---- Contribution form ---- */
.kb-formwrap{margin-top:36px}
.kb-form-masthead{background:linear-gradient(135deg,var(--c-primary),var(--c-primary-dark));color:#fff;padding:26px 28px;border-radius:16px 16px 0 0;border-bottom:3px solid var(--c-accent)}
.kb-form-masthead .kicker{font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:#ffd9a8;font-weight:600}
.kb-form-masthead h2{margin:8px 0 6px;color:#fff;font-size:26px}
.kb-form-masthead p{margin:0;color:rgba(255,255,255,.85);font-size:14.5px;max-width:640px}
.kb-form{background:var(--c-section-bg);padding:8px 0 0;border-radius:0 0 16px 16px}
.kb-fs{background:var(--c-card-bg);border:1px solid var(--c-border);border-radius:12px;margin:18px;overflow:hidden}
.kb-fs-head{display:flex;align-items:center;gap:14px;padding:16px 22px;background:linear-gradient(180deg,var(--c-card-bg),var(--c-section-bg));border-bottom:1px solid var(--c-border)}
.kb-fs-num{flex:none;width:32px;height:32px;border-radius:50%;background:var(--c-primary);color:#fff;display:grid;place-items:center;font-family:var(--font-display);font-weight:600}
.kb-fs-head h3{margin:0;font-size:19px}
.kb-fs-body{padding:20px 22px 24px}
.kb-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px 24px}
.kb-field{display:flex;flex-direction:column}
.kb-field.kb-full{grid-column:1/-1}
.kb-field label{font-weight:600;font-size:14px;margin-bottom:4px;color:var(--c-heading)}
.kb-req{color:var(--c-accent-dark)}
.kb-help{font-size:12.5px;color:var(--c-muted);margin-bottom:8px;line-height:1.45}
.kb-field input,.kb-field select,.kb-field textarea{font-family:inherit;font-size:14.5px;color:var(--c-heading);background:#fff;border:1px solid var(--c-border);border-radius:8px;padding:10px 12px;width:100%;transition:border-color .15s,box-shadow .15s}
.kb-field textarea{resize:vertical;min-height:74px}
.kb-field input:focus,.kb-field select:focus,.kb-field textarea:focus{outline:none;border-color:var(--c-primary);box-shadow:0 0 0 3px color-mix(in srgb,var(--c-primary) 18%,transparent)}
.kb-checks{display:flex;flex-wrap:wrap;gap:8px 14px;padding-top:4px}
.kb-check{display:inline-flex;align-items:center;gap:6px;font-weight:500;font-size:14px}
.kb-check input{width:auto}
.kb-form-actions{display:flex;gap:12px;flex-wrap:wrap;padding:0 18px 22px}
@media(max-width:640px){.kb-grid{grid-template-columns:1fr}}

/* ---- Notices ---- */
.kb-notice{padding:14px 18px;border-radius:10px;margin:0 18px 18px;font-weight:500}
.kb-notice--ok{background:#e4efe9;color:#0a463c;border:1px solid #b5d8cc}
.kb-notice--error{background:#f7dada;color:#9a2f2f;border:1px solid #e6b3b3}

/* ---- Login gate ---- */
.kb-gate{max-width:460px;margin:30px auto}

/* ---- Public KB cards + single ---- */
.kb-pill{display:inline-block;font-family:var(--font-display);font-size:12px;font-weight:600;letter-spacing:.04em;color:#fff;background:var(--c-primary);padding:3px 10px;border-radius:6px;margin-bottom:10px}
.card--kb{border-top:4px solid var(--c-primary)}
.kb-meta{margin:8px 0 14px;display:grid;grid-template-columns:auto 1fr;gap:4px 12px;font-size:14px}
.kb-meta dt{font-weight:600;color:var(--c-muted)}
.kb-meta dd{margin:0;color:var(--c-body)}
.kb-cat-card .card-more{margin-top:auto}
.kb-public-empty,.kb-public-grid{margin-top:8px}
.kb-public-empty{color:var(--c-muted);background:var(--c-section-bg);border:1px dashed var(--c-border);border-radius:12px;padding:26px;text-align:center}
.kb-single{margin-top:28px}
.kb-single-sec{font-size:18px;color:var(--c-primary);margin:22px 0 10px;padding-bottom:8px;border-bottom:2px solid var(--c-border)}
.kb-single-table{width:100%;border-collapse:collapse;font-size:15px}
.kb-single-table th{text-align:left;width:240px;vertical-align:top;padding:9px 14px 9px 0;color:var(--c-muted);font-weight:600}
.kb-single-table td{padding:9px 0;border-bottom:1px solid var(--c-border)}

/* Footer / contact office blocks (multiple addresses) */
/* Office blocks (footer + contact page): stack label, address, phone, email
   vertically with a consistent icon column and even spacing. The display:block
   override beats the generic ".footer-contact li{display:flex}" rule. */
.footer-office,.footer-contact .footer-office{display:block;width:100%;margin:0 0 18px}
.footer-office:last-child{margin-bottom:0}
.footer-office .office-label{display:block;font-weight:700;font-size:13px;letter-spacing:.02em;color:var(--c-accent);margin:0 0 7px;text-transform:uppercase}
.footer-office .office-address,.footer-office .office-phone,.footer-office .office-email{display:flex;gap:9px;align-items:flex-start;margin:0 0 6px;line-height:1.55}
.footer-office .office-phone,.footer-office .office-email{align-items:center}
.footer-office .office-address .icon,.footer-office .office-phone .icon,.footer-office .office-email .icon{flex:none;width:16px;height:16px;margin-top:3px;opacity:.9}
.footer-office .office-phone .icon,.footer-office .office-email .icon{margin-top:0}
.contact-list .footer-office .office-label{color:var(--c-primary)}

/* ==========================================================================
   Support Apps directory + GST HSN Finder tool
   ========================================================================== */

/* ---- Apps directory cards ---- */
.app-card{text-decoration:none}
.app-card .card-more--muted{color:var(--c-muted);cursor:default}
.app-card--soon{opacity:.7}
.app-card--soon:hover{transform:none;box-shadow:0 18px 40px -30px rgba(13,40,60,.5)}

/* ---- HSN tool shell ---- */
.hsn-tool{margin:8px 0 30px;border:1px solid var(--c-border);border-radius:18px;background:var(--c-card-bg);padding:22px;box-shadow:0 22px 50px -38px rgba(13,40,60,.5)}
.hsn-toolbar{display:flex;gap:14px;flex-wrap:wrap;align-items:center;justify-content:space-between}
.hsn-modes{display:inline-flex;background:var(--c-section-bg);border:1px solid var(--c-border);border-radius:999px;padding:4px;gap:4px}
.hsn-mode{display:inline-flex;align-items:center;gap:7px;border:0;background:transparent;color:var(--c-muted);font:inherit;font-size:14px;font-weight:600;padding:9px 16px;border-radius:999px;cursor:pointer;transition:background .2s,color .2s}
.hsn-mode .icon{opacity:.8}
.hsn-mode:hover{color:var(--c-heading)}
.hsn-mode.is-active{background:var(--c-primary);color:#fff}
.hsn-mode.is-active .icon{opacity:1}
.hsn-search{position:relative;flex:1;min-width:240px;display:flex;align-items:center}
.hsn-search-ic{position:absolute;left:14px;display:inline-flex;color:var(--c-muted);pointer-events:none}
.hsn-input{width:100%;padding:13px 44px 13px 42px;border:1px solid var(--c-border);border-radius:12px;background:var(--c-section-bg);color:var(--c-text);font:inherit;font-size:15.5px;transition:border-color .2s,box-shadow .2s}
.hsn-input:focus{outline:0;border-color:var(--c-primary);box-shadow:0 0 0 3px color-mix(in srgb,var(--c-primary) 18%,transparent);background:var(--c-card-bg)}
.hsn-input:disabled{opacity:.6}
.hsn-clear{position:absolute;right:8px;display:inline-flex;align-items:center;justify-content:center;width:30px;height:30px;border:0;background:transparent;color:var(--c-muted);border-radius:8px;cursor:pointer}
.hsn-clear:hover{background:var(--c-section-bg);color:var(--c-heading)}
.hsn-status{margin:16px 2px 10px;color:var(--c-muted);font-size:14px}
.hsn-results{display:flex;flex-direction:column;max-height:560px;overflow:auto;border:1px solid var(--c-border);border-radius:12px}
.hsn-results:empty{display:none}
.hsn-row{display:grid;grid-template-columns:150px 1fr;gap:16px;align-items:baseline;padding:12px 16px;border-bottom:1px solid var(--c-border)}
.hsn-row:last-child{border-bottom:0}
.hsn-row:nth-child(even){background:color-mix(in srgb,var(--c-section-bg) 55%,transparent)}
.hsn-code{font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;font-weight:700;font-size:14px;color:var(--c-primary);background:color-mix(in srgb,var(--c-primary) 10%,transparent);padding:3px 9px;border-radius:6px;white-space:nowrap;justify-self:start}
.hsn-desc{color:var(--c-text);font-size:14.5px;line-height:1.5}
.hsn-disclaimer{margin-top:22px;padding:16px 18px;border-left:3px solid var(--c-accent);background:color-mix(in srgb,var(--c-accent) 8%,transparent);border-radius:0 12px 12px 0}
.hsn-disclaimer p{margin:0;font-size:14px;color:var(--c-muted);line-height:1.6}
.hsn-disclaimer a{color:var(--c-accent-dark);font-weight:600;text-decoration:underline}
@media(max-width:640px){
	.hsn-toolbar{flex-direction:column;align-items:stretch}
	.hsn-modes{justify-content:center}
	.hsn-row{grid-template-columns:1fr;gap:4px}
	.hsn-code{justify-self:start}
}
/* Promoted Support App card on the Resources page */
.app-promo{display:block;margin:6px 0 30px;border-left:4px solid var(--c-accent);text-decoration:none}
.app-promo .card-title{color:var(--c-heading)}
.app-promo:hover{transform:translateY(-3px)}
/* Language switcher: top bar holds it on desktop; this header copy shows on mobile */
.lang-mobile-only{display:none}
@media(max-width:900px){ .lang-mobile-only{display:inline-flex} }
/* Separate "back to English" reset — never translated; shown on the Google proxy */
.lang-reset{display:inline-flex;align-items:center;gap:5px;margin-left:8px;border:1px solid var(--c-border);border-radius:999px;padding:5px 13px;font-size:13px;font-weight:700;color:var(--c-primary);background:#fff;text-decoration:none;line-height:1;white-space:nowrap}
.lang-reset:hover{background:var(--c-primary);color:#fff;border-color:var(--c-primary)}
.lang-switch--topbar + .lang-reset{border-color:rgba(255,255,255,.45);background:transparent;color:var(--c-topbar-text)}
.lang-switch--topbar + .lang-reset:hover{background:#fff;color:var(--c-primary);border-color:#fff}
/* ----------------------------------------------------------- Built-in forms */
.gform-hp{position:absolute!important;left:-9999px!important;width:1px;height:1px;overflow:hidden}
.gform{max-width:760px}
.gform .gform-field{margin-bottom:15px}
.gform-field>label{display:block;font-weight:600;margin-bottom:6px;color:var(--c-heading);font-size:14.5px}
.gform-req{color:#d63b2f}
.gform input[type=text],.gform input[type=email],.gform input[type=tel],.gform input[type=number],.gform input[type=file],.gform textarea,.gform select{
  width:100%;padding:11px 13px;border:1px solid var(--c-border);border-radius:10px;font:inherit;font-size:15px;background:#fff;color:var(--c-body);box-sizing:border-box}
.gform textarea{min-height:120px;resize:vertical}
.gform input:focus,.gform textarea:focus,.gform select:focus{outline:2px solid var(--c-accent);outline-offset:1px;border-color:var(--c-primary)}
.gform-check{display:flex;gap:9px;align-items:flex-start;font-weight:500;color:var(--c-body);cursor:pointer}
.gform-check input,.gform-radio input{width:auto!important;margin:3px 0 0}
.gform-checks,.gform-radios{display:flex;flex-wrap:wrap;gap:10px 20px}
.gform-check--inline,.gform-radio{display:inline-flex;align-items:center;gap:7px;font-weight:500;cursor:pointer}
.gform-check--inline input{margin-top:0}
.gform-section{margin:26px 0 14px;font-size:19px;color:var(--c-heading);border-bottom:1px solid var(--c-border);padding-bottom:7px}
.gform-section:first-of-type{margin-top:4px}
.gform-grid{display:grid;grid-template-columns:1fr 1fr;gap:0 22px}
.gform-grid .gform-field--textarea,.gform-grid .gform-field--checkboxes,.gform-grid .gform-field--checkbox,.gform-grid .gform-field--radio{grid-column:1 / -1}
.gform-actions{margin-top:20px}
.gform-fineprint{font-size:12.5px;color:var(--c-muted);margin-top:12px}
.gform-note{padding:13px 16px;border-radius:12px;margin-bottom:18px;font-weight:600}
.gform-note--ok{background:color-mix(in srgb,var(--c-accent) 14%,#fff);color:var(--c-accent-dark);border:1px solid color-mix(in srgb,var(--c-accent) 35%,#fff)}
.gform-note--err{background:rgba(214,59,47,.08);color:#b3261e;border:1px solid rgba(214,59,47,.32)}
.gform--newsletter{max-width:520px}
.section--newsletter .gform input,.section--newsletter .gform select,.section--newsletter .gform textarea{background:#fff}
@media(max-width:640px){ .gform-grid{grid-template-columns:1fr} }

/* ==========================================================================
   Brand colour & design system — per "GAMSME Colour & Design Inputs" (Jun 2026)
   Navy core · ONE disciplined saffron accent (action only) · emerald = green-MSME.
   60 / 30 / 10 balance: ~60% white+neutral, 30% navy, only 10% saffron.
   ========================================================================== */

/* Eyebrows are labels, not actions → navy tint, not saffron. */
.eyebrow{background:color-mix(in srgb,var(--c-primary) 10%,transparent);color:var(--c-primary)}
.eyebrow::before{background:var(--c-primary)}
/* On the navy bands the eyebrow stays light/saffron for contrast. */
.section--impact .eyebrow,.section--membership .eyebrow{background:rgba(238,155,18,.20);color:#FCEFD7}
.section--impact .eyebrow::before,.section--membership .eyebrow::before{background:var(--c-accent)}

/* Reserve saffron for fills + stat numbers; in-text "accents" become navy. */
.card-more,.duo-card-more,.news-duo-viewall{color:var(--c-primary)}
.card-more:hover,.duo-card-more:hover,.news-duo-viewall:hover{color:var(--c-primary-dark)}
.card-title a:hover,.duo-card-title a:hover{color:var(--c-primary-dark)}

/* Make the numbers the hero: large saffron figures on the navy stats band. */
.section--impact .impact-num{color:var(--c-accent);font-size:clamp(40px,5.2vw,62px);font-weight:700}
.section--impact .impact-prefix,.section--impact .impact-suffix{color:var(--c-accent)}

/* Challenge cards scan faster: muted-slate problem, light-tint response + saffron tag. */
.challenge-problem{background:var(--c-section-bg)}
.challenge-problem h3{color:var(--c-primary)}
.challenge-problem p{color:var(--c-muted)}
.challenge-response{background:color-mix(in srgb,var(--c-accent) 8%,#fff)}
.challenge-tag--ok{color:var(--c-accent-dark)}

/* Saffron buttons always take navy text (never white) + clear focus ring. */
.btn--primary,.btn--header.filled,.btn--primary:hover,.btn--header.filled:hover{color:var(--c-primary)}
.btn:focus-visible{outline:3px solid color-mix(in srgb,var(--c-accent) 60%,#fff);outline-offset:2px}

/* Alternating section rhythm uses the navy tint band. */
.section--alt{background:var(--c-section-bg)}

/* Action Update summary on the homepage duo card + Full Story view bits. */
.duo-card-excerpt{font-size:13px;line-height:1.5;color:var(--c-muted);margin:6px 0 0}

/* Even duo row: make all four cards equal height regardless of how much text
   each has (Action Updates carry a summary; GAMSME in News carry a source name),
   and cap title/summary lines so nothing balloons. */
.news-duo-col{display:flex;flex-direction:column}
.news-duo-list{flex:1;grid-auto-rows:1fr}
.duo-card-title{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.duo-card-excerpt{display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
.duo-tag--media{display:inline-block;font-size:10.5px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--c-primary);background:color-mix(in srgb,var(--c-primary) 10%,transparent);border-radius:999px;padding:3px 9px;margin:0 0 6px}
.news-eyebrow{display:inline-block;font-size:12px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--c-accent-dark);margin:0 0 6px}
.full-story-link{margin:26px 0 8px}
.full-story-link .btn .icon{vertical-align:-3px}
.full-story>*:first-child{margin-top:0}

/* Hero: keep the headline in the left column so it never overlaps the people in
   the hero photo. Smaller heading, constrained text width. */
.hero--image .hero-content{max-width:540px}
.hero--image .hero-title{font-size:clamp(28px,3.8vw,42px);line-height:1.08}
.hero--image .hero-sub{max-width:460px;font-size:clamp(15px,1.8vw,18px)}
@media(max-width:900px){
	/* On phones the photo sits behind; let the copy use the full width again. */
	.hero--image .hero-content,.hero--image .hero-sub{max-width:none}
}

/* Header: tight, constant height (no scroll-shrink → no flicker, no big blank
   space around the menu). Heights are capped here regardless of saved logo size. */
.header-inner{min-height:80px}
.home .header-inner{min-height:92px}
.brand-logo{max-height:64px}
.home .site-header:not(.is-shrunk) .brand-logo{max-height:76px}
/* Even if an is-shrunk class is present, keep the same height (no resize jump). */
.site-header.is-shrunk .header-inner{min-height:80px;padding-block:var(--logo-pad-y)}
.site-header.is-shrunk .brand-logo{max-height:64px}
.home .site-header.is-shrunk .brand-logo{max-height:76px}
@media(max-width:900px){
	.header-inner,.home .header-inner{min-height:64px}
	.brand-logo,.home .site-header:not(.is-shrunk) .brand-logo{max-height:52px}
}
/* Mobile header: slim to brand · search · hamburger (no overflow). The language
   switcher and Join/Login CTAs move into the slide-out drawer. */
@media(max-width:1024px){
	.header-actions .lang-mobile-only,
	.header-actions > .header-login,
	.header-actions > .btn--header{display:none}
	.header-actions{gap:6px;margin-left:auto;flex:none}
}
.mobile-drawer-cta{display:flex;flex-direction:column;gap:10px;margin-bottom:4px}
.mobile-drawer-cta .btn--header,.mobile-drawer-cta .header-login{justify-content:center;width:100%}
.mobile-drawer-cta .header-login--btn{border:1.5px solid var(--c-primary);color:var(--c-primary)}
.mobile-drawer-cta .header-login--out{justify-content:center}

/* Mobile hero: prevent horizontal overflow that was clipping the headline.
   Block layout + min-width:0 so the text wraps to the screen width. */
.hero .container.hero-inner{min-width:0}
.hero-content{min-width:0}
.hero-title,.hero-sub{overflow-wrap:break-word}
@media(max-width:900px){
	html,body{overflow-x:hidden}
	.hero{display:block}
	.hero .container.hero-inner{width:min(100% - 40px,var(--container));max-width:100%}
	.hero-content{max-width:100%}
}
/* Phones (≤640px = where the portrait mobile hero image is swapped in via
   data-bg-mobile): use a vertical scrim — dark at the top so the white headline
   reads over the image's light top, fading down so the people stay visible. */
@media(max-width:640px){
	.hero--image .hero-overlay{
		background:linear-gradient(180deg,
			rgba(8,30,46,.84) 0%,
			rgba(8,30,46,.58) 40%,
			rgba(8,30,46,.26) 66%,
			rgba(8,30,46,.40) 100%);
	}
	.hero{min-height:88vh}
}