/* ============ Bafana Bafana Welcome Home Portal ============ */

:root{
  --gold:#FFB612;
  --gold-deep:#E9A200;
  --green:#00843D;
  --green-deep:#00552A;
  --red:#DE3831;
  --blue:#001489;
  --black:#0a0b0a;
  --black-2:#121410;
  --charcoal:#181b16;
  --white:#f7f7f2;
  --off:#c9cdc2;
  --font-display: 'Anton', 'Bebas Neue', sans-serif;
  --font-body: 'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
  --max: 1180px;
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  margin:0;
  background:var(--black);
  color:var(--white);
  font-family:var(--font-body);
  overflow-x:hidden;
}
img{max-width:100%;display:block;}
a{color:inherit;text-decoration:none;}
h1,h2,h3{font-family:var(--font-display);font-weight:400;letter-spacing:.02em;margin:0;}
p{line-height:1.7;color:var(--off);}
.outline{
  color:transparent;
  -webkit-text-stroke:2px var(--gold);
}

/* subtle grain overlay for texture */
.grain{
  position:fixed;inset:0;pointer-events:none;z-index:9998;opacity:.05;mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='120' height='120'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
}

/* ============ NAV ============ */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:200;
  background:linear-gradient(to bottom, rgba(10,11,10,.85), transparent);
  backdrop-filter:blur(2px);
  transition:background .3s ease, box-shadow .3s ease;
}
.nav.scrolled{
  background:rgba(10,11,10,.92);
  box-shadow:0 2px 24px rgba(0,0,0,.4);
  backdrop-filter:blur(10px);
}
.nav-inner{
  max-width:var(--max);margin:0 auto;padding:16px 24px;
  display:flex;align-items:center;justify-content:space-between;gap:24px;
}
.brand{display:flex;gap:6px;font-family:var(--font-display);font-size:1.25rem;letter-spacing:.03em;}
.brand-mark{color:var(--gold);}
.brand-mark.alt{color:var(--green);}
.nav-links{display:flex;gap:28px;font-size:.92rem;font-weight:600;}
.nav-links a{color:var(--off);transition:color .2s;position:relative;}
.nav-links a:hover{color:var(--gold);}
.nav-cta{
  background:var(--gold);color:var(--black);font-weight:700;font-size:.88rem;
  padding:10px 20px;border-radius:999px;white-space:nowrap;transition:transform .2s, background .2s;
}
.nav-cta:hover{background:var(--white);transform:translateY(-1px);}

@media (max-width:760px){
  .nav-links{display:none;}
}

/* ============ HERO ============ */
.hero{
  position:relative;min-height:100vh;display:flex;flex-direction:column;justify-content:center;
  overflow:hidden;padding:140px 24px 60px;
}
.hero-bg{
  position:absolute;inset:0;background-size:cover;background-position:center 20%;
  transform:scale(1.08);filter:saturate(1.05) contrast(1.05);
  animation:slowzoom 24s ease-in-out infinite alternate;
}
@keyframes slowzoom{from{transform:scale(1.08);}to{transform:scale(1.16);}}
.hero-scrim{
  position:absolute;inset:0;
  background:
    linear-gradient(180deg, rgba(6,7,6,.55) 0%, rgba(6,7,6,.35) 30%, rgba(6,7,6,.75) 75%, var(--black) 100%),
    linear-gradient(100deg, rgba(0,85,42,.55) 0%, rgba(6,7,6,.2) 45%, rgba(222,56,49,.28) 100%);
}
.hero-content{position:relative;z-index:2;max-width:var(--max);margin:0 auto;width:100%;text-align:left;}
.eyebrow{
  color:var(--gold);text-transform:uppercase;letter-spacing:.18em;font-size:.78rem;font-weight:700;margin:0 0 14px;
}
.hero-title{
  font-size:clamp(3.2rem, 10vw, 7.5rem);line-height:.92;color:var(--white);
  text-shadow:0 6px 40px rgba(0,0,0,.5);
}
.hero-title span{display:block;}
.hero-sub{
  max-width:600px;font-size:1.08rem;margin:22px 0 30px;color:var(--white);opacity:.9;
}
.hero-sub strong{color:var(--gold);}
.hero-actions{display:flex;gap:16px;flex-wrap:wrap;}
.btn{
  display:inline-block;padding:15px 30px;border-radius:999px;font-weight:700;font-size:.95rem;
  transition:transform .2s ease, box-shadow .2s ease, background .2s ease;
}
.btn-gold{background:var(--gold);color:var(--black);box-shadow:0 8px 24px rgba(255,182,18,.25);}
.btn-gold:hover{transform:translateY(-2px);box-shadow:0 12px 30px rgba(255,182,18,.4);}
.btn-ghost{border:1.5px solid rgba(255,255,255,.5);color:var(--white);}
.btn-ghost:hover{border-color:var(--gold);color:var(--gold);}

