
:root{
  --bg:#040507;
  --bg-2:#09111f;
  --bg-3:#0f1a2c;
  --panel:#101a2b;
  --text:#111827;
  --muted:#5c6678;
  --white:#ffffff;
  --line:rgba(255,255,255,.08);
  --line-light:#e8edf5;
  --pink:#f51f79;
  --purple:#7c2ed6;
  --magenta:#d81b60;
  --grad:linear-gradient(90deg,var(--purple),var(--magenta),#ff4b4b);
  --shadow:0 24px 60px rgba(2,8,23,.14);
  --shadow-strong:0 28px 72px rgba(2,8,23,.22);
  --radius:28px;
  --container:1240px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:Inter,Arial,Helvetica,sans-serif;
  background:#f6f7fb;
  color:var(--text);
  line-height:1.65;
}
img{display:block;max-width:100%}
a{text-decoration:none;color:inherit}
.container{width:min(var(--container),calc(100% - 32px));margin:0 auto}
.site-header{
  position:sticky; top:0; z-index:1000;
  background:#000; border-bottom:1px solid rgba(255,255,255,.08);
  box-shadow:0 10px 30px rgba(0,0,0,.18);
}
.nav{
  min-height:88px; display:flex; align-items:center; justify-content:space-between; gap:18px;
}
.brand img{width:245px}
.nav-links{
  display:flex; align-items:center; gap:28px; flex-wrap:wrap; color:#fff; font-weight:700; letter-spacing:-.01em;
}
.nav-links a{opacity:.88; position:relative; transition:opacity .18s ease, transform .18s ease}
.nav-links a:hover,.nav-links a.active{opacity:1; transform:translateY(-1px)}
.nav-links a.active::after{
  content:""; position:absolute; left:0; bottom:-12px; width:38px; height:3px; border-radius:999px; background:var(--grad);
}
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:10px;
  padding:15px 26px; border-radius:999px; font-weight:800;
  transition:transform .18s ease, box-shadow .18s ease, filter .18s ease;
}
.btn:hover{transform:translateY(-2px); filter:brightness(1.03)}
.btn-primary{color:#fff; background:var(--grad); box-shadow:0 14px 28px rgba(124,46,214,.25)}
.btn-secondary{color:#fff; border:2px solid rgba(255,255,255,.28); background:rgba(255,255,255,.03)}

.hero{
  position:relative;
  min-height:760px;
  display:flex;
  align-items:center;
  overflow:hidden;
  color:#fff;
  background:
    linear-gradient(90deg, rgba(4,5,7,.82) 0%, rgba(4,5,7,.68) 26%, rgba(4,5,7,.40) 46%, rgba(4,5,7,.16) 65%, rgba(4,5,7,.05) 100%),
    radial-gradient(circle at 14% 22%, rgba(124,46,214,.24), transparent 26%),
    url('assets/hero.jpg') center center / cover no-repeat;
}
.hero::after{
  content:"";
  position:absolute; inset:0;
  background:linear-gradient(180deg, rgba(0,0,0,.18), rgba(0,0,0,.34));
  pointer-events:none;
}
.hero-inner{
  position:relative; z-index:2; padding:110px 0 150px;
}
.hero h1{
  margin:0;
  max-width:760px;
  font-size:clamp(3.4rem,6.2vw,6.6rem);
  line-height:.92;
  letter-spacing:-.065em;
}
.hero h1 .accent{color:var(--pink)}
.hero p{
  margin:26px 0 0;
  max-width:620px;
  color:rgba(255,255,255,.92);
  font-size:1.16rem;
  line-height:1.85;
}
.hero-actions{display:flex; gap:16px; flex-wrap:wrap; margin-top:34px}
.hero-curve{
  position:absolute; left:0; right:0; bottom:-1px; height:130px; pointer-events:none; z-index:2;
}
.hero-curve svg{width:100%; height:100%; display:block}

.page-hero{
  position:relative;
  color:#fff;
  overflow:hidden;
  background:
    linear-gradient(90deg, rgba(4,5,7,.78) 0%, rgba(4,5,7,.58) 34%, rgba(4,5,7,.28) 56%, rgba(4,5,7,.08) 100%);
}
.page-hero::before{
  content:"";
  position:absolute; inset:0;
  background:radial-gradient(circle at 12% 18%, rgba(124,46,214,.22), transparent 26%);
  pointer-events:none;
}
.page-hero-wrap{
  position:relative;
  min-height:540px;
  background-size:cover;
  background-position:center center;
  background-repeat:no-repeat;
}
.page-copy{
  position:relative; z-index:2; padding:92px 0 88px;
}
.page-copy h1{
  margin:0;
  max-width:760px;
  font-size:clamp(3rem,5.4vw,5rem);
  line-height:.94;
  letter-spacing:-.05em;
}
.page-copy p{
  margin:22px 0 0;
  max-width:640px;
  color:rgba(255,255,255,.9);
  font-size:1.08rem;
  line-height:1.85;
}

.section{padding:88px 0}
.section-dark{
  background:linear-gradient(180deg,#05070c 0%, #08111f 100%);
  color:#fff;
}
.section-head{text-align:center; margin-bottom:38px}
.section-head h2{
  margin:0;
  font-size:clamp(2.2rem,4vw,3.6rem);
  line-height:1.04;
  letter-spacing:-.04em;
}
.section-head .eyebrow{
  margin:0 0 10px;
  text-transform:uppercase;
  letter-spacing:.16em;
  font-size:.94rem;
  font-weight:800;
  color:#db2f66;
}
.section-head p{margin:14px auto 0; max-width:820px}
.accent{color:var(--pink)}

.feature-row{
  display:grid; grid-template-columns:repeat(4,1fr); gap:0;
  border-top:1px solid rgba(255,255,255,.10); border-bottom:1px solid rgba(255,255,255,.10);
}
.feature{
  display:flex; gap:16px; padding:28px 22px; border-right:1px solid rgba(255,255,255,.10);
}
.feature:last-child{border-right:none}
.icon-round{
  width:74px; height:74px; flex:0 0 74px; border-radius:50%;
  display:grid; place-items:center; color:#fff; font-size:1.6rem;
  background:radial-gradient(circle at 30% 30%, #ff5aa2, #6a2bd8);
  box-shadow:0 12px 28px rgba(216,27,96,.25);
}
.feature h3{margin:2px 0 8px; font-size:1.1rem; line-height:1.18}
.feature p{margin:0; color:rgba(255,255,255,.78)}

.split{
  display:grid; grid-template-columns:1fr 1fr; gap:28px; align-items:stretch;
}
.single-focus{
  display:grid; grid-template-columns:1.02fr .98fr; gap:28px; align-items:center;
}
.copy-card{
  background:#fff; border:1px solid var(--line-light); border-radius:var(--radius);
  box-shadow:var(--shadow); padding:40px;
}
.copy-card.dark{
  background:linear-gradient(180deg,#08111f,#0f1b31);
  color:#fff;
  border:1px solid rgba(255,255,255,.08);
}
.copy-card h3{
  margin:0 0 14px;
  font-size:2rem;
  line-height:1.05;
  letter-spacing:-.03em;
}
.copy-card p{margin:0 0 16px; color:inherit}
.media-card{
  min-height:520px; border-radius:var(--radius); overflow:hidden; position:relative;
  box-shadow:var(--shadow-strong); background-size:cover; background-position:center center; background-repeat:no-repeat;
  transition:transform .35s ease, box-shadow .35s ease;
}
.media-card:hover{transform:translateY(-2px) scale(1.01)}
.media-card::before{
  content:""; position:absolute; inset:0;
  background:
    linear-gradient(90deg, rgba(5,7,12,.76), rgba(5,7,12,.22) 52%, rgba(5,7,12,.10)),
    radial-gradient(circle at 14% 18%, rgba(124,46,214,.14), transparent 28%);
}
.media-card.light-overlay::before{
  background:
    linear-gradient(90deg, rgba(5,7,12,.32), rgba(5,7,12,.10)),
    radial-gradient(circle at 14% 18%, rgba(124,46,214,.08), transparent 30%);
}
.media-card .content{
  position:relative; z-index:2; height:100%; padding:36px;
  display:flex; flex-direction:column; justify-content:flex-end; color:#fff;
}
.media-card .content h3{
  margin:0 0 12px;
  font-size:clamp(2rem,4vw,3rem);
  line-height:1.03;
  letter-spacing:-.04em;
}
.media-card .content p{margin:0; max-width:520px; color:rgba(255,255,255,.9)}

.bullets{display:grid; gap:14px; margin-top:18px}
.bullet{
  display:flex; gap:14px; padding:16px; border-radius:18px;
  background:#fbfbfd; border:1px solid #ecf0f6;
}
.copy-card.dark .bullet{
  background:rgba(255,255,255,.04);
  border-color:rgba(255,255,255,.08);
}
.bullet strong{display:block; margin-bottom:4px}

.cards{
  display:grid; grid-template-columns:repeat(3,1fr); gap:24px;
}
.card{
  background:#fff; border:1px solid var(--line-light); border-radius:24px;
  box-shadow:var(--shadow); overflow:hidden;
  transition:transform .22s ease, box-shadow .22s ease;
}
.card:hover{transform:translateY(-4px); box-shadow:0 28px 58px rgba(2,8,23,.16)}
.card .pad{padding:26px}
.card h3{margin:0 0 10px; font-size:1.55rem; line-height:1.08}
.card p{margin:0; color:var(--muted)}
.card.no-image .pad{padding:30px}
.two-stat{
  display:grid; grid-template-columns:1fr 1fr; gap:18px; margin-top:18px;
}
.stat-box{
  border-radius:22px; padding:24px;
  background:linear-gradient(180deg,#08111f,#10182c);
  color:#fff; border:1px solid rgba(255,255,255,.08);
}
.stat-box strong{display:block; font-size:1.8rem; line-height:1; margin-bottom:10px}

.cta-band{
  background:linear-gradient(90deg,#05070c,#1a102d 58%, #4d1232);
  color:#fff; border-radius:30px; overflow:hidden; box-shadow:var(--shadow-strong);
}
.cta-inner{
  display:grid; grid-template-columns:1.1fr .9fr; gap:28px;
  align-items:center; padding:44px 34px;
}
.cta-inner h2{
  margin:0 0 12px;
  font-size:clamp(2.1rem,4vw,3.3rem);
  line-height:1.05;
  letter-spacing:-.04em;
}
.contact-grid{
  display:grid; grid-template-columns:repeat(4,1fr);
  border-top:1px solid rgba(255,255,255,.12);
}
.contact-item{
  padding:22px 20px;
  border-right:1px solid rgba(255,255,255,.12);
}
.contact-item:last-child{border-right:none}
.contact-item h4{margin:0 0 6px; font-size:1rem}
.contact-item p{margin:0; color:rgba(255,255,255,.84)}

.footer{
  background:#000; color:#fff; padding-top:28px;
}
.footer-grid{
  display:grid; grid-template-columns:1.2fr .9fr .9fr; gap:28px;
  padding:28px 0 20px; border-top:1px solid rgba(255,255,255,.08);
}
.footer-grid p,.footer-grid a{color:rgba(255,255,255,.76)}
.footer-brand{display:flex; gap:18px; align-items:flex-start}
.footer-brand img{width:190px}
.copy{
  text-align:center;
  padding:14px 0 24px;
  border-top:1px solid rgba(255,255,255,.08);
  color:rgba(255,255,255,.7);
}

.section{animation:fadeUp .8s ease both}
@keyframes fadeUp{
  from{opacity:0; transform:translateY(18px)}
  to{opacity:1; transform:translateY(0)}
}

@media (max-width:1100px){
  .split,.single-focus,.cta-inner,.page-hero-grid{grid-template-columns:1fr}
  .cards,.feature-row,.contact-grid,.footer-grid{grid-template-columns:1fr 1fr}
  .hero{min-height:640px; background-position:center top}
  .hero-inner,.page-copy{padding:58px 0 42px}
}
@media (max-width:760px){
  .nav{flex-direction:column; padding:16px 0}
  .brand img{width:210px}
  .nav-links{justify-content:center; gap:18px}
  .cards,.feature-row,.contact-grid,.footer-grid{grid-template-columns:1fr}
  .feature,.contact-item{border-right:none; border-bottom:1px solid rgba(255,255,255,.10)}
  .feature:last-child,.contact-item:last-child{border-bottom:none}
  .copy-card{padding:30px}
  .media-card{min-height:360px}
  .hero{min-height:560px}
}


/* Final-final hero consistency */
.about-hero{
  background:
    linear-gradient(90deg, rgba(4,5,7,.82) 0%, rgba(4,5,7,.68) 26%, rgba(4,5,7,.40) 46%, rgba(4,5,7,.16) 65%, rgba(4,5,7,.05) 100%),
    radial-gradient(circle at 14% 22%, rgba(124,46,214,.24), transparent 26%),
    url('assets/community.jpg') center center / cover no-repeat;
}
.services-hero{
  background:
    linear-gradient(90deg, rgba(4,5,7,.82) 0%, rgba(4,5,7,.68) 26%, rgba(4,5,7,.40) 46%, rgba(4,5,7,.16) 65%, rgba(4,5,7,.05) 100%),
    radial-gradient(circle at 14% 22%, rgba(124,46,214,.24), transparent 26%),
    url('assets/support-hands.jpg') center center / cover no-repeat;
}
.involved-hero{
  background:
    linear-gradient(90deg, rgba(4,5,7,.82) 0%, rgba(4,5,7,.68) 26%, rgba(4,5,7,.40) 46%, rgba(4,5,7,.16) 65%, rgba(4,5,7,.05) 100%),
    radial-gradient(circle at 14% 22%, rgba(124,46,214,.24), transparent 26%),
    url('assets/support-action.jpg') center center / cover no-repeat;
}
.contact-hero{
  background:
    linear-gradient(90deg, rgba(4,5,7,.82) 0%, rgba(4,5,7,.68) 26%, rgba(4,5,7,.40) 46%, rgba(4,5,7,.16) 65%, rgba(4,5,7,.05) 100%),
    radial-gradient(circle at 14% 22%, rgba(124,46,214,.24), transparent 26%),
    url('assets/connection.jpg') center center / cover no-repeat;
}
.about-hero,.services-hero,.involved-hero,.contact-hero{
  min-height:520px;
  display:flex;
  align-items:center;
}
.hero h1, .page-copy h1{
  text-shadow: 0 10px 30px rgba(0,0,0,0.55);
}
.hero p, .page-copy p{
  text-shadow: 0 6px 20px rgba(0,0,0,0.45);
}


/* Hero image alignment fixes */
.hero,
.about-hero,
.services-hero,
.involved-hero,
.contact-hero{
  background-position: center center !important;
  background-size: cover !important;
  background-repeat: no-repeat !important;
}

.hero{
  min-height: 780px;
}

.hero-inner{
  max-width: 1240px;
}

.page-copy{
  max-width: 720px;
}

@media (min-width: 1400px){
  .hero,
  .about-hero,
  .services-hero,
  .involved-hero,
  .contact-hero{
    background-position: center 38% !important;
  }
}

@media (max-width: 1200px){
  .hero{
    min-height: 680px;
    background-position: center 28% !important;
  }
  .about-hero,
  .services-hero,
  .involved-hero,
  .contact-hero{
    min-height: 500px;
    background-position: center 28% !important;
  }
}

@media (max-width: 900px){
  .hero{
    min-height: 580px;
    background-position: center 20% !important;
  }
  .about-hero,
  .services-hero,
  .involved-hero,
  .contact-hero{
    min-height: 430px;
    background-position: center 18% !important;
  }
  .hero-inner,
  .page-copy{
    padding-top: 54px !important;
    padding-bottom: 54px !important;
  }
}

@media (max-width: 640px){
  .hero{
    min-height: 500px;
    background-position: center 16% !important;
  }
  .about-hero,
  .services-hero,
  .involved-hero,
  .contact-hero{
    min-height: 380px;
    background-position: center 14% !important;
  }
  .hero h1,
  .page-copy h1{
    font-size: clamp(2.35rem, 9vw, 3.4rem) !important;
    line-height: .98 !important;
  }
  .hero p,
  .page-copy p{
    font-size: 1rem !important;
    max-width: 100% !important;
  }
}

/* Slightly calmer image cards */
.media-card{
  background-position: center center !important;
}
