/* ============================================================
   CTS YOUTH SPORTS — app.css
   Production stylesheet · Navy #0D1E3A | Gold #C9A030 | Red #A51C1C
============================================================ */

/* ─── TOKENS ─── */
:root {
  --navy:       #0D1E3A;
  --navy2:      #162844;
  --navy3:      #1D3258;
  --gold:       #C9A030;
  --gold-dk:    #A8841E;
  --gold-lt:    #F0C84A;
  --gold-bg:    #FDF6E3;
  --gold-line:  #E8D49A;
  --red:        #A51C1C;
  --red-dk:     #7A1515;
  --red-lt:     #C82020;
  --red-bg:     #FEF0F0;
  --red-line:   #F5BABA;
  --white:      #FFFFFF;
  --cream:      #FAFAF8;
  --off:        #F4F1EA;
  --line:       #E8E4D8;
  --line2:      #D4CEBC;
  --ink:        #1A1208;
  --slate:      #5A5040;
  --muted:      #8A7E6A;
  --ff-head:    'Oswald', sans-serif;
  --ff-body:    'Nunito', sans-serif;
  --r:          8px;
  --r-lg:       16px;
}

/* ─── RESET ─── */
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; }
body {
  font-family: var(--ff-body);
  background: var(--white);
  color: var(--ink);
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
}
a { text-decoration:none; color:inherit; }
img { display:block; max-width:100%; }
button { font-family:var(--ff-body); cursor:pointer; border:none; background:none; }

/* Screen-reader only utility */
.sr-only {
  position:absolute; width:1px; height:1px;
  padding:0; margin:-1px; overflow:hidden;
  clip:rect(0,0,0,0); white-space:nowrap; border:0;
}

/* ─── LAYOUT ─── */
.wrap { max-width:1180px; margin:0 auto; padding:0 48px; }

/* ─── UTILITIES ─── */
.eyebrow {
  display:inline-flex; align-items:center; gap:10px;
  font-family:var(--ff-body); font-size:11px; font-weight:800;
  letter-spacing:.16em; text-transform:uppercase;
  color:var(--gold); margin-bottom:14px;
}
.eyebrow::before {
  content:''; width:6px; height:6px; border-radius:50%;
  background:var(--gold); flex-shrink:0;
}
.eyebrow::after {
  content:''; flex:1; max-width:40px; height:1px;
  background:var(--gold-line);
}
.sec-title {
  font-family:var(--ff-head);
  font-size:clamp(36px,4.5vw,62px);
  font-weight:700; line-height:1.05;
  letter-spacing:.02em; text-transform:uppercase;
}
.body-lg { font-size:17px; color:var(--slate); line-height:1.85; }
.body-md { font-size:15px; color:var(--muted); line-height:1.75; }
.sec    { padding:96px 0; }
.sec-sm { padding:64px 0; }

/* ─── FLASH MESSAGES ─── */
.flash {
  position:fixed; top:80px; right:20px; z-index:9999;
  display:flex; align-items:center; gap:12px;
  padding:14px 20px; border-radius:var(--r);
  font-size:14px; font-weight:700; max-width:420px;
  box-shadow:0 8px 32px rgba(0,0,0,.15);
  animation:slideIn .3s ease;
}
@keyframes slideIn { from{opacity:0;transform:translateY(-10px)} to{opacity:1;transform:none} }
.flash-success { background:var(--gold-bg); border:1px solid var(--gold-line); color:var(--gold-dk); }
.flash-error   { background:var(--red-bg);  border:1px solid var(--red-line);  color:var(--red-dk); }
.flash button  { margin-left:auto; font-size:16px; cursor:pointer; background:none; border:none; opacity:.6; }
.flash button:hover { opacity:1; }

/* ─── BUTTONS ─── */
.btn {
  display:inline-flex; align-items:center; gap:9px;
  font-family:var(--ff-body); font-size:13px; font-weight:800;
  letter-spacing:.08em; text-transform:uppercase;
  padding:14px 28px; border-radius:6px;
  cursor:pointer; transition:all .22s ease;
  border:2px solid transparent;
}
.btn-gold {
  background:var(--gold); color:var(--navy); border-color:var(--gold);
}
.btn-gold:hover {
  background:var(--gold-lt); border-color:var(--gold-lt);
  transform:translateY(-2px); box-shadow:0 10px 28px rgba(201,160,48,.35);
}
.btn-navy {
  background:var(--navy); color:var(--white); border-color:var(--navy);
}
.btn-navy:hover {
  background:var(--navy2); transform:translateY(-2px);
  box-shadow:0 10px 28px rgba(13,30,58,.35);
}
.btn-outline-navy {
  background:transparent; color:var(--navy); border-color:var(--navy);
}
.btn-outline-navy:hover {
  background:var(--navy); color:var(--white); transform:translateY(-2px);
}
.btn-outline-gold {
  background:transparent; color:var(--gold); border-color:var(--gold);
}
.btn-outline-gold:hover {
  background:var(--gold); color:var(--navy); transform:translateY(-2px);
}
.btn-lg { padding:17px 36px; font-size:14px; border-radius:8px; }

/* ─── REVEAL ANIMATIONS ─── */
.rv { opacity:0; transform:translateY(22px); transition:opacity .6s ease,transform .6s ease; }
.rv.on { opacity:1; transform:none; }
.d1{transition-delay:.08s} .d2{transition-delay:.16s}
.d3{transition-delay:.24s} .d4{transition-delay:.32s}