.hero-stats{
  position:relative;z-index:2;max-width:var(--max);margin:56px auto 0;width:100%;
  display:grid;grid-template-columns:repeat(4,1fr);gap:20px;
  border-top:1px solid rgba(255,255,255,.15);padding-top:28px;
}
.stat{display:flex;flex-direction:column;gap:4px;}
.stat-num{font-family:var(--font-display);font-size:2.2rem;color:var(--gold);}
.stat-label{font-size:.8rem;color:var(--off);line-height:1.4;}
@media (max-width:760px){
  .hero-stats{grid-template-columns:repeat(2,1fr);}
  .hero{padding-top:110px;}
}

.scroll-cue{
  position:absolute;bottom:22px;left:50%;transform:translateX(-50%);z-index:2;
  width:26px;height:42px;border:2px solid rgba(255,255,255,.5);border-radius:20px;
}
.scroll-cue span{
  position:absolute;top:6px;left:50%;transform:translateX(-50%);width:4px;height:8px;
  background:var(--gold);border-radius:2px;animation:cue 1.6s infinite;
}
@keyframes cue{0%{opacity:1;top:6px;}100%{opacity:0;top:22px;}}

/* ============ TICKER ============ */
.ticker{
  background:var(--gold);color:var(--black);overflow:hidden;white-space:nowrap;
  border-top:3px solid var(--black);border-bottom:3px solid var(--black);
}
.ticker-track{
  display:inline-flex;gap:48px;padding:12px 0;animation:tick 160s linear infinite;
  font-weight:700;font-size:.88rem;text-transform:uppercase;letter-spacing:.03em;
}
.ticker-track span{display:inline-flex;align-items:center;gap:48px;}
.ticker-track .dot{color:var(--red);font-size:1.1rem;}
@keyframes tick{from{transform:translateX(0);}to{transform:translateX(-50%);}}

/* ============ SECTION HEAD ============ */
.section-head{max-width:680px;margin:0 auto 48px;text-align:center;padding:0 24px;}
.section-head h2{font-size:clamp(2.1rem,5vw,3.2rem);margin:8px 0 14px;color:var(--white);}
.section-sub{font-size:1rem;}

/* ============ JOURNEY / TIMELINE ============ */
.journey{padding:110px 24px 100px;background:
  radial-gradient(ellipse at 20% 0%, rgba(0,132,61,.18), transparent 55%),
  radial-gradient(ellipse at 85% 100%, rgba(222,56,49,.12), transparent 50%),
  var(--black);}
.timeline{max-width:820px;margin:0 auto;position:relative;}
.timeline::before{
  content:"";position:absolute;left:24px;top:8px;bottom:8px;width:2px;
  background:linear-gradient(to bottom, var(--gold), var(--green), var(--red));
  opacity:.5;
}
@media(min-width:761px){.timeline::before{left:50%;margin-left:-1px;}}

.tl-item{
  position:relative;padding:0 0 56px 64px;
}
@media(min-width:761px){
  .tl-item{width:50%;padding:0 48px 64px 0;}
  .tl-item:nth-child(even){margin-left:50%;padding:0 0 64px 48px;}
}
.tl-item::before{
  content:"";position:absolute;left:16px;top:4px;width:18px;height:18px;border-radius:50%;
  background:var(--black);border:3px solid var(--gold);z-index:2;
}
@media(min-width:761px){
  .tl-item::before{left:auto;right:-9px;}
  .tl-item:nth-child(even)::before{left:-9px;right:auto;}
}
.tl-phase{color:var(--gold);font-weight:800;font-size:.72rem;text-transform:uppercase;letter-spacing:.14em;margin-bottom:8px;display:block;}
.tl-card{
  background:var(--charcoal);border:1px solid rgba(255,255,255,.06);border-radius:16px;padding:22px 24px;
  box-shadow:0 10px 30px rgba(0,0,0,.25);
}
.tl-card h3{font-size:1.25rem;color:var(--white);margin-bottom:10px;line-height:1.2;font-family:var(--font-body);font-weight:800;}
.tl-card p{font-size:.92rem;margin:0;}

