
/* ═══════════════════════════════════════
   DESIGN TOKENS
   Navy Blue + Emerald Green blend
════════════════════════════════════════ */
:root{
  --navy:      #1B3A6B;
  --navy-dk:   #112450;
  --navy-lt:   #EEF2FA;

  --green:     #1A7A4A;
  --green-dk:  #115233;
  --green-lt:  #EAF5EE;
  --green-mid: #2E9E63;

  --gold:      #C8860A;
  --gold-lt:   #E9C46A;
  --gold-bg:   #FFFBF0;

  --line:      #DDE4EF;
  --text:      #141E2E;
  --muted:     #4A5568;
  --white:     #FFFFFF;
  --bg:        #F4F7FB;
}

*,*::before,*::after{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{font-family:'Inter',sans-serif;color:var(--text);background:var(--white);line-height:1.65;-webkit-font-smoothing:antialiased;}
img{display:block;max-width:100%;height:auto;}
a{color:inherit;text-decoration:none;}

/* ═══ TYPOGRAPHY ════════════════════════ */
h1,h2,h3,h4{font-family:'Playfair Display',serif;font-weight:700;line-height:1.25;color:var(--navy-dk);}
h2{font-size:clamp(1.75rem,3.5vw,2.5rem);}
h3{font-size:1.1rem;}
p{font-size:.96rem;color:var(--muted);line-height:1.8;}

/* ═══ LAYOUT ════════════════════════════ */
.wrap{max-width:1120px;margin:0 auto;padding:0 5%;}
.sec{padding:5rem 0;}
.lbl{display:block;font-size:.68rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--green);margin-bottom:.5rem;}
.rule{width:34px;height:2px;background:var(--gold);margin:.65rem 0 1.4rem;border-radius:1px;}

/* ═══ NAV ═══════════════════════════════ */
nav{
  position:fixed;top:0;left:0;width:100%;z-index:900;
  background:var(--navy-dk);height:66px;
  display:flex;align-items:center;justify-content:space-between;
  padding:0 5%;
  border-bottom:2px solid var(--green);
}
.nav-logo{font-family:'Playfair Display',serif;font-size:1.4rem;font-weight:700;color:var(--white);}
.nav-logo span{color:var(--gold-lt);}
.nav-menu{display:flex;gap:1.8rem;list-style:none;align-items:center;}
.nav-menu a{font-size:.84rem;font-weight:500;color:rgba(255,255,255,.75);letter-spacing:.02em;transition:color .15s;}
.nav-menu a:hover{color:var(--white);}
.nav-btn{
  background:var(--green);color:var(--white)!important;
  padding:.42rem 1.2rem;border-radius:4px;
  font-weight:600!important;font-size:.82rem!important;
  transition:background .15s;
}
.nav-btn:hover{background:var(--green-dk)!important;}
.burger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:4px;}
.burger span{width:23px;height:2px;background:var(--gold-lt);border-radius:1px;}

/* ═══ HERO SLIDER ═══════════════════════ */
.hero{
  margin-top:66px;
  height:calc(100vh - 66px);
  min-height:560px;
  position:relative;overflow:hidden;
}
.slide{position:absolute;inset:0;opacity:0;transition:opacity 1.1s ease;}
.slide.active{opacity:1;}
.slide-bg{
  position:absolute;inset:0;
  background-size:cover;background-position:center;
  transform:scale(1.03);transition:transform 8s ease;
}
.slide.active .slide-bg{transform:scale(1);}

/*
  STRONG layered overlay — photos appear "faded/disappeared"
  so text is crystal clear at all times on any image.
  Layer 1: deep left-to-right navy gradient  
  Layer 2: uniform dark tint across whole slide
  Layer 3: bottom vignette so lower text stays readable
*/
.slide-overlay{
  position:absolute;inset:0;z-index:1;
  background:
    linear-gradient(
      to right,
      rgba(17,36,80,.92) 0%,
      rgba(17,36,80,.78) 35%,
      rgba(17,36,80,.50) 65%,
      rgba(17,36,80,.25) 100%
    );
}
.slide-overlay::before{
  content:'';position:absolute;inset:0;
  background:rgba(10,22,50,.35);
}
.slide-overlay::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(to top, rgba(10,22,50,.55) 0%, transparent 45%);
}

