:root{
  --navy:#16345f; --navy-2:#0f2547; --navy-3:#1f4480;
  --red:#c8102e; --gold:#b8923a; --gold-soft:#d9c08a;
  --ink:#1c2433; --muted:#5a6678; --line:#e3e8f0;
  --bg:#faf7f1; --bg-soft:#f5f7fa;
  --serif:'PT Serif',Georgia,serif;
  --sans:'Inter',-apple-system,'Segoe UI',Roboto,sans-serif;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:var(--sans);color:var(--ink);background:var(--bg);line-height:1.6;font-size:17px}
img{max-width:100%;display:block}
a{color:var(--navy);text-decoration:none}
.wrap{max-width:1180px;margin:0 auto;padding:0 24px}
h1,h2,h3,.serif{font-family:var(--serif)}

/* header */
.topline{height:4px;background:linear-gradient(90deg,var(--navy) 0 33.4%,var(--red) 33.4% 66.7%,var(--gold) 66.7% 100%)}
header.site{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.97);backdrop-filter:blur(6px);border-bottom:1px solid var(--line)}
.hrow{display:flex;align-items:center;gap:14px;min-height:72px;padding:8px 0}
.brand{display:flex;align-items:center;gap:12px;min-height:44px}
.brand img{width:46px;height:52px;object-fit:contain}
.brand .t1{font-family:var(--serif);font-weight:700;font-size:1.05rem;color:var(--navy);letter-spacing:.04em;line-height:1.15}
.brand .t2{font-size:.72rem;color:var(--gold);font-weight:600;letter-spacing:.18em;text-transform:uppercase}
nav.main{margin-left:auto;display:flex;gap:4px;align-items:center}
nav.main a{padding:12px 14px;font-size:.92rem;font-weight:500;color:var(--ink);border-radius:6px;min-height:44px;display:inline-flex;align-items:center}
nav.main a:hover{background:var(--bg-soft);color:var(--navy)}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:10px;min-height:48px;padding:12px 26px;border-radius:8px;font-weight:600;font-size:.95rem;border:2px solid transparent;cursor:pointer;transition:.18s}
.btn-red{background:var(--red);color:#fff}
.btn-red:hover{background:#a90d26}
.btn-navy{background:var(--navy);color:#fff}
.btn-navy:hover{background:var(--navy-3)}
.btn-outline-w{border-color:rgba(255,255,255,.55);color:#fff}
.btn-outline-w:hover{background:rgba(255,255,255,.12)}
.btn-outline{border-color:var(--navy);color:var(--navy)}
.btn-outline:hover{background:var(--navy);color:#fff}
.hcta{margin-left:8px}
@media(max-width:900px){nav.main a.navlink{display:none}}

/* hero */
.hero{background:linear-gradient(140deg,var(--navy) 0%,var(--navy-2) 70%,#0a1c38 100%);color:#fff;position:relative;overflow:hidden}
.hero::after{content:"";position:absolute;right:-120px;top:-80px;width:480px;height:480px;border-radius:50%;background:radial-gradient(circle,rgba(255,255,255,.06) 0 60%,transparent 62%);pointer-events:none}
.hero-in{display:grid;grid-template-columns:1.5fr .8fr;gap:48px;align-items:center;padding:84px 0 88px}
.kicker{display:inline-flex;align-items:center;gap:10px;font-size:.78rem;letter-spacing:.18em;text-transform:uppercase;color:var(--gold-soft);font-weight:600;margin-bottom:20px}
.kicker::before{content:"";width:34px;height:2px;background:var(--gold)}
.hero h1{font-size:clamp(1.7rem,4vw,2.9rem);line-height:1.18;font-weight:700;margin-bottom:20px}
.hero h1 .red{color:#ff5a6e}
.hero p.sub{font-size:1.08rem;color:#cdd8ea;max-width:560px;margin-bottom:34px}
.hero .actions{display:flex;gap:14px;flex-wrap:wrap}
.hero-emblem{display:flex;justify-content:center}
.hero-emblem .disc{width:300px;height:300px;border-radius:50%;background:#fff;display:flex;align-items:center;justify-content:center;box-shadow:0 24px 70px rgba(0,0,0,.4);border:6px solid var(--gold-soft)}
.hero-emblem img{width:200px;height:222px}

/* stats */
.stats{background:var(--bg);border-bottom:1px solid var(--line)}
.stats-in{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;padding:38px 0}
.stat{text-align:center;padding:6px 10px;border-left:1px solid var(--line)}
.stat:first-child{border-left:none}
.stat .n{font-family:var(--serif);font-size:2.2rem;font-weight:700;color:var(--navy);line-height:1.1}
.stat .n .accent{color:var(--red)}
.stat .l{font-size:.85rem;color:var(--muted);margin-top:6px}

/* sections */
section{padding:76px 0}
.sec-head{max-width:720px;margin-bottom:42px}
.overline{font-size:.76rem;letter-spacing:.2em;text-transform:uppercase;color:var(--red);font-weight:700;margin-bottom:12px;display:flex;align-items:center;gap:10px}
.overline::before{content:"";width:28px;height:2px;background:var(--red)}
h2.sec{font-size:clamp(1.5rem,3vw,2.2rem);color:var(--navy);line-height:1.2;margin-bottom:14px}
.sec-head p{color:var(--muted)}
.soft{background:var(--bg-soft)}

/* event cards */
.egrid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.ecard{background:#fff;border:1px solid var(--line);border-radius:12px;overflow:hidden;display:flex;flex-direction:column;transition:.18s;box-shadow:0 1px 3px rgba(22,52,95,.06)}
.ecard:hover{box-shadow:0 14px 34px rgba(22,52,95,.14);transform:translateY(-3px)}
.ecard .ph{aspect-ratio:16/10;overflow:hidden;background:var(--bg-soft)}
.ecard .ph img{width:100%;height:100%;object-fit:cover}
.ecard .body{padding:20px 22px 24px;display:flex;flex-direction:column;gap:10px;flex:1}
.emeta{display:flex;gap:16px;flex-wrap:wrap;font-size:.8rem;color:var(--muted)}
.emeta span{display:inline-flex;align-items:center;gap:7px}
.emeta i{color:var(--gold);font-size:.85rem}
.emeta .city i{color:var(--red)}
.ecard h3{font-size:1.08rem;line-height:1.35;color:var(--navy)}
.ecard p.x{font-size:.9rem;color:var(--muted);display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
.more-row{margin-top:42px;text-align:center}

/* branches */
.bgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.bcard{background:#fff;border:1px solid var(--line);border-radius:12px;padding:28px;display:flex;flex-direction:column;gap:10px;box-shadow:0 1px 3px rgba(22,52,95,.06)}
.bcard .ic{width:52px;height:52px;border-radius:10px;background:var(--navy);color:#fff;display:flex;align-items:center;justify-content:center;font-size:1.25rem;margin-bottom:6px}
.bcard h3{color:var(--navy);font-size:1.2rem}
.bcard .lead{font-size:.9rem;color:var(--ink)}
.bcard .lead b{font-weight:600}
.bcard .note{font-size:.86rem;color:var(--muted)}
.bcard .cnt{margin-top:auto;padding-top:12px;border-top:1px solid var(--line);font-size:.84rem;color:var(--muted);display:flex;align-items:center;gap:8px}
.bcard .cnt i{color:var(--gold)}
.bcard .cnt b{color:var(--navy);font-family:var(--serif);font-size:1.05rem}

/* help */
.hgrid{display:grid;grid-template-columns:repeat(4,1fr);gap:26px}
.hcard{background:#fff;border:1px solid var(--line);border-radius:12px;padding:28px 24px;display:flex;flex-direction:column;gap:12px;transition:.18s;box-shadow:0 1px 3px rgba(22,52,95,.06)}
a.hcard:hover{box-shadow:0 14px 34px rgba(22,52,95,.14);transform:translateY(-3px)}
.hcard .ic{width:52px;height:52px;border-radius:50%;background:rgba(200,16,46,.09);color:var(--red);display:flex;align-items:center;justify-content:center;font-size:1.2rem}
.hcard h3{color:var(--navy);font-size:1.05rem}
.hcard p{font-size:.88rem;color:var(--muted);flex:1}
.hcard .go{font-size:.86rem;font-weight:600;color:var(--red);display:inline-flex;align-items:center;gap:8px}

/* join */
.join{background:linear-gradient(140deg,var(--navy) 0%,var(--navy-2) 100%);color:#fff}
.join .overline{color:var(--gold-soft)}.join .overline::before{background:var(--gold)}
.join h2.sec{color:#fff}
.jgrid{display:grid;grid-template-columns:1fr 1fr;gap:26px;margin:36px 0}
.jcol{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.14);border-radius:12px;padding:30px}
.jcol h3{font-size:1.15rem;margin-bottom:16px;color:var(--gold-soft)}
.jcol ul{list-style:none;display:flex;flex-direction:column;gap:12px}
.jcol li{display:flex;gap:12px;font-size:.95rem;color:#dde6f3}
.jcol li i{color:var(--gold);margin-top:4px;flex:none}
.jfree{display:flex;align-items:center;gap:14px;background:rgba(184,146,58,.14);border:1px solid rgba(217,192,138,.4);border-radius:10px;padding:16px 22px;margin-bottom:30px;font-size:.95rem;color:#f0e6cf}
.jfree i{color:var(--gold-soft);font-size:1.2rem}
.jcta{display:flex;gap:14px;flex-wrap:wrap;align-items:center}
.jcta .tel{font-family:var(--serif);font-size:1.3rem;font-weight:700;color:#fff;display:inline-flex;gap:12px;align-items:center}
.jcta .tel i{color:var(--gold-soft)}

/* leadership + contacts */
.lgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px;margin-bottom:56px}
.lcard{border:1px solid var(--line);border-left:4px solid var(--gold);border-radius:10px;padding:24px 26px;background:#fff}
.lcard .nm{font-family:var(--serif);font-weight:700;font-size:1.12rem;color:var(--navy)}
.lcard .rl{font-size:.85rem;color:var(--muted);margin-top:6px}
.cgrid{display:grid;grid-template-columns:1fr 1fr;gap:26px}
.ccard{border:1px solid var(--line);border-radius:12px;padding:30px;background:#fff}
.ccard h3{color:var(--navy);font-size:1.15rem;margin-bottom:18px}
.crow{display:flex;gap:14px;padding:10px 0;font-size:.95rem;align-items:flex-start}
.crow i{color:var(--red);width:20px;text-align:center;margin-top:4px;flex:none}
.crow a{font-weight:500}
.crow a:hover{text-decoration:underline}

/* footer */
footer{background:var(--navy-2);color:#9fb0c9;font-size:.85rem}
.frow{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:36px;padding:52px 0 40px}
.frow h4{color:#fff;font-family:var(--serif);font-size:1rem;margin-bottom:14px}
.frow p{margin-bottom:8px}
.frow a{color:#c4d2e6}
.frow a:hover{color:#fff;text-decoration:underline}
.fbrand{display:flex;gap:12px;align-items:flex-start}
.fbrand img{width:40px;height:45px;object-fit:contain;filter:drop-shadow(0 0 1px rgba(255,255,255,.4))}
.fbottom{border-top:1px solid rgba(255,255,255,.12);padding:18px 0;display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;align-items:center}
.fbottom .plate{display:inline-flex;align-items:center;gap:8px}
.fbottom .plate i{color:var(--gold-soft)}

/* events page */
.page-hero{background:linear-gradient(140deg,var(--navy) 0%,var(--navy-2) 100%);color:#fff;padding:56px 0}
.page-hero h1{font-size:clamp(1.6rem,3.4vw,2.4rem);margin:14px 0 10px}
.page-hero p{color:#cdd8ea;max-width:640px}
.filters{display:flex;gap:10px;flex-wrap:wrap;padding:26px 0 4px}
.fbtn{min-height:44px;padding:10px 20px;border-radius:999px;border:1px solid var(--line);background:#fff;color:var(--ink);font-size:.88rem;font-weight:500;cursor:pointer;font-family:var(--sans)}
.fbtn.active{background:var(--navy);border-color:var(--navy);color:#fff}
.elist{display:flex;flex-direction:column;gap:34px;padding:34px 0 80px}
article.ev{background:#fff;border:1px solid var(--line);border-radius:14px;overflow:hidden;box-shadow:0 1px 3px rgba(22,52,95,.06)}
.ev-in{display:grid;grid-template-columns:380px 1fr;gap:0}
.ev .media{background:var(--bg-soft);display:flex;flex-direction:column}
.ev .media .main{flex:1;min-height:240px;max-height:420px;overflow:hidden}
.ev .media .main img{width:100%;height:100%;object-fit:cover}
.ev .thumbs{display:grid;grid-template-columns:repeat(3,1fr);gap:2px;background:#fff}
.ev .thumbs a{display:block;aspect-ratio:4/3;overflow:hidden}
.ev .thumbs img{width:100%;height:100%;object-fit:cover}
.ev .body{padding:28px 32px}
.ev h2{font-size:1.3rem;color:var(--navy);line-height:1.3;margin:10px 0 14px}
.ev .txt{font-size:.94rem;color:#39424f;white-space:pre-line}
.ev details{margin-top:8px}
.ev details summary{cursor:pointer;list-style:none;display:inline-flex;align-items:center;gap:9px;color:var(--red);font-weight:600;font-size:.9rem;min-height:44px}
.ev details summary::-webkit-details-marker{display:none}
.ev details summary .less{display:none}
.ev details[open] summary .more{display:none}
.ev details[open] summary .less{display:inline-flex;align-items:center;gap:9px}

@media(max-width:980px){
  .hero-in{grid-template-columns:1fr;padding:60px 0}
  .hero-emblem{display:none}
  .egrid,.bgrid{grid-template-columns:repeat(2,1fr)}
  .hgrid{grid-template-columns:repeat(2,1fr)}
  .stats-in{grid-template-columns:repeat(2,1fr);gap:18px}
  .stat{border-left:none;border-top:1px solid var(--line);padding-top:16px}
  .stat:nth-child(-n+2){border-top:none}
  .ev-in{grid-template-columns:1fr}
  .ev .media .main{max-height:320px}
  .frow{grid-template-columns:1fr}
  .lgrid{grid-template-columns:1fr}
  .cgrid{grid-template-columns:1fr}
}
@media(max-width:640px){
  section{padding:56px 0}
  .egrid,.bgrid,.hgrid,.jgrid{grid-template-columns:1fr}
  .hrow{flex-wrap:wrap}
  .hcta{margin-left:auto}
  .brand .t1{font-size:.95rem}
  .ev .body{padding:22px 20px}
  .hero p.sub{font-size:1rem}
}
