/* ============================================================
   Knowing God Missions — knowinggodmissions.org
   Design system v2 — drawn from the KGM logo + original site:
   Navy #16344F · Ocean #1D7DA8 · Leaf #5E9732 · Sun #F6C244 · White
   Type: Montserrat (headings, caps) + Nunito Sans (body)
   ============================================================ */

:root{
  --navy:#16344F;
  --navy-deep:#0D2236;
  --ocean:#1D7DA8;
  --ocean-soft:#9CCBE0;
  --green:#5E9732;
  --green-dark:#4C7D27;
  --green-leaf:#7CB94E;
  --sun:#F6C244;
  --paper:#FFFFFF;
  --mist:#F0F5F8;
  --ink:#22313D;
  --muted:#5C6B77;
  --line:rgba(22,52,79,.14);
  --shadow:0 8px 26px rgba(13,34,54,.12);
  --radius:10px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:'Nunito Sans',system-ui,-apple-system,'Segoe UI',Arial,sans-serif;
  font-size:17px;line-height:1.7;color:var(--ink);
  background:var(--paper);
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block}
a{color:var(--ocean)}
a:focus-visible,button:focus-visible{outline:3px solid var(--sun);outline-offset:2px}

h1,h2,h3,.display{
  font-family:'Montserrat',Arial,sans-serif;
  color:var(--navy);
  line-height:1.18;
  font-weight:800;
  margin:0 0 .55em;
}
h1{font-size:clamp(1.9rem,4.4vw,2.9rem);letter-spacing:.01em}
h2{font-size:clamp(1.35rem,2.8vw,1.9rem);text-transform:uppercase;letter-spacing:.06em}
h3{font-size:clamp(1.05rem,2vw,1.25rem);text-transform:uppercase;letter-spacing:.05em;font-weight:700}
p{margin:0 0 1.1em}

.eyebrow{
  font-family:'Montserrat',sans-serif;
  font-size:.74rem;font-weight:700;letter-spacing:.24em;text-transform:uppercase;
  color:var(--ocean);margin-bottom:.9rem;
}
.on-dark .eyebrow{color:var(--sun)}
.lead{font-size:1.13rem;color:var(--muted)}

.wrap{max-width:1080px;margin:0 auto;padding:0 22px}
.narrow{max-width:760px}
section{padding:60px 0}
.section-tight{padding:44px 0}