.slide-body{
  position:absolute;inset:0;z-index:3;
  display:flex;align-items:center;
  padding:0 7%;
}
.slide-copy{max-width:600px;}
.slide-copy h1{
  font-size:clamp(2.1rem,5vw,3.9rem);
  color:var(--white);font-weight:700;
  line-height:1.13;margin-bottom:.9rem;
  text-shadow:0 2px 16px rgba(0,0,0,.3);
}
.slide-copy h1 em{font-style:italic;color:var(--gold-lt);}
.slide-copy p{
  color:rgba(255,255,255,.92);
  font-size:1rem;line-height:1.75;
  max-width:460px;margin-bottom:1.9rem;
  text-shadow:0 1px 8px rgba(0,0,0,.25);
}
.hero-btns{display:flex;gap:.85rem;flex-wrap:wrap;}
.btn-hero{
  background:var(--green);color:var(--white);
  padding:.68rem 1.8rem;border-radius:4px;
  font-weight:600;font-size:.9rem;
  display:inline-flex;align-items:center;gap:.45rem;
  transition:background .15s,transform .15s;
}
.btn-hero:hover{background:var(--green-dk);transform:translateY(-1px);}
.btn-hero-ol{
  border:1.5px solid rgba(255,255,255,.65);color:var(--white);
  padding:.68rem 1.8rem;border-radius:4px;
  font-weight:500;font-size:.9rem;
  display:inline-flex;align-items:center;gap:.45rem;
  transition:background .15s;
}
.btn-hero-ol:hover{background:rgba(255,255,255,.13);}

/* Slider arrows */
.s-arrow{
  position:absolute;top:50%;transform:translateY(-50%);
  z-index:10;width:46px;height:46px;border-radius:50%;
  background:rgba(255,255,255,.14);
  border:1.5px solid rgba(255,255,255,.38);
  color:var(--white);
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;font-size:.92rem;
  transition:background .2s,border-color .2s;
}
.s-arrow:hover{background:var(--green);border-color:var(--green);}
.s-prev{left:1.8%;}
.s-next{right:1.8%;}
.s-dots{
  position:absolute;bottom:22px;left:50%;transform:translateX(-50%);
  display:flex;gap:8px;z-index:10;
}
.dot{
  width:7px;height:7px;border-radius:50%;
  background:rgba(255,255,255,.38);
  border:1px solid rgba(255,255,255,.5);
  cursor:pointer;transition:.2s;
}
.dot.on{background:var(--gold-lt);border-color:var(--gold-lt);}
.s-num{
  position:absolute;bottom:24px;right:5%;
  font-size:.73rem;color:rgba(255,255,255,.55);
  letter-spacing:.1em;z-index:10;
}

/* ═══ ABOUT ══════════════════════════════
   Full-width photo banner → then text content
════════════════════════════════════════ */
#about{background:var(--white);}

.about-banner{
  width:100%;
  height:clamp(260px, 40vw, 480px);
  object-fit:cover;
  object-position:center 30%;
  display:block;
}

.about-content{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:3.5rem;
  align-items:start;
  padding:3.5rem 0 0;
}
.about-copy p{margin-bottom:.9rem;}

/* ═══ VALUE CARDS ════════════════════════
   Left coloured strip + photo + text
   Responsive: 2-col laptop, 2-col tablet, 1-col phone
════════════════════════════════════════ */
.val-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:1rem;
  margin-top:1.6rem;
}
.val-card{
  display:flex;
  flex-direction:column;
  border-radius:8px;
  overflow:hidden;
  background:var(--white);
  border:1px solid var(--line);
  border-left:4px solid transparent; /* coloured strip — set per card below */
  box-shadow:0 2px 10px rgba(27,58,107,.06);
  transition:box-shadow .22s, transform .22s;
}
.val-card:hover{
  box-shadow:0 6px 22px rgba(27,58,107,.12);
  transform:translateY(-3px);
}

