/* ============================================================
   CAREPATH NGO — MAIN STYLESHEET
   DM Sans · Forest Green · Amber · Coral · Cream
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=DM+Sans:ital,opsz,wght@0,9..40,300;0,9..40,400;0,9..40,500;0,9..40,600;0,9..40,700;0,9..40,800;0,9..40,900;1,9..40,400&display=swap');

/* ===== TOKENS ===== */
:root {
  --g-900: #040f08;
  --g-800: #0a1f12;
  --g-700: #0e3a28;
  --g-600: #1b5e42;
  --g-500: #2d8a60;
  --g-400: #52b384;
  --g-100: #c6e8d7;
  --amber:  #f2a71b;
  --amber-l:#ffca47;
  --coral:  #e8503a;
  --coral-l:#ff7a62;
  --cream:  #fbf7f0;
  --cream-d:#ede6d8;
  --cream-dd:#dfd5c5;
  --white:  #ffffff;
  --text:   #1c3828;
  --muted:  #6b8577;

  --font: 'DM Sans', sans-serif;
  --ease: cubic-bezier(0.16, 1, 0.3, 1);
  --ease-in: cubic-bezier(0.4, 0, 1, 1);

  --r-sm: 0.5rem;
  --r-md: 1rem;
  --r-lg: 1.75rem;
  --r-xl: 3rem;

  --sh-sm: 0 2px 16px rgba(14,58,40,.07);
  --sh-md: 0 8px 40px rgba(14,58,40,.11);
  --sh-lg: 0 24px 80px rgba(14,58,40,.16);
}

/* ===== RESET ===== */
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; font-size:16px; }
body { font-family:var(--font); background:var(--cream); color:var(--text); line-height:1.65; overflow-x:hidden; }
img  { max-width:100%; display:block; }
a    { text-decoration:none; color:inherit; }
ul   { list-style:none; }
button { cursor:pointer; font-family:var(--font); border:none; outline:none; background:none; }
input, textarea, select { font-family:var(--font); }

