@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:wght@400;600;700&family=Inter:wght@400;500;600;700&display=swap');

/* ====== RESET & BASE ====== */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Inter',sans-serif;color:#2C2420;background:#F7F2EC;-webkit-font-smoothing:antialiased;line-height:1.6}
a{text-decoration:none;color:inherit}
img{max-width:100%;display:block}
button{cursor:pointer;font-family:inherit;border:none;background:none}
ul,ol{list-style:none}

/* ====== VARIABLES ====== */
:root{
  --terracotta:#C75C2E;
  --terracotta-dark:#A84A22;
  --terracotta-light:#F0DCD3;
  --sage:#3A6B4F;
  --sage-light:#D4E4D8;
  --cream:#F7F2EC;
  --cream-dark:#EDE5DA;
  --charcoal:#2C2420;
  --charcoal-light:#5A524A;
  --gold:#D4A843;
  --gold-light:#E8D5A3;
  --white:#FFFFFF;
}

/* ====== UTILITIES ====== */
.font-display{font-family:'Playfair Display',serif}
.font-body{font-family:'Inter',sans-serif}
.container{max-width:1200px;margin:0 auto;padding-left:1.5rem;padding-right:1.5rem}
.container-narrow{max-width:800px;margin:0 auto;padding-left:1.5rem;padding-right:1.5rem}