/* Strip colours alternating navy / green */
.val-card:nth-child(1){border-left-color:var(--navy);}
.val-card:nth-child(2){border-left-color:var(--green);}
.val-card:nth-child(3){border-left-color:var(--green);}
.val-card:nth-child(4){border-left-color:var(--navy);}

.val-card img{
  width:100%;
  height:130px;
  object-fit:cover;
  flex-shrink:0;
}
.val-body{padding:.9rem 1rem 1rem;}
.val-title{
  font-family:'Playfair Display',serif;
  font-size:1rem;font-weight:700;
  margin-bottom:.3rem;
  line-height:1.2;
}
/* Title colours matching the strip */
.val-card:nth-child(1) .val-title{color:var(--navy);}
.val-card:nth-child(2) .val-title{color:var(--green-dk);}
.val-card:nth-child(3) .val-title{color:var(--green-dk);}
.val-card:nth-child(4) .val-title{color:var(--navy);}
.val-body p{font-size:.8rem;color:var(--muted);line-height:1.6;}

/* Side image for about (right column) */
.about-side-img{
  width:100%;
  height:clamp(280px,35vw,440px);
  object-fit:cover;
  border-radius:6px;
  box-shadow:0 4px 24px rgba(27,58,107,.12);
}
.est-tag{
  display:inline-flex;align-items:center;gap:.5rem;
  background:var(--navy-dk);color:var(--white);
  font-size:.78rem;font-weight:600;
  padding:.45rem .9rem;border-radius:4px;
  margin-bottom:1.1rem;
  border-left:3px solid var(--green);
}

/* ═══ STATS BAR ═════════════════════════ */
.stats-bar{
  background:var(--navy-dk);
  border-top:3px solid var(--green);
  padding:3.5rem 0;
}
.stats-inner{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:1.5rem;
  text-align:center;
}
.stat{color:var(--white);}
.stat-n{
  font-family:'Playfair Display',serif;
  font-size:2.8rem;font-weight:700;
  color:var(--gold-lt);line-height:1;
}
.stat-l{font-size:.82rem;font-weight:500;opacity:.75;margin-top:.4rem;}

/* ═══ CAUSES ════════════════════════════ */
#causes{background:var(--bg);}
.causes-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(300px,1fr));
  gap:1.4rem;margin-top:2.5rem;
}
.c-card{
  background:var(--white);border:1px solid var(--line);
  border-radius:6px;overflow:hidden;
  display:flex;flex-direction:column;
  transition:box-shadow .2s,transform .2s;
  border-top:3px solid var(--navy);
}
.c-card:hover{box-shadow:0 6px 24px rgba(27,58,107,.1);transform:translateY(-3px);}
.c-card img{width:100%;height:175px;object-fit:cover;display:block;}
.c-body{padding:1.2rem 1.3rem;flex:1;display:flex;flex-direction:column;}
.c-body h3{font-size:1rem;color:var(--navy-dk);margin-bottom:.45rem;}
.c-body p{font-size:.85rem;line-height:1.7;flex:1;margin-bottom:1rem;}
.c-meta{display:flex;align-items:center;justify-content:space-between;margin-bottom:.8rem;}
.c-target{font-size:.77rem;font-weight:600;color:var(--green-dk);}
.c-pct{font-size:.77rem;color:var(--muted);}
.prog{background:var(--green-lt);border-radius:2px;height:5px;margin-bottom:1.1rem;}
.prog-fill{height:100%;border-radius:2px;background:linear-gradient(90deg,var(--green),var(--navy));}
.btn-sup{
  align-self:flex-start;
  background:var(--navy);color:var(--white);
  padding:.48rem 1.15rem;border-radius:4px;
  font-size:.82rem;font-weight:600;
  transition:background .15s;
}
.btn-sup:hover{background:var(--navy-dk);}