/* ===== GRAIN ===== */
body::after {
  content:'';
  position:fixed; inset:0;
  pointer-events:none;
  z-index:9998;
  opacity:.028;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

/* ===== CONTAINER ===== */
.container { width:90%; max-width:1300px; margin:0 auto; }
.container--sm { width:90%; max-width:880px; margin:0 auto; }

/* ===== TYPOGRAPHY ===== */
.disp-xl {
  font-size: clamp(3.2rem, 8vw, 7.5rem);
  font-weight:900; line-height:1.0; letter-spacing:-0.035em;
}
.disp-lg {
  font-size: clamp(2.5rem, 5.5vw, 5rem);
  font-weight:800; line-height:1.05; letter-spacing:-0.03em;
}
.disp-md {
  font-size: clamp(2rem, 4vw, 3.2rem);
  font-weight:700; line-height:1.1; letter-spacing:-0.025em;
}
.disp-sm {
  font-size: clamp(1.6rem, 3vw, 2.25rem);
  font-weight:700; line-height:1.15; letter-spacing:-0.02em;
}
.body-lg { font-size:1.125rem; line-height:1.75; }
.body-md { font-size:1rem; line-height:1.7; }
.body-sm { font-size:0.875rem; line-height:1.65; }
.label {
  font-size:.72rem; font-weight:700; letter-spacing:.18em;
  text-transform:uppercase; display:inline-flex; align-items:center; gap:.5rem;
  color:var(--amber);
}
.label::before {
  content:''; display:block; width:1.75rem; height:2px; background:var(--amber);
}
.label--light { color:rgba(251,247,240,.5); }
.label--light::before { background:rgba(251,247,240,.4); }

.tc { text-align:center; }
.amber { color:var(--amber); }
.coral { color:var(--coral); }
.muted { color:var(--muted); }
.cream { color:var(--cream); }

/* Underline highlight */
.hl { position:relative; display:inline-block; }
.hl::after {
  content:''; position:absolute; bottom:.08em; left:-.04em; right:-.04em;
  height:.28em; background:var(--amber); opacity:.35; z-index:-1; border-radius:3px;
  transform:skew(-4deg);
}

/* ===== BUTTONS ===== */
.btn {
  display:inline-flex; align-items:center; gap:.5rem;
  padding:.9rem 2rem; border-radius:100px;
  font-size:.9rem; font-weight:700;
  transition:all .35s var(--ease);
  border:2px solid transparent; cursor:pointer;
  position:relative; overflow:hidden;
  white-space:nowrap;
}
.btn svg,
.btn i { transition:transform .3s var(--ease); }
.btn:hover svg,
.btn:hover i { transform:translateX(4px); }

.btn--primary {
  background:var(--amber); color:var(--g-800);
  border-color:var(--amber);
}
.btn--primary:hover {
  background:var(--amber-l); border-color:var(--amber-l);
  transform:translateY(-3px);
  box-shadow:0 10px 30px rgba(242,167,27,.4);
}
.btn--white {
  background:var(--white); color:var(--g-700);
  border-color:var(--white);
}
.btn--white:hover {
  background:var(--cream); transform:translateY(-3px);
  box-shadow:0 10px 30px rgba(255,255,255,.2);
}
.btn--outline {
  background:transparent; color:var(--cream);
  border-color:rgba(255,255,255,.35);
}
.btn--outline:hover {
  background:rgba(255,255,255,.1); border-color:rgba(255,255,255,.7);
  transform:translateY(-3px);
}
.btn--outline-dark {
  background:transparent; color:var(--g-700);
  border-color:var(--g-600);
}
.btn--outline-dark:hover {
  background:var(--g-700); color:var(--cream);
  transform:translateY(-3px);
}
.btn--coral {
  background:var(--coral); color:var(--white);
  border-color:var(--coral);
}
.btn--coral:hover {
  background:var(--coral-l); border-color:var(--coral-l);
  transform:translateY(-3px);
  box-shadow:0 10px 30px rgba(232,80,58,.4);
}
.btn--lg { padding:1.1rem 2.75rem; font-size:1rem; }
.btn--sm { padding:.6rem 1.25rem; font-size:.8rem; }
.btn--full { width:100%; justify-content:center; }

/* ===== BADGE ===== */
.badge {
  display:inline-block; padding:.28rem .85rem;
  border-radius:100px; font-size:.7rem; font-weight:700;
  letter-spacing:.06em; text-transform:uppercase;
}
.badge--green  { background:rgba(45,138,96,.12); color:var(--g-500); }
.badge--amber  { background:rgba(242,167,27,.15); color:#9a6900; }
.badge--coral  { background:rgba(232,80,58,.1); color:var(--coral); }
.badge--cream  { background:rgba(251,247,240,.15); color:var(--cream); border:1px solid rgba(251,247,240,.25); }

/* ===== HEADER ===== */
.header {
  position:fixed; top:0; left:0; right:0; z-index:1000;
  padding:1.4rem 0;
  transition:all .45s var(--ease);
}
.header.scrolled {
  background:rgba(4,15,8,.95);
  backdrop-filter:blur(24px);
  padding:.9rem 0;
  box-shadow:0 4px 40px rgba(0,0,0,.25);
}
.header-inner {
  display:flex; align-items:center; justify-content:space-between; gap:1rem;
}
.logo { display:flex; align-items:center; gap:.7rem; }
.logo-icon {
  width:42px; height:42px; background:var(--amber); border-radius:12px;
  display:flex; align-items:center; justify-content:center; flex-shrink:0;
}
.logo-icon svg { width:22px; height:22px; fill:var(--g-800); }
.logo-name { font-weight:900; font-size:1.3rem; color:var(--white); letter-spacing:-.03em; }
.logo-name em { font-style:normal; color:var(--amber); }

.nav { display:flex; align-items:center; gap:.15rem; }
.nav-link {
  color:rgba(255,255,255,.75); font-size:.88rem; font-weight:500;
  padding:.45rem .9rem; border-radius:6px; transition:all .2s;
}
.nav-link:hover, .nav-link.active { color:var(--white); background:rgba(255,255,255,.09); }
.nav-cta { margin-left:1rem; }

/* Hamburger */
.hamburger { display:none; flex-direction:column; gap:5px; padding:8px; }
.hamburger span {
  display:block; width:24px; height:2px;
  background:var(--white); border-radius:2px; transition:all .3s var(--ease);
}
.hamburger.active span:nth-child(1) { transform:translateY(7px) rotate(45deg); }
.hamburger.active span:nth-child(2) { opacity:0; transform:scaleX(0); }
.hamburger.active span:nth-child(3) { transform:translateY(-7px) rotate(-45deg); }

/* Mobile menu */
.mob-menu {
  display:none; position:fixed; inset:0;
  background:var(--g-800); z-index:999;
  padding:5.5rem 2rem 2rem;
  flex-direction:column; gap:.75rem;
  transform:translateX(100%);
  transition:transform .45s var(--ease);
  overflow-y:auto;
}
.mob-menu.open { transform:translateX(0); }
.mob-menu-link {
  font-size:2.2rem; font-weight:800; color:var(--cream);
  display:block; padding:.4rem 0;
  border-bottom:1px solid rgba(255,255,255,.08);
  transition:color .2s;
}
.mob-menu-link:hover { color:var(--amber); }

/* ===== FOOTER ===== */
.footer {
  background:var(--g-800); color:var(--cream);
  padding:5.5rem 0 2rem;
}
.footer-grid {
  display:grid; grid-template-columns:2fr 1fr 1fr 1fr;
  gap:3rem; margin-bottom:3.5rem;
}
.footer-brand-desc {
  font-size:.88rem; color:rgba(251,247,240,.55);
  line-height:1.8; margin:1rem 0 1.5rem;
}
.footer-socials { display:flex; gap:.6rem; }
.soc-btn {
  width:36px; height:36px; border-radius:9px;
  background:rgba(255,255,255,.08);
  display:flex; align-items:center; justify-content:center;
  color:var(--cream); transition:all .2s;
}
.soc-btn:hover { background:var(--amber); color:var(--g-800); transform:translateY(-3px); }
.soc-btn svg { width:16px; height:16px; fill:currentColor; }

.footer-col h4 {
  font-size:.72rem; font-weight:700; letter-spacing:.15em;
  text-transform:uppercase; color:var(--amber); margin-bottom:1.25rem;
}
.footer-col li { margin-bottom:.65rem; }
.footer-col a {
  color:rgba(251,247,240,.55); font-size:.88rem; transition:color .2s;
}
.footer-col a:hover { color:var(--cream); }

.footer-bottom {
  border-top:1px solid rgba(255,255,255,.08);
  padding-top:2rem;
  display:flex; align-items:center; justify-content:space-between; flex-wrap:wrap; gap:1rem;
}
.footer-bottom p { font-size:.78rem; color:rgba(251,247,240,.35); }

/* ===== PAGE HERO ===== */
.page-hero {
  background:var(--g-700); color:var(--cream);
  padding:13rem 0 7rem; position:relative; overflow:hidden;
}
.page-hero::before {
  content:''; position:absolute; top:-40%; right:-15%;
  width:55vw; height:55vw; border-radius:50%;
  background:radial-gradient(circle, rgba(242,167,27,.14) 0%, transparent 70%);
  pointer-events:none;
}
.page-hero::after {
  content:''; position:absolute; bottom:-30%; left:-10%;
  width:40vw; height:40vw; border-radius:50%;
  background:radial-gradient(circle, rgba(232,80,58,.08) 0%, transparent 65%);
  pointer-events:none;
}

/* ===== SECTIONS ===== */
.section { padding:7rem 0; }
.section--dark  { background:var(--g-700); color:var(--cream); }
.section--darker{ background:var(--g-800); color:var(--cream); }
.section--amber { background:var(--amber); color:var(--g-800); }
.section--white { background:var(--white); }
.section--cream { background:var(--cream); }

/* ===== CARDS ===== */
.card {
  background:var(--white); border-radius:var(--r-lg);
  overflow:hidden; transition:all .45s var(--ease);
  box-shadow:var(--sh-sm);
}
.card:hover { transform:translateY(-10px); box-shadow:var(--sh-lg); }
.card-img { width:100%; height:225px; object-fit:cover; display:block; }
.card-body { padding:1.75rem; }
.card-meta {
  display:flex; align-items:center; gap:.75rem;
  font-size:.75rem; font-weight:600; color:var(--muted);
  margin-bottom:.75rem;
}

/* ===== STAT ===== */
.stat-num {
  font-size:clamp(2.5rem, 5vw, 4.5rem);
  font-weight:900; letter-spacing:-.04em; line-height:1;
  color:var(--amber); display:block;
}
.stat-lbl {
  font-size:.78rem; font-weight:600; letter-spacing:.1em;
  text-transform:uppercase; color:rgba(251,247,240,.5);
  margin-top:.5rem; display:block;
}

/* ===== GRID HELPERS ===== */
.g2 { display:grid; grid-template-columns:repeat(2,1fr); gap:1.5rem; }
.g3 { display:grid; grid-template-columns:repeat(3,1fr); gap:1.5rem; }
.g4 { display:grid; grid-template-columns:repeat(4,1fr); gap:1.5rem; }
.g-auto { display:grid; grid-template-columns:repeat(auto-fit,minmax(280px,1fr)); gap:1.5rem; }

/* ===== FORMS ===== */
.form-row { margin-bottom:1.25rem; }
.form-label { display:block; font-size:.85rem; font-weight:600; margin-bottom:.45rem; color:var(--text); }
.form-input {
  width:100%; padding:.9rem 1.15rem;
  border:2px solid var(--cream-d); border-radius:var(--r-sm);
  font-family:var(--font); font-size:.95rem; color:var(--text);
  background:var(--white); transition:border-color .2s; outline:none;
}
.form-input:focus { border-color:var(--g-500); }
.form-input::placeholder { color:var(--muted); }
textarea.form-input { resize:vertical; min-height:130px; }
select.form-input { appearance:none; cursor:pointer; }

/* ===== PROGRESS BAR ===== */
.prog-bar {
  height:6px; background:rgba(255,255,255,.12);
  border-radius:100px; overflow:hidden;
}
.prog-fill {
  height:100%; width:0; background:var(--amber);
  border-radius:100px; transition:width 1.6s var(--ease);
}

/* ===== TABS ===== */
.tabs { display:flex; gap:.5rem; flex-wrap:wrap; }
.tab {
  padding:.55rem 1.25rem; border-radius:100px;
  font-size:.85rem; font-weight:600;
  border:2px solid var(--cream-dd);
  background:transparent; color:var(--muted);
  cursor:pointer; transition:all .25s;
}
.tab.active, .tab:hover {
  background:var(--g-700); color:var(--cream);
  border-color:var(--g-700);
}

/* ===== TICKER ===== */
.ticker { background:var(--amber); color:var(--g-800); overflow:hidden; padding:.6rem 0; }
.ticker-track {
  display:flex; width:max-content;
  animation:ticker-scroll 28s linear infinite;
}
.ticker-track:hover { animation-play-state:paused; }
.ticker-item {
  display:flex; align-items:center; gap:2rem;
  padding:0 2.5rem; font-size:.82rem; font-weight:700;
  letter-spacing:.04em; text-transform:uppercase; white-space:nowrap;
}
.ticker-dot { width:5px; height:5px; border-radius:50%; background:var(--g-800); opacity:.4; }
@keyframes ticker-scroll {
  from { transform:translateX(0); }
  to   { transform:translateX(-50%); }
}

/* ===== REVEAL TARGETS ===== */
.reveal       { opacity:0; transform:translateY(40px); }
.reveal-l     { opacity:0; transform:translateX(-40px); }
.reveal-r     { opacity:0; transform:translateX(40px); }
.reveal-s     { opacity:0; transform:scale(.93); }

/* ===== DIVIDER ===== */
.divider { height:1px; background:var(--cream-d); margin:2rem 0; }

/* ===== MISC ===== */
.icon-box {
  width:56px; height:56px; border-radius:14px;
  display:flex; align-items:center; justify-content:center; flex-shrink:0;
}
.icon-box svg { width:26px; height:26px; }
.icon-box--amber  { background:rgba(242,167,27,.15); color:var(--amber); }
.icon-box--green  { background:rgba(45,138,96,.12); color:var(--g-500); }
.icon-box--coral  { background:rgba(232,80,58,.1); color:var(--coral); }
.icon-box--dark   { background:rgba(255,255,255,.08); color:var(--cream); }

.img-frame {
  border-radius:var(--r-lg); overflow:hidden;
  position:relative; box-shadow:var(--sh-lg);
}
.img-frame img { width:100%; height:100%; object-fit:cover; }

.chip {
  display:inline-flex; align-items:center; gap:.4rem;
  padding:.3rem .8rem; border-radius:100px;
  font-size:.7rem; font-weight:700; letter-spacing:.06em; text-transform:uppercase;
  background:rgba(242,167,27,.15); color:#9a6900;
}
.chip--live { background:rgba(232,80,58,.12); color:var(--coral); }
.chip--green { background:rgba(45,138,96,.12); color:var(--g-500); }

/* ===== Donation page ===== */
.donate-amount {
  display:grid; grid-template-columns:repeat(3,1fr); gap:.75rem;
}
.amt-btn {
  padding:1rem; border-radius:var(--r-md);
  border:2px solid var(--cream-d); background:var(--white);
  font-family:var(--font); font-weight:700; font-size:1.1rem;
  cursor:pointer; transition:all .25s; color:var(--text);
}
.amt-btn.active, .amt-btn:hover {
  border-color:var(--amber); background:rgba(242,167,27,.1); color:var(--g-700);
}
.freq-toggle { display:flex; background:var(--cream-d); border-radius:100px; padding:4px; }
.freq-btn {
  flex:1; padding:.6rem 1.5rem; border-radius:100px;
  font-size:.85rem; font-weight:700; cursor:pointer;
  border:none; background:transparent; color:var(--muted);
  transition:all .25s;
}
.freq-btn.active { background:var(--white); color:var(--g-700); box-shadow:0 2px 8px rgba(0,0,0,.1); }

/* ===== Team cards ===== */
.team-card {
  background:var(--white); border-radius:var(--r-lg);
  overflow:hidden; box-shadow:var(--sh-sm);
  transition:all .45s var(--ease);
}
.team-card:hover { transform:translateY(-8px); box-shadow:var(--sh-lg); }
.team-card-img {
  width:100%; aspect-ratio:1; object-fit:cover;
  background:var(--g-100); display:block;
  position:relative; overflow:hidden;
}
.team-card-img img { width:100%; height:100%; object-fit:cover; }
.team-card-body { padding:1.5rem; }
.team-card-name { font-weight:800; font-size:1.05rem; color:var(--text); }
.team-card-role { font-size:.8rem; color:var(--g-500); font-weight:600; margin-top:.2rem; }
.team-card-bio  { font-size:.83rem; color:var(--muted); margin-top:.75rem; line-height:1.65; }

/* ===== Blog ===== */
.blog-featured {
  background:var(--g-700); border-radius:var(--r-xl);
  overflow:hidden; display:grid; grid-template-columns:1fr 1fr;
  min-height:460px;
}
.blog-featured-img { position:relative; overflow:hidden; }
.blog-featured-img img { width:100%; height:100%; object-fit:cover; opacity:.7; }
.blog-featured-body { padding:3.5rem 3rem; color:var(--cream); display:flex; flex-direction:column; justify-content:flex-end; }

/* ===== Event cards ===== */
.event-card {
  display:flex; gap:1.5rem; align-items:flex-start;
  background:var(--white); border-radius:var(--r-lg);
  padding:1.75rem; box-shadow:var(--sh-sm);
  transition:all .35s var(--ease);
}
.event-card:hover { transform:translateX(6px); box-shadow:var(--sh-md); }
.event-date {
  flex-shrink:0; width:60px; text-align:center;
  padding:.75rem .5rem; background:var(--g-700); border-radius:12px; color:var(--cream);
}
.event-date-day  { font-size:1.6rem; font-weight:900; line-height:1; }
.event-date-mon  { font-size:.68rem; font-weight:700; letter-spacing:.08em; text-transform:uppercase; opacity:.7; }

/* ===== Values grid ===== */
.value-card {
  padding:2rem 1.75rem; border-radius:var(--r-lg);
  background:var(--white); box-shadow:var(--sh-sm);
  transition:all .4s var(--ease); border-bottom:4px solid transparent;
}
.value-card:hover { transform:translateY(-6px); box-shadow:var(--sh-lg); border-bottom-color:var(--amber); }

/* ===== Timeline ===== */
.timeline { position:relative; padding-left:2.5rem; }
.timeline::before {
  content:''; position:absolute; left:10px; top:0; bottom:0;
  width:2px; background:var(--cream-d);
}
.timeline-item { position:relative; margin-bottom:2.5rem; }
.timeline-item::before {
  content:''; position:absolute; left:-2.1rem; top:4px;
  width:14px; height:14px; border-radius:50%;
  background:var(--amber); border:3px solid var(--white);
  box-shadow:0 0 0 3px var(--amber);
}
.timeline-year {
  font-size:.72rem; font-weight:700; letter-spacing:.12em;
  text-transform:uppercase; color:var(--amber); margin-bottom:.25rem;
}

/* ===== Contact ===== */
.contact-info-card {
  background:var(--white); border-radius:var(--r-lg);
  padding:2rem; box-shadow:var(--sh-sm); display:flex; gap:1.25rem;
  align-items:flex-start; transition:all .35s var(--ease);
}
.contact-info-card:hover { transform:translateY(-4px); box-shadow:var(--sh-md); }

/* ===== Map placeholder ===== */
.map-placeholder {
  border-radius:var(--r-lg); overflow:hidden;
  background:var(--g-600); position:relative;
  min-height:380px; display:flex; align-items:center; justify-content:center;
}
.map-placeholder::before {
  content:''; position:absolute; inset:0;
  background:
    radial-gradient(circle at 30% 40%, rgba(242,167,27,.3) 0%, transparent 45%),
    radial-gradient(circle at 70% 65%, rgba(232,80,58,.2) 0%, transparent 40%);
}

/* ===== RESPONSIVE ===== */
@media (max-width:1024px) {
  .footer-grid { grid-template-columns:1fr 1fr; }
  .g4 { grid-template-columns:repeat(2,1fr); }
  .blog-featured { grid-template-columns:1fr; }
  .blog-featured-img { height:280px; }
}
@media (max-width:768px) {
  .section { padding:5rem 0; }
  .nav, .nav-cta { display:none; }
  .hamburger { display:flex; }
  .mob-menu { display:flex; }
  .g2, .g3 { grid-template-columns:1fr; }
  .footer-grid { grid-template-columns:1fr; gap:2rem; }
  .footer-bottom { flex-direction:column; text-align:center; }
  .page-hero { padding:10rem 0 5rem; }
  .donate-amount { grid-template-columns:repeat(2,1fr); }
  .event-card { flex-direction:column; }
}
@media (max-width:480px) {
  .container { width:95%; }
  .g4 { grid-template-columns:1fr; }
  .donate-amount { grid-template-columns:1fr 1fr; }
}