/* ============================================================
   SALA — South African Legacy Association
   Modern static website · design system
   ============================================================ */
:root{
  --bg:#f7f6f2; --bg-2:#efece4; --paper:#ffffff; --dk:#0c0c12; --dk-2:#14141d;
  --ink:#16161b; --ink-soft:#3c3c44; --muted:#74716a;
  --gold:#b8901f; --gold-2:#caa233; --gold-3:#e7c659; --gold-deep:#8a6c14;
  --green:#1f8a4c; --blue:#1d4ed8; --red:#c62f2b;
  --line:rgba(184,144,31,.30); --line-soft:rgba(20,20,26,.08);
  --shadow-sm:0 6px 18px rgba(20,20,26,.06);
  --shadow:0 18px 44px rgba(20,20,26,.12);
  --shadow-lg:0 30px 70px rgba(20,20,26,.18);
  --serif:'Playfair Display',Georgia,serif;
  --sans:'Montserrat','Helvetica Neue',sans-serif;
  --maxw:1180px;
  --r:18px;
}
*{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  font-family:var(--sans); background:var(--bg); color:var(--ink);
  -webkit-font-smoothing:antialiased; line-height:1.6; overflow-x:hidden;
}
img{max-width:100%;display:block;}
a{color:inherit;text-decoration:none;}
.container{max-width:var(--maxw); margin:0 auto; padding:0 24px;}
.serif{font-family:var(--serif);}