/* ─── NAVBAR ─── */
#nav {
  position:fixed; top:0; left:0; right:0; z-index:999;
  height:70px; display:flex; align-items:center; justify-content:space-between;
  padding:0 48px;
  background:rgba(255,255,255,.95);
  backdrop-filter:blur(16px);
  -webkit-backdrop-filter:blur(16px);
  border-bottom:2px solid var(--gold-line);
  transition:box-shadow .3s;
}
#nav.scrolled { box-shadow:0 4px 30px rgba(13,30,58,.12); }
#nav::before {
  content:''; position:absolute; top:0; left:0; right:0; height:3px;
  background:linear-gradient(90deg,var(--red),var(--gold),var(--navy),var(--gold),var(--red));
}
.nav-logo {
  display:flex; align-items:center; gap:12px; cursor:pointer;
  text-decoration:none;
}
.nav-logo-placeholder {
  width:44px; height:44px; border-radius:50%;
  background:var(--navy); border:2px solid var(--gold);
  display:flex; align-items:center; justify-content:center;
  font-family:var(--ff-head); font-size:14px; font-weight:700;
  color:var(--gold); flex-shrink:0; letter-spacing:.5px;
}
.nav-name {
  font-family:var(--ff-head); font-size:18px; font-weight:700;
  color:var(--navy); letter-spacing:.04em; text-transform:uppercase; line-height:1.1;
}
.nav-name span { color:var(--gold); }
.nav-links {
  display:flex; align-items:center; gap:2px; list-style:none;
}
.nav-links li a {
  display:block;
  font-family:var(--ff-body); font-size:13px; font-weight:700;
  color:var(--slate); padding:8px 14px; border-radius:6px;
  transition:all .2s; letter-spacing:.01em;
}
.nav-links li a:hover,
.nav-links li a.act { color:var(--navy); background:var(--off); }
.nav-donate-btn {
  background:var(--gold) !important; color:var(--navy) !important;
  border-radius:6px !important; padding:9px 20px !important;
  font-weight:800 !important; border:2px solid var(--gold) !important;
}
.nav-donate-btn:hover { background:var(--gold-lt) !important; }
.ham {
  display:none; flex-direction:column; gap:5px; padding:4px;
  cursor:pointer;
}
.ham span { width:22px; height:2px; background:var(--navy); border-radius:2px; display:block; }
.mob-nav {
  display:none; position:fixed; top:70px; left:0; right:0; z-index:998;
  background:#fff; border-bottom:2px solid var(--gold-line);
  padding:16px 20px 24px; flex-direction:column; gap:4px;
  box-shadow:0 8px 32px rgba(13,30,58,.1);
}
.mob-nav.open { display:flex; }
.mob-nav a {
  font-size:15px; font-weight:700; color:var(--ink);
  padding:12px 0; border-bottom:1px solid var(--line); text-align:left;
  display:block;
}
.mob-nav a:hover { color:var(--gold); }

/* ─── INNER PAGE BANNER ─── */
.pg-banner {
  padding:130px 0 72px;
  background:var(--navy);
  position:relative; overflow:hidden;
}
.pg-banner::before {
  content:''; position:absolute; inset:0;
  background:
    radial-gradient(ellipse 60% 80% at 80% 50%,rgba(201,160,48,.12) 0%,transparent 60%),
    repeating-linear-gradient(45deg,transparent,transparent 30px,rgba(201,160,48,.03) 30px,rgba(201,160,48,.03) 31px);
  pointer-events:none;
}
.pg-banner::after {
  content:attr(data-ghost);
  position:absolute; right:-10px; bottom:-40px;
  font-family:var(--ff-head); font-size:200px; font-weight:700;
  color:rgba(201,160,48,.08); letter-spacing:.02em; text-transform:uppercase;
  pointer-events:none; user-select:none; line-height:1; white-space:nowrap;
}
.pg-banner-inner { position:relative; z-index:2; }
.breadcrumb {
  display:inline-flex; align-items:center; gap:8px;
  font-size:12px; font-weight:700; color:rgba(255,255,255,.5);
  letter-spacing:.06em; margin-bottom:20px; transition:color .2s;
}
.breadcrumb::before { content:'←'; font-size:11px; }
.breadcrumb span { color:var(--gold); }
.breadcrumb a { color:inherit; }
.breadcrumb a:hover { color:var(--gold); }
.pg-banner h1 {
  font-family:var(--ff-head);
  font-size:clamp(48px,7vw,88px);
  font-weight:700; line-height:.95;
  text-transform:uppercase; letter-spacing:.02em;
  color:var(--white);
}
.pg-banner h1 .hl { color:var(--gold); }
.pg-banner p { font-size:17px; color:rgba(255,255,255,.6); max-width:500px; line-height:1.75; margin-top:18px; }
.gold-rule {
  height:4px;
  background:linear-gradient(90deg,var(--red-dk),var(--red),var(--gold),var(--gold-lt),var(--gold),var(--red),var(--red-dk));
}

/* ─── FOOTER ─── */
.footer { background:var(--navy); color:var(--white); padding:72px 0 28px; }
.footer-grid {
  display:grid; grid-template-columns:1.8fr 1fr 1fr 1fr;
  gap:50px; margin-bottom:50px;
}
.f-logo { display:flex; align-items:center; gap:12px; margin-bottom:14px; }
.f-logo-mark {
  width:44px; height:44px; border-radius:50%;
  background:var(--navy2); border:2px solid var(--gold);
  display:flex; align-items:center; justify-content:center;
  font-family:var(--ff-head); font-size:14px; font-weight:700; color:var(--gold); flex-shrink:0;
}
.f-logo-name { font-family:var(--ff-head); font-size:18px; font-weight:700; color:#fff; text-transform:uppercase; letter-spacing:.04em; }
.f-logo-name span { color:var(--gold); }
.f-desc { font-size:14px; color:rgba(255,255,255,.5); line-height:1.7; margin-bottom:14px; }
.f-badge {
  display:inline-flex; align-items:center; gap:6px;
  background:rgba(201,160,48,.1); border:1px solid rgba(201,160,48,.2);
  border-radius:6px; padding:6px 12px;
  font-size:11px; font-weight:800; letter-spacing:.06em; color:var(--gold); text-transform:uppercase;
}
.f-col-head {
  font-size:11px; font-weight:800; letter-spacing:.12em; text-transform:uppercase;
  color:var(--gold); margin-bottom:16px;
}
.f-nav { list-style:none; display:flex; flex-direction:column; gap:8px; }
.f-nav a {
  font-size:14px; color:rgba(255,255,255,.55);
  transition:color .2s; cursor:pointer;
}
.f-nav a:hover { color:var(--gold); }
.f-row { display:flex; align-items:flex-start; gap:10px; margin-bottom:10px; font-size:14px; color:rgba(255,255,255,.55); }
.f-row a { color:inherit; transition:color .2s; }
.f-row a:hover { color:var(--gold); }
.f-ico { font-size:14px; flex-shrink:0; margin-top:1px; }
.f-socials { display:flex; gap:8px; flex-wrap:wrap; }
.f-soc {
  width:38px; height:38px; background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.1); border-radius:8px;
  display:flex; align-items:center; justify-content:center; font-size:16px;
  transition:all .2s;
}
.f-soc:hover { background:rgba(201,160,48,.15); border-color:rgba(201,160,48,.3); transform:translateY(-2px); }
.f-bottom {
  border-top:1px solid rgba(255,255,255,.08); padding-top:24px;
  display:flex; justify-content:space-between; align-items:center;
}
.f-bottom p { font-size:13px; color:rgba(255,255,255,.35); }
.f-bottom span { color:var(--gold); }

