/* ============================================================
   EndHomeless.us — Shared Stylesheet
   ============================================================ */

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
  --ink:        #1a1a18;
  --ink-mid:    #3d3c38;
  --ink-soft:   #6b6a65;
  --ink-faint:  #a8a7a2;
  --paper:      #faf9f6;
  --paper-warm: #f2ede4;
  --accent:     #c0392b;
  --accent-dk:  #96271f;
  --accent-lt:  #f9ebe9;
  --teal:       #1a6b5c;
  --teal-lt:    #e4f2ef;
  --gold:       #b8860b;
  --gold-lt:    #fdf6e3;
  --border:     rgba(26,26,24,0.10);
  --border-md:  rgba(26,26,24,0.18);
  --radius:     10px;
  --radius-lg:  16px;
  --radius-xl:  24px;
  --font-head:  'DM Serif Display', Georgia, serif;
  --font-body:  'DM Sans', system-ui, sans-serif;
  --max:        1100px;
  --nav-h:      68px;
  --shadow-sm:  0 2px 8px rgba(0,0,0,.06);
  --shadow-md:  0 8px 32px rgba(0,0,0,.09);
  --shadow-lg:  0 24px 64px rgba(0,0,0,.12);
}

html { scroll-behavior: smooth; font-size: 16px; }
body { font-family: var(--font-body); background: var(--paper); color: var(--ink); line-height: 1.65; -webkit-font-smoothing: antialiased; }
img  { display: block; max-width: 100%; }
a    { color: inherit; }

/* ── LAYOUT ── */
.container { max-width: var(--max); margin: 0 auto; padding: 0 28px; }
.section    { padding: 96px 0; }
.section-sm { padding: 64px 0; }

/* ── TYPOGRAPHY ── */
h1,h2,h3,h4 { font-family: var(--font-head); line-height: 1.12; color: var(--ink); }
h1 { font-size: clamp(40px, 5.5vw, 68px); }
h2 { font-size: clamp(30px, 4vw,  48px); }
h3 { font-size: clamp(20px, 2.5vw,26px); }
h4 { font-size: 18px; }
p  { font-size: 16px; color: var(--ink-mid); line-height: 1.75; }
em { font-style: italic; color: var(--accent); }

.eyebrow {
  display: inline-flex; align-items: center; gap: 8px;
  font-size: 11px; font-weight: 700; letter-spacing: .1em;
  text-transform: uppercase; color: var(--accent); margin-bottom: 18px;
}
.eyebrow::before { content:''; width:20px; height:2px; background:var(--accent); flex-shrink:0; }

.section-intro { max-width: 560px; margin-bottom: 56px; }
.section-intro p { font-size: 17px; margin-top: 14px; }

/* ── TAGS ── */
.tag { display:inline-block; font-size:11px; font-weight:700; letter-spacing:.07em; text-transform:uppercase; padding:4px 10px; border-radius:4px; }
.tag-red  { background:var(--accent-lt); color:var(--accent); }
.tag-teal { background:var(--teal-lt);   color:var(--teal);   }
.tag-gold { background:var(--gold-lt);   color:var(--gold);   }