/* ---------- typography helpers ---------- */
h1,h2,h3,h4{font-family:var(--serif); font-weight:800; line-height:1.05; color:var(--ink);}
.eyebrow{font-family:var(--sans); letter-spacing:.38em; text-transform:uppercase; font-size:11px; font-weight:700; color:var(--gold-deep);}
.eyebrow .line{display:inline-block; width:44px; height:2px; background:linear-gradient(90deg,var(--gold),transparent); vertical-align:middle; margin-right:12px;}
.section{padding:96px 0;}
.section-head{max-width:720px; margin-bottom:54px;}
.section-head h2{font-size:clamp(30px,4vw,46px); margin:14px 0 16px;}
.section-head p{font-size:16px; color:var(--muted); line-height:1.8;}
.center{text-align:center; margin-left:auto; margin-right:auto;}
.flag-rule{height:3px; width:120px; border-radius:2px; background:
  linear-gradient(90deg,#222 0 12%, var(--gold) 12% 30%, var(--green) 30% 46%, #fff 46% 54%, var(--blue) 54% 70%, var(--red) 70% 88%, #222 88% 100%);}

/* ---------- buttons ---------- */
.btn{display:inline-flex; align-items:center; gap:9px; padding:14px 26px; border-radius:40px;
  font-weight:700; font-size:14px; letter-spacing:.02em; transition:.25s; cursor:pointer; border:1.5px solid transparent;}
.btn-gold{background:linear-gradient(90deg,var(--gold-2),var(--gold)); color:#1a1408; box-shadow:0 10px 26px rgba(184,144,31,.32);}
.btn-gold:hover{transform:translateY(-2px); box-shadow:0 16px 34px rgba(184,144,31,.42);}
.btn-ghost{border-color:var(--line); color:var(--ink); background:rgba(255,255,255,.5);}
.btn-ghost:hover{border-color:var(--gold); background:#fff; transform:translateY(-2px);}
.btn-light{background:#fff; color:var(--ink); box-shadow:var(--shadow-sm);}
.btn-light:hover{transform:translateY(-2px); box-shadow:var(--shadow);}

/* ---------- header / nav ---------- */
.nav{position:fixed; top:0; left:0; right:0; z-index:100; transition:.3s;
  padding:18px 0; background:transparent;}
.nav.scrolled{background:rgba(247,246,242,.86); backdrop-filter:blur(14px); padding:12px 0;
  box-shadow:0 6px 24px rgba(20,20,26,.07); border-bottom:1px solid var(--line-soft);}
.nav-inner{display:flex; align-items:center; justify-content:space-between;}
.brand{display:flex; align-items:center; gap:12px; font-family:var(--serif); font-weight:800; font-size:19px; color:#fff;}
.nav.scrolled .brand{color:var(--ink);}
.brand img{height:68px; width:auto;}
.brand .bt small{display:block; font-family:var(--sans); font-weight:600; font-size:9px; letter-spacing:.18em; text-transform:uppercase; opacity:.7;}
.nav-links{display:flex; align-items:center; gap:34px; list-style:none;}
.nav-links a{font-size:14px; font-weight:600; color:rgba(255,255,255,.92); transition:.2s; position:relative;}
.nav.scrolled .nav-links a{color:var(--ink-soft);}
.nav-links a::after{content:""; position:absolute; left:0; bottom:-6px; width:0; height:2px; background:var(--gold); transition:.25s;}
.nav-links a:hover::after, .nav-links a.active::after{width:100%;}
.nav-links a:hover{color:var(--gold-3);}
.nav.scrolled .nav-links a:hover{color:var(--gold-deep);}
.nav-cta{padding:10px 20px; border-radius:30px; background:linear-gradient(90deg,var(--gold-2),var(--gold)); color:#1a1408 !important; font-weight:700;}
.nav-cta::after{display:none;}
.burger{display:none; flex-direction:column; gap:5px; cursor:pointer; background:none; border:none; padding:6px;}
.burger span{width:26px; height:2.5px; background:#fff; border-radius:2px; transition:.3s;}
.nav.scrolled .burger span{background:var(--ink);}

/* ---------- hero ---------- */
.hero{position:relative; min-height:100vh; display:flex; align-items:center; overflow:hidden;
  background:var(--dk); color:#fff;}
.hero-bg{position:absolute; inset:0; z-index:0;}
.hero-bg img{width:100%; height:100%; object-fit:cover; object-position:center 28%;}
.hero-bg::after{content:""; position:absolute; inset:0;
  background:linear-gradient(110deg, rgba(8,8,14,.5) 0%, rgba(8,8,14,.28) 40%, rgba(8,8,14,.08) 70%, rgba(8,8,14,0) 100%);}
.hero-waves{position:absolute; top:0; right:0; height:100%; width:46%; z-index:1; opacity:.85; pointer-events:none;}
.hero-inner{position:relative; z-index:2; padding-top:90px;}
.hero .eyebrow{color:var(--gold-3);}
.hero h1{font-size:clamp(42px,7vw,86px); color:#fff; letter-spacing:-1px; margin:20px 0; text-shadow:0 2px 24px rgba(0,0,0,.55);}
.hero h1 .g{color:var(--gold-3);}
.hero .lead{font-size:clamp(16px,2vw,20px); color:#f1eee6; max-width:560px; line-height:1.7; font-weight:300; text-shadow:0 1px 14px rgba(0,0,0,.6);}
.hero-cta{display:flex; gap:14px; margin-top:36px; flex-wrap:wrap;}
.hero-stats{display:flex; gap:40px; margin-top:54px; flex-wrap:wrap;}
.hero-stats .s .n{font-family:var(--serif); font-weight:800; font-size:40px; color:var(--gold-3); line-height:1;}
.hero-stats .s .l{font-size:11px; letter-spacing:.14em; text-transform:uppercase; color:#bdb9af; margin-top:6px;}
.scroll-hint{position:absolute; bottom:28px; left:50%; transform:translateX(-50%); z-index:2;
  font-size:10px; letter-spacing:.3em; text-transform:uppercase; color:rgba(255,255,255,.6); display:flex; flex-direction:column; align-items:center; gap:10px;}
.scroll-hint .dot{width:24px; height:38px; border:1.5px solid rgba(255,255,255,.4); border-radius:14px; position:relative;}
.scroll-hint .dot::after{content:""; position:absolute; top:7px; left:50%; transform:translateX(-50%); width:4px; height:7px; background:var(--gold-3); border-radius:2px; animation:scrolldot 1.6s infinite;}
@keyframes scrolldot{0%{opacity:0;top:7px}40%{opacity:1}80%{opacity:0;top:18px}100%{opacity:0}}

/* ---------- decorative waves (light sections) ---------- */
.wave-deco{position:absolute; pointer-events:none; opacity:.5; z-index:0;}

/* ---------- intro / about strip ---------- */
.intro{position:relative; background:var(--bg); overflow:hidden;}
.intro-grid{display:grid; grid-template-columns:1.05fr .95fr; gap:60px; align-items:center;}
.intro-photo{position:relative; border-radius:var(--r); overflow:hidden; box-shadow:var(--shadow-lg); aspect-ratio:4/3;}
.intro-photo img{width:100%;height:100%;object-fit:cover;}
.intro-photo .badge{position:absolute; bottom:18px; left:18px; background:rgba(255,255,255,.95); backdrop-filter:blur(6px); border-radius:14px; padding:14px 20px; box-shadow:var(--shadow);}
.intro-photo .badge .n{font-family:var(--serif); font-weight:800; font-size:26px; color:var(--gold-deep); line-height:1;}
.intro-photo .badge .l{font-size:10px; letter-spacing:.12em; text-transform:uppercase; color:var(--muted); margin-top:3px;}
.intro p{font-size:16px; color:var(--ink-soft); line-height:1.9; margin-top:18px;}
.intro p strong{color:var(--gold-deep);}

/* ---------- cards / grids ---------- */
.grid{display:grid; gap:24px;}
.grid-3{grid-template-columns:repeat(3,1fr);}
.grid-2{grid-template-columns:repeat(2,1fr);}
.grid-4{grid-template-columns:repeat(4,1fr);}
.card{background:var(--paper); border:1px solid var(--line-soft); border-radius:var(--r); padding:32px;
  box-shadow:var(--shadow-sm); transition:.3s; position:relative; overflow:hidden;}
.card:hover{transform:translateY(-6px); box-shadow:var(--shadow); border-color:var(--line);}
.card .ic{width:54px; height:54px; border-radius:14px; display:flex; align-items:center; justify-content:center;
  background:radial-gradient(circle at 30% 30%, rgba(184,144,31,.22), rgba(184,144,31,.05)); border:1px solid var(--line); margin-bottom:20px;}
.card .ic svg{width:26px; height:26px; stroke:var(--gold-deep); fill:none; stroke-width:1.7;}
.card h3{font-size:21px; margin-bottom:10px;}
.card p{font-size:14px; color:var(--muted); line-height:1.75;}
.card .num-tag{position:absolute; top:22px; right:26px; font-family:var(--serif); font-weight:800; font-size:34px; color:rgba(184,144,31,.16);}

/* ---------- objectives feature ---------- */
.obj-card{display:flex; gap:20px; align-items:flex-start;}
.obj-card .ic{flex:0 0 auto; margin-bottom:0;}

/* ---------- pipeline ---------- */
.pipeline{display:grid; grid-template-columns:repeat(5,1fr); gap:16px; position:relative;}
.pstep{background:var(--paper); border:1px solid var(--line-soft); border-radius:16px; padding:26px 20px; text-align:center; box-shadow:var(--shadow-sm); position:relative; transition:.3s;}
.pstep:hover{transform:translateY(-6px); box-shadow:var(--shadow);}
.pstep .pn{font-family:var(--serif); font-weight:800; font-size:40px; color:var(--gold-3); line-height:1;}
.pstep h4{font-size:16px; margin:10px 0 8px;}
.pstep p{font-size:12px; color:var(--muted); line-height:1.6;}

/* ---------- programmes ---------- */
.prog-card{position:relative; border-radius:var(--r); overflow:hidden; min-height:360px; display:flex; align-items:flex-end; box-shadow:var(--shadow); transition:.35s;}
.prog-card img{position:absolute; inset:0; width:100%; height:100%; object-fit:cover; transition:.6s; z-index:0;}
.prog-card:hover img{transform:scale(1.06);}
.prog-card::after{content:""; position:absolute; inset:0; background:linear-gradient(0deg, rgba(8,8,12,.92) 0%, rgba(8,8,12,.5) 45%, rgba(8,8,12,.08) 100%); z-index:1;}
.prog-card .pc-body{position:relative; z-index:2; padding:30px; color:#fff;}
.prog-card .pc-tag{font-family:var(--serif); font-weight:800; font-size:38px; color:var(--gold-3); line-height:.9;}
.prog-card h3{color:#fff; font-size:23px; margin:6px 0 8px;}
.prog-card p{font-size:13.5px; color:#e2ddd2; line-height:1.65;}

/* ---------- values ---------- */
.val-card{background:var(--paper); border:1px solid var(--line-soft); border-radius:16px; padding:28px; box-shadow:var(--shadow-sm); transition:.3s;}
.val-card:hover{transform:translateY(-5px); box-shadow:var(--shadow);}
.val-card .msg{font-size:13px; font-style:italic; color:var(--gold-deep); margin:8px 0 10px; line-height:1.5;}
.val-card p{font-size:13px; color:var(--muted); line-height:1.7;}

/* ---------- team ---------- */
.team-card{text-align:center;}
.team-ph{width:160px; height:160px; border-radius:50%; margin:0 auto 18px; padding:4px;
  background:conic-gradient(from 140deg, var(--gold-3), var(--gold-deep), var(--blue), var(--gold-3)); transition:.3s;}
.team-card:hover .team-ph{transform:scale(1.05) rotate(-2deg);}
.team-ph img{width:100%; height:100%; border-radius:50%; object-fit:cover; border:4px solid var(--bg);}
.team-card h4{font-size:18px;}
.team-card .role{font-size:11px; letter-spacing:.12em; text-transform:uppercase; color:var(--gold-deep); margin-top:5px; font-weight:600;}
.team-card .bio{font-size:12.5px; color:var(--muted); margin-top:12px; line-height:1.7;}

/* ---------- impact band ---------- */
.impact{background:linear-gradient(135deg, var(--dk) 0%, var(--dk-2) 100%); color:#fff; position:relative; overflow:hidden;}
.impact .grid-4{position:relative; z-index:2;}
.impact .imp{text-align:center;}
.impact .imp .n{font-family:var(--serif); font-weight:800; font-size:clamp(40px,5vw,58px); color:var(--gold-3); line-height:1;}
.impact .imp .l{font-size:12px; letter-spacing:.1em; text-transform:uppercase; color:#bdb9af; margin-top:10px;}

/* ---------- CTA band ---------- */
.cta-band{background:linear-gradient(90deg,var(--gold-2),var(--gold)); color:#1a1408; text-align:center; padding:70px 0;}
.cta-band h2{color:#1a1408; font-size:clamp(28px,4vw,42px);}
.cta-band p{font-size:16px; color:#3a2f10; margin:14px 0 28px;}

/* ---------- footer ---------- */
.footer{background:var(--dk); color:#cdc9bf; padding:70px 0 30px; position:relative; overflow:hidden;}
.footer-grid{display:grid; grid-template-columns:1.6fr 1fr 1fr 1.2fr; gap:40px; position:relative; z-index:2;}
.footer .brand{color:#fff; margin-bottom:18px;}
.footer p{font-size:13.5px; line-height:1.8; color:#a9a59b;}
.footer h5{color:#fff; font-family:var(--sans); font-size:12px; letter-spacing:.16em; text-transform:uppercase; margin-bottom:18px;}
.footer ul{list-style:none;}
.footer ul li{margin-bottom:11px;}
.footer ul a{font-size:13.5px; color:#a9a59b; transition:.2s;}
.footer ul a:hover{color:var(--gold-3); padding-left:4px;}
.footer-social{display:flex; gap:12px; margin-top:6px;}
.footer-social a{width:40px; height:40px; border-radius:50%; border:1px solid rgba(255,255,255,.16); display:flex; align-items:center; justify-content:center; transition:.25s;}
.footer-social a:hover{background:var(--gold); border-color:var(--gold); transform:translateY(-3px);}
.footer-social svg{width:17px; height:17px; fill:#cdc9bf;}
.footer-social a:hover svg{fill:#1a1408;}
.footer-bottom{border-top:1px solid rgba(255,255,255,.1); margin-top:48px; padding-top:24px; display:flex; justify-content:space-between; flex-wrap:wrap; gap:10px; font-size:12px; color:#7f7b72; position:relative; z-index:2;}

/* ---------- page hero (sub pages) ---------- */
.page-hero{background:linear-gradient(135deg,var(--dk),var(--dk-2)); color:#fff; padding:160px 0 80px; position:relative; overflow:hidden;}
.page-hero h1{color:#fff; font-size:clamp(36px,5vw,60px);}
.page-hero p{color:#cfcabf; font-size:17px; max-width:560px; margin-top:16px; line-height:1.7;}
.page-hero .eyebrow{color:var(--gold-3);}
.breadcrumb{font-size:12px; color:#8d897f; margin-top:20px; letter-spacing:.04em;}
.breadcrumb a:hover{color:var(--gold-3);}

/* ---------- entrepreneurs table ---------- */
.ent-table{width:100%; border-collapse:collapse; background:var(--paper); border-radius:var(--r); overflow:hidden; box-shadow:var(--shadow-sm);}
.ent-table th{text-align:left; font-size:11px; letter-spacing:.12em; text-transform:uppercase; color:#fff; padding:16px 20px; background:linear-gradient(90deg,var(--gold),var(--gold-deep)); font-weight:700;}
.ent-table td{padding:18px 20px; border-bottom:1px solid var(--line-soft); font-size:14px; color:var(--ink-soft); vertical-align:top;}
.ent-table tr:last-child td{border-bottom:none;}
.ent-table tr:nth-child(even) td{background:rgba(184,144,31,.03);}
.ent-table .bn{font-weight:700; color:var(--gold-deep);}

/* ---------- regions ---------- */
.reg-chip{display:flex; align-items:center; gap:14px; background:var(--paper); border:1px solid var(--line-soft); border-radius:14px; padding:20px; box-shadow:var(--shadow-sm); transition:.3s;}
.reg-chip:hover{transform:translateY(-4px); box-shadow:var(--shadow); border-color:var(--line);}
.reg-chip svg{width:24px; height:24px; stroke:var(--gold-deep); fill:none; stroke-width:1.6;}
.reg-chip h4{font-size:17px;}
.reg-chip span{font-size:10px; letter-spacing:.1em; text-transform:uppercase; color:var(--muted);}

/* ---------- contact ---------- */
.contact-grid{display:grid; grid-template-columns:1fr 1fr; gap:48px;}
.contact-item{display:flex; gap:18px; align-items:flex-start; margin-bottom:26px;}
.contact-item .ic{flex:0 0 auto; width:48px; height:48px; border-radius:12px; display:flex; align-items:center; justify-content:center; background:radial-gradient(circle at 30% 30%, rgba(184,144,31,.2), rgba(184,144,31,.04)); border:1px solid var(--line);}
.contact-item .ic svg{width:22px; height:22px; stroke:var(--gold-deep); fill:none; stroke-width:1.7;}
.contact-item .cl{font-size:11px; letter-spacing:.16em; text-transform:uppercase; color:var(--muted); margin-bottom:4px;}
.contact-item .cv{font-family:var(--serif); font-size:19px; font-weight:600; color:var(--ink);}
.contact-item .cv a:hover{color:var(--gold-deep);}
.form-field{margin-bottom:18px;}
.form-field label{display:block; font-size:12px; font-weight:600; letter-spacing:.04em; color:var(--ink-soft); margin-bottom:7px;}
.form-field input, .form-field textarea{width:100%; padding:14px 16px; border:1.5px solid var(--line-soft); border-radius:12px; font-family:var(--sans); font-size:14px; background:var(--paper); transition:.2s; resize:vertical;}
.form-field input:focus, .form-field textarea:focus{outline:none; border-color:var(--gold); box-shadow:0 0 0 3px rgba(184,144,31,.12);}

/* ---------- reveal animation ---------- */
.reveal{opacity:0; transform:translateY(28px); transition:.8s cubic-bezier(.16,.84,.44,1);}
.reveal.in{opacity:1; transform:none;}
.reveal.d1{transition-delay:.08s;} .reveal.d2{transition-delay:.16s;}
.reveal.d3{transition-delay:.24s;} .reveal.d4{transition-delay:.32s;}

/* ---------- responsive ---------- */
@media(max-width:980px){
  .grid-4{grid-template-columns:repeat(2,1fr);}
  .grid-3{grid-template-columns:repeat(2,1fr);}
  .pipeline{grid-template-columns:repeat(2,1fr);}
  .intro-grid{grid-template-columns:1fr; gap:40px;}
  .contact-grid{grid-template-columns:1fr; gap:36px;}
  .footer-grid{grid-template-columns:1fr 1fr; gap:32px;}
  .hero-waves{width:70%; opacity:.5;}
}
@media(max-width:640px){
  .section{padding:64px 0;}
  .grid-4,.grid-3,.grid-2,.pipeline{grid-template-columns:1fr;}
  .footer-grid{grid-template-columns:1fr;}
  .nav-links{position:fixed; inset:0 0 0 auto; width:78%; max-width:320px; background:var(--dk);
    flex-direction:column; align-items:flex-start; justify-content:center; gap:28px; padding:40px; transform:translateX(100%); transition:.35s; box-shadow:-20px 0 60px rgba(0,0,0,.4);}
  .nav-links.open{transform:none;}
  .nav-links a{color:#fff !important; font-size:18px;}
  .burger{display:flex;}
  .hero-stats{gap:28px;}
  .hero-stats .s .n{font-size:32px;}
}