/* ============ ARTICLES ============ */
.articles{padding:100px 24px;background:var(--black-2);}
.filter-row{
  max-width:var(--max);margin:0 auto 36px;display:flex;gap:10px;flex-wrap:wrap;justify-content:center;
}
.filter-btn{
  padding:9px 18px;border-radius:999px;border:1px solid rgba(255,255,255,.18);
  background:transparent;color:var(--off);font-size:.85rem;font-weight:600;cursor:pointer;
  transition:all .2s ease;font-family:var(--font-body);
}
.filter-btn:hover{border-color:var(--gold);color:var(--gold);}
.filter-btn.active{background:var(--gold);color:var(--black);border-color:var(--gold);}

.articles-grid{
  max-width:var(--max);margin:0 auto;display:grid;
  grid-template-columns:repeat(3,1fr);gap:28px;
}
@media(max-width:980px){.articles-grid{grid-template-columns:repeat(2,1fr);}}
@media(max-width:640px){.articles-grid{grid-template-columns:1fr;}}

.card{
  background:var(--charcoal);border-radius:18px;overflow:hidden;cursor:pointer;
  border:1px solid rgba(255,255,255,.06);
  transition:transform .3s ease, box-shadow .3s ease, border-color .3s ease;
  display:flex;flex-direction:column;
}
.card:hover{transform:translateY(-6px);box-shadow:0 20px 40px rgba(0,0,0,.4);border-color:rgba(255,182,18,.35);}
.card-media{position:relative;aspect-ratio:16/10;overflow:hidden;background:#000;}
.card-media img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease;}
.card:hover .card-media img{transform:scale(1.07);}
.card-tag{
  position:absolute;top:14px;left:14px;padding:6px 14px;border-radius:999px;
  font-size:.7rem;font-weight:800;text-transform:uppercase;letter-spacing:.06em;color:var(--black);
}
.card-tag.gold{background:var(--gold);}
.card-tag.green{background:var(--green);color:var(--white);}
.card-tag.red{background:var(--red);color:var(--white);}
.card-tag.blue{background:#1a3fcf;color:var(--white);}
.card-body{padding:22px 22px 24px;flex:1;display:flex;flex-direction:column;}
.card-date{font-size:.72rem;color:var(--gold);font-weight:700;text-transform:uppercase;letter-spacing:.08em;margin-bottom:10px;}
.card h3{font-size:1.12rem;color:var(--white);line-height:1.32;margin-bottom:10px;font-family:var(--font-body);font-weight:800;}
.card p{font-size:.87rem;margin:0 0 16px;flex:1;
  display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;}
.card-read{font-size:.82rem;font-weight:700;color:var(--gold);display:flex;align-items:center;gap:6px;}
.card-read::after{content:"→";transition:transform .2s;}
.card:hover .card-read::after{transform:translateX(4px);}

/* ============ GALLERY ============ */
.gallery{padding:100px 24px;background:var(--black);}
.gallery-grid{
  max-width:var(--max);margin:0 auto;display:grid;
  grid-template-columns:repeat(4,1fr);grid-auto-rows:170px;gap:14px;
}
.gallery-grid figure{
  margin:0;position:relative;overflow:hidden;border-radius:12px;cursor:pointer;background:#000;
}
.gallery-grid img{width:100%;height:100%;object-fit:cover;transition:transform .45s ease, filter .3s ease;filter:saturate(.92);}
.gallery-grid figure:hover img{transform:scale(1.08);filter:saturate(1.1);}
.gallery-grid figure::after{
  content:"";position:absolute;inset:0;background:linear-gradient(to top, rgba(0,0,0,.55), transparent 45%);
  opacity:0;transition:opacity .3s;
}
.gallery-grid figure:hover::after{opacity:1;}
.gallery-grid figcaption{
  position:absolute;left:12px;right:12px;bottom:10px;font-size:.76rem;font-weight:600;color:var(--white);
  opacity:0;transform:translateY(6px);transition:all .3s;z-index:1;
}
.gallery-grid figure:hover figcaption{opacity:1;transform:translateY(0);}
.gallery-grid figure.tall{grid-row:span 2;}
.gallery-grid figure.wide{grid-column:span 2;}

@media(max-width:900px){
  .gallery-grid{grid-template-columns:repeat(2,1fr);grid-auto-rows:150px;}
  .gallery-grid figure.wide{grid-column:span 2;}
}

/* ============ CLOSING BANNER ============ */
.closing{
  padding:130px 24px;text-align:center;position:relative;overflow:hidden;
  background:
    radial-gradient(ellipse at 50% 0%, rgba(255,182,18,.15), transparent 60%),
    linear-gradient(135deg, var(--green-deep), var(--black) 60%);
}
.closing-inner h2{font-size:clamp(2.6rem,8vw,5rem);color:var(--white);}
.closing-inner p{font-size:1.1rem;max-width:480px;margin:18px auto 34px;}
.flag-bar{
  height:8px;width:220px;margin:0 auto;border-radius:6px;overflow:hidden;
  background:linear-gradient(90deg, var(--red) 0 20%, var(--white) 20% 25%, var(--blue) 25% 45%, var(--white) 45% 50%, var(--green) 50% 75%, var(--gold) 75% 100%);
}

/* ============ FOOTER ============ */
.footer{background:var(--black-2);padding:70px 24px 24px;border-top:1px solid rgba(255,255,255,.06);}
.footer-inner{
  max-width:var(--max);margin:0 auto;display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:40px;
}
.footer-brand p{margin-top:14px;font-size:.86rem;max-width:280px;}
.footer-col h4{color:var(--gold);font-size:.85rem;text-transform:uppercase;letter-spacing:.08em;margin-bottom:16px;}
.footer-col p{font-size:.85rem;}
.footer-col a{display:block;font-size:.88rem;color:var(--off);margin-bottom:10px;transition:color .2s;}
.footer-col a:hover{color:var(--gold);}
.footer-col code{background:rgba(255,255,255,.08);padding:1px 6px;border-radius:4px;font-size:.8em;}
.footer-bottom{
  max-width:var(--max);margin:50px auto 0;padding-top:20px;border-top:1px solid rgba(255,255,255,.06);
}
.footer-bottom p{font-size:.76rem;color:#777;}
@media(max-width:760px){.footer-inner{grid-template-columns:1fr;}}

/* ============ MODAL ============ */
.modal-overlay{
  position:fixed;inset:0;z-index:500;background:rgba(4,5,4,.88);backdrop-filter:blur(6px);
  display:none;align-items:flex-start;justify-content:center;padding:60px 20px;overflow-y:auto;
}
.modal-overlay.open{display:flex;}
.modal{
  background:var(--charcoal);max-width:720px;width:100%;border-radius:20px;position:relative;
  border:1px solid rgba(255,255,255,.08);box-shadow:0 30px 80px rgba(0,0,0,.6);
  animation:modalIn .3s ease;
}
@keyframes modalIn{from{opacity:0;transform:translateY(18px);}to{opacity:1;transform:translateY(0);}}
.modal-close{
  position:absolute;top:16px;right:16px;z-index:5;width:38px;height:38px;border-radius:50%;
  background:rgba(0,0,0,.5);color:var(--white);border:none;font-size:1.4rem;cursor:pointer;
  display:flex;align-items:center;justify-content:center;transition:background .2s;
}
.modal-close:hover{background:var(--red);}
.modal-scroll img{width:100%;aspect-ratio:16/9;object-fit:cover;border-radius:20px 20px 0 0;}
.modal-body{padding:34px 38px 42px;}
.modal-tag{display:inline-block;padding:5px 14px;border-radius:999px;font-size:.7rem;font-weight:800;text-transform:uppercase;color:var(--black);margin-bottom:16px;}
.modal-body h2{font-family:var(--font-body);font-weight:800;font-size:1.6rem;line-height:1.3;color:var(--white);margin-bottom:10px;}
.modal-meta{font-size:.8rem;color:var(--gold);font-weight:700;margin-bottom:22px;text-transform:uppercase;letter-spacing:.06em;}
.modal-body p{color:var(--off);font-size:1rem;margin-bottom:18px;}
.modal-source{
  margin-top:26px;padding-top:22px;border-top:1px solid rgba(255,255,255,.08);
  display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;
}
.modal-source a{
  background:var(--gold);color:var(--black);padding:11px 22px;border-radius:999px;font-weight:700;font-size:.86rem;
}
.modal-source span{font-size:.78rem;color:#888;}

/* ============ LIGHTBOX ============ */
.lightbox{
  position:fixed;inset:0;z-index:600;background:rgba(2,2,2,.95);display:none;
  align-items:center;justify-content:center;flex-direction:column;padding:40px;
}
.lightbox.open{display:flex;}
.lightbox img{max-width:90vw;max-height:80vh;border-radius:10px;box-shadow:0 20px 60px rgba(0,0,0,.6);}
.lightbox p{color:var(--off);margin-top:16px;font-size:.9rem;}
.lightbox-close{
  position:absolute;top:24px;right:28px;background:none;border:none;color:var(--white);font-size:2rem;cursor:pointer;
}

/* ============ REVEAL ANIMATION ============ */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .7s ease, transform .7s ease;}
.reveal.visible{opacity:1;transform:translateY(0);}
