/* ============================================================
   CA Sri Lanka Qatar Chapter — shared stylesheet
   Brand: navy / chapter-red / cream. Display: Fraunces. Body: Manrope.
   ============================================================ */
:root{
  --bg:#f6f5f2; --navy:#1b2030; --ink:#11141d; --charcoal:#3b3d47;
  --grey:#8c8d98; --muted:#6a6e7d; --red:#b22b35; --red-dark:#8c1f28;
  --gold:#c08a2d; --white:#fff; --cream:#fff7ec;
  --line:rgba(27,32,48,.12); --line-soft:rgba(27,32,48,.07);
  --shadow:0 26px 70px rgba(27,32,48,.14); --shadow-sm:0 14px 40px rgba(27,32,48,.09);
  --radius:22px; --radius-lg:30px; --maxw:1180px;
  --display:"Fraunces",Georgia,serif; --body:"Manrope",ui-sans-serif,system-ui,-apple-system,sans-serif;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:var(--body);background:var(--bg);color:var(--charcoal);-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
img{max-width:100%}
h1,h2,h3,.display{font-family:var(--display);font-weight:600}
.wrap{width:min(var(--maxw),calc(100% - 32px));margin:0 auto}

/* ---------- Header ---------- */
.topbar{position:sticky;top:0;z-index:50;background:rgba(246,245,242,.85);backdrop-filter:blur(18px);border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;justify-content:space-between;gap:18px;padding:12px 0}
.brand{display:flex;align-items:center;gap:12px;min-width:0}
.brand-logo{height:50px;width:auto;display:block}
@media(max-width:560px){.brand-logo{height:42px}}
.brand .crest{width:46px;height:46px;border-radius:13px;flex:none;display:grid;place-items:center;background:linear-gradient(150deg,var(--red),var(--red-dark));color:#fff;font-family:var(--display);font-weight:900;font-size:19px;box-shadow:0 10px 24px rgba(178,43,53,.3);letter-spacing:-.02em}
.brand .bt{display:flex;flex-direction:column;line-height:1.05}
.brand .bt b{font-family:var(--display);font-weight:700;color:var(--navy);font-size:16px}
.brand .bt small{color:var(--muted);font-size:11px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;margin-top:2px}
.nav-links{display:flex;align-items:center;gap:4px}
.nav-links a{color:var(--navy);font-size:14px;font-weight:700;padding:9px 11px;border-radius:11px;transition:.16s ease;white-space:nowrap}
.nav-links a:hover{color:var(--red);background:rgba(178,43,53,.07)}
.nav-links a.active{color:var(--red);background:rgba(178,43,53,.1)}
.nav-links .join{color:#fff;background:linear-gradient(135deg,var(--red),var(--red-dark));box-shadow:0 12px 26px rgba(178,43,53,.22);margin-left:6px}
.nav-links .join:hover{color:#fff;transform:translateY(-1px)}
.menu-btn{display:none;border:1px solid var(--line);background:#fff;border-radius:12px;padding:9px 13px;color:var(--navy);font-weight:800;cursor:pointer}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:9px;border-radius:999px;padding:13px 22px;font-weight:800;font-size:15px;border:1px solid transparent;cursor:pointer;transition:.18s ease;font-family:var(--body)}
.btn:hover{transform:translateY(-2px)}
.btn-primary{color:#fff;background:linear-gradient(135deg,var(--red),var(--red-dark));box-shadow:0 16px 34px rgba(178,43,53,.24)}
.btn-secondary{color:var(--navy);background:#fff;border-color:var(--line)}
.btn-sm{padding:9px 15px;font-size:13px}

/* ---------- Page header band ---------- */
.page-band{position:relative;overflow:hidden;border-bottom:1px solid var(--line);background:radial-gradient(circle at 16% 30%,rgba(178,43,53,.14),transparent 40%),linear-gradient(135deg,#fff,#f3efeb 60%,#fff8f1)}
.page-band::after{content:"CA";position:absolute;right:-2vw;bottom:-9vw;font-family:var(--display);font-weight:900;font-size:clamp(140px,24vw,360px);color:rgba(27,32,48,.05);line-height:.8;pointer-events:none}
.page-band .wrap{position:relative;z-index:1;padding:clamp(40px,6vw,70px) 0}
.page-band .kicker{color:var(--red);font-weight:800;font-size:13px;letter-spacing:.16em;text-transform:uppercase;margin:0 0 12px}
.page-band h1{margin:0;color:var(--navy);font-size:clamp(34px,5.4vw,60px);line-height:1.02;letter-spacing:-.02em}
.page-band p{margin:16px 0 0;max-width:640px;color:#55596a;font-size:clamp(16px,1.7vw,19px);line-height:1.7}

/* ---------- Sections ---------- */
section{padding:clamp(48px,7vw,84px) 0}
.section-head{display:flex;align-items:end;justify-content:space-between;gap:22px;margin-bottom:28px}
.kicker{color:var(--red);font-weight:800;font-size:13px;letter-spacing:.16em;text-transform:uppercase;margin:0 0 10px}
.section-head h2{margin:0;color:var(--navy);font-size:clamp(28px,4.4vw,46px);letter-spacing:-.02em;line-height:1.05}
.section-head .lead{max-width:520px;color:var(--muted);line-height:1.7;margin:0}
.alt{background:linear-gradient(180deg,#fff,#faf7f3);border-top:1px solid var(--line-soft);border-bottom:1px solid var(--line-soft)}

/* ---------- Hero carousel ---------- */
.hero{position:relative;overflow:hidden;background:radial-gradient(circle at 16% 18%,rgba(178,43,53,.16),transparent 34%),radial-gradient(circle at 84% 8%,rgba(27,32,48,.1),transparent 30%),linear-gradient(135deg,#fff,#f3efeb 55%,#fff8f1);border-bottom:1px solid var(--line)}
.hero::after{content:"CA";position:absolute;right:-3vw;bottom:-11vw;font-family:var(--display);font-weight:900;font-size:clamp(180px,30vw,440px);color:rgba(27,32,48,.055);line-height:.8;pointer-events:none}
.carousel{position:relative;z-index:1}
.slide{display:none;grid-template-columns:1fr;gap:30px;align-items:center;padding:clamp(46px,7vw,82px) 0 clamp(70px,8vw,96px);animation:fade .7s ease}
.slide.active{display:grid}
@media(min-width:940px){.slide{grid-template-columns:1.05fr .95fr}}
@keyframes fade{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}
.eyebrow{display:inline-flex;align-items:center;gap:9px;padding:8px 14px;border-radius:999px;border:1px solid rgba(178,43,53,.24);background:rgba(255,255,255,.7);color:var(--red-dark);font-size:12px;letter-spacing:.1em;text-transform:uppercase;font-weight:800}
.eyebrow .dot{width:7px;height:7px;border-radius:50%;background:var(--red)}
.slide h1{margin:18px 0 16px;color:var(--navy);font-size:clamp(36px,6vw,66px);line-height:1;letter-spacing:-.02em;font-weight:600}
.slide h1 em{font-style:italic;color:var(--red);font-weight:500}
.slide p{max-width:560px;margin:0;font-size:clamp(16px,1.7vw,19px);line-height:1.7;color:#55596a}
.hero-actions{display:flex;flex-wrap:wrap;gap:12px;margin-top:28px}
.hero-visual{background:rgba(255,255,255,.8);border:1px solid var(--line);border-radius:var(--radius-lg);padding:clamp(22px,3.4vw,34px);box-shadow:var(--shadow);position:relative;overflow:hidden}
.hero-visual .vbadge{font-family:var(--display);font-size:clamp(38px,6vw,60px);color:var(--navy);font-weight:700;letter-spacing:-.02em;line-height:1}
.hero-visual .vsub{color:var(--muted);font-weight:700;margin-top:8px}
.stat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-top:22px}
.stat{border-radius:16px;background:#fff;border:1px solid var(--line);padding:15px 10px;text-align:center}
.stat strong{display:block;font-family:var(--display);color:var(--red);font-size:24px;line-height:1}
.stat span{display:block;margin-top:7px;color:#6a6e7d;font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.05em}
.car-controls{position:absolute;left:0;right:0;bottom:clamp(20px,3vw,32px);display:flex;align-items:center;justify-content:space-between;z-index:3;pointer-events:none}
.dots{display:flex;gap:9px;pointer-events:auto}
.dots button{width:30px;height:5px;border-radius:999px;border:0;cursor:pointer;padding:0;background:rgba(27,32,48,.18);transition:.25s ease}
.dots button.on{background:var(--red);width:44px}
.arrows{display:flex;gap:8px;pointer-events:auto}
.arrows button{width:40px;height:40px;border-radius:50%;border:1px solid var(--line);background:rgba(255,255,255,.85);color:var(--navy);cursor:pointer;font-size:16px;font-weight:800;display:grid;place-items:center;transition:.16s ease}
.arrows button:hover{background:#fff;transform:translateY(-2px);color:var(--red)}

/* ---------- Home highlights ---------- */
.tiles{display:grid;grid-template-columns:1fr;gap:18px}
@media(min-width:640px){.tiles{grid-template-columns:repeat(2,1fr)}}
@media(min-width:980px){.tiles{grid-template-columns:repeat(3,1fr)}}
.tile{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:26px;box-shadow:var(--shadow-sm);transition:.18s ease;display:block}
.tile:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.tile .ic{width:46px;height:46px;border-radius:13px;display:grid;place-items:center;background:var(--cream);border:1px solid rgba(178,43,53,.16);color:var(--red);font-size:22px;margin-bottom:16px}
.tile h3{margin:0 0 8px;color:var(--navy);font-size:21px}
.tile p{margin:0;color:var(--muted);line-height:1.6;font-size:14px}
.tile .go{display:inline-block;margin-top:14px;color:var(--red);font-weight:800;font-size:14px}

/* ---------- Cards / generic ---------- */
.grid-2{display:grid;grid-template-columns:1fr;gap:22px}
@media(min-width:880px){.grid-2{grid-template-columns:1.1fr .9fr}}
.card{border-radius:var(--radius);background:var(--white);border:1px solid var(--line);box-shadow:var(--shadow-sm);padding:clamp(24px,3.6vw,34px)}
.card h3{margin:0 0 14px;color:var(--navy);font-size:24px}
.card p{margin:0 0 14px;color:#5d6171;line-height:1.85}
.notice{margin-top:18px;padding:16px 18px;border-radius:16px;background:var(--cream);border:1px solid rgba(178,43,53,.16);color:#6a4b2b;line-height:1.7;font-size:14px}

/* ---------- President block ---------- */
.president{background:linear-gradient(140deg,#232838,#11141d);color:#fff;position:relative;overflow:hidden}
.president::after{content:"";position:absolute;width:280px;height:280px;border-radius:50%;background:rgba(178,43,53,.35);right:-90px;top:-100px;filter:blur(6px)}
.president>*{position:relative;z-index:1}
.president h3{color:#fff}
.president p{color:rgba(255,255,255,.8)}
.pres-top{display:flex;align-items:center;gap:16px;margin-bottom:18px}
.pres-top img{width:78px;height:78px;border-radius:18px;object-fit:cover;border:2px solid rgba(255,255,255,.18)}
.pres-top .nm{font-family:var(--display);font-size:21px;font-weight:700}
.pres-top .ro{color:var(--gold);font-weight:800;font-size:13px;margin-top:2px}
.signature{margin-top:22px!important;color:#fff!important;font-weight:800;font-family:var(--display)}
.signature span{display:block;margin-top:4px;color:rgba(255,255,255,.62);font-size:14px;font-weight:600;font-family:var(--body)}

/* ---------- Legacy timeline ---------- */
.timeline{display:grid;gap:16px}
.tl-item{display:grid;grid-template-columns:120px 1fr;gap:20px;align-items:start;padding:24px;background:#fff;border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-sm)}
.tl-item .yr{font-family:var(--display);font-weight:700;color:var(--red);font-size:18px;background:var(--cream);border:1px solid rgba(178,43,53,.16);border-radius:14px;padding:14px 10px;text-align:center}
.tl-item h3{margin:0 0 8px;color:var(--navy);font-size:20px}
.tl-item p{margin:0;color:#5d6171;line-height:1.75}
@media(max-width:620px){.tl-item{grid-template-columns:1fr}}

/* ---------- Past presidents ---------- */
.pp-grid{display:grid;grid-template-columns:1fr;gap:12px}
@media(min-width:640px){.pp-grid{grid-template-columns:repeat(2,1fr)}}
.pp{display:flex;align-items:center;gap:14px;background:#fff;border:1px solid var(--line);border-radius:16px;padding:16px 18px;box-shadow:var(--shadow-sm)}
.pp .badge{width:46px;height:46px;flex:none;border-radius:12px;display:grid;place-items:center;background:linear-gradient(140deg,var(--navy),var(--ink));color:#fff;font-family:var(--display);font-weight:800;font-size:15px}
.pp .pn{font-weight:800;color:var(--navy);line-height:1.2}
.pp .py{color:var(--muted);font-size:13px;font-weight:700;margin-top:3px}

/* ---------- Vision / mission ---------- */
.vm-grid{display:grid;grid-template-columns:1fr;gap:18px;margin-bottom:20px}
@media(min-width:760px){.vm-grid{grid-template-columns:1fr 1fr}}
.vm{border-radius:var(--radius);padding:28px;border:1px solid var(--line);box-shadow:var(--shadow-sm)}
.vm.v{background:linear-gradient(140deg,#232838,#11141d);color:#fff}
.vm.m{background:#fff}
.vm h3{margin:0 0 12px;font-size:22px}
.vm.v h3{color:#fff}.vm.m h3{color:var(--navy)}
.vm.v p{color:rgba(255,255,255,.82);margin:0;line-height:1.8}
.vm.m p{color:#5d6171;margin:0;line-height:1.8}
.obj-list{display:grid;grid-template-columns:1fr;gap:10px}
@media(min-width:760px){.obj-list{grid-template-columns:1fr 1fr}}
.obj{display:flex;gap:12px;align-items:flex-start;background:#fff;border:1px solid var(--line);border-radius:14px;padding:16px;box-shadow:var(--shadow-sm)}
.obj .n{flex:none;width:28px;height:28px;border-radius:8px;display:grid;place-items:center;background:var(--cream);border:1px solid rgba(178,43,53,.16);color:var(--red);font-weight:800;font-size:13px}
.obj span{color:#5d6171;line-height:1.55;font-size:14px}

/* ---------- Leadership ---------- */
.leaders{display:grid;grid-template-columns:1fr;gap:18px}
@media(min-width:640px){.leaders{grid-template-columns:repeat(2,1fr)}}
@media(min-width:920px){.leaders{grid-template-columns:repeat(3,1fr)}}
.leader{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:24px;text-align:center;box-shadow:var(--shadow-sm)}
.leader .photo{width:110px;height:110px;border-radius:50%;margin:0 auto 16px;object-fit:cover;border:3px solid #fff;box-shadow:0 10px 26px rgba(27,32,48,.18)}
.leader .ph-placeholder{width:110px;height:110px;border-radius:50%;margin:0 auto 16px;display:grid;place-items:center;color:#fff;font-family:var(--display);font-weight:800;font-size:30px;background:linear-gradient(140deg,var(--navy),var(--ink))}
.leader strong{display:block;font-family:var(--display);color:var(--navy);font-size:21px}
.leader .role{display:block;margin-top:6px;color:var(--red);font-weight:800;font-size:13px}
.leader .meta{display:block;margin-top:6px;color:var(--muted);font-size:13px}

/* ---------- Toolbar / directory / jobs ---------- */
.toolbar{display:flex;flex-wrap:wrap;gap:12px;align-items:center;margin-bottom:24px}
.field{position:relative;flex:1 1 240px}
.field input,.field select{width:100%;padding:13px 15px;border-radius:14px;border:1px solid var(--line);background:#fff;font:inherit;color:var(--navy);outline:none;transition:.15s ease}
.field input:focus,.field select:focus{border-color:var(--red);box-shadow:0 0 0 4px rgba(178,43,53,.1)}
.cap{display:block;font-size:12px;font-weight:800;color:var(--muted);text-transform:uppercase;letter-spacing:.08em;margin-bottom:7px}
.count-pill{font-size:13px;font-weight:800;color:var(--muted)}
.cards-grid{display:grid;grid-template-columns:1fr;gap:16px}
@media(min-width:640px){.cards-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:980px){.cards-grid{grid-template-columns:repeat(3,1fr)}}
.member{background:#fff;border:1px solid var(--line);border-radius:18px;padding:20px;box-shadow:var(--shadow-sm);transition:.18s ease}
.member:hover{transform:translateY(-3px);box-shadow:var(--shadow)}
.member .mtop{display:flex;align-items:center;gap:13px}
.member .mav{width:50px;height:50px;border-radius:14px;flex:none;display:grid;place-items:center;background:linear-gradient(140deg,var(--red),var(--red-dark));color:#fff;font-weight:800;font-family:var(--display);font-size:18px}
.member .mn{font-weight:800;color:var(--navy);line-height:1.2}
.member .md{color:var(--red);font-size:12px;font-weight:800;margin-top:3px}
.member .mrow{margin-top:14px;color:var(--muted);font-size:14px;line-height:1.6}
.member .mrow b{color:var(--charcoal);font-weight:700}
.tag{display:inline-block;margin-top:12px;padding:5px 11px;border-radius:999px;background:var(--cream);border:1px solid rgba(178,43,53,.14);color:var(--red-dark);font-size:12px;font-weight:800}
.loadmore-wrap{text-align:center;margin-top:28px}
.empty{text-align:center;color:var(--muted);padding:40px 0;font-weight:600}
.job{background:#fff;border:1px solid var(--line);border-radius:18px;padding:22px;box-shadow:var(--shadow-sm);display:flex;flex-direction:column}
.job:hover{box-shadow:var(--shadow)}
.job .jt{font-family:var(--display);font-weight:700;color:var(--navy);font-size:20px;line-height:1.2}
.job .jc{color:var(--red);font-weight:800;font-size:14px;margin-top:5px}
.job .jmeta{display:flex;flex-wrap:wrap;gap:8px;margin:14px 0}
.chip{font-size:12px;font-weight:800;padding:5px 11px;border-radius:999px;background:#f1f0ee;color:var(--charcoal);border:1px solid var(--line-soft)}
.chip.type{background:var(--cream);color:var(--red-dark);border-color:rgba(178,43,53,.16)}
.job .jdesc{color:var(--muted);line-height:1.6;font-size:14px;flex:1}
.job .jfoot{display:flex;align-items:center;justify-content:space-between;margin-top:18px;gap:10px}
.job .jdate{color:var(--grey);font-size:12px;font-weight:700}

/* ---------- Register form ---------- */
.register{display:grid;grid-template-columns:1fr;gap:26px;align-items:start}
@media(min-width:920px){.register{grid-template-columns:.85fr 1.15fr}}
.reg-intro{background:linear-gradient(140deg,#232838,#11141d);color:#fff;border-radius:var(--radius-lg);padding:clamp(26px,3.6vw,38px);position:relative;overflow:hidden}
.reg-intro::after{content:"";position:absolute;width:260px;height:260px;border-radius:50%;background:rgba(192,138,45,.28);left:-90px;bottom:-110px;filter:blur(8px)}
.reg-intro>*{position:relative;z-index:1}
.reg-intro h3{font-family:var(--display);font-size:26px;margin:0 0 14px}
.reg-intro p{color:rgba(255,255,255,.8);line-height:1.8;margin:0 0 16px}
.reg-intro ul{margin:0;padding-left:18px;color:rgba(255,255,255,.86);line-height:1.9}
.reg-form{background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);padding:clamp(24px,3.4vw,34px);box-shadow:var(--shadow-sm)}
.form-grid{display:grid;grid-template-columns:1fr;gap:16px}
@media(min-width:560px){.form-grid{grid-template-columns:1fr 1fr}.form-grid .full{grid-column:1 / -1}}
.consent{display:flex;gap:11px;align-items:flex-start;margin-top:16px;color:var(--muted);font-size:13px;line-height:1.6}
.consent input{margin-top:3px;width:17px;height:17px;accent-color:var(--red);flex:none}
.privacy-box{margin-top:16px;padding:14px 16px;border-radius:14px;background:#f4f7fb;border:1px solid #d8e2ef;color:#3c4a5e;font-size:13px;line-height:1.6}
.form-msg{margin-top:16px;padding:14px 16px;border-radius:14px;font-weight:700;font-size:14px;display:none}
.form-msg.ok{display:block;background:#edf7ee;border:1px solid #bfe3c2;color:#246b2b}
.form-msg.err{display:block;background:#fdeded;border:1px solid #f3c4c4;color:#9a2630}

/* ---------- Events ---------- */
.event{background:#fff;border:1px solid var(--line);border-radius:20px;overflow:hidden;box-shadow:var(--shadow-sm);transition:.2s ease;display:block}
.event:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.event .ebanner{aspect-ratio:16/10;display:grid;place-items:center;text-align:center;padding:22px;position:relative;color:#fff}
.event .ebanner h3{margin:0;font-size:23px;line-height:1.15}
.event .ebanner::after{content:"Open Gallery →";position:absolute;right:12px;bottom:12px;font-size:12px;font-weight:800;background:rgba(255,255,255,.16);border:1px solid rgba(255,255,255,.26);border-radius:999px;padding:6px 11px}
.event .ebody{padding:18px 20px 20px}
.event .edate{color:var(--red);font-weight:800;font-size:12px;letter-spacing:.05em;text-transform:uppercase}
.event .ebody p{margin:8px 0 0;color:var(--muted);line-height:1.6;font-size:14px}

/* ---------- Achievers ---------- */
.achievers-grid{display:grid;grid-template-columns:1fr;gap:18px}
@media(min-width:640px){.achievers-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:980px){.achievers-grid{grid-template-columns:repeat(3,1fr)}}
.achiever{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:24px;text-align:center;box-shadow:var(--shadow-sm);position:relative;overflow:hidden}
.achiever::before{content:"";position:absolute;inset:0 0 auto 0;height:5px;background:linear-gradient(90deg,var(--gold),var(--red))}
.achiever .aph{width:96px;height:96px;border-radius:50%;margin:6px auto 14px;display:grid;place-items:center;background:linear-gradient(140deg,var(--gold),#9c6c1f);color:#fff;font-family:var(--display);font-weight:800;font-size:28px;box-shadow:0 10px 24px rgba(192,138,45,.32)}
.achiever strong{display:block;font-family:var(--display);color:var(--navy);font-size:20px}
.achiever .award{display:inline-block;margin:10px 0;color:var(--red-dark);font-weight:800;font-size:13px;background:var(--cream);border:1px solid rgba(178,43,53,.14);padding:5px 12px;border-radius:999px}
.achiever .anote{color:var(--muted);line-height:1.6;font-size:14px;margin:0}

/* ---------- News ---------- */
.news-list{display:grid;grid-template-columns:1fr;gap:14px}
.news-item{background:#fff;border:1px solid var(--line);border-radius:18px;padding:22px 24px;box-shadow:var(--shadow-sm);display:grid;grid-template-columns:96px 1fr;gap:20px;align-items:start}
@media(max-width:620px){.news-item{grid-template-columns:1fr}}
.news-date{background:var(--cream);border:1px solid rgba(178,43,53,.14);border-radius:14px;padding:12px;text-align:center}
.news-date .d{font-family:var(--display);font-size:26px;font-weight:700;color:var(--red);line-height:1}
.news-date .m{display:block;margin-top:4px;font-size:11px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}
.news-body h3{margin:0 0 7px;color:var(--navy);font-size:21px}
.news-body p{margin:0;color:var(--muted);line-height:1.7}
.news-body a.read{display:inline-block;margin-top:10px;color:var(--red);font-weight:800;font-size:14px}

/* ---------- Contact ---------- */
.contact{background:linear-gradient(135deg,#fff,#fff7f1);border:1px solid var(--line);border-radius:var(--radius-lg);padding:clamp(28px,5vw,48px);box-shadow:var(--shadow);display:grid;grid-template-columns:1fr;gap:24px}
@media(min-width:860px){.contact{grid-template-columns:1.2fr .8fr;align-items:center}}
.contact h2{margin:0 0 12px;color:var(--navy);font-size:clamp(28px,4.4vw,42px);letter-spacing:-.02em}
.contact p{margin:0;color:#5d6171;line-height:1.8}
.contact .links{display:flex;flex-direction:column;gap:10px}

/* ---------- Footer ---------- */
footer{background:#14171f;color:rgba(255,255,255,.7);padding:40px 0 30px;margin-top:10px}
.foot-grid{display:grid;grid-template-columns:1fr;gap:24px}
@media(min-width:760px){.foot-grid{grid-template-columns:1.4fr 1fr 1fr}}
.foot-grid h4{color:#fff;font-family:var(--display);font-size:18px;margin:0 0 12px}
.foot-grid a{display:block;color:rgba(255,255,255,.66);padding:4px 0;font-size:14px}
.foot-grid a:hover{color:#fff}
.foot-bottom{margin-top:30px;padding-top:20px;border-top:1px solid rgba(255,255,255,.12);display:flex;flex-wrap:wrap;justify-content:space-between;gap:12px;font-size:13px}

/* ---------- Mobile nav ---------- */
@media(max-width:980px){
  .nav-links{display:none;position:absolute;left:16px;right:16px;top:72px;background:#fff;border:1px solid var(--line);border-radius:18px;padding:12px;flex-direction:column;align-items:stretch;box-shadow:var(--shadow);z-index:60}
  .nav-links.open{display:flex}
  .nav-links a{padding:12px 14px}
  .nav-links .join{margin-left:0;margin-top:4px;text-align:center}
  .menu-btn{display:inline-flex}
  .section-head{display:block}
  .section-head .lead{margin-top:12px}
}
@media(prefers-reduced-motion:reduce){
  *{animation:none!important;scroll-behavior:auto!important}
  .btn:hover,.member:hover,.event:hover,.tile:hover{transform:none}
}

.gallery-status{display:inline-block;margin-top:12px;color:var(--red-dark);font-weight:800;font-size:12px;background:var(--cream);border:1px solid rgba(178,43,53,.14);padding:6px 10px;border-radius:999px}