/* ─── HERO ─── */
.hero {
  min-height:100vh; background:var(--white);
  display:flex; flex-direction:column;
  position:relative; overflow:hidden;
  padding-top:70px;
}
.hero-split {
  position:absolute; right:0; top:0; bottom:0; width:42%;
  background:var(--navy); clip-path:polygon(10% 0,100% 0,100% 100%,0 100%);
}
.hero-split-line {
  position:absolute; right:41%; top:0; bottom:0; width:2px;
  background:linear-gradient(180deg,transparent,var(--gold),transparent);
  opacity:.4;
}
.hero-dots {
  position:absolute; right:3%; top:15%; width:200px; height:200px;
  background-image:radial-gradient(circle,rgba(201,160,48,.3) 1px,transparent 1px);
  background-size:18px 18px; pointer-events:none;
}
.hero-body {
  flex:1; display:flex; align-items:center;
  padding:60px 0 40px; position:relative; z-index:2;
}
.hero-grid { display:grid; grid-template-columns:1fr 1fr; align-items:center; gap:40px; }
.hero-left { padding-right:40px; }
.hero-kicker {
  display:inline-flex; align-items:center; gap:10px;
  font-size:11px; font-weight:800; letter-spacing:.14em; text-transform:uppercase;
  color:var(--gold); margin-bottom:20px;
}
.hero-kicker-dot {
  width:6px; height:6px; border-radius:50%; background:var(--gold);
}
.hero-title {
  font-family:var(--ff-head); font-weight:700; text-transform:uppercase;
  line-height:.92; letter-spacing:.02em; color:var(--navy);
  display:flex; flex-direction:column;
}
.hero-title .l1 { font-size:clamp(52px,8vw,108px); animation:fup .5s .05s ease both; }
.hero-title .l2 { font-size:clamp(52px,8vw,108px); color:var(--gold); animation:fup .5s .12s ease both; }
.hero-title .l3 { font-size:clamp(52px,8vw,108px); animation:fup .5s .19s ease both; }
.hero-sub {
  font-size:17px; color:var(--slate); line-height:1.85; max-width:440px;
  margin:22px 0 28px; animation:fup .5s .26s ease both;
}
.hero-btns { display:flex; gap:14px; flex-wrap:wrap; animation:fup .5s .32s ease both; margin-bottom:32px; }
.hero-trust {
  display:flex; align-items:center; gap:22px;
  animation:fup .5s .38s ease both;
}
.trust-stat { display:flex; flex-direction:column; }
.trust-num {
  font-family:var(--ff-head); font-size:32px; font-weight:700;
  color:var(--navy); line-height:1; display:block;
}
.trust-lbl { font-size:11px; color:var(--muted); font-weight:700; letter-spacing:.04em; text-transform:uppercase; }
.trust-div { width:1px; height:36px; background:var(--line2); }
@keyframes fup { from{opacity:0;transform:translateY(22px)} to{opacity:1;transform:none} }

/* Hero right cards */
.hero-right {
  position:relative; height:580px;
  display:flex; align-items:center; justify-content:center;
  padding-left:60px;
}
.card-main {
  background:#fff; border-radius:var(--r-lg);
  box-shadow:0 24px 80px rgba(13,30,58,.25);
  padding:32px; width:270px;
  position:relative; z-index:4;
  border-top:4px solid var(--gold);
  animation:fup .6s .15s ease both;
}
.card-main-lbl { font-size:11px; font-weight:800; letter-spacing:.12em; text-transform:uppercase; color:var(--muted); margin-bottom:8px; }
.card-main-num { font-family:var(--ff-head); font-size:58px; font-weight:700; color:var(--gold); line-height:1; }
.card-main-sub { font-size:13px; color:var(--muted); margin-top:4px; }
.card-main-bar { margin-top:16px; height:4px; background:var(--line); border-radius:2px; overflow:hidden; }
.card-main-fill { height:100%; background:linear-gradient(90deg,var(--gold),var(--gold-lt)); border-radius:2px; width:0; animation:grow 1.4s .9s ease both; }
@keyframes grow { from{width:0}to{width:76%} }
.card-main-bar-lbl { font-size:11px; color:var(--muted); margin-top:5px; }
.card-gold {
  position:absolute; top:50px; right:10px; z-index:6;
  background:var(--gold); border-radius:var(--r-lg);
  padding:22px 24px; width:180px;
  box-shadow:0 16px 50px rgba(201,160,48,.5);
  animation:fup .6s .28s ease both;
}
.card-gold-ico { font-size:26px; margin-bottom:8px; }
.card-gold-num { font-family:var(--ff-head); font-size:36px; font-weight:700; color:var(--navy); line-height:1; }
.card-gold-lbl { font-size:12px; font-weight:700; color:rgba(13,30,58,.7); margin-top:3px; text-transform:uppercase; letter-spacing:.04em; }
.card-sports {
  position:absolute; bottom:70px; right:0; z-index:5;
  background:var(--navy); border-radius:var(--r-lg);
  padding:20px 22px; width:220px;
  box-shadow:0 16px 50px rgba(13,30,58,.5);
  animation:fup .6s .38s ease both;
  border:1px solid rgba(201,160,48,.2);
}
.card-sports-lbl { font-size:11px; font-weight:800; letter-spacing:.1em; text-transform:uppercase; color:rgba(201,160,48,.7); margin-bottom:12px; }
.card-sports-chips { display:flex; gap:8px; }
.sport-chip {
  width:36px; height:36px; border-radius:8px;
  background:rgba(255,255,255,.07); border:1px solid rgba(201,160,48,.2);
  display:flex; align-items:center; justify-content:center;
  font-size:17px; transition:all .2s;
}
.sport-chip:hover { background:rgba(201,160,48,.2); transform:translateY(-2px); }
.card-badge {
  position:absolute; top:50%; left:-10px; transform:translateY(-50%); z-index:7;
  background:var(--red); color:#fff; border-radius:var(--r);
  padding:12px 16px; width:150px;
  box-shadow:0 10px 36px rgba(165,28,28,.5);
  animation:fup .6s .44s ease both;
}
.card-badge-t1 { font-family:var(--ff-head); font-size:18px; font-weight:700; text-transform:uppercase; line-height:1; }
.card-badge-t2 { font-size:11px; opacity:.8; font-weight:700; letter-spacing:.04em; margin-top:3px; }

