/* ============================================================
   Central Church — shared brand foundation
   Tokens, base, inner-page nav, buttons, footer.
   Extends the system established on the home page.
   ============================================================ */
:root{
  --ink:        #1E454D;   /* Blue Hill — deep teal */
  --ink-soft:   #41635F;   /* muted teal-grey body text */
  --paper:      #F6F5EF;   /* soft off-white page base */
  --paper-2:    #EDECE6;   /* sand wash */
  --line:       #D9D7CD;
  --ocean:      #019196;   /* Splashy — primary accent */
  --ocean-deep: #016B70;   /* deeper Splashy */
  --gold:       #EFC73B;   /* Cheerful — secondary accent */
  --spa:        #A7DCDC;   /* Spa — light teal */
  --iron:       #434341;   /* Iron Ore — charcoal */
  --white:#fff;

  --maxw: 1240px;
  --gut: clamp(20px, 5vw, 64px);
  --r: 4px;
  --ff: "Figtree", system-ui, sans-serif;
}

*{ box-sizing:border-box; margin:0; padding:0; }
html{ scroll-behavior:smooth; scroll-padding-top:96px; }
body{ font-family:var(--ff); color:var(--ink); background:var(--paper); -webkit-font-smoothing:antialiased; line-height:1.5; }
img{ display:block; max-width:100%; }
a{ color:inherit; text-decoration:none; }
::selection{ background:var(--ocean); color:#fff; }

.wrap{ max-width:var(--maxw); margin:0 auto; padding-inline:var(--gut); }
.eyebrow{ font-size:.72rem; font-weight:700; letter-spacing:.22em; text-transform:uppercase; color:var(--ocean); }
h1,h2,h3{ font-weight:800; line-height:1.04; letter-spacing:-.03em; }

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex; align-items:center; gap:.6em;
  font-weight:700; font-size:.86rem; letter-spacing:.04em; text-transform:uppercase;
  padding:.95em 1.7em; border-radius:var(--r); cursor:pointer; border:1.5px solid transparent;
  transition:transform .15s ease, background .2s ease, color .2s ease, border-color .2s ease; white-space:nowrap;
}
.btn:hover{ transform:translateY(-2px); }
.btn--solid{ background:var(--ocean); color:#fff; }
.btn--solid:hover{ background:var(--ocean-deep); }
.btn--ink{ background:var(--ink); color:#fff; }
.btn--ink:hover{ background:var(--ocean-deep); }
.btn--outline{ border-color:var(--ink); color:var(--ink); }
.btn--outline:hover{ background:var(--ink); color:#fff; }
.btn--ghost{ border-color:rgba(255,255,255,.55); color:#fff; }
.btn--ghost:hover{ background:#fff; color:var(--ink); border-color:#fff; }
.arrow{ transition:transform .2s ease; }
.btn:hover .arrow, .lnk:hover .arrow{ transform:translateX(4px); }
.lnk{ display:inline-flex; align-items:center; gap:.5em; font-weight:700; font-size:.8rem; letter-spacing:.06em; text-transform:uppercase; color:var(--ocean-deep); }

/* ---------- Inner-page nav (solid) ---------- */
header.inav{ position:sticky; top:0; z-index:50; background:rgba(246,245,239,.9); -webkit-backdrop-filter:saturate(1.4) blur(10px); backdrop-filter:saturate(1.4) blur(10px); border-bottom:1px solid var(--line); }
.inav-inner{ display:flex; align-items:center; justify-content:space-between; gap:24px; height:74px; }
.brand{ display:flex; flex-direction:column; line-height:1; }
.brand b{ font-weight:800; letter-spacing:.18em; font-size:1.18rem; color:var(--ink); }
.brand span{ font-size:.58rem; letter-spacing:.3em; text-transform:uppercase; color:var(--ocean); margin-top:5px; white-space:nowrap; }
.imenu{ display:flex; align-items:center; gap:4px; }
.imenu a{ position:relative; padding:.7em .95em; font-weight:600; font-size:.82rem; letter-spacing:.06em; text-transform:uppercase; color:var(--ink-soft); transition:color .2s ease; white-space:nowrap; }
.imenu a::after{ content:""; position:absolute; left:.95em; right:.95em; bottom:.5em; height:1.5px; background:currentColor; transform:scaleX(0); transform-origin:left; transition:transform .32s cubic-bezier(.7,0,.2,1); }
.imenu a:hover{ color:var(--ocean-deep); }
.imenu a:hover::after, .imenu a.active::after{ transform:scaleX(1); }
.imenu a.active{ color:var(--ink); }
.inav-cta{ display:flex; align-items:center; gap:14px; }
.inav-cta .give{ padding:.7em 1.4em; border-radius:var(--r); border:1.5px solid var(--ink); color:var(--ink); font-weight:700; font-size:.8rem; letter-spacing:.08em; text-transform:uppercase; transition:.2s ease; }
.inav-cta .give:hover{ background:var(--ink); color:#fff; }
.ihamb{ display:none; flex-direction:column; gap:5px; background:none; border:0; cursor:pointer; padding:8px; }
.ihamb span{ width:26px; height:2px; background:var(--ink); }

/* dark nav variant (Direction C) */
header.inav.dark{ background:rgba(16,38,40,.72); border-bottom-color:rgba(255,255,255,.12); }
header.inav.dark .brand b{ color:#fff; }
header.inav.dark .brand span{ color:var(--spa); }
header.inav.dark .imenu a{ color:rgba(255,255,255,.78); }
header.inav.dark .imenu a:hover, header.inav.dark .imenu a.active{ color:#fff; }
header.inav.dark .inav-cta .give{ border-color:rgba(255,255,255,.55); color:#fff; }
header.inav.dark .inav-cta .give:hover{ background:#fff; color:var(--ink); }
header.inav.dark .ihamb span{ background:#fff; }

/* ---------- Footer ---------- */
footer.site{ background:var(--ink); color:rgba(255,255,255,.7); padding-block:64px 32px; }
.foot-grid{ display:grid; grid-template-columns:1.4fr 1fr 1fr 1fr; gap:40px; padding-bottom:42px; border-bottom:1px solid rgba(255,255,255,.12); }
.foot-brand b{ font-weight:800; letter-spacing:.18em; color:#fff; font-size:1.3rem; display:block; }
.foot-brand span{ font-size:.6rem; letter-spacing:.3em; text-transform:uppercase; color:var(--gold); }
.foot-brand p{ font-size:.95rem; margin:16px 0 20px; max-width:34ch; line-height:1.6; }
.socials{ display:flex; gap:12px; }
.socials a{ width:40px; height:40px; border-radius:50%; border:1px solid rgba(255,255,255,.2); display:grid; place-items:center; transition:.2s ease; color:#fff; }
.socials a:hover{ background:var(--ocean); border-color:var(--ocean); transform:translateY(-3px); }
.foot-col h5{ font-size:.72rem; letter-spacing:.16em; text-transform:uppercase; color:#fff; margin-bottom:16px; font-weight:700; }
.foot-col a{ display:block; padding:6px 0; font-size:.92rem; color:rgba(255,255,255,.62); transition:color .2s ease; }
.foot-col a:hover{ color:#fff; }
.foot-bottom{ display:flex; flex-wrap:wrap; justify-content:space-between; gap:14px; padding-top:24px; font-size:.8rem; color:rgba(255,255,255,.45); }

@media (max-width:900px){
  .imenu, .inav-cta .give{ display:none; }
  .ihamb{ display:flex; }
  .foot-grid{ grid-template-columns:1fr 1fr; }
}
@media (max-width:560px){ .foot-grid{ grid-template-columns:1fr; } }