/* ====== HEADER ====== */
.header{position:fixed;top:0;left:0;right:0;z-index:100;background:rgba(255,255,255,0.92);backdrop-filter:blur(12px);border-bottom:1px solid rgba(44,36,32,0.06);transition:box-shadow .3s}
.header.scrolled{box-shadow:0 2px 8px rgba(44,36,32,0.08)}
.header-inner{display:flex;align-items:center;justify-content:space-between;height:72px}
.header-logo{display:flex;align-items:center;gap:8px}
.header-logo svg{color:var(--sage)}
.header-logo span{font-family:'Playfair Display',serif;font-size:14px;font-weight:700;letter-spacing:0.5px;text-transform:uppercase;color:var(--charcoal)}
.header-nav{display:flex;align-items:center;gap:24px}
.header-nav a{font-size:14px;font-weight:500;letter-spacing:0.5px;color:var(--charcoal-light);transition:color .2s;position:relative;padding-bottom:2px}
.header-nav a:hover,.header-nav a.active{color:var(--terracotta)}
.header-nav a.active::after{content:'';position:absolute;bottom:-2px;left:0;right:0;height:2px;background:var(--terracotta)}
.header-cta{display:inline-flex;align-items:center;gap:6px;padding:8px 20px;background:var(--terracotta);color:#fff;font-size:14px;font-weight:500;border-radius:9999px;transition:all .2s}
.header-cta:hover{background:var(--terracotta-dark);box-shadow:0 0 24px rgba(199,92,46,0.25);transform:scale(1.02)}
.header-hamburger{display:none;padding:8px;color:var(--charcoal)}

/* ====== MOBILE MENU ====== */
.mobile-menu{position:fixed;inset:0;z-index:200;background:var(--cream-dark);transform:translateX(100%);transition:transform .4s cubic-bezier(0.25,0.46,0.45,0.94)}
.mobile-menu.open{transform:translateX(0)}
.mobile-menu-close{position:absolute;top:20px;right:20px;padding:8px;color:var(--charcoal)}
.mobile-menu-nav{padding:80px 32px 32px;display:flex;flex-direction:column;gap:24px}
.mobile-menu-nav a{font-family:'Playfair Display',serif;font-size:24px;color:var(--charcoal)}
.mobile-menu-nav a.active{color:var(--terracotta)}

/* ====== HERO ====== */
.hero{position:relative;width:100%;min-height:100vh;display:flex;align-items:center;justify-content:center;overflow:hidden}
.hero-slider{position:absolute;inset:0}
.hero-slide{position:absolute;inset:0;background-size:cover;background-position:center;opacity:0;transition:opacity .8s ease}
.hero-slide.active{opacity:1}
.hero-overlay{position:absolute;inset:0;background:rgba(44,36,32,0.55);z-index:1}
.hero-content{position:relative;z-index:2;max-width:800px;margin:0 auto;padding:80px 24px;text-align:center}
.hero-label{display:inline-block;color:var(--gold);font-size:12px;font-weight:600;letter-spacing:0.15em;text-transform:uppercase}
.hero-line{width:40px;height:2px;background:var(--gold);margin:16px auto}
.hero-title{font-family:'Playfair Display',serif;font-size:clamp(2.5rem,5vw,4rem);font-weight:700;color:#fff;line-height:1.1;text-shadow:0 2px 30px rgba(0,0,0,0.4)}
.hero-subtitle{margin-top:24px;font-size:18px;color:#fff;line-height:1.7;max-width:600px;margin-left:auto;margin-right:auto}
.hero-buttons{margin-top:40px;display:flex;flex-wrap:wrap;justify-content:center;gap:16px}
.btn-primary{display:inline-flex;align-items:center;gap:8px;padding:14px 32px;background:var(--terracotta);color:#fff;font-size:14px;font-weight:500;border-radius:9999px;transition:all .2s}
.btn-primary:hover{background:var(--terracotta-dark);box-shadow:0 0 24px rgba(199,92,46,0.25);transform:scale(1.02)}
.btn-secondary{display:inline-flex;align-items:center;padding:14px 32px;border:2px solid #fff;color:#fff;font-size:14px;font-weight:500;border-radius:9999px;transition:all .2s}
.btn-secondary:hover{background:#fff;color:var(--terracotta)}
.hero-scroll{margin-top:64px;display:flex;flex-direction:column;align-items:center;gap:4px}
.hero-scroll svg{width:24px;height:24px;color:rgba(255,255,255,0.5);animation:bounceSlow 1.5s ease-in-out infinite}
.hero-scroll span{font-size:12px;color:rgba(255,255,255,0.5)}

/* Slider dots */
.slider-dots{position:absolute;bottom:32px;left:50%;transform:translateX(-50%);z-index:3;display:flex;gap:8px}
.slider-dot{width:16px;height:6px;border-radius:9999px;background:rgba(255,255,255,0.4);transition:all .3s;cursor:pointer;border:none}
.slider-dot.active{width:32px;background:#fff}

/* ====== SECTIONS ====== */
.section{padding:64px 0}
.section-md{padding:48px 0}
@media(min-width:768px){.section{padding:80px 0}.section-md{padding:64px 0}}

.section-label{display:block;color:var(--terracotta);font-size:12px;font-weight:600;letter-spacing:0.12em;text-transform:uppercase;margin-bottom:12px}
.section-line{width:40px;height:2px;background:var(--terracotta);margin-bottom:16px}
.section-line.center{margin-left:auto;margin-right:auto}
.section-title{font-family:'Playfair Display',serif;font-size:clamp(1.5rem,3vw,2.25rem);font-weight:600;color:var(--charcoal);line-height:1.2}
.section-desc{margin-top:16px;font-size:16px;color:var(--charcoal-light);max-width:640px}
.section-desc.center{margin-left:auto;margin-right:auto}

/* ====== STATS ====== */
.stats-bar{background:var(--charcoal);padding:64px 0}
.stats-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:32px}
@media(min-width:1024px){.stats-grid{grid-template-columns:repeat(4,1fr);gap:48px}}
.stat{text-align:center}
.stat-number{font-family:'Playfair Display',serif;font-size:clamp(2rem,4vw,3rem);font-weight:700;color:var(--gold)}
.stat-label{margin-top:8px;font-size:12px;font-weight:600;letter-spacing:0.08em;text-transform:uppercase;color:rgba(247,242,236,0.6)}
.stat-desc{margin-top:4px;font-size:13px;color:rgba(247,242,236,0.5);max-width:250px;margin-left:auto;margin-right:auto}

/* ====== CARDS ====== */
.card{background:#fff;border-radius:12px;box-shadow:0 8px 32px rgba(44,36,32,0.08);overflow:hidden;transition:all .3s;height:100%;display:flex;flex-direction:column}
.card:hover{transform:translateY(-4px);box-shadow:0 16px 48px rgba(44,36,32,0.12)}
.card-img{overflow:hidden;aspect-ratio:16/10}
.card-img img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}
.card:hover .card-img img{transform:scale(1.05)}
.card-body{padding:24px;display:flex;flex-direction:column;flex:1}
.card-tag{font-size:12px;font-weight:600;letter-spacing:0.08em;text-transform:uppercase;color:var(--terracotta);margin-bottom:8px}
.card-meta{font-size:12px;font-weight:600;letter-spacing:0.08em;text-transform:uppercase;color:var(--sage);margin-bottom:8px}
.card-title{font-family:'Playfair Display',serif;font-size:18px;font-weight:600;color:var(--charcoal);line-height:1.3}
.card-text{margin-top:8px;font-size:14px;color:var(--charcoal-light);line-height:1.6;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
.card-link{margin-top:auto;padding-top:16px;display:inline-flex;align-items:center;gap:4px;color:var(--terracotta);font-size:14px;font-weight:600;transition:gap .2s}
.card-link:hover{gap:8px}

/* ====== CARDS GRID ====== */
.cards-grid{display:grid;gap:32px}
@media(min-width:768px){.cards-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1024px){.cards-grid{grid-template-columns:repeat(3,1fr)}}

/* ====== TWO COL ====== */
.two-col{display:grid;gap:48px}
@media(min-width:1024px){.two-col{grid-template-columns:1fr 1fr;align-items:center}}
.two-col-55-45{display:grid;gap:48px}
@media(min-width:1024px){.two-col-55-45{grid-template-columns:55fr 45fr;align-items:center}}
.two-col-45-55{display:grid;gap:48px}
@media(min-width:1024px){.two-col-45-55{grid-template-columns:45fr 55fr;align-items:center}}

/* ====== IMAGES ====== */
.img-rounded{border-radius:12px;box-shadow:0 16px 48px rgba(44,36,32,0.12)}
.img-full{width:100%;height:100%;object-fit:cover}

/* ====== TESTIMONIAL ====== */
.testimonial{background:var(--sage);padding:80px 24px;text-align:center}
.testimonial-quote{font-family:'Playfair Display',serif;font-size:clamp(1.1rem,2vw,1.4rem);color:rgba(255,255,255,0.9);font-style:italic;line-height:1.6;max-width:700px;margin:0 auto;position:relative}
.testimonial-quote::before{content:'"';position:absolute;top:-40px;left:-20px;font-size:8rem;color:rgba(255,255,255,0.05);font-family:'Playfair Display',serif;line-height:1}
.testimonial-author{margin-top:24px}
.testimonial-author strong{color:#fff;font-weight:600}
.testimonial-author span{color:rgba(255,255,255,0.6);font-size:14px}

/* ====== CTA BANNER ====== */
.cta-banner{position:relative;background:var(--terracotta);padding:64px 24px;text-align:center;overflow:hidden}
.cta-banner-pattern{position:absolute;inset:0;opacity:0.05;background-image:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='%23ffffff'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/svg%3E")}
.cta-banner h2{font-family:'Playfair Display',serif;font-size:clamp(1.5rem,3vw,2rem);font-weight:700;color:#fff}
.cta-banner p{margin-top:16px;font-size:16px;color:rgba(255,255,255,0.85);max-width:600px;margin-left:auto;margin-right:auto}
.cta-banner-buttons{margin-top:32px;display:flex;flex-wrap:wrap;justify-content:center;gap:16px}
.btn-white{display:inline-flex;padding:12px 32px;background:#fff;color:var(--terracotta);font-size:14px;font-weight:500;border-radius:9999px;transition:all .2s}
.btn-white:hover{background:var(--cream)}
.btn-outline-white{display:inline-flex;padding:12px 32px;border:2px solid #fff;color:#fff;font-size:14px;font-weight:500;border-radius:9999px;transition:all .2s}
.btn-outline-white:hover{background:#fff;color:var(--terracotta)}
.btn-readmore{display:inline-flex;align-items:center;gap:4px;margin-top:12px;font-size:13px;font-weight:600;color:var(--terracotta);transition:all .2s}
.btn-readmore:hover{gap:8px;color:var(--terracotta-dark)}

/* ====== ARTICLE PAGES ====== */
.article-breadcrumb{display:flex;align-items:center;gap:8px;margin-bottom:32px;font-size:14px;color:var(--charcoal-light);flex-wrap:wrap}
.article-breadcrumb a{color:var(--terracotta);font-weight:500}
.article-breadcrumb a:hover{text-decoration:underline}
.article-breadcrumb span{color:var(--charcoal-light)}
.article-meta{font-size:13px;color:var(--charcoal-light);margin-bottom:24px;padding-bottom:16px;border-bottom:1px solid var(--cream-dark)}
.article-paragraph{font-size:16px;line-height:1.8;color:var(--charcoal);margin-bottom:20px;text-align:justify}
.article-gallery{margin-top:32px}
.article-figure{border-radius:12px;overflow:hidden}
.article-figure img{width:100%;height:auto;object-fit:cover}
.article-figure figcaption{font-size:13px;color:var(--charcoal-light);margin-top:10px;font-style:italic}

/* ====== PUBLICATIONS ====== */
.pub-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:24px}
.pub-card{background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 2px 12px rgba(44,36,32,0.06);transition:box-shadow .3s,transform .3s}
.pub-card:hover{box-shadow:0 8px 32px rgba(44,36,32,0.12);transform:translateY(-4px)}
.pub-img{aspect-ratio:3/2;overflow:hidden}
.pub-img img{width:100%;height:100%;object-fit:cover;transition:transform .4s ease}
.pub-card:hover .pub-img img{transform:scale(1.05)}
.pub-body{padding:24px}
.pub-meta{display:flex;align-items:center;gap:12px;margin-bottom:10px;flex-wrap:wrap}
.pub-tag{font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:0.5px;color:var(--sage);background:var(--sage-light);padding:4px 10px;border-radius:9999px}
.pub-date{font-size:12px;color:var(--charcoal-light)}
.pub-title{font-family:'Playfair Display',serif;font-size:18px;font-weight:600;color:var(--charcoal);line-height:1.35;margin-bottom:10px}
.pub-text{font-size:14px;color:var(--charcoal-light);line-height:1.7}
.pub-list-simple{display:grid;gap:20px}
.pub-simple{display:grid;grid-template-columns:auto 1fr;gap:20px;background:#fff;border-radius:12px;padding:24px;box-shadow:0 2px 12px rgba(44,36,32,0.06);transition:box-shadow .3s}
.pub-simple:hover{box-shadow:0 8px 32px rgba(44,36,32,0.12)}
.pub-simple-date{display:flex;flex-direction:column;align-items:center;justify-content:center;min-width:72px;padding:12px;background:var(--cream-dark);border-radius:10px;text-align:center}
.pub-simple-day{font-family:'Playfair Display',serif;font-size:28px;font-weight:700;color:var(--terracotta);line-height:1}
.pub-simple-month{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:1px;color:var(--charcoal);margin-top:4px}
.pub-simple-year{font-size:12px;color:var(--charcoal-light);margin-top:2px}
@media(max-width:640px){
.pub-simple{grid-template-columns:1fr}
.pub-simple-date{flex-direction:row;gap:8px;min-width:auto;justify-content:flex-start;padding:8px 16px}
.pub-simple-day{font-size:20px}
}

/* ====== VALUES ====== */
.value-card{background:#fff;border-radius:12px;padding:24px;text-align:center;transition:box-shadow .3s}
.value-card:hover{box-shadow:0 8px 32px rgba(44,36,32,0.12)}
.value-icon{width:48px;height:48px;margin:0 auto;color:var(--terracotta)}
.value-icon svg{width:100%;height:100%}
.value-title{margin-top:16px;font-family:'Playfair Display',serif;font-size:16px;font-weight:600;color:var(--charcoal)}
.value-desc{margin-top:8px;font-size:14px;color:var(--charcoal-light);line-height:1.6}

/* ====== TEAM ====== */
.team-card{background:var(--cream);border-radius:8px;padding:20px;display:flex;align-items:center;gap:16px}
.team-avatar{width:56px;height:56px;border-radius:50%;background:var(--terracotta-light);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.team-avatar span{font-family:'Playfair Display',serif;font-size:18px;font-weight:600;color:var(--terracotta)}
.team-name{font-weight:600;font-size:14px;color:var(--charcoal)}
.team-role{font-size:12px;color:var(--terracotta);margin-top:2px}

/* ====== TIMELINE ====== */
.timeline{position:relative;padding-left:24px}
.timeline::before{content:'';position:absolute;left:6px;top:0;bottom:0;width:2px;background:rgba(44,36,32,0.15)}
.timeline-item{position:relative;margin-bottom:32px}
.timeline-item:last-child{margin-bottom:0}
.timeline-dot{position:absolute;left:-22px;top:4px;width:12px;height:12px;border-radius:50%;background:var(--terracotta)}
.timeline-year{font-family:'Playfair Display',serif;font-size:18px;font-weight:600;color:var(--terracotta)}
.timeline-text{margin-top:4px;font-size:14px;color:var(--charcoal-light)}

/* ====== BOARD GRID ====== */
.board-grid{display:grid;gap:16px}
@media(min-width:640px){.board-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1024px){.board-grid{grid-template-columns:repeat(3,1fr)}}

/* ====== NZAU FAMILY ====== */
.nzau-section{background:var(--terracotta);padding:80px 24px;text-align:center}
.nzau-section .section-label{color:var(--gold)}
.nzau-section .section-line{background:var(--gold);margin-left:auto;margin-right:auto}
.nzau-section h2{color:#fff}
.nzau-section blockquote{font-family:'Playfair Display',serif;font-size:clamp(1.1rem,2vw,1.3rem);color:rgba(255,255,255,0.9);font-style:italic;line-height:1.6;max-width:700px;margin:24px auto 0}
.nzau-section p{margin-top:16px;font-size:17px;color:rgba(255,255,255,0.85);max-width:700px;margin-left:auto;margin-right:auto}

/* ====== LEMBA ====== */
.lemba-section{background:var(--cream);padding:80px 0}

/* ====== PROGRAMS PAGE ====== */
.need-block{display:grid;gap:32px;margin-bottom:64px}
@media(min-width:1024px){.need-block{grid-template-columns:1fr 1fr;align-items:center}}
.need-block.reverse .need-img{order:2}
.need-block.reverse .need-text{order:1}
.need-img{border-radius:12px;overflow:hidden;box-shadow:0 8px 32px rgba(44,36,32,0.08)}
.need-img img{width:100%;height:100%;object-fit:cover;aspect-ratio:16/10}
.need-text h3{font-family:'Playfair Display',serif;font-size:22px;font-weight:600;color:var(--charcoal)}
.need-text p{margin-top:16px;color:var(--charcoal-light);line-height:1.7}
.need-stat{display:inline-block;margin-top:16px;padding:8px 16px;background:var(--terracotta-light);border-radius:9999px;color:var(--terracotta);font-size:14px;font-weight:600}

/* Education bullets */
.bullet-list{margin-top:16px;space-y:8px}
.bullet-list li{display:flex;align-items:flex-start;gap:8px;color:var(--charcoal);font-size:14px;margin-bottom:8px}
.bullet-list li::before{content:'';width:6px;height:6px;border-radius:50%;background:var(--terracotta);margin-top:7px;flex-shrink:0}

/* Training cards */
.training-grid{display:grid;gap:16px}
@media(min-width:640px){.training-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1024px){.training-grid{grid-template-columns:repeat(3,1fr)}}
.training-card{background:var(--cream);border-radius:8px;padding:20px;transition:box-shadow .3s}
.training-card:hover{box-shadow:0 8px 32px rgba(44,36,32,0.08)}
.training-icon{width:48px;height:48px;border-radius:50%;background:var(--terracotta-light);display:flex;align-items:center;justify-content:center;margin-bottom:12px}
.training-icon svg{width:24px;height:24px;color:var(--terracotta)}

/* Value pillars */
.pillar-card{background:#fff;border-radius:16px;padding:32px;text-align:center}
.pillar-icon{width:64px;height:64px;border-radius:50%;background:var(--terracotta-light);display:flex;align-items:center;justify-content:center;margin:0 auto 16px}
.pillar-icon svg{width:32px;height:32px;color:var(--terracotta)}
.pillar-title{font-family:'Playfair Display',serif;font-size:18px;font-weight:600;color:var(--charcoal)}
.pillar-desc{margin-top:8px;font-size:14px;color:var(--charcoal-light);line-height:1.6}

/* Community impact block */
.impact-block{background:var(--sage);border-radius:16px;padding:32px;text-align:center}
.impact-block h3{font-family:'Playfair Display',serif;font-size:18px;font-weight:600;color:#fff}
.impact-block p{margin-top:12px;font-size:14px;color:rgba(255,255,255,0.85);line-height:1.6}
.impact-block a{margin-top:12px;display:inline-flex;align-items:center;gap:4px;color:#fff;font-weight:600;transition:gap .2s}
.impact-block a:hover{gap:8px}

/* ====== ACHIEVEMENTS ====== */
.community-grid{display:grid;gap:16px}
@media(min-width:640px){.community-grid{grid-template-columns:repeat(2,1fr)}}
.community-card{background:rgba(255,255,255,0.08);border:1px solid rgba(255,255,255,0.15);border-radius:12px;padding:24px}
.community-icon{width:40px;height:40px;border-radius:50%;background:rgba(212,168,67,0.2);display:flex;align-items:center;justify-content:center;margin-bottom:12px}
.community-icon svg{width:20px;height:20px;color:var(--gold)}
.community-card h4{font-family:'Playfair Display',serif;font-size:16px;font-weight:600;color:#fff}
.community-card p{margin-top:8px;font-size:14px;color:rgba(255,255,255,0.8);line-height:1.6}

/* ====== SUPPORT PAGE ====== */
.donation-grid{display:grid;gap:24px}
@media(min-width:640px){.donation-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1024px){.donation-grid{grid-template-columns:repeat(4,1fr)}}
.donation-card{background:#fff;border-radius:12px;box-shadow:0 8px 32px rgba(44,36,32,0.08);padding:24px;display:flex;flex-direction:column;transition:all .3s}
.donation-card:hover{transform:translateY(-4px);box-shadow:0 16px 48px rgba(44,36,32,0.12)}
.donation-icon{width:56px;height:56px;border-radius:50%;background:var(--terracotta-light);display:flex;align-items:center;justify-content:center;margin-bottom:16px;transition:all .3s}
.donation-card:hover .donation-icon{background:var(--terracotta)}
.donation-card:hover .donation-icon svg{color:#fff}
.donation-icon svg{width:28px;height:28px;color:var(--terracotta);transition:color .3s}
.donation-title{font-family:'Playfair Display',serif;font-size:16px;font-weight:600;color:var(--charcoal)}
.donation-desc{margin-top:8px;font-size:14px;color:var(--charcoal-light);line-height:1.6;flex:1}
.donation-btn{margin-top:16px;padding:8px 20px;border-radius:9999px;font-size:14px;font-weight:500;transition:all .2s;display:inline-block;text-align:center}
.donation-btn-primary{background:var(--terracotta);color:#fff}
.donation-btn-primary:hover{background:var(--terracotta-dark)}
.donation-btn-outline{border:1px solid var(--terracotta);color:var(--terracotta)}
.donation-btn-outline:hover{background:var(--terracotta);color:#fff}

/* Material cards */
.material-grid{display:grid;gap:24px}
@media(min-width:640px){.material-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1024px){.material-grid{grid-template-columns:repeat(4,1fr)}}
.material-card{background:#fff;border-radius:12px;padding:24px;box-shadow:0 8px 32px rgba(44,36,32,0.08);transition:box-shadow .3s}
.material-card:hover{box-shadow:0 16px 48px rgba(44,36,32,0.12)}

/* Volunteering */
.volunteer-section{background:var(--terracotta);padding:80px 0}
.volunteer-section h2{color:#fff}
.volunteer-section p{color:rgba(255,255,255,0.9)}
.volunteer-section ul li{color:rgba(255,255,255,0.9)}

/* Other ways */
.ways-grid{display:grid;gap:24px}
@media(min-width:768px){.ways-grid{grid-template-columns:repeat(3,1fr)}}

/* ====== FAQ ====== */
.faq-item{border-bottom:1px solid rgba(44,36,32,0.1)}
.faq-question{width:100%;display:flex;align-items:center;justify-content:space-between;padding:20px 0;text-align:left;cursor:pointer}
.faq-question span{font-family:'Playfair Display',serif;font-size:16px;color:var(--charcoal);padding-right:16px}
.faq-question svg{width:20px;height:20px;color:var(--terracotta);transition:transform .3s;flex-shrink:0}
.faq-question.active svg{transform:rotate(45deg)}
.faq-answer{max-height:0;overflow:hidden;transition:max-height .4s ease,padding .4s ease}
.faq-answer.open{max-height:300px;padding-bottom:20px}
.faq-answer p{font-size:14px;color:var(--charcoal-light);line-height:1.6}

/* ====== CONTACT PAGE ====== */
.contact-grid{display:grid;gap:24px}
@media(min-width:1024px){.contact-grid{grid-template-columns:repeat(4,1fr)}}
@media(min-width:640px) and (max-width:1023px){.contact-grid{grid-template-columns:repeat(2,1fr)}}
.contact-card{background:#fff;border-radius:12px;padding:24px;box-shadow:0 2px 8px rgba(44,36,32,0.08);transition:all .3s;height:100%}
.contact-card:hover{box-shadow:0 8px 32px rgba(44,36,32,0.12)}
.contact-icon{width:48px;height:48px;border-radius:50%;background:var(--terracotta-light);display:flex;align-items:center;justify-content:center;margin-bottom:16px;transition:all .3s}
.contact-card:hover .contact-icon{background:var(--terracotta)}
.contact-card:hover .contact-icon svg{color:#fff}
.contact-icon svg{width:24px;height:24px;color:var(--terracotta);transition:color .3s}
.contact-title{font-family:'Playfair Display',serif;font-size:16px;font-weight:600;color:var(--charcoal)}
.contact-detail{margin-top:8px;font-size:14px;color:var(--charcoal-light);line-height:1.6}
.contact-detail a{color:var(--terracotta-light)}
.contact-detail a:hover{color:var(--terracotta)}

/* Mobile money */
.mm-grid{display:grid;gap:12px}
@media(min-width:640px){.mm-grid{grid-template-columns:repeat(3,1fr)}}
.mm-item{background:#fff;border-radius:8px;padding:12px;text-align:center;font-size:13px}
.mm-item strong{color:var(--charcoal)}

/* Contact form */
.form-row{display:grid;gap:24px}
@media(min-width:640px){.form-row{grid-template-columns:1fr 1fr}}
.form-group{margin-bottom:24px}
.form-group label{display:block;font-size:14px;font-weight:500;color:var(--charcoal);margin-bottom:8px}
.form-group label .required{color:#e53e3e}
.form-input{width:100%;padding:12px 16px;background:var(--cream);border:1px solid rgba(44,36,32,0.1);border-radius:8px;font-size:15px;color:var(--charcoal);transition:all .2s}
.form-input::placeholder{color:rgba(44,36,32,0.4)}
.form-input:focus{outline:none;border-color:var(--terracotta);box-shadow:0 0 0 3px rgba(199,92,46,0.1)}
.form-input.error{border-color:#e53e3e}
textarea.form-input{resize:vertical;min-height:160px}
select.form-input{cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%23C75C2E' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:40px}
.form-error{font-size:12px;color:#e53e3e;margin-top:4px}

/* Form success */
.form-success{text-align:center;padding:48px 0}
.form-success-icon{width:64px;height:64px;border-radius:50%;background:var(--sage-light);display:flex;align-items:center;justify-content:center;margin:0 auto 16px}
.form-success-icon svg{width:32px;height:32px;color:var(--sage)}

/* Map & address */
.map-block{background:var(--cream);border-radius:12px;min-height:300px;display:flex;align-items:center;justify-content:center;position:relative}
.address-block{background:#fff;border-radius:12px;padding:32px;height:100%}

/* Social */
.social-section{text-align:center;padding:48px 24px}
.social-icons{display:flex;justify-content:center;gap:16px;margin-top:24px}
.social-icon{width:56px;height:56px;border-radius:50%;background:var(--terracotta);display:flex;align-items:center;justify-content:center;color:#fff;transition:all .2s}
.social-icon:hover{transform:scale(1.1);box-shadow:0 8px 32px rgba(44,36,32,0.12)}

/* ====== FOOTER ====== */
.footer{background:var(--charcoal);color:var(--cream);padding-top:64px;padding-bottom:32px}
.footer-grid{display:grid;gap:40px}
@media(min-width:768px){.footer-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1024px){.footer-grid{grid-template-columns:1.2fr 1fr 1fr 1.2fr}}
.footer-logo{display:flex;align-items:center;gap:8px;margin-bottom:16px}
.footer-logo svg{color:var(--sage);width:20px;height:20px}
.footer-logo span{font-family:'Playfair Display',serif;font-size:14px;font-weight:700;text-transform:uppercase;letter-spacing:0.5px;color:#fff}
.footer-text{font-size:14px;color:rgba(247,242,236,0.6);line-height:1.6;margin-bottom:16px}
.footer-address{display:flex;align-items:flex-start;gap:8px;font-size:14px;color:rgba(247,242,236,0.6)}
.footer-address svg{color:var(--gold);width:16px;height:16px;margin-top:3px;flex-shrink:0}
.footer-heading{color:var(--gold);font-size:12px;font-weight:600;letter-spacing:0.12em;text-transform:uppercase;margin-bottom:16px}
.footer-links{display:flex;flex-direction:column;gap:10px}
.footer-links a{font-size:14px;color:rgba(247,242,236,0.6);transition:color .2s}
.footer-links a:hover{color:var(--gold)}
.footer-contact{display:flex;flex-direction:column;gap:12px}
.footer-contact-item{display:flex;align-items:center;gap:8px;font-size:14px;color:rgba(247,242,236,0.6)}
.footer-contact-item svg{color:var(--gold);width:16px;height:16px;flex-shrink:0}
.footer-socials{display:flex;gap:8px;margin-top:16px}
.footer-social{width:40px;height:40px;border-radius:50%;background:rgba(255,255,255,0.1);display:flex;align-items:center;justify-content:center;color:#fff;transition:background .2s}
.footer-social:hover{background:var(--terracotta)}
.footer-newsletter-input{display:flex;gap:8px}
.footer-newsletter-input input{flex:1;min-width:0;padding:10px 16px;background:rgba(255,255,255,0.08);border:1px solid rgba(255,255,255,0.15);border-radius:9999px;color:#fff;font-size:14px}
.footer-newsletter-input input::placeholder{color:rgba(247,242,236,0.4)}
.footer-newsletter-input button{padding:10px 16px;background:var(--terracotta);color:#fff;font-size:14px;font-weight:500;border-radius:9999px;transition:background .2s;white-space:nowrap}
.footer-newsletter-input button:hover{background:var(--terracotta-dark)}
.footer-bar{border-top:1px solid rgba(255,255,255,0.08);margin-top:48px;padding-top:24px;display:flex;flex-direction:column;align-items:center;gap:8px;font-size:12px;color:rgba(247,242,236,0.4)}
@media(min-width:640px){.footer-bar{flex-direction:row;justify-content:space-between}}

/* ====== BACK TO TOP ====== */
.back-to-top{position:fixed;bottom:24px;right:24px;width:48px;height:48px;border-radius:50%;background:var(--terracotta);color:#fff;display:flex;align-items:center;justify-content:center;z-index:50;opacity:0;transform:translateY(20px);transition:all .3s;pointer-events:none}
.back-to-top.visible{opacity:1;transform:translateY(0);pointer-events:all}
.back-to-top:hover{transform:scale(1.1);box-shadow:0 0 24px rgba(199,92,46,0.25)}

/* ====== SCROLL ANIMATIONS ====== */
.reveal{opacity:0;transform:translateY(30px);transition:opacity .6s ease,transform .6s cubic-bezier(0.25,0.46,0.45,0.94)}
.reveal.revealed{opacity:1;transform:translateY(0)}
.reveal-left{opacity:0;transform:translateX(-40px);transition:opacity .6s ease,transform .6s cubic-bezier(0.25,0.46,0.45,0.94)}
.reveal-left.revealed{opacity:1;transform:translateX(0)}
.reveal-right{opacity:0;transform:translateX(40px);transition:opacity .6s ease,transform .6s cubic-bezier(0.25,0.46,0.45,0.94)}
.reveal-right.revealed{opacity:1;transform:translateX(0)}

/* Delays */
.delay-1{transition-delay:.1s}.delay-2{transition-delay:.2s}.delay-3{transition-delay:.3s}
.delay-4{transition-delay:.4s}.delay-5{transition-delay:.5s}

/* ====== ANIMATIONS ====== */
@keyframes bounceSlow{0%,100%{transform:translateY(0)}50%{transform:translateY(8px)}}
@keyframes spin{from{transform:rotate(0)}to{transform:rotate(360deg)}}
.animate-bounce-slow{animation:bounceSlow 1.5s ease-in-out infinite}
.animate-spin{animation:spin 1s linear infinite}

/* ====== RESPONSIVE HEADER ====== */
@media(max-width:1023px){
  .header-nav{display:none}
  .header-hamburger{display:block}
  .header-inner{height:64px}
}
@media(max-width:639px){
  .header-cta span{display:none}
  .header-cta{padding:8px}
}

/* ====== HERO SLIDER ====== */
.slider-slide{position:absolute;inset:0;background-size:cover;background-position:center;opacity:0;transition:opacity 1s ease}
.slider-slide.active{opacity:1}

/* ====== PAGE HERO ====== */
.page-hero{position:relative;width:100%;min-height:50vh;max-height:500px;display:flex;align-items:center;justify-content:center;overflow:hidden}
.page-hero-bg{position:absolute;inset:0;background-size:cover;background-position:center;background-attachment:fixed}
.page-hero-overlay{position:absolute;inset:0;background:rgba(44,36,32,0.55)}
.page-hero-content{position:relative;z-index:2;max-width:800px;margin:0 auto;padding:80px 24px;text-align:center}

/* ====== MISC ====== */
.text-center{text-align:center}
.mt-1{margin-top:4px}.mt-2{margin-top:8px}.mt-3{margin-top:12px}.mt-4{margin-top:16px}
.mt-6{margin-top:24px}.mt-8{margin-top:32px}.mt-10{margin-top:40px}.mt-12{margin-top:48px}
.mt-16{margin-top:64px}
.mb-4{margin-bottom:16px}.mb-6{margin-bottom:24px}.mb-8{margin-bottom:32px}
.mb-12{margin-bottom:48px}
.py-4{padding-top:16px;padding-bottom:16px}
.gap-2{gap:8px}.gap-3{gap:12px}.gap-4{gap:16px}.gap-6{gap:24px}.gap-8{gap:32px}
.flex{display:flex}.flex-col{flex-direction:column}
.flex-wrap{flex-wrap:wrap}
.items-center{align-items:center}.items-start{align-items:flex-start}
.justify-center{justify-content:center}
.space-y-3>*+*{margin-top:12px}.space-y-4>*+*{margin-top:16px}
.space-y-6>*+*{margin-top:24px}
.leading-relaxed{line-height:1.7}
.line-clamp-3{display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
.inline-flex{display:inline-flex}
.inline-block{display:inline-block}
.grid{display:grid}
.shrink-0{flex-shrink:0}
.flex-1{flex:1}
.w-full{width:100%}.h-full{height:100%}
.max-w-2xl{max-width:640px}.max-w-lg{max-width:512px}
.mx-auto{margin-left:auto;margin-right:auto}
.hidden{display:none}
@media(min-width:640px){.sm\\:grid-cols-2{grid-template-columns:repeat(2,1fr)}.sm\\:flex-row{flex-direction:row}.sm\\:inline-flex{display:inline-flex}}
@media(min-width:768px){.md\\:grid-cols-2{grid-template-columns:repeat(2,1fr)}.md\\:grid-cols-3{grid-template-columns:repeat(3,1fr)}.md\\:flex-row{flex-direction:row}}
@media(min-width:1024px){.lg\\:grid-cols-2{grid-template-columns:repeat(2,1fr)}.lg\\:grid-cols-3{grid-template-columns:repeat(3,1fr)}.lg\\:grid-cols-4{grid-template-columns:repeat(4,1fr)}.lg\\:flex{display:flex}.lg\\:hidden{display:none}}

/* ====== GALLERY & ALBUMS ====== */
.album-grid{display:grid;gap:16px;grid-template-columns:repeat(2,1fr)}
@media(min-width:640px){.album-grid{grid-template-columns:repeat(3,1fr);gap:20px}}
@media(min-width:1024px){.album-grid{grid-template-columns:repeat(4,1fr)}}
.album-photo{position:relative;border-radius:12px;overflow:hidden;cursor:pointer;aspect-ratio:1;background:var(--cream-dark)}
.album-photo img{width:100%;height:100%;object-fit:cover;transition:transform .4s ease}
.album-photo:hover img{transform:scale(1.05)}
.album-photo-overlay{position:absolute;inset:0;background:rgba(44,36,32,0);display:flex;align-items:center;justify-content:center;transition:background .3s}
.album-photo:hover .album-photo-overlay{background:rgba(44,36,32,0.3)}
.album-photo-overlay svg{color:#fff;opacity:0;transform:scale(0.8);transition:all .3s;width:32px;height:32px}
.album-photo:hover .album-photo-overlay svg{opacity:1;transform:scale(1)}

/* ====== LIGHTBOX ====== */
.lightbox{position:fixed;inset:0;z-index:1000;background:rgba(44,36,32,0.95);display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .3s}
.lightbox.active{opacity:1;pointer-events:all}
.lightbox-img{max-width:90vw;max-height:85vh;object-fit:contain;border-radius:8px;box-shadow:0 24px 64px rgba(0,0,0,0.4)}
.lightbox-close{position:absolute;top:20px;right:20px;width:44px;height:44px;border-radius:50%;background:rgba(255,255,255,0.1);display:flex;align-items:center;justify-content:center;color:#fff;cursor:pointer;transition:background .2s;border:none;z-index:10}
.lightbox-close:hover{background:rgba(255,255,255,0.2)}
.lightbox-prev,.lightbox-next{position:absolute;top:50%;transform:translateY(-50%);width:48px;height:48px;border-radius:50%;background:rgba(255,255,255,0.1);display:flex;align-items:center;justify-content:center;color:#fff;cursor:pointer;transition:background .2s;border:none;z-index:10}
.lightbox-prev:hover,.lightbox-next:hover{background:rgba(255,255,255,0.25)}
.lightbox-prev{left:20px}
.lightbox-next{right:20px}
.lightbox-counter{position:absolute;bottom:20px;left:50%;transform:translateX(-50%);color:rgba(255,255,255,0.7);font-size:14px;font-weight:500}

/* Album header breadcrumb */
.album-breadcrumb{display:flex;align-items:center;gap:8px;margin-top:16px;font-size:14px;color:rgba(255,255,255,0.7)}
.album-breadcrumb a{color:var(--gold);transition:color .2s}
.album-breadcrumb a:hover{color:#fff}
.album-breadcrumb span{color:rgba(255,255,255,0.5)}

/* Album nav arrows shared */
.album-nav-btn{position:fixed;top:50%;transform:translateY(-50%);width:48px;height:48px;border-radius:50%;background:rgba(255,255,255,0.1);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;color:#fff;cursor:pointer;transition:all .2s;border:none;z-index:1001}
.album-nav-btn:hover{background:var(--terracotta)}
.album-nav-btn.prev{left:16px}
.album-nav-btn.next{right:16px}
@media(max-width:639px){.album-nav-btn.prev{left:8px}.album-nav-btn.next{right:8px}.album-nav-btn{width:40px;height:40px}}