/* ─── TICKER ─── */
.ticker-wrap {
  background:var(--navy); overflow:hidden;
  border-top:3px solid var(--gold); border-bottom:3px solid var(--gold);
  position:relative; z-index:2;
}
.ticker-row { display:flex; animation:scroll 24s linear infinite; white-space:nowrap; }
.ticker-item {
  display:inline-flex; align-items:center;
  font-family:var(--ff-head); font-size:15px; font-weight:500;
  letter-spacing:.1em; text-transform:uppercase;
  color:var(--cream); padding:14px 40px; gap:20px;
}
.ticker-item .sep {
  width:6px; height:6px; border-radius:50%; background:var(--gold); flex-shrink:0;
}
@keyframes scroll { from{transform:translateX(0)} to{transform:translateX(-50%)} }

/* ─── STATS ─── */
.stats-s { background:var(--gold-bg); border-bottom:2px solid var(--gold-line); padding:60px 0; }
.stats-row { display:grid; grid-template-columns:repeat(4,1fr); gap:0; position:relative; }
.stats-row::before {
  content:''; position:absolute; inset:0;
  background:url("data:image/svg+xml,%3Csvg width='32' height='32' viewBox='0 0 32 32' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M16 0 L17 15 L32 16 L17 17 L16 32 L15 17 L0 16 L15 15 Z' fill='rgba(201,160,48,0.06)'/%3E%3C/svg%3E") repeat;
  pointer-events:none;
}
.stat-col { padding:0 36px; border-right:1px solid var(--gold-line); text-align:center; position:relative; z-index:1; }
.stat-col:last-child { border-right:none; }
.stat-n { font-family:var(--ff-head); font-size:56px; font-weight:700; color:var(--navy); line-height:1; }
.stat-n em { color:var(--gold); font-style:normal; font-size:.75em; vertical-align:super; }
.stat-l { font-size:12px; font-weight:700; letter-spacing:.08em; text-transform:uppercase; color:var(--muted); margin-top:5px; }

/* ─── MISSION ─── */
.mission-s { background:var(--white); }
.mission-grid { display:grid; grid-template-columns:1fr 1fr; gap:72px; align-items:center; }
.mission-img-wrap { position:relative; }
.mission-img-main {
  width:100%; aspect-ratio:4/3; border-radius:var(--r-lg);
  overflow:hidden; background:var(--off);
  border:3px solid var(--gold-line);
  box-shadow:8px 8px 0 var(--gold-line);
}
.mission-img-main img { width:100%; height:100%; object-fit:cover; }
.mission-badge {
  position:absolute; bottom:-22px; right:-22px;
  background:var(--navy); color:var(--gold);
  border-radius:var(--r-lg); padding:20px 24px;
  box-shadow:0 16px 44px rgba(13,30,58,.4);
  border:2px solid var(--gold); text-align:center;
}
.mission-badge-num { font-family:var(--ff-head); font-size:26px; font-weight:700; line-height:1; text-transform:uppercase; }
.mission-badge-lbl { font-size:11px; opacity:.75; font-weight:700; letter-spacing:.06em; text-transform:uppercase; margin-top:3px; }
.mission-tag {
  position:absolute; top:-18px; left:-18px;
  background:var(--red); color:#fff;
  border-radius:var(--r); padding:10px 16px;
  font-family:var(--ff-head); font-size:14px; font-weight:700;
  text-transform:uppercase; letter-spacing:.04em;
  box-shadow:0 8px 28px rgba(165,28,28,.4);
}
.mission-quote {
  margin:22px 0; padding:20px 24px;
  background:var(--off); border-left:4px solid var(--gold);
  border-radius:0 var(--r) var(--r) 0;
}
.mission-quote p { font-size:16px; font-style:italic; color:var(--ink); line-height:1.75; }
.mission-pts { display:flex; flex-direction:column; gap:12px; margin-top:22px; }
.mission-pt {
  display:flex; align-items:flex-start; gap:14px;
  padding:14px 16px; border-radius:var(--r);
  border:1px solid var(--line); transition:all .25s; background:#fff;
}
.mission-pt:hover { border-color:var(--gold-line); background:var(--gold-bg); }
.mission-pt-ico {
  width:34px; height:34px; flex-shrink:0; border-radius:8px;
  background:var(--gold-bg); border:1px solid var(--gold-line);
  display:flex; align-items:center; justify-content:center; font-size:16px;
}
.mission-pt-title { font-size:14px; font-weight:800; color:var(--navy); margin-bottom:2px; }
.mission-pt-desc { font-size:13px; color:var(--muted); line-height:1.5; }

