/*!
Theme Name: British Jamaican Chamber
Theme URI: https://example.com/
Author: Omnus AI Lab
Description: A bilateral chamber of commerce theme for the British Jamaican Chamber of Commerce, built around a navy, green and gold palette drawn from the UK and Jamaican flags. Includes a rich homepage, news and events content types, a membership enquiry form and Customizer controls.
Version: 1.7.8
Requires at least: 6.4
Requires PHP: 8.0
License: GNU General Public License v2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: jamaica-chamber
*/

:root{
  --navy:#0b2545; --navy-700:#11366a; --navy-800:#0a2342; --navy-900:#071a33;
  --green:#137a3c; --green-700:#0e5e2e; --green-50:#e8f3ec; --green-100:#cfe7d8;
  --gold:#e8a317; --gold-600:#c98a08; --gold-50:#fbf0d6;
  --ink:#13233b; --muted:#586172; --line:#e5e8ef;
  --paper:#f7f8fb; --white:#ffffff;
  --serif:"Inter",system-ui,-apple-system,"Segoe UI",Arial,sans-serif;
  --sans:"Inter",system-ui,-apple-system,"Segoe UI",Arial,sans-serif;
  --wrap:1140px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:var(--sans);color:var(--ink);background:var(--paper);line-height:1.65;font-size:17px;-webkit-font-smoothing:antialiased}
img{max-width:100%;height:auto;display:block}
a{color:var(--green-700);text-decoration:none}
h1,h2,h3,h4{font-family:var(--serif);font-weight:560;line-height:1.1;margin:0 0 .4em;letter-spacing:-.01em;color:var(--ink)}
p{margin:0 0 1em}
.wrap{max-width:var(--wrap);margin:0 auto;padding:0 24px}
.eyebrow{font-family:var(--sans);font-weight:700;font-size:13px;letter-spacing:.16em;text-transform:uppercase;color:var(--green);margin:0 0 14px;display:inline-flex;align-items:center;gap:10px}
.eyebrow::before{content:"";width:26px;height:2px;background:var(--gold);display:inline-block}
.eyebrow.on-dark{color:var(--gold)}
.skip{position:absolute;left:-9999px;top:0;background:var(--gold);color:var(--navy);padding:10px 16px;z-index:200}
.skip:focus{left:8px;top:8px}
.section{padding:84px 0}
.section.tight{padding:60px 0}
.lead{font-size:20px;color:var(--muted);max-width:60ch}