.skip{position:absolute;left:-999px;top:0;background:var(--navy);color:#fff;padding:10px 16px;z-index:100}
.skip:focus{left:10px}

/* ---------- Header (dark navy, like the original site) ---------- */
.site-head{
  position:sticky;top:0;z-index:50;
  background:var(--navy);
  border-bottom:3px solid var(--sun);
}
.head-in{
  max-width:1180px;margin:0 auto;padding:10px 22px;
  display:flex;align-items:center;gap:18px;flex-wrap:wrap;justify-content:space-between;
}
.wordmark{
  font-family:'Montserrat',Arial,sans-serif;
  font-size:1.02rem;font-weight:800;color:#fff;text-decoration:none;
  letter-spacing:.08em;white-space:nowrap;text-transform:uppercase;
  display:flex;align-items:center;gap:11px;
}
.wordmark .logo{width:52px;height:52px;flex:none;border-radius:50%;background:#fff;border:2px solid #fff}
.wordmark .wm-name{color:#fff}
.wordmark .wm-name em{font-style:normal;color:var(--green-leaf)}
.wordmark small{
  display:block;font-family:'Nunito Sans',sans-serif;font-size:.58rem;font-weight:800;
  letter-spacing:.28em;color:var(--ocean-soft);text-transform:uppercase;margin-top:2px;
}
nav.main{display:flex;align-items:center;gap:4px 16px;flex-wrap:wrap}
nav.main a{
  color:#fff;text-decoration:none;font-weight:700;font-size:.88rem;
  padding:6px 2px;border-bottom:2px solid transparent;
}
nav.main a:hover{border-color:var(--sun)}
nav.main a.active{border-color:var(--green-leaf);color:var(--green-leaf)}
.btn{
  display:inline-block;text-decoration:none;font-weight:700;
  font-family:'Montserrat',Arial,sans-serif;text-transform:uppercase;letter-spacing:.08em;
  border-radius:6px;padding:13px 26px;font-size:.85rem;
  transition:transform .12s ease, box-shadow .12s ease, background .12s ease;
}
.btn:hover{transform:translateY(-1px);box-shadow:var(--shadow)}
.btn-gold{background:var(--green);color:#fff}
.btn-gold:hover{background:var(--green-dark)}
.btn-terra{background:var(--ocean);color:#fff}
.btn-outline{border:2px solid var(--navy);color:var(--navy)}
.on-dark .btn-outline{border-color:#fff;color:#fff}
.btn-sm{padding:9px 16px;font-size:.74rem}
.btn-xl{padding:16px 32px;font-size:.95rem}
.lang-toggle{
  border:1.5px solid rgba(255,255,255,.5);border-radius:6px;padding:5px 11px;
  font-size:.74rem;font-weight:800;letter-spacing:.08em;color:#fff!important;
  text-decoration:none;font-family:'Montserrat',sans-serif;
}
.lang-toggle:hover{border-color:var(--sun);color:var(--sun)!important}

/* ---------- Hero ---------- */
.hero{
  background:linear-gradient(160deg,var(--navy) 0%,var(--navy-deep) 70%);
  color:#fff;padding:78px 0 64px;
}
.hero.hero-photo{
  background:
    linear-gradient(to bottom, rgba(13,34,54,.55) 0%, rgba(13,34,54,.62) 55%, rgba(13,34,54,.92) 100%),
    url('../images/compassion-embrace.jpg') center 24%/cover no-repeat;
}
.hero-brand{
  font-family:'Montserrat',Arial,sans-serif;font-weight:800;
  font-size:clamp(2rem,5.6vw,3.6rem);letter-spacing:.10em;text-transform:uppercase;
  color:#fff;margin:0 0 .35em;line-height:1.1;
  text-shadow:0 2px 18px rgba(13,34,54,.55);
}
.hero h1{
  color:#fff;font-weight:600;text-transform:none;letter-spacing:0;
  font-size:clamp(1.25rem,2.6vw,1.7rem);line-height:1.45;max-width:780px;
  text-shadow:0 1px 12px rgba(13,34,54,.5);
}
.hero h1 em{font-style:normal;color:var(--sun)}
.hero .lead{color:rgba(255,255,255,.92);max-width:680px;text-shadow:0 1px 10px rgba(13,34,54,.5)}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap;margin-top:26px;align-items:center}
.hero-note{font-size:.85rem;color:rgba(255,255,255,.78)}

/* rule */
.rule{width:64px;height:4px;background:var(--green-leaf);border:0;margin:0 0 1.4rem}
.rule.center{margin:0 auto 1.4rem}

/* ---------- Fact strip (sunshine bar, like the old social bar) ---------- */
.facts{background:var(--sun);padding:0}
.facts ul{
  max-width:1080px;margin:0 auto;padding:16px 22px;list-style:none;
  display:flex;flex-wrap:wrap;gap:8px 36px;justify-content:center;
}
.facts li{
  color:var(--navy-deep);font-weight:800;font-size:.9rem;letter-spacing:.02em;
  font-family:'Montserrat',sans-serif;text-transform:uppercase;font-size:.78rem;
}

/* ---------- Cards (photo-top, like the original three projects) ---------- */
.grid3{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:26px}
.card{
  background:var(--paper);border-radius:var(--radius);
  box-shadow:var(--shadow);border:1px solid var(--line);
  display:flex;flex-direction:column;overflow:hidden;
}
.card-photo{width:100%;aspect-ratio:4/3;object-fit:cover}
.card-body{padding:24px 24px 26px;display:flex;flex-direction:column;flex:1}
.card h3{margin-top:.1em;color:var(--navy)}
.card .more{
  margin-top:auto;font-weight:800;text-decoration:none;color:var(--ocean);
  font-family:'Montserrat',sans-serif;font-size:.8rem;text-transform:uppercase;letter-spacing:.08em;
}
.card .more:hover{color:var(--green-dark)}
.card-icon{
  width:46px;height:46px;border-radius:10px;background:var(--mist);
  display:flex;align-items:center;justify-content:center;margin-bottom:14px;
}
.card-icon svg{width:24px;height:24px;stroke:var(--ocean)}

/* ---------- Split (text + image) ---------- */
.split{display:grid;grid-template-columns:1.1fr .9fr;gap:46px;align-items:center}
.split .portrait{
  border-radius:var(--radius);box-shadow:var(--shadow);
  border:5px solid #fff;outline:1px solid var(--line);
}
blockquote.pull{
  font-family:'Montserrat',Arial,sans-serif;font-size:1.18rem;line-height:1.5;font-weight:600;
  color:var(--navy);border-left:5px solid var(--green-leaf);margin:1.4em 0;padding:.2em 0 .2em 1em;
}
blockquote.pull cite{display:block;font-family:'Nunito Sans',sans-serif;font-size:.85rem;color:var(--muted);font-style:normal;margin-top:.6em;font-weight:400}

/* ---------- Dark band ---------- */
.band{
  background:linear-gradient(160deg,var(--navy) 0%,var(--navy-deep) 80%);
  color:#fff;
}
.band h2,.band h3{color:#fff}
.band p{color:rgba(255,255,255,.88)}

/* alternating light section */
.alt-section{background:var(--mist)}

/* ---------- Tiers ---------- */
.tiers{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin:30px 0 8px}
.tier{
  background:#fff;border-radius:var(--radius);padding:28px 22px;text-align:center;
  box-shadow:var(--shadow);border:1px solid var(--line);color:var(--ink);
}
.tier.featured{border:3px solid var(--green-leaf);position:relative}
.tier .flag{
  position:absolute;top:-14px;left:50%;transform:translateX(-50%);
  background:var(--green);color:#fff;font-size:.66rem;font-weight:800;
  letter-spacing:.14em;text-transform:uppercase;border-radius:4px;padding:4px 12px;white-space:nowrap;
  font-family:'Montserrat',sans-serif;
}
.tier .amt{font-family:'Montserrat',Arial,sans-serif;font-size:2.2rem;font-weight:800;color:var(--navy)}
.tier .amt small{font-size:.95rem;color:var(--muted);font-family:'Nunito Sans',sans-serif;font-weight:700}
.tier p{font-size:.94rem;color:var(--muted)}

/* ---------- Donate page ---------- */
.donate-head{background:var(--navy);border-bottom:3px solid var(--sun);padding:12px 0}
.donate-head a[href="index.html"]{color:#fff!important}
.donate-head span a{color:var(--ocean-soft)!important}
.donate-hero{background:linear-gradient(160deg,var(--navy),var(--navy-deep));color:#fff;padding:50px 0 42px}
.donate-hero h1{color:#fff;text-transform:none;font-size:clamp(1.5rem,3vw,2.1rem)}
.give-block{
  background:#fff;border-radius:var(--radius);box-shadow:var(--shadow);
  padding:32px 30px;margin-bottom:26px;border-left:6px solid var(--green-leaf);
  border-top:1px solid var(--line);border-right:1px solid var(--line);border-bottom:1px solid var(--line);
}
.give-block.alt{border-left-color:var(--ocean)}
.trustline{
  display:flex;gap:10px 26px;flex-wrap:wrap;align-items:center;justify-content:center;
  font-size:.86rem;color:var(--muted);font-weight:700;margin-top:14px;
}
.trustline span::before{content:"✓ ";color:var(--green);font-weight:900}
.etrans{
  background:var(--mist);border:1.5px dashed var(--ocean);border-radius:8px;
  padding:16px 18px;font-size:.98rem;margin:14px 0;
}
.etrans strong{color:var(--navy)}
.fineprint{font-size:.84rem;color:var(--muted)}

/* ---------- Forms ---------- */
form .field{margin-bottom:16px}
label{display:block;font-weight:800;font-size:.88rem;color:var(--navy);margin-bottom:6px}
input[type=text],input[type=email],select,textarea{
  width:100%;padding:12px 14px;border:1.5px solid var(--line);border-radius:8px;
  font:inherit;background:#fff;color:var(--ink);
}
input:focus,select:focus,textarea:focus{border-color:var(--ocean);outline:none}
.consent{display:flex;gap:10px;align-items:flex-start;font-size:.88rem;color:var(--muted)}
.consent input{margin-top:4px;width:auto}
.newsletter-row{display:flex;gap:12px;flex-wrap:wrap}
.newsletter-row input[type=email]{flex:1;min-width:230px}

/* ---------- Content photos ---------- */
figure.cphoto{margin:1.8em auto;text-align:center}
figure.cphoto img{width:100%;max-width:640px;height:auto;border-radius:var(--radius);box-shadow:var(--shadow)}
figure.cphoto.small img{max-width:400px}
figure.cphoto figcaption{font-size:.85rem;color:var(--muted);margin-top:9px}

/* ---------- Footer ---------- */
.site-foot{background:var(--navy-deep);color:rgba(255,255,255,.85);padding:54px 0 30px;margin-top:0;border-top:4px solid var(--sun)}
.site-foot a{color:var(--ocean-soft);text-decoration:none}
.site-foot a:hover{color:var(--sun);text-decoration:underline}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:34px;margin-bottom:30px}
.foot-grid h3{color:#fff;font-size:.95rem}
.foot-grid ul{list-style:none;margin:0;padding:0}
.foot-grid li{margin-bottom:8px}
.foot-tag{color:var(--green-leaf);font-weight:700}
.legal{
  border-top:1px solid rgba(255,255,255,.18);padding-top:22px;
  font-size:.82rem;line-height:1.8;color:rgba(255,255,255,.62);
}

/* ---------- Tables / notes ---------- */
.center{text-align:center}
.mt0{margin-top:0}.mb0{margin-bottom:0}
.note{
  background:var(--mist);border-left:5px solid var(--ocean);
  padding:14px 18px;border-radius:0 8px 8px 0;font-size:.95rem;color:var(--ink);
}
table.clean{width:100%;border-collapse:collapse;font-size:.97rem}
table.clean th,table.clean td{text-align:left;padding:10px 12px;border-bottom:1px solid var(--line);vertical-align:top}
table.clean th{color:var(--navy);font-size:.78rem;text-transform:uppercase;letter-spacing:.08em;font-family:'Montserrat',sans-serif}

.mobile-jump{display:none}

/* ---------- Responsive ---------- */
@media (max-width:880px){
  .grid3,.tiers{grid-template-columns:1fr}
  .grid2,.split,.foot-grid{grid-template-columns:1fr}
  .split .portrait{max-width:380px;margin:0 auto}
  section{padding:46px 0}
  .hero{padding:56px 0 48px}
  .mobile-jump{display:inline-block;position:sticky;top:84px;z-index:40}
  .head-in{justify-content:center;text-align:center}
  nav.main{justify-content:center}
}
