/* ══════════════════════════════════════════════════════════════
   HOPE & CHANCE — SHARED STYLESHEET
   Navy · Teal · Sage · Ivory  |  Fraunces + DM Sans
   ══════════════════════════════════════════════════════════════ */
@import url('https://fonts.googleapis.com/css2?family=Fraunces:ital,wght@0,300;0,500;0,600;0,700;1,300;1,500&family=DM+Sans:wght@300;400;500;600&display=swap');
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'DM Sans',system-ui,sans-serif;background:#F9F7F4;color:#1A1F2E;line-height:1.65;overflow-x:hidden;-webkit-font-smoothing:antialiased}
img{max-width:100%;height:auto;display:block}
a{text-decoration:none;color:inherit}
ul{list-style:none}
:root{
  --navy:#1C3557;--navy-light:#264A78;--navy-dark:#112240;--navy-deep:#0D1B2E;
  --teal:#2A9D8F;--teal-light:#4BBCB0;--teal-dark:#1E7268;--teal-pale:#E0F4F2;--teal-mist:#F0FAF9;
  --sage:#6B8C72;--sage-light:#8EAE95;--sage-pale:#E8F2EA;
  --cyan:#48C4CE;--cyan-pale:#DCF4F6;
  --ivory:#F9F7F4;--ivory-warm:#F2EDE6;
  --white:#FFFFFF;
  --gray-soft:#EAE7E2;--gray-mid:#C5C0B8;
  --text-dark:#1A1F2E;--text-mid:#3A4555;--text-soft:#7A8899;
  --sand:#C9A97A;--sand-light:#F0E4CE;
  --shadow-xs:0 1px 6px rgba(28,53,87,.05);
  --shadow-sm:0 2px 12px rgba(28,53,87,.08);
  --shadow-md:0 8px 32px rgba(28,53,87,.11);
  --shadow-lg:0 20px 60px rgba(28,53,87,.14);
  --shadow-xl:0 40px 100px rgba(28,53,87,.18);
  --radius:16px;--radius-sm:10px;--radius-lg:24px;--radius-xl:40px;
  --font-display:'Fraunces',Georgia,serif;
  --font-body:'DM Sans',system-ui,sans-serif;
  --ease:cubic-bezier(.4,0,.2,1);--transition:.25s var(--ease);
}