/* ─── HOW TO HELP ─── */
.help-s { background:var(--navy); }
.help-header { display:grid; grid-template-columns:1fr 1fr; align-items:end; gap:40px; margin-bottom:52px; }
.help-cards { display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }
.help-card {
  background:rgba(255,255,255,.04); border:1px solid rgba(201,160,48,.15);
  border-radius:var(--r-lg); padding:32px 26px;
  cursor:pointer; transition:all .3s; position:relative; overflow:hidden;
  display:block; color:inherit;
}
.help-card::before {
  content:''; position:absolute; top:0; left:0; right:0; height:3px;
  background:linear-gradient(90deg,var(--red),var(--gold),var(--gold-lt));
  transform:scaleX(0); transform-origin:left; transition:transform .3s ease;
}
.help-card:hover {
  background:rgba(255,255,255,.07); border-color:rgba(201,160,48,.4);
  transform:translateY(-5px); box-shadow:0 20px 50px rgba(0,0,0,.4);
}
.help-card:hover::before { transform:scaleX(1); }
.help-n { font-family:var(--ff-head); font-size:72px; font-weight:700; color:rgba(255,255,255,.04); line-height:1; position:absolute; top:10px; right:14px; }
.help-ico {
  width:48px; height:48px; border-radius:10px;
  background:rgba(201,160,48,.1); border:1px solid rgba(201,160,48,.2);
  display:flex; align-items:center; justify-content:center; font-size:22px; margin-bottom:18px;
}
.help-title { font-family:var(--ff-head); font-size:22px; font-weight:700; text-transform:uppercase; letter-spacing:.03em; margin-bottom:10px; color:#fff; }
.help-desc { font-size:14px; color:rgba(255,255,255,.5); line-height:1.7; margin-bottom:20px; }
.help-link { font-size:12px; font-weight:800; letter-spacing:.1em; text-transform:uppercase; color:var(--gold); display:flex; align-items:center; gap:6px; }
.help-link::after { content:'→'; font-size:14px; }

/* ─── VALUES ─── */
.values-s { background:var(--off); }
.values-layout { display:grid; grid-template-columns:1fr 1.2fr; gap:72px; align-items:center; }
.values-left { padding-right:20px; }
.values-big-text {
  font-family:var(--ff-head); font-size:clamp(44px,5vw,72px);
  font-weight:700; text-transform:uppercase; letter-spacing:.02em;
  color:var(--navy); line-height:1.0; margin-top:18px;
}
.values-big-text .accent  { color:var(--gold); }
.values-big-text .accent2 { color:var(--red); }
.values-grid { display:grid; grid-template-columns:1fr 1fr; gap:14px; }
.val-card {
  padding:20px 18px; border-radius:var(--r);
  background:#fff; border:1px solid var(--line);
  transition:all .25s;
}
.val-card:hover { border-color:var(--gold-line); background:var(--gold-bg); transform:translateY(-2px); }
.val-card:first-child { background:var(--navy); border-color:var(--navy); color:#fff; }
.val-card:first-child .val-name { color:#fff; }
.val-card:first-child .val-desc { color:rgba(255,255,255,.6); }
.val-ico  { font-size:22px; margin-bottom:9px; }
.val-name { font-size:13px; font-weight:800; color:var(--navy); margin-bottom:3px; text-transform:uppercase; letter-spacing:.04em; }
.val-desc { font-size:12px; color:var(--muted); line-height:1.55; }

/* ─── CTA ─── */
.cta-s { background:var(--navy); padding:88px 0; position:relative; overflow:hidden; }
.cta-s::before {
  content:''; position:absolute; inset:0;
  background:
    radial-gradient(ellipse 50% 80% at 20% 50%,rgba(165,28,28,.15) 0%,transparent 55%),
    radial-gradient(ellipse 50% 80% at 80% 50%,rgba(201,160,48,.1) 0%,transparent 55%);
}
.cta-gold-line {
  position:absolute; top:0; left:0; right:0; height:4px;
  background:linear-gradient(90deg,var(--red-dk),var(--red),var(--gold),var(--gold-lt),var(--gold),var(--red),var(--red-dk));
}
.cta-inner { position:relative; z-index:1; display:flex; align-items:center; justify-content:space-between; gap:40px; }
.cta-title {
  font-family:var(--ff-head); font-size:clamp(34px,4.5vw,58px);
  font-weight:700; text-transform:uppercase; letter-spacing:.02em;
  color:#fff; line-height:1.02; max-width:560px;
}
.cta-title .hl { color:var(--gold); }
.cta-sub { font-size:15px; color:rgba(255,255,255,.5); margin-top:12px; max-width:420px; line-height:1.7; }
.cta-btns { display:flex; flex-direction:column; gap:12px; flex-shrink:0; min-width:190px; }

/* ─── ABOUT ─── */
.about-grid { display:grid; grid-template-columns:1fr 1fr; gap:64px; align-items:center; }
.about-img-main {
  width:100%; aspect-ratio:4/3; border-radius:var(--r-lg);
  overflow:hidden; background:var(--off);
  border:3px solid var(--gold-line);
  box-shadow:6px 6px 0 var(--gold-line);
}
.about-img-main img { width:100%; height:100%; object-fit:cover; }
.about-img-grid { display:grid; grid-template-columns:1fr 1fr; gap:12px; margin-top:12px; }
.about-img-sm { border-radius:var(--r); overflow:hidden; background:var(--off); border:2px solid var(--line); }
.about-img-sm img { width:100%; height:180px; object-fit:cover; }
.about-float {
  position:absolute; top:-18px; right:-18px;
  background:var(--gold); color:var(--navy);
  border-radius:var(--r); padding:12px 18px;
  font-family:var(--ff-head); font-size:15px; font-weight:700;
  text-transform:uppercase; letter-spacing:.04em;
  box-shadow:0 10px 36px rgba(201,160,48,.45);
}
.about-float span { display:block; font-family:var(--ff-body); font-size:11px; font-weight:700; opacity:.7; letter-spacing:.06em; }
.tax-chip {
  display:inline-flex; align-items:center; gap:8px;
  background:var(--off); border:1px solid var(--line2);
  border-radius:7px; padding:10px 16px; margin-top:18px;
  font-size:13px; font-weight:700; color:var(--ink);
}
.tax-chip b { color:var(--navy); }

/* TIMELINE */
.tl-list { display:flex; flex-direction:column; gap:0; }
.tl-item { display:flex; gap:18px; padding-bottom:28px; }
.tl-item:last-child { padding-bottom:0; }
.tl-line-col { display:flex; flex-direction:column; align-items:center; }
.tl-dot { width:14px; height:14px; border-radius:50%; background:var(--gold); border:3px solid var(--cream); flex-shrink:0; z-index:1; }
.tl-item:nth-child(2) .tl-dot { background:var(--red); }
.tl-item:nth-child(3) .tl-dot { background:var(--navy); }
.tl-connector { flex:1; width:2px; background:var(--line2); margin:4px 0; }
.tl-item:last-child .tl-connector { display:none; }
.tl-yr { font-size:11px; font-weight:800; letter-spacing:.1em; color:var(--gold); text-transform:uppercase; margin-bottom:3px; }
.tl-item:nth-child(2) .tl-yr { color:var(--red); }
.tl-item:nth-child(3) .tl-yr { color:var(--navy); }
.tl-title { font-family:var(--ff-head); font-size:20px; font-weight:700; text-transform:uppercase; letter-spacing:.03em; margin-bottom:5px; }
.tl-desc { font-size:14px; color:var(--muted); line-height:1.65; }
.panel-card {
  background:#fff; border:1px solid var(--line);
  border-radius:var(--r-lg); padding:34px;
  box-shadow:0 8px 36px rgba(13,30,58,.07);
  position:relative; overflow:hidden;
}
.panel-card::before {
  content:''; position:absolute; top:0; left:0; right:0; height:4px;
  background:linear-gradient(90deg,var(--red),var(--gold),var(--gold-lt));
}

/* ─── NEWSLETTER ─── */
.nl-box {
  background:var(--navy); border-radius:var(--r-lg); padding:38px;
  border:2px solid rgba(201,160,48,.2);
  box-shadow:0 20px 60px rgba(13,30,58,.35);
}
.nl-title { font-family:var(--ff-head); font-size:26px; font-weight:700; text-transform:uppercase; letter-spacing:.04em; margin-bottom:8px; color:#fff; }
.nl-sub { font-size:14px; color:rgba(255,255,255,.55); margin-bottom:22px; line-height:1.65; }
.nl-form { display:flex; gap:10px; }
.nl-inp {
  flex:1; background:rgba(255,255,255,.08); border:1px solid rgba(201,160,48,.3);
  border-radius:7px; padding:12px 16px;
  font-family:var(--ff-body); font-size:14px; color:#fff; outline:none;
}
.nl-inp::placeholder { color:rgba(255,255,255,.35); }
.nl-inp:focus { border-color:var(--gold); }
.nl-btn {
  background:var(--gold); color:var(--navy); border:none;
  font-family:var(--ff-body); font-size:13px; font-weight:800;
  letter-spacing:.06em; text-transform:uppercase;
  padding:12px 20px; border-radius:7px; cursor:pointer; flex-shrink:0; transition:all .2s;
}
.nl-btn:hover { background:var(--gold-lt); }

/* ─── GALLERY ─── */
.gal-filters { display:flex; gap:8px; flex-wrap:wrap; margin-bottom:32px; }
.gf-btn {
  font-family:var(--ff-body); font-size:12px; font-weight:800;
  letter-spacing:.1em; text-transform:uppercase;
  padding:9px 20px; border-radius:6px;
  border:2px solid var(--line2); color:var(--slate);
  background:#fff; cursor:pointer; transition:all .2s;
}
.gf-btn:hover { border-color:var(--gold); color:var(--gold); }
.gf-btn.on { background:var(--navy); border-color:var(--navy); color:#fff; }
.gal-grid { columns:3; gap:14px; }
.gal-item {
  break-inside:avoid; margin-bottom:14px; border-radius:var(--r);
  overflow:hidden; cursor:pointer; position:relative;
}
.gal-item img { width:100%; height:auto; display:block; transition:transform .4s ease; }
.gal-item:hover img { transform:scale(1.05); }
.gal-ov {
  position:absolute; inset:0; background:rgba(13,30,58,.55);
  opacity:0; transition:opacity .3s;
  display:flex; align-items:flex-end; padding:14px;
}
.gal-item:hover .gal-ov { opacity:1; }
.gal-ov span {
  font-size:11px; font-weight:800; letter-spacing:.1em; text-transform:uppercase;
  background:var(--gold); color:var(--navy);
  padding:4px 10px; border-radius:4px;
}
.lb {
  position:fixed; inset:0; background:rgba(0,0,0,.93);
  z-index:10000; display:none; align-items:center; justify-content:center;
}
.lb.open { display:flex; }
.lb-img { max-width:90vw; max-height:90vh; border-radius:var(--r); box-shadow:0 32px 80px rgba(0,0,0,.8); }
.lb-x {
  position:absolute; top:20px; right:24px;
  font-size:24px; color:#fff; cursor:pointer; background:rgba(255,255,255,.1);
  border:none; width:44px; height:44px; border-radius:50%;
  display:flex; align-items:center; justify-content:center; transition:all .2s;
}
.lb-x:hover { background:rgba(255,255,255,.2); }
.lb-nav {
  position:absolute; top:50%; transform:translateY(-50%);
  font-size:40px; color:#fff; cursor:pointer; background:rgba(255,255,255,.08);
  border:none; width:56px; height:56px; border-radius:50%;
  display:flex; align-items:center; justify-content:center; transition:all .2s;
}
.lb-nav:hover { background:rgba(255,255,255,.18); }
.lb-prev { left:20px; }
.lb-next { right:20px; }

/* ─── DONATE ─── */
.plt-grid { display:grid; grid-template-columns:1fr 1fr; gap:12px; }
.plt-card {
  display:flex; align-items:center; gap:12px;
  background:#fff; border:1.5px solid var(--line);
  border-radius:var(--r); padding:14px 16px;
  transition:all .25s; cursor:pointer;
}
.plt-card:hover { border-color:var(--gold); background:var(--gold-bg); transform:translateY(-2px); box-shadow:0 8px 24px rgba(201,160,48,.15); }
.plt-ico { font-size:22px; flex-shrink:0; }
.plt-nm { font-size:14px; font-weight:800; color:var(--navy); }
.plt-sub { font-size:12px; color:var(--muted); }
.d-card {
  background:#fff; border:1px solid var(--line);
  border-radius:var(--r-lg); padding:28px;
  position:relative; overflow:hidden;
  box-shadow:0 4px 24px rgba(13,30,58,.06);
  margin-bottom:20px;
}
.d-card-accent {
  position:absolute; top:0; left:0; right:0; height:4px;
  background:linear-gradient(90deg,var(--red),var(--gold),var(--gold-lt));
}
.d-card-title { font-family:var(--ff-head); font-size:20px; font-weight:700; text-transform:uppercase; letter-spacing:.03em; color:var(--navy); margin-bottom:16px; }
.il { list-style:none; display:flex; flex-direction:column; gap:9px; }
.il li {
  font-size:14px; color:var(--slate); padding:8px 0;
  border-bottom:1px solid var(--line); display:flex; align-items:center; gap:10px;
}
.il li::before { content:'›'; color:var(--gold); font-weight:700; font-size:16px; }
.il li:last-child { border-bottom:none; }
.amt-grid { display:grid; grid-template-columns:1fr 1fr 1fr; gap:8px; margin-bottom:4px; }
.amt-btn {
  border:2px solid var(--line2); border-radius:var(--r);
  padding:12px 8px; text-align:center; cursor:pointer;
  background:#fff; transition:all .22s;
}
.amt-btn:hover { border-color:var(--gold); background:var(--gold-bg); }
.amt-btn.on { border-color:var(--gold); background:var(--gold); }
.amt-btn.on .amt-val { color:var(--navy); }
.amt-btn.on .amt-tag { color:rgba(13,30,58,.7); }
.amt-val { font-family:var(--ff-head); font-size:22px; font-weight:700; color:var(--navy); display:block; line-height:1.1; }
.amt-tag { font-size:10px; font-weight:800; letter-spacing:.06em; text-transform:uppercase; color:var(--muted); margin-top:3px; }

/* ─── CONTACT ─── */
.ci-item { display:flex; align-items:flex-start; gap:16px; margin-bottom:22px; }
.ci-ico {
  width:44px; height:44px; border-radius:10px; flex-shrink:0;
  background:var(--gold-bg); border:1px solid var(--gold-line);
  display:flex; align-items:center; justify-content:center; font-size:18px;
}
.ci-head { font-size:11px; font-weight:800; letter-spacing:.1em; text-transform:uppercase; color:var(--muted); margin-bottom:4px; }
.ci-val { font-size:14px; color:var(--ink); line-height:1.7; }
.ci-val a { color:var(--navy); font-weight:700; transition:color .2s; }
.ci-val a:hover { color:var(--gold); }
.cf-box {
  background:#fff; border-radius:var(--r-lg);
  box-shadow:0 12px 48px rgba(13,30,58,.1);
  padding:36px; border:1px solid var(--line);
}
.cf-title { font-family:var(--ff-head); font-size:24px; font-weight:700; text-transform:uppercase; letter-spacing:.04em; color:var(--navy); margin-bottom:24px; }
.cf-row { display:grid; grid-template-columns:1fr 1fr; gap:14px; }
.cf-group { display:flex; flex-direction:column; gap:6px; margin-bottom:16px; }
.cf-lbl { font-size:12px; font-weight:800; letter-spacing:.06em; text-transform:uppercase; color:var(--slate); }
.cf-inp {
  background:var(--cream); border:1.5px solid var(--line2);
  border-radius:7px; padding:12px 14px;
  font-family:var(--ff-body); font-size:14px; color:var(--ink);
  outline:none; transition:border-color .2s;
}
.cf-inp:focus { border-color:var(--gold); background:#fff; }
.cf-inp-error { border-color:var(--red) !important; }
.cf-ta { min-height:130px; resize:vertical; }
.cf-err { font-size:12px; color:var(--red); font-weight:700; }
.cf-submit {
  width:100%; background:var(--navy); color:#fff; border:none;
  font-family:var(--ff-body); font-size:13px; font-weight:800;
  letter-spacing:.08em; text-transform:uppercase;
  padding:15px; border-radius:7px; cursor:pointer; transition:all .22s;
}
.cf-submit:hover { background:var(--navy2); transform:translateY(-1px); box-shadow:0 8px 24px rgba(13,30,58,.3); }
.form-errors {
  background:var(--red-bg); border:1px solid var(--red-line);
  border-radius:var(--r); padding:14px 18px; margin-bottom:20px;
}
.form-errors ul { list-style:none; }
.form-errors li { font-size:13px; color:var(--red); font-weight:700; padding:3px 0; }
.form-errors li::before { content:'⚠ '; }

/* ─── TWO-COL GRID UTILITY (replaces inline style grids in about/contact/donate) ─── */
.two-col-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 72px;
  align-items: start;
}
.two-col-grid--contact { grid-template-columns: 1fr 1.2fr; gap: 60px; }
.two-col-grid--donate  { grid-template-columns: 1.3fr 1fr; gap: 60px; }

/* ─── RESPONSIVE ─── */

/* ── Tablet ≤ 980px ── */
@media(max-width:980px) {
  /* Grids → single column */
  .hero-grid,
  .mission-grid,
  .help-cards,
  .two-col-grid,
  .two-col-grid--contact,
  .two-col-grid--donate { grid-template-columns: 1fr; }

  /* Hero */
  .hero-right,.hero-split,.hero-split-line,.hero-dots { display:none; }
  .hero-left { padding-right:0; }
  .hero-body { padding:40px 0 32px; }

  /* Stats */
  .stats-row { grid-template-columns:1fr 1fr; }
  .stat-col { border-right:none; padding:20px; border-bottom:1px solid var(--gold-line); }
  .stat-col:last-child,
  .stat-col:nth-child(even) { border-bottom:none; }
  .stat-n { font-size:44px; }

  /* Footer */
  .footer-grid { grid-template-columns:1fr 1fr; gap:32px; }

  /* Gallery */
  .gal-grid { columns:2; }

  /* CTA */
  .cta-inner { flex-direction:column; align-items:flex-start; gap:28px; }
  .cta-btns  { flex-direction:row; }

  /* Help */
  .help-header { grid-template-columns:1fr; }
  .help-card { padding:28px 22px; }

  /* Team */
  .team-grid { grid-template-columns: repeat(auto-fill, minmax(240px, 1fr)); gap: 20px; }
}

/* ── Mobile ≤ 640px ── */
@media(max-width:640px) {
  /* Layout */
  .wrap { padding:0 16px; }
  .sec  { padding:52px 0; }

  /* Grids → single column on mobile */
  .values-layout,
  .about-grid { grid-template-columns:1fr; }

  /* Navbar */
  #nav { padding:0 16px; height:60px; }
  .hero { padding-top:60px; }
  .pg-banner { padding-top:80px; }
  .nav-links { display:none; }
  .ham { display:flex; }

  /* Page banners */
  .pg-banner { padding:80px 0 40px; }
  .pg-banner h1 { font-size:clamp(34px,10vw,54px); line-height:1.0; }
  .pg-banner p  { font-size:15px; margin-top:12px; }
  .pg-banner::after { display:none; }

  /* Hero */
  .hero-body { padding:28px 0 20px; }
  .hero-title .l1,
  .hero-title .l2,
  .hero-title .l3 { font-size:clamp(40px,12vw,72px); }
  .hero-sub { font-size:15px; margin:14px 0 20px; }
  .hero-btns { flex-direction:column; gap:10px; margin-bottom:22px; }
  .hero-btns .btn { width:100%; justify-content:center; }
  .hero-trust { flex-wrap:wrap; gap:12px 20px; }
  .trust-div  { display:none; }

  /* Stats */
  .stats-s { padding:36px 0; }
  .stat-col { padding:16px 12px; }
  .stat-n   { font-size:36px; }

  /* Mission — floating elements go off-screen, reset to static */
  .mission-grid { gap:20px; }
  .mission-badge {
    position:static; display:inline-flex; align-items:center;
    gap:10px; margin-top:12px; border-radius:8px; padding:12px 16px;
  }
  .mission-tag { position:static; display:inline-block; margin-bottom:10px; }

  /* Section titles */
  .sec-title { font-size:clamp(26px,8vw,44px); }

  /* Values */
  .values-big-text { font-size:clamp(36px,10vw,56px); }
  .values-grid { grid-template-columns:1fr 1fr; }

  /* Help cards */
  .help-header { margin-bottom:28px; }
  .help-card   { padding:22px 16px; }
  .help-n      { font-size:52px; }

  /* CTA */
  .cta-s { padding:56px 0; }
  .cta-inner { flex-direction:column; gap:22px; align-items:flex-start; }
  .cta-btns { flex-direction:column; width:100%; min-width:0; }
  .cta-btns .btn { width:100%; justify-content:center; }

  /* About page floating badge */
  .about-float { position:static; display:inline-block; margin-top:10px; }
  .about-img-sm img { height:130px; }

  /* Footer */
  .footer { padding:48px 0 20px; }
  .footer-grid { grid-template-columns:1fr; gap:26px; margin-bottom:28px; }
  .f-bottom { flex-direction:column; gap:8px; text-align:center; }

  /* Gallery */
  .gal-grid { columns:1; gap:10px; }
  .gal-item { margin-bottom:10px; }
  .gal-filters { gap:6px; }
  .gf-btn { padding:8px 14px; font-size:11px; }
  .lb-prev { left:8px; }
  .lb-next { right:8px; }
  .lb-nav  { width:44px; height:44px; font-size:28px; }
  .lb-x    { top:12px; right:12px; }

  /* Donate */
  .plt-grid { grid-template-columns:1fr; }
  .d-card   { padding:20px 16px; }
  .amt-grid { grid-template-columns:1fr 1fr; }
  .amt-val  { font-size:18px; }

  /* Contact */
  .cf-row { grid-template-columns:1fr; }
  .cf-box { padding:22px 16px; }

  /* Newsletter */
  .nl-box { padding:26px 18px; }
  .nl-form { flex-direction:column; }
  .nl-btn  { width:100%; padding:14px; }

  /* Buttons — minimum 44px touch target */
  .btn    { min-height:44px; }
  .btn-lg { padding:14px 28px; font-size:13px; }

  /* Flash messages */
  .flash { left:12px; right:12px; max-width:none; top:68px; }

  /* Panel cards */
  .panel-card { padding:22px 16px; }

  /* Team */
  .team-grid { grid-template-columns:1fr; gap:18px; }
  .team-card { padding:28px 20px 22px; }
  .team-photo-wrap { width:90px; height:90px; }
  .team-photo, .team-initials { width:90px; height:90px; font-size:30px; }

  /* Ticker safety */
  .ticker-wrap { overflow:hidden; }
}

/* ── Extra small ≤ 390px (iPhone SE, older Androids) ── */
@media(max-width:390px) {
  .wrap { padding:0 12px; }
  .hero-title .l1,
  .hero-title .l2,
  .hero-title .l3 { font-size:clamp(34px,11vw,54px); }
  .values-grid { grid-template-columns:1fr; }
  .stat-n  { font-size:30px; }
  .amt-val { font-size:16px; }
  .amt-tag { font-size:9px; }
}

/* ─── FOCUS ACCESSIBILITY ─── */
:focus-visible {
  outline:3px solid var(--gold);
  outline-offset:2px;
}

/* ─── TEAM SECTION ─── */
.team-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 28px;
}
.team-card {
  background: var(--white);
  border: 1px solid var(--line);
  border-radius: var(--r-lg);
  padding: 36px 28px 28px;
  text-align: center;
  position: relative;
  overflow: hidden;
  transition: all .28s ease;
  box-shadow: 0 4px 20px rgba(13,30,58,.05);
}
.team-card::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 4px;
  background: linear-gradient(90deg, var(--red), var(--gold), var(--gold-lt));
  transform: scaleX(0);
  transform-origin: left;
  transition: transform .35s ease;
}
.team-card:hover {
  border-color: var(--gold-line);
  box-shadow: 0 16px 52px rgba(13,30,58,.12);
  transform: translateY(-4px);
}
.team-card:hover::before { transform: scaleX(1); }

/* Photo */
.team-photo-wrap {
  position: relative;
  width: 110px;
  height: 110px;
  margin: 0 auto 20px;
}
.team-photo {
  width: 110px;
  height: 110px;
  border-radius: 50%;
  object-fit: cover;
  border: 3px solid var(--gold-line);
  position: relative;
  z-index: 1;
  display: block;
}
.team-initials {
  width: 110px;
  height: 110px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--navy), var(--navy3));
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--ff-head);
  font-size: 38px;
  font-weight: 700;
  color: var(--gold);
  border: 3px solid var(--gold-line);
  position: relative;
  z-index: 1;
  letter-spacing: .04em;
}
.team-photo-ring {
  position: absolute;
  inset: -6px;
  border-radius: 50%;
  border: 2px dashed var(--gold-line);
  animation: spin 18s linear infinite;
  z-index: 0;
}
@keyframes spin { to { transform: rotate(360deg); } }
.team-card:hover .team-photo-ring {
  border-color: var(--gold);
  animation-duration: 6s;
}

/* Text */
.team-name {
  font-family: var(--ff-head);
  font-size: 22px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .04em;
  color: var(--navy);
  margin-bottom: 6px;
  line-height: 1.1;
}
.team-title {
  font-size: 12px;
  font-weight: 800;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--gold-dk);
  background: var(--gold-bg);
  border: 1px solid var(--gold-line);
  border-radius: 20px;
  display: inline-block;
  padding: 4px 14px;
  margin-bottom: 14px;
}
.team-bio {
  font-size: 14px;
  color: var(--slate);
  line-height: 1.7;
  margin-bottom: 18px;
  text-align: left;
}

/* Links */
.team-links {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
  flex-wrap: wrap;
  margin-top: 4px;
}
.team-link {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 12px;
  font-weight: 800;
  letter-spacing: .06em;
  text-transform: uppercase;
  color: var(--navy);
  background: var(--off);
  border: 1px solid var(--line2);
  border-radius: 6px;
  padding: 7px 14px;
  transition: all .22s;
}
.team-link:hover {
  background: var(--gold);
  border-color: var(--gold);
  color: var(--navy);
  transform: translateY(-1px);
}

/* Responsive */