/* ═══ DONATE ════════════════════════════ */
#donate{
  background:linear-gradient(135deg,var(--navy-dk) 0%,var(--navy) 50%,#1E4B82 100%);
  padding:5rem 0;
}
.don-inner{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center;}
.don-copy .lbl{color:var(--gold-lt);}
.don-copy h2{color:var(--white);}
.don-copy .rule{background:var(--green-mid);}
.don-copy p{color:rgba(255,255,255,.78);margin-bottom:.9rem;}
.don-box{
  background:var(--white);border-radius:8px;
  padding:2.2rem 2rem;
  border-top:3px solid var(--green);
  box-shadow:0 8px 32px rgba(0,0,0,.18);
}
.don-box>p{font-size:.88rem;color:var(--muted);}
.don-email{
  font-size:.98rem;font-weight:600;color:var(--navy-dk);
  background:var(--bg);padding:.7rem 1rem;
  border-radius:4px;margin:.7rem 0 1.2rem;
  border:1px solid var(--line);word-break:break-all;
  letter-spacing:.01em;
}
.don-note{
  font-size:.82rem;color:var(--muted);line-height:1.7;
  margin-bottom:1.5rem;padding-top:.8rem;
  border-top:1px solid var(--line);
}
.btn-paypal{
  display:inline-flex;align-items:center;gap:.5rem;
  background:var(--green);color:var(--white);
  padding:.7rem 1.75rem;border-radius:4px;
  font-weight:600;font-size:.9rem;
  transition:background .15s;
}
.btn-paypal:hover{background:var(--green-dk);}

/* ═══ GALLERY ═══════════════════════════ */
#gallery{background:var(--white);}
.g-tabs{
  display:flex;gap:0;
  border-bottom:2px solid var(--line);
  margin:1.5rem 0 1.4rem;
}
.g-tab{
  padding:.62rem 1.5rem;
  font-size:.86rem;font-weight:600;
  color:var(--muted);cursor:pointer;
  background:none;border:none;
  border-bottom:2px solid transparent;
  margin-bottom:-2px;
  display:inline-flex;align-items:center;gap:.38rem;
  transition:color .15s,border-color .15s;
}
.g-tab.on{color:var(--navy);border-bottom-color:var(--navy);}
.g-tab:hover:not(.on){color:var(--text);}
.g-panel{display:none;}
.g-panel.on{display:block;}

/* Photos grid */
.photos-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  grid-template-rows:200px 200px;
  gap:10px;
  border-radius:6px;overflow:hidden;
}
.g-cell{position:relative;overflow:hidden;}
.g-cell:first-child{grid-row:span 2;}
.g-cell img{width:100%;height:100%;object-fit:cover;transition:transform .4s;}
.g-cell:hover img{transform:scale(1.04);}
.g-ov{
  position:absolute;inset:0;
  background:rgba(17,36,80,0);
  transition:.3s;
  display:flex;align-items:center;justify-content:center;
}
.g-cell:hover .g-ov{background:rgba(17,36,80,.25);}
.g-ov i{color:var(--white);font-size:1.3rem;opacity:0;transition:.25s;}
.g-cell:hover .g-ov i{opacity:1;}