/* ── TOP BAR ──────────────────────────────────────────────── */
.top-bar{background:var(--navy-dark);color:#B8C8D8;font-size:.77rem;font-weight:400;letter-spacing:.02em;padding:9px 0}
.top-bar .inner{max-width:1200px;margin:0 auto;padding:0 24px;display:flex;justify-content:space-between;align-items:center;gap:20px;flex-wrap:wrap}
.top-bar .tb-left{display:flex;gap:20px;align-items:center;flex-wrap:wrap}
.top-bar a{color:#B8C8D8;display:flex;align-items:center;gap:7px;transition:color var(--transition)}
.top-bar a:hover{color:var(--teal-light)}
.top-bar i{color:var(--teal);font-size:.74rem}
.top-bar .crisis{font-size:.74rem;font-weight:600;color:#B8C8D8;display:flex;align-items:center;gap:6px}
.top-bar .crisis strong{color:var(--white)}

/* ── NAV ──────────────────────────────────────────────────── */
nav{background:var(--white);position:sticky;top:0;z-index:999;box-shadow:0 1px 0 #E8E5E0,0 2px 12px rgba(28,53,87,.08)}
.nav-inner{max-width:1200px;margin:0 auto;padding:0 24px;display:flex;align-items:center;justify-content:space-between;height:72px;gap:16px}
.logo{display:flex;align-items:center;text-decoration:none;flex-shrink:0}
.logo img{height:50px;width:auto;transition:opacity var(--transition)}
.logo:hover img{opacity:.88}
.logo-fallback{display:none;font-family:var(--font-display);font-weight:700;font-size:1.05rem;color:var(--navy)}
.nav-links{display:flex;align-items:center;gap:2px;list-style:none;flex:1;justify-content:flex-end}
.nav-links>li{position:relative}
.nav-links>li>a{display:flex;align-items:center;gap:5px;padding:8px 13px;font-size:.86rem;font-weight:500;color:var(--text-mid);border-radius:var(--radius-sm);transition:color var(--transition),background var(--transition);white-space:nowrap}
.nav-links>li>a:hover,.nav-links>li>a.active{color:var(--navy);background:var(--teal-mist)}
.nav-links>li>a .caret{font-size:.58rem;color:var(--text-soft);transition:transform var(--transition)}
.nav-links>li:hover>a .caret{transform:rotate(180deg)}
/* Dropdown */
.dropdown{position:absolute;top:calc(100% + 10px);left:50%;transform:translateX(-50%) translateY(8px);background:var(--white);border:1px solid #E2DDD8;border-radius:var(--radius);box-shadow:var(--shadow-lg);min-width:300px;padding:8px;opacity:0;visibility:hidden;pointer-events:none;transition:opacity var(--transition),transform var(--transition),visibility var(--transition);list-style:none;z-index:200}
.nav-links>li:hover .dropdown,.has-dd:hover .dropdown{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0);pointer-events:all}
.dropdown li a{display:flex;align-items:center;gap:10px;padding:10px 14px;border-radius:var(--radius-sm);font-size:.84rem;color:var(--text-mid);transition:background var(--transition),color var(--transition);white-space:nowrap}
.dropdown li a:hover,.dropdown li a.active{background:var(--teal-mist);color:var(--teal-dark)}
.dropdown li a i{width:18px;color:var(--teal);font-size:.82rem;flex-shrink:0}
.nav-donate{background:linear-gradient(135deg,var(--teal) 0%,var(--teal-dark) 100%)!important;color:var(--white)!important;padding:9px 18px!important;border-radius:50px!important;font-weight:600!important;font-size:.83rem!important;box-shadow:0 4px 14px rgba(42,157,143,.28);transition:all var(--transition)!important}
.nav-donate:hover{background:linear-gradient(135deg,var(--teal-light) 0%,var(--teal) 100%)!important;transform:translateY(-1px)!important;color:var(--white)!important}
.nav-cta{background:var(--navy)!important;color:var(--white)!important;padding:9px 18px!important;border-radius:50px!important;font-weight:600!important;font-size:.83rem!important;box-shadow:0 4px 14px rgba(28,53,87,.22);transition:all var(--transition)!important}
.nav-cta:hover{background:var(--navy-light)!important;color:var(--white)!important;transform:translateY(-1px)!important}
.hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:8px;background:none;border:none}
.hamburger span{display:block;height:2px;width:24px;background:var(--text-dark);border-radius:2px;transition:var(--transition)}
.hamburger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.hamburger.open span:nth-child(2){opacity:0}
.hamburger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* ── BUTTONS ──────────────────────────────────────────────── */
.btn{display:inline-flex;align-items:center;gap:8px;padding:13px 28px;border-radius:50px;font-family:var(--font-body);font-size:.9rem;font-weight:600;cursor:pointer;border:2px solid transparent;transition:all var(--transition);white-space:nowrap;text-decoration:none}
.btn-sm{padding:9px 20px;font-size:.84rem}
.btn-navy{background:var(--navy);color:var(--white);box-shadow:0 6px 20px rgba(28,53,87,.28)}
.btn-navy:hover{background:var(--navy-light);transform:translateY(-2px);box-shadow:0 10px 28px rgba(28,53,87,.35)}
.btn-teal{background:var(--teal);color:var(--white);box-shadow:0 6px 20px rgba(42,157,143,.3)}
.btn-teal:hover{background:var(--teal-dark);transform:translateY(-2px);box-shadow:0 10px 28px rgba(42,157,143,.40)}
.btn-teal-outline{background:transparent;color:var(--teal-dark);border-color:var(--teal)}
.btn-teal-outline:hover{background:var(--teal);color:var(--white);transform:translateY(-2px)}
.btn-white{background:var(--white);color:var(--navy);box-shadow:0 4px 16px rgba(28,53,87,.12)}
.btn-white:hover{background:var(--ivory);transform:translateY(-2px)}
.btn-ghost-white{background:rgba(255,255,255,.12);color:var(--white);border-color:rgba(255,255,255,.3);backdrop-filter:blur(6px)}
.btn-ghost-white:hover{background:rgba(255,255,255,.22);transform:translateY(-2px)}

/* ── PAGE HERO ────────────────────────────────────────────── */
.page-hero{background:linear-gradient(135deg,rgba(13,27,46,.84) 0%,rgba(28,53,87,.74) 55%,rgba(30,114,104,.58) 100%),url('titlebar.png') center/cover no-repeat;padding:80px 0 60px;position:relative;overflow:hidden;min-height:44vh;display:flex;align-items:flex-end}
.page-hero::before{content:'';position:absolute;inset:0;opacity:.04;background-image:radial-gradient(circle at 1px 1px,rgba(255,255,255,.9) 1px,transparent 0);background-size:28px 28px}
.ph-glow{position:absolute;border-radius:50%;filter:blur(90px);pointer-events:none}
.ph-glow-a{width:55vw;height:55vw;max-width:650px;background:radial-gradient(circle,rgba(42,157,143,.18),transparent 70%);top:-25%;right:-8%}
.ph-glow-b{width:40vw;height:40vw;max-width:440px;background:radial-gradient(circle,rgba(28,53,87,.2),transparent 70%);bottom:-10%;left:2%}
.page-hero .inner{max-width:1200px;margin:0 auto;padding:0 24px;position:relative;z-index:2;width:100%}
.breadcrumb{display:flex;align-items:center;gap:.5rem;font-size:.75rem;color:rgba(255,255,255,.45);margin-bottom:1.25rem}
.breadcrumb a{color:rgba(255,255,255,.55);transition:color var(--transition)}
.breadcrumb a:hover{color:var(--white)}
.breadcrumb i{font-size:.55rem}
.page-hero h1{font-family:var(--font-display);font-size:clamp(2.4rem,5.5vw,4rem);font-weight:700;color:var(--white);line-height:1.08;margin-bottom:1rem}
.page-hero h1 em{font-style:italic;font-weight:300;color:var(--teal-light)}
.page-hero p{font-size:clamp(.92rem,1.7vw,1.08rem);color:rgba(255,255,255,.72);max-width:560px;line-height:1.78}

/* ── SECTION ──────────────────────────────────────────────── */
.section{padding:90px 0}
.section-sm{padding:60px 0}
.section-inner{max-width:1200px;margin:0 auto;padding:0 24px}
.section-label{display:inline-flex;align-items:center;gap:8px;font-size:.72rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--teal-dark);margin-bottom:10px}
.section-label::before{content:'';display:inline-block;width:20px;height:2px;background:var(--teal);border-radius:2px}
.section-title{font-family:var(--font-display);font-size:clamp(1.8rem,3.5vw,2.7rem);font-weight:700;line-height:1.2;color:var(--text-dark);margin-bottom:12px}
.section-title em{font-style:italic;font-weight:300;color:var(--teal)}
.section-sub{font-size:.97rem;color:var(--text-soft);max-width:540px;line-height:1.72}
.text-center{text-align:center}
.text-center .section-label{justify-content:center}
.text-center .section-sub{margin:0 auto}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2.5rem,5vw,5rem);align-items:start}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:1.25rem}
.grid-auto{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.5rem}
@media(max-width:900px){.grid-2{grid-template-columns:1fr}.grid-3{grid-template-columns:1fr 1fr}.grid-4{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.grid-3,.grid-4{grid-template-columns:1fr}}

/* ── CARDS ────────────────────────────────────────────────── */
.card{background:var(--white);border-radius:var(--radius);padding:2rem;box-shadow:var(--shadow-sm);border:1px solid var(--gray-soft);transition:transform var(--transition),box-shadow var(--transition)}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}
.card-mist{background:var(--teal-mist);border-color:rgba(42,157,143,.15)}
.card-navy{background:var(--navy)}
.card-navy h3,.card-navy h4,.card-navy p{color:rgba(255,255,255,.85)}