/* buttons */
.btn{display:inline-flex;align-items:center;gap:9px;font-family:var(--sans);font-weight:700;font-size:15px;padding:14px 26px;border-radius:4px;border:2px solid transparent;cursor:pointer;transition:transform .15s ease,background .15s ease,color .15s ease,border-color .15s ease}
.btn:hover{transform:translateY(-2px)}
.btn-gold{background:var(--gold);color:var(--navy);border-color:var(--gold)}
.btn-gold:hover{background:var(--gold-600);border-color:var(--gold-600)}
.btn-green{background:var(--green);color:#fff;border-color:var(--green)}
.btn-green:hover{background:var(--green-700);border-color:var(--green-700)}
.btn-navy{background:var(--navy);color:#fff;border-color:var(--navy)}
.btn-navy:hover{background:var(--navy-700);border-color:var(--navy-700)}
.btn-ghost{background:transparent;color:#fff;border-color:rgba(255,255,255,.5)}
.btn-ghost:hover{border-color:var(--gold);color:var(--gold)}
.btn-outline{background:transparent;color:var(--navy);border-color:var(--navy)}
.btn-outline:hover{background:var(--navy);color:#fff}

/* utility bar */
.utility{background:var(--navy-900);color:#cdd6e4;font-size:13.5px}
.utility .wrap{display:flex;justify-content:space-between;align-items:center;gap:16px;padding-top:9px;padding-bottom:9px;flex-wrap:wrap}
.utility a{color:#cdd6e4}
.utility .u-contact{display:flex;gap:22px;flex-wrap:wrap}
.utility .u-contact span{display:inline-flex;align-items:center;gap:7px}
.utility .u-social{display:flex;gap:16px}
.utility svg{width:15px;height:15px;fill:var(--gold)}

/* header */
.site-header{background:#fff;position:sticky;top:0;z-index:100;border-bottom:1px solid var(--line);box-shadow:0 1px 14px rgba(11,37,69,.05)}
.site-header .wrap{display:flex;align-items:center;justify-content:space-between;gap:20px;padding-top:14px;padding-bottom:14px}
.brand{display:flex;align-items:center;gap:13px}
.brand .logo{height:56px;width:auto;display:block}
.nav{display:flex;align-items:center;gap:28px}
.nav ul{display:flex;gap:26px;list-style:none;margin:0;padding:0}
.nav a{color:var(--ink);font-weight:600;font-size:15px;padding:6px 0;position:relative}
.nav a:hover{color:var(--green)}
.nav a::after{content:"";position:absolute;left:0;bottom:-2px;width:0;height:2px;background:var(--gold);transition:width .2s ease}
.nav a:hover::after{width:100%}
.nav-toggle{display:none;background:transparent;border:0;cursor:pointer;padding:8px}
.nav-toggle svg{width:28px;height:28px;fill:var(--navy)}

/* hero */
.hero{position:relative;overflow:hidden;background:radial-gradient(1200px 600px at 78% -10%,var(--navy-700) 0%,var(--navy) 45%,var(--navy-900) 100%);color:#fff}
.hero .wrap{position:relative;z-index:2;padding-top:96px;padding-bottom:120px;max-width:var(--wrap)}
.hero h1{color:#fff;font-size:clamp(40px,6.4vw,76px);font-weight:580;max-width:16ch;margin-bottom:.3em}
.hero h1 .u{position:relative;white-space:nowrap}

.hero p{color:#cdd9e8;font-size:21px;max-width:56ch}
.hero .cta-row{display:flex;gap:14px;flex-wrap:wrap;margin-top:34px}
.hero .bars{position:absolute;right:max(24px,calc((100% - var(--wrap))/2 + 24px));bottom:0;display:flex;align-items:flex-end;gap:14px;height:300px;z-index:1;opacity:.95}
.hero .bars span{width:30px;background:linear-gradient(180deg,var(--gold),var(--gold-600));border-radius:5px 5px 0 0;display:block}
.hero-cut{position:absolute;left:0;right:0;bottom:-1px;z-index:2;width:100%;display:block}
.hero-cut svg{width:100%;height:64px;display:block}
.fade-up{opacity:0;transform:translateY(18px);animation:fu .7s ease forwards}
@keyframes fu{to{opacity:1;transform:none}}

/* who we are */
.intro .grid{display:grid;grid-template-columns:1.1fr .9fr;gap:56px;align-items:center}
.intro .stat-card{background:var(--navy);color:#fff;border-radius:12px;padding:38px 34px;position:relative;overflow:hidden}
.intro .stat-card::after{content:"";position:absolute;right:-40px;top:-40px;width:160px;height:160px;border-radius:50%;background:rgba(232,163,23,.18)}
.intro .stat-card .big{font-family:var(--serif);font-size:58px;font-weight:600;color:var(--gold);line-height:1}
.intro .stat-card p{margin:14px 0 0;color:#dbe4f0}

/* mandate grid */
.mandate{background:var(--white)}
.mandate .head{max-width:62ch;margin-bottom:48px}
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.card{background:var(--paper);border:1px solid var(--line);border-radius:12px;padding:30px 28px;transition:transform .18s ease,box-shadow .18s ease,border-color .18s ease}
.card:hover{transform:translateY(-4px);box-shadow:0 14px 30px rgba(11,37,69,.09);border-color:var(--green-100)}
.card .ico{width:50px;height:50px;border-radius:10px;background:var(--green-50);display:flex;align-items:center;justify-content:center;margin-bottom:18px}
.card .ico svg{width:26px;height:26px;fill:var(--green)}
.card h3{font-size:21px;margin-bottom:.35em}
.card p{color:var(--muted);font-size:16px;margin:0}

/* stats band */
.statband{background:var(--navy);background-image:linear-gradient(120deg,var(--navy-800),var(--navy-900));color:#fff}
.statband .grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;text-align:center}
.statband .num{font-family:var(--serif);font-size:54px;font-weight:600;color:var(--gold);line-height:1}
.statband .lab{color:#c4d0e2;font-size:15px;margin-top:8px}

/* why join */
.why{background:var(--paper)}
.why .cards{grid-template-columns:repeat(3,1fr)}
.why .card{background:#fff}
.why .card .tag{display:inline-block;font-size:12px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--gold-600);margin-bottom:10px}

/* process */
.process{background:#fff}
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;counter-reset:s}
.step{position:relative;padding:34px 28px 28px;border:1px solid var(--line);border-radius:12px;background:var(--paper)}
.step::before{counter-increment:s;content:"0" counter(s);position:absolute;top:-22px;left:24px;font-family:var(--serif);font-size:40px;font-weight:600;color:var(--gold)}
.step h3{margin-top:14px;font-size:20px}
.step p{color:var(--muted);font-size:16px;margin:0}

/* partners */
.partners{background:#eef1f7}
.partners .head{text-align:center;margin-bottom:36px}
.logos{display:grid;grid-template-columns:repeat(5,1fr);gap:16px}
.logos .logo{height:84px;background:#fff;border:1px solid var(--line);border-radius:10px;display:flex;align-items:center;justify-content:center;color:#9aa3b4;font-weight:700;font-size:13px;letter-spacing:.04em}

/* news */
.news{background:var(--white)}
.news .head{display:flex;justify-content:space-between;align-items:flex-end;gap:20px;margin-bottom:40px;flex-wrap:wrap}
.posts{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.post{background:var(--paper);border:1px solid var(--line);border-radius:12px;overflow:hidden;transition:transform .18s ease,box-shadow .18s ease}
.post:hover{transform:translateY(-4px);box-shadow:0 14px 30px rgba(11,37,69,.09)}
.post .thumb{height:160px;background:linear-gradient(135deg,var(--navy-700),var(--navy-900));position:relative}
.post .thumb .cat{position:absolute;left:14px;bottom:14px;background:var(--gold);color:var(--navy);font-size:12px;font-weight:700;padding:4px 11px;border-radius:3px;letter-spacing:.03em}
.post .body{padding:22px 22px 26px}
.post .date{color:var(--muted);font-size:13.5px;margin-bottom:8px}
.post h3{font-size:20px;margin-bottom:.4em}
.post h3 a{color:var(--ink)}
.post h3 a:hover{color:var(--green)}
.post p{color:var(--muted);font-size:15.5px;margin:0}

/* faq */
.faq{background:var(--paper)}
.faq .grid{display:grid;grid-template-columns:.8fr 1.2fr;gap:48px;align-items:start}
.faq details{border-bottom:1px solid var(--line);padding:20px 0}
.faq summary{font-family:var(--serif);font-size:20px;font-weight:560;cursor:pointer;list-style:none;display:flex;justify-content:space-between;gap:16px;align-items:center;color:var(--ink)}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";font-family:var(--sans);font-size:26px;color:var(--green);font-weight:400;line-height:1}
.faq details[open] summary::after{content:"\2013"}
.faq details p{color:var(--muted);margin:14px 0 0;font-size:16px}

/* contact */
.contact{background:var(--navy);background-image:linear-gradient(140deg,var(--navy-800),var(--navy-900));color:#fff}
.contact .grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:56px;align-items:start}
.contact h2{color:#fff}
.contact .lead{color:#cdd9e8}
.contact .info{margin-top:26px;display:flex;flex-direction:column;gap:14px}
.contact .info span{display:flex;align-items:center;gap:12px;color:#dbe4f0}
.contact .info svg{width:18px;height:18px;fill:var(--gold);flex:none}
.form{background:#fff;border-radius:14px;padding:32px}
.form label{display:block;font-weight:700;font-size:14px;color:var(--ink);margin:0 0 7px}
.form .field{margin-bottom:18px}
.form input,.form textarea{width:100%;font-family:var(--sans);font-size:16px;padding:13px 15px;border:1px solid var(--line);border-radius:7px;background:var(--paper);color:var(--ink)}
.form input:focus,.form textarea:focus{outline:none;border-color:var(--green);box-shadow:0 0 0 3px var(--green-50)}
.form .row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.notice{background:var(--green-50);border:1px solid var(--green-100);color:var(--green-700);padding:14px 16px;border-radius:8px;margin-bottom:18px;font-size:15px}

/* cta band */
.ctaband{background:var(--gold);color:var(--navy)}
.ctaband .wrap{display:flex;align-items:center;justify-content:space-between;gap:30px;flex-wrap:wrap}
.ctaband h2{font-size:clamp(28px,3.5vw,40px);max-width:18ch;margin:0;color:var(--navy)}
.ctaband p{margin:.5em 0 0;color:#5a4410;max-width:48ch}

/* footer */
.site-footer{background:var(--navy-900);color:#aebcd0;font-size:15px}
.site-footer .top{display:grid;grid-template-columns:1.5fr 1fr 1fr 1.1fr 1.3fr;gap:30px;padding:68px 0 48px}
.foot-brand .bj{font-family:var(--serif);font-size:25px;font-weight:600;color:#fff;display:block;letter-spacing:.01em}
.foot-brand .bj em{color:var(--green);font-style:normal}
.foot-brand .sub{display:inline-block;font-family:var(--sans);font-size:12px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);margin-top:8px;padding-top:8px;border-top:2px solid var(--gold)}
.site-footer p{color:#92a2ba}
.site-footer h4{font-family:var(--sans);font-size:13px;letter-spacing:.14em;text-transform:uppercase;color:var(--gold);margin:0 0 16px}
.site-footer ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:10px}
.site-footer a{color:#c4d0e2}
.site-footer a:hover{color:var(--gold)}
.site-footer .news-signup input{width:100%;padding:12px 14px;border-radius:7px;border:1px solid rgba(255,255,255,.18);background:rgba(255,255,255,.06);color:#fff;margin-bottom:10px}
.site-footer .news-signup input::placeholder{color:#92a2ba}
.site-footer .social{display:flex;gap:14px;margin-top:18px}
.site-footer .social a{width:38px;height:38px;border-radius:8px;background:rgba(255,255,255,.08);display:flex;align-items:center;justify-content:center}
.site-footer .social svg{width:17px;height:17px;fill:var(--gold)}
.site-footer .bottom{border-top:1px solid rgba(255,255,255,.1);padding:22px 0;display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;font-size:13.5px;color:#92a2ba}
.site-footer .bottom a{color:#92a2ba;margin-left:18px}

/* responsive */
@media(max-width:980px){
  .intro .grid,.faq .grid,.contact .grid{grid-template-columns:1fr;gap:34px}
  .cards,.why .cards,.steps,.posts{grid-template-columns:1fr 1fr}
  .statband .grid{grid-template-columns:1fr 1fr;gap:34px}
  .logos{grid-template-columns:repeat(3,1fr)}
  .site-footer .top{grid-template-columns:1fr 1fr;gap:30px}
}
@media(max-width:680px){
  .section{padding:60px 0}
  body{font-size:16px}
  .brand .logo{height:46px}
  .nav{position:fixed;inset:0 0 0 auto;width:80%;max-width:320px;background:var(--navy);flex-direction:column;align-items:flex-start;padding:88px 28px;transform:translateX(100%);transition:transform .25s ease;gap:0}
  .nav.open{transform:none}
  .nav a{color:#eafaef}
  .nav ul{flex-direction:column;gap:4px;width:100%}
  .nav ul li{width:100%;border-bottom:1px solid rgba(255,255,255,.08)}
  .nav a{display:block;padding:14px 0;font-size:17px}
  .nav .btn{margin-top:18px}
  .nav-toggle{display:block;z-index:120}
  .cards,.why .cards,.steps,.posts,.logos{grid-template-columns:1fr}
  .form .row{grid-template-columns:1fr}
  .hero .bars{display:none}
  .site-footer .top{grid-template-columns:1fr}
}

/* ---- inner pages ---- */
.page-hero{background:var(--navy);background-image:radial-gradient(900px 400px at 80% -20%,var(--navy-700),var(--navy-900));color:#fff;padding:64px 0}
.page-hero h1{color:#fff;font-size:clamp(32px,5vw,52px);margin:0}
.page-hero .crumb{color:#b6c4da;font-size:14px;margin-bottom:10px}
.page-hero .crumb a{color:#b6c4da}
.entry{max-width:760px;margin:0 auto}
.entry img{border-radius:10px;margin:1.2em 0}
.entry h2{font-size:30px;margin-top:1.4em}
.entry h3{font-size:23px;margin-top:1.2em}
.entry blockquote{border-left:4px solid var(--gold);margin:1.4em 0;padding:.4em 0 .4em 22px;font-family:var(--serif);font-size:21px;color:var(--ink)}
.entry-meta{color:var(--muted);font-size:14.5px;margin-bottom:8px}
.archive-list{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.pagination{margin-top:48px;display:flex;gap:10px;flex-wrap:wrap}
.pagination .page-numbers{display:inline-flex;min-width:42px;height:42px;align-items:center;justify-content:center;border:1px solid var(--line);border-radius:8px;color:var(--ink);padding:0 12px}
.pagination .page-numbers.current{background:var(--navy);color:#fff;border-color:var(--navy)}
.event-meta{display:flex;gap:18px;flex-wrap:wrap;color:var(--muted);font-size:15px;margin-bottom:18px}
.event-meta span{display:inline-flex;align-items:center;gap:8px}
.event-meta svg{width:17px;height:17px;fill:var(--green)}
@media(max-width:980px){.archive-list{grid-template-columns:1fr 1fr}}
@media(max-width:680px){.archive-list{grid-template-columns:1fr}}

/* ---- v0.3 additions: founders, membership, official, gallery, media ---- */
/* background rhythm overrides */
.why{background:#fff}
.why .card{background:var(--paper)}
.faq{background:#fff}
.founders{background:var(--paper)}
.membership{background:var(--paper)}
.gallery{background:#fff}
.media{background:var(--paper)}
.official{background:#eef1f7}

/* founding members */
.founders .head{max-width:62ch;margin-bottom:48px}
.team{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.member{background:#fff;border:1px solid var(--line);border-radius:12px;padding:26px 20px;text-align:center}
.member .ava{width:74px;height:74px;border-radius:50%;overflow:hidden;margin:0 auto 14px;background:linear-gradient(135deg,var(--navy),var(--navy-700));color:#fff;font-family:var(--serif);font-weight:600;font-size:25px;display:flex;align-items:center;justify-content:center}
.member .ava img{width:100%;height:100%;object-fit:cover;display:block}
.member .tag{display:block;font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--gold-600);margin-bottom:7px}
.member h3{font-size:17px;margin:0 0 .4em;line-height:1.25}
.member p{color:var(--muted);font-size:13.5px;margin:0;line-height:1.5}

/* membership / join now */
.membership .grid{display:grid;grid-template-columns:.95fr 1.05fr;gap:56px;align-items:start}
.membership .form{border:1px solid var(--line)}
.ministeps{display:flex;flex-direction:column;gap:16px;margin-top:24px}
.ministep{display:flex;gap:15px;align-items:flex-start}
.ministep .n{flex:none;width:34px;height:34px;border-radius:50%;background:var(--green-50);color:var(--green-700);font-weight:700;display:flex;align-items:center;justify-content:center}
.ministep h4{font-family:var(--sans);font-size:16px;margin:4px 0 2px;color:var(--ink)}
.ministep p{margin:0;color:var(--muted);font-size:15px}
.form select{width:100%;font-family:var(--sans);font-size:16px;padding:13px 15px;border:1px solid var(--line);border-radius:7px;background:var(--paper);color:var(--ink);appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='%23586172'%3E%3Cpath d='M7 10l5 5 5-5z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;background-size:20px}
.form select:focus{outline:none;border-color:var(--green);box-shadow:0 0 0 3px var(--green-50)}

/* official partners & links */
.official .head{text-align:center;margin-bottom:36px}
.crests{display:grid;grid-template-columns:repeat(2,1fr);gap:18px;max-width:720px;margin:0 auto 26px}
.crest{background:#fff;border:1px solid var(--line);border-radius:12px;padding:24px;display:flex;align-items:center;gap:16px}
.crest .ph{width:60px;height:60px;border-radius:8px;background:#eef1f7;border:1px dashed #c4cddd;flex:none;display:flex;align-items:center;justify-content:center;color:#9aa3b4;font-size:10px;text-align:center;font-weight:700;line-height:1.2}
.crest .crest-logo{height:72px;width:auto;flex:none}
.crest .t b{display:block;color:var(--ink);font-weight:700;font-size:15px}
.crest .t span{color:var(--muted);font-size:13.5px}
.links-row{display:flex;flex-wrap:wrap;gap:12px;justify-content:center}
.links-row a{display:inline-flex;align-items:center;gap:9px;background:#fff;border:1px solid var(--line);border-radius:8px;padding:11px 18px;font-weight:600;color:var(--navy);font-size:14.5px}
.links-row a:hover{border-color:var(--navy);transform:translateY(-2px);transition:.15s}
.links-row svg{width:15px;height:15px;fill:var(--gold-600)}
.official .memberlogos{display:grid;grid-template-columns:repeat(5,1fr);gap:16px;margin-top:34px}
.official .memberlogos .logo{height:74px;background:#fff;border:1px solid var(--line);border-radius:10px;display:flex;align-items:center;justify-content:center;color:#9aa3b4;font-weight:700;font-size:12px}

/* gallery */
.gallery .head{margin-bottom:34px}
.gallery-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.gtile{aspect-ratio:4/3;border-radius:10px;background:linear-gradient(135deg,#eef1f7,#e2e8f2);border:1px dashed #c4cddd;display:flex;align-items:center;justify-content:center;color:#8a93a6;font-size:13px;font-weight:600}
.gallery .note{text-align:center;color:var(--muted);font-size:14.5px;margin-top:22px}

/* media & press */
.media .head{display:flex;justify-content:space-between;align-items:flex-end;gap:20px;margin-bottom:36px;flex-wrap:wrap}
.media .press{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.presscard{background:#fff;border:1px solid var(--line);border-radius:12px;padding:26px}
.presscard .k{font-size:12px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--gold-600);margin-bottom:10px}
.presscard h3{font-size:18px;margin:0 0 .4em}
.presscard p{color:var(--muted);font-size:15px;margin:0}

@media(max-width:980px){
  .team{grid-template-columns:repeat(3,1fr)}
  .membership .grid{grid-template-columns:1fr;gap:34px}
  .gallery-grid{grid-template-columns:repeat(3,1fr)}
  .official .memberlogos{grid-template-columns:repeat(3,1fr)}
  .media .press{grid-template-columns:1fr}
}
@media(max-width:680px){
  .team{grid-template-columns:1fr 1fr}
  .crests{grid-template-columns:1fr}
  .gallery-grid{grid-template-columns:1fr 1fr}
  .official .memberlogos{grid-template-columns:1fr 1fr}
}

/* ---- v1.0 launch hardening: a11y, anchor offset, motion, focus ---- */
section[id]{scroll-margin-top:96px}
:focus-visible{outline:3px solid var(--gold);outline-offset:2px;border-radius:2px}
.site-header .nav a:focus-visible,.utility a:focus-visible,.contact a:focus-visible,.site-footer a:focus-visible{outline-offset:3px}
.jc-hp{position:absolute!important;left:-9999px!important;top:auto;width:1px;height:1px;overflow:hidden}
/* lift footer text contrast */
.site-footer p{color:#aebdd2}
.site-footer .bottom{color:#aebdd2}
.site-footer .bottom a{color:#aebdd2}
@media (prefers-reduced-motion: reduce){
  html{scroll-behavior:auto}
  .fade-up{animation:none!important;opacity:1!important;transform:none!important}
  .btn:hover,.card:hover,.post:hover,.member:hover{transform:none!important}
}

/* ---- Membership application page ---- */
.wrap.narrow{max-width:820px}
.apply-hero{background:linear-gradient(135deg,var(--navy-900),var(--navy-700));color:#fff;padding:66px 0 56px}
.apply-hero h1{font-family:var(--serif);font-weight:600;color:#fff;font-size:clamp(32px,5vw,52px);line-height:1.05;margin:.12em 0 .35em}
.apply-hero .lead{color:#cdd7e6;max-width:62ch;font-size:18px}
.apply-form fieldset{border:1px solid var(--line);border-radius:16px;padding:24px 24px 10px;margin:0 0 24px;background:#fff}
.apply-form legend{float:left;width:100%;font-family:var(--serif);font-weight:600;font-size:21px;line-height:1.35;color:var(--navy);padding:0;margin:2px 0 18px}
.apply-form legend + *{clear:both}
.apply-form label{display:block;font-weight:600;font-size:14px;margin-bottom:6px;color:var(--navy)}
.apply-form .field{margin-bottom:16px}
.apply-form .req{color:#c0392b}
.apply-form input[type=text],.apply-form input[type=email],.apply-form input[type=tel],.apply-form input[type=url],.apply-form select,.apply-form textarea{width:100%;padding:12px 14px;border:1px solid var(--line);border-radius:10px;font:inherit;background:#fff;color:var(--ink)}
.apply-form input:focus,.apply-form select:focus,.apply-form textarea:focus{outline:none;border-color:var(--green);box-shadow:0 0 0 3px var(--green-100)}
.apply-form textarea{min-height:112px;resize:vertical}
.apply-form .row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.apply-form .checks{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:12px 24px;margin:2px 0 14px}
.apply-form .check,.apply-form .consent{display:flex;align-items:flex-start;gap:10px;font-size:15px;font-weight:400;color:var(--ink)}
.apply-form .check span,.apply-form .consent span{font-weight:400;line-height:1.4;min-width:0}
.apply-form .other-specify{margin-top:8px}
.apply-form .check input,.apply-form .consent input{margin-top:3px;flex:none;width:17px;height:17px;accent-color:var(--green)}
.apply-form .consent{margin-bottom:14px}
@media(max-width:680px){.apply-form .row,.apply-form .checks{grid-template-columns:1fr}}
.apply-cta h3{font-family:var(--serif);font-weight:600;font-size:24px;color:var(--navy);margin:0 0 10px}
.apply-cta p{color:var(--muted);margin:0 0 20px}

/* ---- Why Join page ---- */
.why-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:18px;margin-top:8px}
.why-card{background:#fff;border:1px solid var(--line);border-radius:16px;padding:24px}
.why-card .ico{display:inline-flex;align-items:center;justify-content:center;width:42px;height:42px;border-radius:11px;background:var(--green-50);color:var(--green-700);margin-bottom:14px}
.why-card h3{font-family:var(--serif);font-weight:600;font-size:19px;color:var(--navy);margin:0 0 8px}
.why-card p{color:var(--muted);margin:0;font-size:15px;line-height:1.55}
@media(max-width:680px){.why-grid{grid-template-columns:1fr}}
.section.alt{background:var(--paper)}
.btn-line{background:transparent;color:var(--navy);border:1.5px solid var(--navy)}
.btn-line:hover{background:var(--navy);color:#fff}

/* ---- About: trade stats strip ---- */
.stat-strip{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin:12px 0 4px}
.stat{background:#fff;border:1px solid var(--line);border-radius:14px;padding:20px}
.stat .n{display:block;font-family:var(--serif);font-weight:600;font-size:30px;line-height:1;color:var(--green-700)}
.stat .l{display:block;margin-top:8px;color:var(--muted);font-size:13.5px;line-height:1.45}
.source-note{font-size:13px;color:var(--muted);margin-top:14px}
@media(max-width:760px){.stat-strip{grid-template-columns:1fr 1fr}}

/* ---- About: support areas list ---- */
.support-cols{display:grid;grid-template-columns:1fr 1fr;gap:14px 30px;margin:6px 0 0;padding:0;list-style:none}
.support-cols li{position:relative;padding-left:22px;color:var(--muted);font-size:15px;line-height:1.55}
.support-cols li::before{content:"";position:absolute;left:0;top:8px;width:8px;height:8px;border-radius:2px;background:var(--green-700)}
.support-cols strong{color:var(--navy);font-weight:600}
@media(max-width:680px){.support-cols{grid-template-columns:1fr}}

/* ---- Contact page ---- */
.contact-grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:48px;align-items:start}
.contact-info .block{margin-bottom:22px}
.contact-info h3{font-family:var(--serif);font-weight:600;font-size:19px;color:var(--navy);margin:0 0 4px}
.contact-info p{margin:0;color:var(--muted)}
.contact-info a{color:var(--green-700);font-weight:600;text-decoration:none}
.contact-info a:hover{text-decoration:underline}
.contact-social{display:flex;gap:12px;margin-top:8px}
.contact-social a{width:40px;height:40px;border:1px solid var(--line);border-radius:10px;display:inline-flex;align-items:center;justify-content:center;color:var(--navy)}
.contact-social a:hover{background:var(--navy);color:#fff}
.contact-social svg{width:18px;height:18px;fill:currentColor}
.contact-note{background:var(--green-50);border:1px solid #cfe6d6;border-radius:14px;padding:16px 18px;margin-top:6px}
.contact-note p{color:var(--ink)}
@media(max-width:760px){.contact-grid{grid-template-columns:1fr;gap:32px}}

/* ---- Founders page ---- */
.founder-list{display:flex;flex-direction:column;gap:36px;margin-top:6px}
.founder-profile{display:grid;grid-template-columns:150px 1fr;gap:28px;align-items:start}
.founder-profile img{width:150px;height:150px;object-fit:cover;border-radius:16px;border:1px solid var(--line)}
.founder-profile h3{font-family:var(--serif);font-weight:600;font-size:23px;color:var(--navy);margin:0}
.founder-profile .role{color:var(--green-700);font-weight:600;font-size:14.5px;margin:3px 0 10px}
.founder-profile p{margin:0;color:var(--muted);line-height:1.65}
@media(max-width:640px){.founder-profile{grid-template-columns:1fr;gap:14px}.founder-profile img{width:120px;height:120px}}

/* Supported by — High Commission strip */
.supported-by{background:#fff;border-top:1px solid var(--line);padding:36px 0}
.supported-by .wrap{text-align:center}
.sb-label{font-size:12px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);margin:0 0 20px}
.sb-logos{display:flex;justify-content:center;align-items:center;gap:56px;flex-wrap:wrap}
.sb-logos img{height:86px;width:auto;display:block}
@media(max-width:560px){.sb-logos{gap:30px}.sb-logos img{height:62px}}

/* Footer subscribe notice */
.news-signup .foot-note{color:#cdd6e4;font-size:13px;line-height:1.5;margin:0 0 12px}
.news-signup form input[type=email]{margin-bottom:10px}
.news-signup .sub-ok{color:#bfe3c8;font-size:14px;line-height:1.5;margin:0;font-weight:600}
.news-signup .sub-err{color:#f3c0c0;font-size:13px;margin:0 0 10px}