/* Videos grid */
.vids-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:1.2rem;
}
.vid-item{
  border-radius:6px;overflow:hidden;
  border:1px solid var(--line);
  background:var(--bg);
  border-top:3px solid var(--green);
}
.vid-thumb{
  position:relative;width:100%;
  padding-top:56.25%;
  background:var(--navy-dk);
}
.vid-thumb iframe,
.vid-thumb video{
  position:absolute;inset:0;
  width:100%;height:100%;border:0;
}
.vid-placeholder{
  position:absolute;inset:0;
  background:linear-gradient(135deg,var(--navy-dk),var(--navy));
  display:flex;flex-direction:column;
  align-items:center;justify-content:center;
  gap:.6rem;color:rgba(255,255,255,.55);
}
.vid-placeholder i{font-size:2.2rem;color:var(--gold-lt);}
.vid-placeholder span{font-size:.75rem;letter-spacing:.06em;text-transform:uppercase;}
.vid-play{
  position:absolute;top:50%;left:50%;
  transform:translate(-50%,-50%);
  width:50px;height:50px;border-radius:50%;
  background:rgba(233,196,106,.9);
  display:flex;align-items:center;justify-content:center;
  font-size:1rem;color:var(--navy-dk);
  box-shadow:0 4px 16px rgba(0,0,0,.2);
  cursor:pointer;transition:transform .2s,background .2s;
}
.vid-item:hover .vid-play{transform:translate(-50%,-50%) scale(1.08);background:#f4d483;}
.vid-info{padding:.85rem 1rem 1rem;}
.vid-info h4{font-family:'Playfair Display',serif;font-size:.98rem;color:var(--navy-dk);margin-bottom:.28rem;}
.vid-info p{font-size:.8rem;color:var(--muted);}
.vid-note{
  margin-top:1.3rem;padding:.9rem 1.1rem;
  background:var(--navy-lt);border-radius:6px;
  border-left:3px solid var(--navy);
  font-size:.83rem;color:var(--muted);line-height:1.65;
}
.vid-note strong{color:var(--navy-dk);}

/* ═══ CONTACT ═══════════════════════════ */
#contact{background:var(--bg);}
.con-grid{display:grid;grid-template-columns:1fr 1.3fr;gap:3.5rem;align-items:start;margin-top:2.5rem;}
.con-info h3{color:var(--navy-dk);margin-bottom:.55rem;}
.con-info>p{margin-bottom:1.5rem;}
.i-row{display:flex;align-items:center;gap:.85rem;margin-bottom:.95rem;}
.i-icon{
  width:38px;height:38px;border-radius:4px;flex-shrink:0;
  background:var(--navy-dk);color:var(--white);
  display:flex;align-items:center;justify-content:center;
  font-size:.85rem;
}
.i-row a{font-weight:500;font-size:.9rem;color:var(--text);}
.i-row a:hover{color:var(--navy);}
.i-row span{font-size:.9rem;color:var(--muted);}
.frow{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1rem;}
.inp{
  width:100%;padding:.78rem 1rem;
  border:1px solid var(--line);border-radius:4px;
  font-family:'Inter',sans-serif;font-size:.9rem;
  color:var(--text);background:var(--white);
  outline:none;transition:border-color .15s;
  margin-bottom:1rem;
}
.frow .inp{margin-bottom:0;}
.inp:focus{border-color:var(--navy);}
textarea.inp{height:128px;resize:vertical;margin-bottom:1rem;}
.btn-send{
  width:100%;padding:.78rem;
  background:var(--navy-dk);color:var(--white);
  border:none;border-radius:4px;
  font-family:'Inter',sans-serif;font-size:.9rem;font-weight:600;
  cursor:pointer;transition:background .15s;
  display:flex;align-items:center;justify-content:center;gap:.42rem;
}
.btn-send:hover{background:var(--navy);}

/* ═══ FOOTER ════════════════════════════ */
footer{
  background:var(--navy-dk);
  border-top:3px solid var(--green);
  color:rgba(255,255,255,.75);
  padding:3.5rem 0 2rem;
}
.ft-grid{display:grid;grid-template-columns:2fr 1fr 1fr;gap:3rem;margin-bottom:2.5rem;}
.ft-name{font-family:'Playfair Display',serif;font-size:1.3rem;color:var(--white);font-weight:700;display:block;margin-bottom:.7rem;}
.ft-name span{color:var(--gold-lt);}
.ft-brand p{font-size:.85rem;line-height:1.7;max-width:280px;opacity:.7;}
.ft-col h5{font-size:.68rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--gold-lt);margin-bottom:1rem;}
.ft-col ul{list-style:none;}
.ft-col li{margin-bottom:.52rem;}
.ft-col a{font-size:.85rem;color:rgba(255,255,255,.58);transition:color .15s;}
.ft-col a:hover{color:var(--white);}
.ft-bottom{border-top:1px solid rgba(249, 245, 245, 0.986);padding-top:1.5rem;text-align:center;font-size:.8rem;opacity:.42;}