/* Service card */
.service-card{background:var(--ivory);border:1px solid #E8E4DE;border-radius:var(--radius);padding:30px 26px;display:block;position:relative;overflow:hidden;transition:transform var(--transition),box-shadow var(--transition),border-color var(--transition)}
.service-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--navy),var(--teal),var(--cyan));transform:scaleX(0);transform-origin:left;transition:transform var(--transition);border-radius:3px 3px 0 0}
.service-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg);border-color:transparent}
.service-card:hover::before{transform:scaleX(1)}
.card-icon{width:50px;height:50px;border-radius:13px;display:flex;align-items:center;justify-content:center;font-size:1.2rem;margin-bottom:18px;transition:transform var(--transition)}
.service-card:hover .card-icon{transform:scale(1.1) rotate(-3deg)}
.icon-navy{background:rgba(28,53,87,.08);color:var(--navy)}
.icon-teal{background:var(--teal-pale);color:var(--teal-dark)}
.icon-sage{background:var(--sage-pale);color:var(--sage)}
.icon-cyan{background:var(--cyan-pale);color:#1A8C94}
.icon-sand{background:var(--sand-light);color:#7A5020}
.icon-indigo{background:#EEF2FF;color:#4338CA}
.service-card h3{font-family:var(--font-display);font-size:1.08rem;font-weight:700;margin-bottom:8px;color:var(--text-dark)}
.service-card p{font-size:.84rem;color:var(--text-soft);line-height:1.65;margin-bottom:14px}
.card-link{display:inline-flex;align-items:center;gap:6px;font-size:.79rem;font-weight:600;color:var(--teal-dark)}
.card-link i{font-size:.68rem;transition:transform var(--transition)}
.service-card:hover .card-link i{transform:translateX(4px)}

/* Team card */
.team-card{background:var(--white);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm);border:1px solid var(--gray-soft);transition:transform var(--transition),box-shadow var(--transition)}
.team-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-md)}
.team-card-head{height:140px;background:linear-gradient(135deg,var(--navy-dark),var(--navy));display:flex;align-items:center;justify-content:center;position:relative}
.team-avatar{width:80px;height:80px;border-radius:50%;background:linear-gradient(135deg,var(--teal-dark),var(--teal));display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-size:1.65rem;font-weight:700;color:var(--white);border:3px solid rgba(255,255,255,.15)}
.team-badge{position:absolute;top:.85rem;right:.85rem;background:rgba(42,157,143,.9);color:var(--white);font-size:.6rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;padding:.22rem .65rem;border-radius:50px}
.team-card-body{padding:1.35rem 1.5rem 1.65rem}
.team-card-body h3{font-family:var(--font-display);font-size:1.2rem;color:var(--navy);margin-bottom:.15rem}
.team-card-body .role{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.12em;color:var(--teal-dark);margin-bottom:.75rem;display:block}
.team-card-body p{font-size:.82rem;color:var(--text-soft);line-height:1.65;margin:0}