/* ── BUTTONS ── */
.btn { display:inline-flex; align-items:center; gap:7px; font-family:var(--font-body); font-weight:600; border:none; border-radius:var(--radius); cursor:pointer; text-decoration:none; transition:all .2s; white-space:nowrap; }
.btn-sm  { font-size:13px; padding: 8px 16px; }
.btn-md  { font-size:15px; padding:12px 24px; }
.btn-lg  { font-size:16px; padding:15px 32px; border-radius:12px; }
.btn-xl  { font-size:17px; padding:18px 36px; border-radius:14px; }
.btn-primary { background:var(--accent); color:#fff; }
.btn-primary:hover { background:var(--accent-dk); transform:translateY(-1px); box-shadow:0 6px 20px rgba(192,57,43,.3); }
.btn-outline { background:transparent; border:1.5px solid var(--ink); color:var(--ink); }
.btn-outline:hover { background:var(--ink); color:var(--paper); }
.btn-outline-white { background:transparent; border:1.5px solid rgba(255,255,255,.4); color:#fff; }
.btn-outline-white:hover { background:rgba(255,255,255,.1); border-color:#fff; }
.btn-teal { background:var(--teal); color:#fff; }
.btn-teal:hover { background:#155a4d; transform:translateY(-1px); }

/* ── NAV ── */
.site-nav {
  position:sticky; top:0; z-index:200; height:var(--nav-h);
  background:rgba(250,249,246,.96); backdrop-filter:blur(12px);
  border-bottom:1px solid var(--border);
}
.nav-inner { display:flex; align-items:center; justify-content:space-between; height:100%; }
.nav-logo  { font-family:var(--font-head); font-size:19px; color:var(--ink); text-decoration:none; }
.nav-logo span { color:var(--accent); }
.nav-links { display:flex; align-items:center; gap:30px; list-style:none; }
.nav-links a { font-size:14px; font-weight:500; color:var(--ink-soft); text-decoration:none; transition:color .15s; padding:4px 0; border-bottom:2px solid transparent; }
.nav-links a:hover, .nav-links a.active { color:var(--ink); border-bottom-color:var(--accent); }
.nav-cta { margin-left:8px; }

/* Mobile nav toggle */
.nav-toggle { display:none; background:none; border:none; cursor:pointer; padding:4px; flex-direction:column; gap:5px; }
.nav-toggle span { display:block; width:22px; height:2px; background:var(--ink); border-radius:2px; transition:all .2s; }
.nav-mobile { display:none; position:fixed; inset:var(--nav-h) 0 0 0; background:var(--paper); z-index:199; padding:32px 28px; flex-direction:column; gap:8px; overflow-y:auto; }
.nav-mobile.open { display:flex; }
.nav-mobile a { font-size:20px; font-family:var(--font-head); color:var(--ink); text-decoration:none; padding:14px 0; border-bottom:1px solid var(--border); }
.nav-mobile .btn { margin-top:16px; justify-content:center; }

/* ── FOOTER ── */
.site-footer { background:var(--ink); color:rgba(255,255,255,.55); padding:72px 0 36px; }
.footer-grid { display:grid; grid-template-columns:2fr 1fr 1fr 1fr; gap:48px; margin-bottom:56px; }
.footer-brand .nav-logo { color:#fff; }
.footer-brand .nav-logo span { color:var(--accent); }
.footer-brand p { font-size:14px; line-height:1.7; margin-top:14px; max-width:260px; }
.footer-address { font-size:13px; color:rgba(255,255,255,.35); margin-top:16px; line-height:1.6; }
.footer-col h5 { font-size:11px; font-weight:700; letter-spacing:.1em; text-transform:uppercase; color:rgba(255,255,255,.28); margin-bottom:18px; }
.footer-col ul { list-style:none; display:flex; flex-direction:column; gap:10px; }
.footer-col ul a { font-size:14px; color:rgba(255,255,255,.55); text-decoration:none; transition:color .15s; }
.footer-col ul a:hover { color:#fff; }
.footer-bottom { border-top:1px solid rgba(255,255,255,.07); padding-top:28px; display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:12px; }
.footer-bottom p { font-size:13px; }
.footer-ein { font-size:12px; color:rgba(255,255,255,.28); }

/* ── TRUST BADGE ROW ── */
.trust-row { display:flex; flex-wrap:wrap; gap:18px; align-items:center; }
.trust-item { display:flex; align-items:center; gap:7px; font-size:13px; color:var(--ink-soft); }
.trust-item .check { width:18px; height:18px; border-radius:50%; background:var(--teal-lt); display:flex; align-items:center; justify-content:center; flex-shrink:0; }
.trust-item .check svg { width:10px; height:10px; }

/* ── CARDS ── */
.card { background:#fff; border:1px solid var(--border); border-radius:var(--radius-lg); padding:32px; transition:box-shadow .2s, transform .2s; }
.card:hover { box-shadow:var(--shadow-md); transform:translateY(-2px); }

/* ── IMPACT STRIP ── */
.impact-strip { background:var(--ink); padding:60px 0; }
.impact-grid  { display:grid; grid-template-columns:repeat(4,1fr); gap:1px; background:rgba(255,255,255,.08); border:1px solid rgba(255,255,255,.08); border-radius:var(--radius-lg); overflow:hidden; }
.impact-cell  { background:var(--ink); padding:36px 24px; text-align:center; }
.impact-num   { font-family:var(--font-head); font-size:44px; color:#fff; line-height:1; }
.impact-unit  { font-size:20px; color:var(--accent); }
.impact-label { font-size:12px; color:rgba(255,255,255,.45); margin-top:8px; text-transform:uppercase; letter-spacing:.07em; }

/* ── PAGE HERO (inner pages) ── */
.page-hero { background:var(--paper-warm); padding:72px 0 64px; border-bottom:1px solid var(--border); }
.page-hero h1 { margin-bottom:16px; }
.page-hero p  { font-size:18px; max-width:560px; }

/* ── RESPONSIVE ── */
@media (max-width:900px) {
  .nav-links, .nav-cta { display:none; }
  .nav-toggle { display:flex; }
  .footer-grid { grid-template-columns:1fr 1fr; gap:36px; }
  .impact-grid { grid-template-columns:repeat(2,1fr); }
}
@media (max-width:560px) {
  .container { padding:0 20px; }
  .section { padding:64px 0; }
  .footer-grid { grid-template-columns:1fr; }
  .impact-grid { grid-template-columns:1fr 1fr; }
}