/* ═══ REVEAL ANIMATION ══════════════════ */
.reveal{opacity:0;transform:translateY(18px);transition:opacity .6s ease,transform .6s ease;}
.reveal.in{opacity:1;transform:translateY(0);}

/* ═══ RESPONSIVE ════════════════════════ */

/* Tablet — ≤ 900px */
@media(max-width:900px){
  .about-content{grid-template-columns:1fr;gap:2.5rem;}
  .stats-inner{grid-template-columns:repeat(2,1fr);}
  .don-inner{grid-template-columns:1fr;gap:2.5rem;}
  .con-grid{grid-template-columns:1fr;gap:2.5rem;}
  .ft-grid{grid-template-columns:1fr 1fr;}
  .photos-grid{grid-template-columns:1fr 1fr;grid-template-rows:auto;}
  .g-cell:first-child{grid-row:auto;}
  /* Value cards: 2 columns on tablet — keep nice */
  .val-grid{grid-template-columns:1fr 1fr;}
  .val-card img{height:115px;}
}

/* Phone — ≤ 600px */
@media(max-width:600px){
  .nav-menu{
    display:none;flex-direction:column;
    position:fixed;top:66px;left:0;width:100%;
    background:var(--navy-dk);
    padding:1.3rem 5%;gap:1rem;
    border-top:1px solid rgba(255,255,255,.08);
  }
  .nav-menu.open{display:flex;}
  .burger{display:flex;}

  /* Hero text stays readable */
  .slide-copy h1{font-size:1.9rem;}

  /* About banner smaller on phone */
  .about-banner{height:220px;}

  /* Value cards: 1 column on phone — clear & readable */
  .val-grid{grid-template-columns:1fr;}
  .val-card{flex-direction:row;align-items:stretch;}
  .val-card img{width:100px;height:auto;flex-shrink:0;object-fit:cover;}
  .val-body{padding:.85rem .9rem;}
  .val-title{font-size:.95rem;}

  .frow{grid-template-columns:1fr;}
  .ft-grid{grid-template-columns:1fr;}
  .vids-grid{grid-template-columns:1fr;}
  .photos-grid{grid-template-columns:1fr;grid-template-rows:auto;}
  .g-cell{height:180px;}
  .causes-grid{grid-template-columns:1fr;}
  .s-arrow{width:38px;height:38px;font-size:.8rem;}
}

/* ═══ VISION & MISSION (NO IMAGE VERSION) ═══════════ */
.vm-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:1.4rem;
  margin-top:1.8rem;
}

.vm-card{
  position:relative;
  display:flex;
  border-radius:10px;
  background:var(--white);
  border:1px solid var(--line);
  border-left:5px solid transparent;
  box-shadow:0 4px 18px rgba(27,58,107,.08);
  transition:transform .25s, box-shadow .25s;
}

.vm-card:hover{
  transform:translateY(-4px);
  box-shadow:0 10px 28px rgba(27,58,107,.14);
}

/* Left strip colors */
.vm-card:nth-child(1){border-left-color:var(--navy);}
.vm-card:nth-child(2){border-left-color:var(--green);}

.vm-body{
  padding:1.4rem 1.5rem;
}

/* Header with icon + title */
.vm-head{
  display:flex;
  align-items:center;
  gap:.6rem;
  margin-bottom:.6rem;
}

.vm-icon{
  font-size:1.4rem;
}

.vm-title{
  font-family:'Playfair Display',serif;
  font-size:1.2rem;
  font-weight:700;
  color:var(--navy);
}

/* Match title color to strip */
.vm-card:nth-child(2) .vm-title{
  color:var(--green-dk);
}

.vm-body p{
  font-size:.9rem;
  color:var(--muted);
  line-height:1.7;
}

/* 📱 Phone */
@media (max-width:768px){
  .vm-grid{
    grid-template-columns:1fr;
  }
}