/* Resource card */
.resource-card{background:var(--white);border-radius:var(--radius);padding:1.35rem;box-shadow:var(--shadow-xs);border:1px solid var(--gray-soft);display:flex;flex-direction:column;gap:.65rem;transition:transform var(--transition),box-shadow var(--transition)}
.resource-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-md)}
.resource-card h4{font-family:var(--font-display);font-size:1rem;color:var(--navy);line-height:1.3}
.resource-card p{font-size:.8rem;color:var(--text-soft);margin:0;line-height:1.6}
.res-tag{display:inline-block;font-size:.65rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;padding:.22rem .7rem;border-radius:50px}
.res-phone{display:flex;align-items:center;gap:.4rem;font-size:.78rem;color:var(--text-mid);font-weight:500}
.res-phone i{color:var(--teal);font-size:.72rem}
.res-actions{display:flex;gap:.45rem;flex-wrap:wrap;margin-top:auto;padding-top:.4rem}
.res-btn{display:inline-flex;align-items:center;gap:.3rem;padding:.36rem .85rem;border-radius:50px;font-size:.74rem;font-weight:600;border:1.5px solid;transition:all .2s}
.res-btn-primary{background:var(--navy);color:var(--white);border-color:var(--navy)}
.res-btn-primary:hover{background:var(--navy-light);border-color:var(--navy-light)}
.res-btn-outline{background:transparent;color:var(--navy);border-color:var(--gray-mid)}
.res-btn-outline:hover{background:var(--teal-mist);border-color:var(--teal)}
.cat-crisis{background:#FFF0EE;color:#C13926}
.cat-mental{background:#EEF2FF;color:#3730A3}
.cat-housing{background:var(--teal-pale);color:var(--teal-dark)}
.cat-recovery{background:var(--sage-pale);color:var(--sage)}
.cat-food{background:#FFFBEA;color:#92400E}
.cat-transport{background:var(--cyan-pale);color:#1A8C94}
.cat-employ{background:#F5F0FF;color:#5B21B6}
.cat-health{background:#FFF1F2;color:#9F1239}
.cat-community{background:var(--sand-light);color:#7A5020}

/* Search & filter */
.search-bar{display:flex;gap:.5rem;background:var(--white);border-radius:50px;padding:.42rem .42rem .42rem 1.35rem;box-shadow:var(--shadow-md);border:1.5px solid var(--gray-soft);max-width:600px;margin:0 auto 1.5rem;transition:border-color var(--transition)}
.search-bar:focus-within{border-color:var(--teal)}
.search-bar input{flex:1;border:none;outline:none;background:none;font-size:.9rem;color:var(--text-dark);font-family:var(--font-body)}
.search-bar input::placeholder{color:var(--text-soft)}
.search-bar button{background:var(--navy);color:var(--white);border:none;border-radius:50px;padding:.58rem 1.35rem;font-size:.83rem;font-weight:600;cursor:pointer;transition:background var(--transition);font-family:var(--font-body)}
.search-bar button:hover{background:var(--navy-light)}
.filter-bar{display:flex;flex-wrap:wrap;gap:.45rem;justify-content:center;margin-bottom:2rem}
.filter-pill{padding:.38rem 1rem;border-radius:50px;border:1.5px solid var(--gray-soft);font-size:.76rem;font-weight:600;cursor:pointer;background:var(--white);color:var(--text-mid);transition:all .2s;font-family:var(--font-body)}
.filter-pill:hover,.filter-pill.active{background:var(--navy);color:var(--white);border-color:var(--navy)}

/* Form */
.form-group{display:flex;flex-direction:column;gap:.4rem;margin-bottom:1rem}
.form-group label{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--text-mid)}
.form-group input,.form-group textarea,.form-group select{padding:.82rem 1rem;border:1.5px solid var(--gray-soft);border-radius:var(--radius-sm);font-size:.9rem;color:var(--text-dark);background:var(--ivory);outline:none;transition:border-color var(--transition);font-family:var(--font-body)}
.form-group input:focus,.form-group textarea:focus,.form-group select:focus{border-color:var(--teal)}
.form-group textarea{resize:vertical;min-height:120px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.form-submit{width:100%;padding:1.05rem;background:var(--navy);color:var(--white);border:none;border-radius:50px;font-size:.95rem;font-weight:700;cursor:pointer;transition:background var(--transition),transform var(--transition);font-family:var(--font-body)}
.form-submit:hover{background:var(--navy-light);transform:translateY(-1px)}

/* Impact / stats */
.impact-section{background:linear-gradient(135deg,var(--navy-dark) 0%,var(--navy) 50%,var(--teal-dark) 100%);position:relative;overflow:hidden}
.impact-section::before{content:'';position:absolute;top:-50%;left:30%;width:600px;height:600px;border-radius:50%;background:radial-gradient(circle,rgba(42,157,143,.14) 0%,transparent 65%);pointer-events:none}
.impact-inner{position:relative;z-index:1}
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.stat-card{background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.1);border-radius:var(--radius);padding:28px 18px;text-align:center;transition:background var(--transition),transform var(--transition)}
.stat-card:hover{background:rgba(255,255,255,.12);transform:translateY(-4px)}
.stat-card .num{font-family:var(--font-display);font-size:clamp(2.2rem,4vw,3.2rem);font-weight:700;color:var(--white);line-height:1;display:block;margin-bottom:8px}
.stat-card .label{font-size:.77rem;color:rgba(255,255,255,.55);line-height:1.5}
.stat-card .sub{font-size:.67rem;color:var(--teal-light);margin-top:4px;display:block}
@media(max-width:768px){.stats-grid{grid-template-columns:1fr 1fr}}
@media(max-width:420px){.stats-grid{grid-template-columns:1fr}}

/* Testimonial */
.testi-card{background:var(--ivory);border:1px solid #E8E4DE;border-radius:var(--radius);padding:26px;display:flex;flex-direction:column;transition:transform var(--transition),box-shadow var(--transition)}
.testi-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}
.testi-card.featured{background:var(--navy);border-color:var(--navy)}
.testi-card.featured .quote,.testi-card.featured .qmark{color:rgba(255,255,255,.12)}
.testi-card.featured .quote{color:rgba(255,255,255,.85)}
.testi-card.featured .divider{border-color:rgba(255,255,255,.1)}
.testi-card.featured .author-name{color:var(--white)}
.testi-card.featured .author-note{color:rgba(255,255,255,.5)}
.testi-card.featured .author-icon{background:rgba(255,255,255,.12);color:var(--white)}
.qmark{font-family:var(--font-display);font-size:3rem;color:var(--teal-pale);font-weight:700;line-height:.6;margin-bottom:10px}
.quote{font-family:var(--font-display);font-size:1.02rem;font-style:italic;font-weight:300;line-height:1.65;color:var(--text-mid);flex:1}
.divider{border:none;border-top:1px solid var(--gray-soft);margin:16px 0}
.testi-author{display:flex;align-items:center;gap:10px}
.author-icon{width:38px;height:38px;border-radius:50%;background:var(--teal-pale);display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-size:.88rem;font-weight:600;color:var(--navy);flex-shrink:0}
.author-name{font-size:.88rem;font-weight:600;color:var(--navy)}
.author-note{font-size:.73rem;color:var(--text-soft)}

/* CTA section */
.cta-section{background:linear-gradient(135deg,var(--navy-deep) 0%,var(--navy) 60%,#1B4F72 100%);position:relative;overflow:hidden}
.cta-section::before{content:'';position:absolute;top:-50%;left:35%;width:600px;height:600px;border-radius:50%;background:radial-gradient(circle,rgba(42,157,143,.12) 0%,transparent 65%);pointer-events:none}
.cta-inner{position:relative;z-index:1;display:flex;align-items:center;justify-content:space-between;gap:40px;flex-wrap:wrap}
.cta-text h2{font-family:var(--font-display);font-size:clamp(1.7rem,3vw,2.4rem);font-weight:700;color:var(--white);line-height:1.2;margin-bottom:10px}
.cta-text h2 em{font-style:italic;font-weight:300;color:var(--teal-light)}
.cta-text p{font-size:.93rem;color:rgba(255,255,255,.62);max-width:440px;line-height:1.68}
.cta-actions{display:flex;flex-direction:column;gap:12px;flex-shrink:0}
.cta-contact-line{display:flex;align-items:center;gap:10px;color:rgba(255,255,255,.65);font-size:.82rem}
.cta-contact-line i{color:var(--teal-light)}
.cta-contact-line a{color:var(--white);font-weight:600;transition:color var(--transition)}
.cta-contact-line a:hover{color:var(--teal-light)}

/* Footer */
footer{background:#0A0F1A;color:#9EB3C8;padding:60px 0 28px}
.footer-inner{max-width:1200px;margin:0 auto;padding:0 24px}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1.5fr;gap:46px;margin-bottom:42px;padding-bottom:36px;border-bottom:1px solid rgba(255,255,255,.08)}
.footer-brand p{font-size:.84rem;line-height:1.72;margin:14px 0 20px;max-width:270px}
.footer-logo img{height:46px;width:auto;filter:brightness(0) invert(1) opacity(.75)}
.footer-socials{display:flex;gap:10px}
.social-btn{width:36px;height:36px;border-radius:10px;background:rgba(255,255,255,.07);display:flex;align-items:center;justify-content:center;color:#9EB3C8;font-size:.83rem;transition:background var(--transition),color var(--transition),transform var(--transition)}
.social-btn:hover{background:var(--teal);color:#fff;transform:translateY(-2px)}
.footer-col h4{font-size:.75rem;font-weight:700;letter-spacing:.13em;text-transform:uppercase;color:rgba(255,255,255,.88);margin-bottom:16px}
.footer-col ul{display:flex;flex-direction:column;gap:9px}
.footer-col ul li a{font-size:.83rem;color:#9EB3C8;transition:color var(--transition)}
.footer-col ul li a:hover{color:var(--teal-light)}
.footer-contact-item{display:flex;gap:10px;margin-bottom:12px;align-items:flex-start}
.footer-contact-item i{color:var(--teal);font-size:.83rem;margin-top:3px;flex-shrink:0}
.footer-contact-item a,.footer-contact-item span{font-size:.83rem;color:#9EB3C8;line-height:1.55;transition:color var(--transition)}
.footer-contact-item a:hover{color:var(--teal-light)}
.footer-donate-strip{background:rgba(42,157,143,.1);border:1px solid rgba(42,157,143,.18);border-radius:var(--radius);padding:18px 22px;display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap;margin-bottom:26px}
.footer-donate-strip p{font-size:.85rem;color:rgba(255,255,255,.6);margin:0}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px;font-size:.76rem;color:rgba(255,255,255,.3)}
.footer-bottom-links{display:flex;gap:16px}
.footer-bottom-links a{font-size:.76rem;color:rgba(255,255,255,.3);transition:color var(--transition)}
.footer-bottom-links a:hover{color:var(--teal-light)}

/* Reveal animations */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.reveal-left{opacity:0;transform:translateX(-22px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.reveal-right{opacity:0;transform:translateX(22px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.reveal.visible,.reveal-left.visible,.reveal-right.visible{opacity:1;transform:none}
.d1{transition-delay:.08s}.d2{transition-delay:.16s}.d3{transition-delay:.24s}.d4{transition-delay:.32s}.d5{transition-delay:.40s}.d6{transition-delay:.48s}

/* Mobile */
@media(max-width:768px){
  .nav-links{display:none;flex-direction:column;align-items:stretch;position:absolute;top:72px;left:0;right:0;background:var(--white);border-top:1px solid var(--gray-soft);padding:14px 24px 22px;box-shadow:var(--shadow-lg);gap:0}
  .nav-links.mobile-open{display:flex}
  /* mobile dropdown: hidden until .dd-open */
  .nav-links.mobile-open .has-dd .dropdown{display:none;position:static;transform:none!important;opacity:1!important;visibility:visible!important;pointer-events:all!important;box-shadow:none;border:none;padding:4px 0 4px 16px;background:var(--teal-mist);border-left:3px solid var(--teal);border-radius:0;margin:.25rem 0 .5rem;min-width:0}
  .nav-links.mobile-open .has-dd.dd-open .dropdown{display:block}
  .nav-links>li>a{padding:11px 0;border-radius:0;border-bottom:1px solid var(--gray-soft)}
  .nav-links>li:last-child>a{border-bottom:none}
  /* dropdown handled by dd-open above */
  .hamburger{display:flex}
  .top-bar .tb-left{display:none}
  .top-bar .inner{justify-content:center}
  .nav-donate,.nav-cta{margin-top:8px!important;padding:11px 0!important;border-radius:0!important;text-align:center!important;justify-content:center!important;box-shadow:none!important;font-size:.88rem!important}
  .nav-donate{border-top:2px solid var(--teal)!important;color:var(--teal-dark)!important;background:transparent!important}
  .nav-cta{border-top:2px solid var(--navy)!important;color:var(--navy)!important;background:transparent!important}
  .cta-inner{flex-direction:column;text-align:center}
  .cta-contact-line{justify-content:center}
  .footer-grid{grid-template-columns:1fr 1fr;gap:28px}
  .form-row{grid-template-columns:1fr}
  section,.section{padding:60px 0}
}
@media(max-width:540px){
  .footer-grid{grid-template-columns:1fr}
  .hero-actions,.cta-btns{flex-direction:column}
  .hero-actions .btn,.cta-btns .btn{width:100%;justify-content:center}
}
