/* ============================================================
   Holyway Baptist Church, Okeho
   The Sanctuary of Faith & Holiness
   
   Stylesheet
   Last updated: April 2026
   ============================================================ */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
:root{
  --maroon:#7B1C1C;--maroon-deep:#5A1212;--maroon-mid:#9B2A2A;
  --gold:#C9963A;--gold-light:#E0B05A;--gold-pale:#F5E6C8;
  --ivory:#FAF7F2;--ivory-dk:#F0EAE0;--ivory-bd:#DDD5C8;
  --ink:#1C1409;--ink-mid:#4A3828;--ink-light:#7A6550;
  --charcoal:#151820;--charcoal-card:#1c2028;
  --white:#FFF;
  --display:'Playfair Display',Georgia,serif;
  --body:'Montserrat',system-ui,sans-serif;
  --ease:cubic-bezier(.25,.1,.25,1);--ease-out:cubic-bezier(0,0,.2,1);
}
html{-webkit-font-smoothing:antialiased}
body{font-family:var(--body);background:var(--ivory);color:var(--ink);overflow-x:hidden;font-size:17px;line-height:1.65}
a{transition:color .25s ease,text-decoration .25s ease}

/* SPA */
.page{display:none}.page.active{display:block}

/* NAV */
#mainNav{
  position:fixed;top:0;left:0;right:0;z-index:900;height:64px;
  display:flex;align-items:center;justify-content:space-between;
  padding:0 16px;background:rgba(250,247,242,.96);
  backdrop-filter:saturate(180%) blur(20px);-webkit-backdrop-filter:saturate(180%) blur(20px);
  border-bottom:1px solid var(--ivory-bd);transition:box-shadow .3s;
}
#mainNav.scrolled{box-shadow:0 2px 24px rgba(28,20,9,.12)}
@media(min-width:768px){#mainNav{height:72px;padding:0 40px}}

.nav-brand{display:flex;align-items:center;gap:10px;text-decoration:none;cursor:pointer}
.nav-brand img{height:40px;width:40px;border-radius:50%;object-fit:cover;border:2px solid var(--gold);flex-shrink:0}
@media(min-width:768px){.nav-brand img{height:48px;width:48px}}
.nav-brand-text{display:flex;flex-direction:column;line-height:1.15}
.nav-brand-text strong{font-family:var(--display);font-size:14px;font-weight:700;color:var(--maroon)}
.nav-brand-text span{font-size:10px;color:var(--ink-light);letter-spacing:.06em;text-transform:uppercase}
@media(min-width:768px){.nav-brand-text strong{font-size:16px}.nav-brand-text span{font-size:11px}}

.nav-links{display:none;list-style:none;align-items:center}
@media(min-width:1024px){.nav-links{display:flex}}
.nav-links a{
  font-size:14px;font-weight:500;color:var(--ink-mid);
  text-decoration:none;padding:8px 12px;transition:color .2s;cursor:pointer;position:relative;
}
.nav-links a::after{
  content:'';position:absolute;bottom:2px;left:12px;right:12px;height:1.5px;
  background:var(--gold);transform:scaleX(0);transition:transform .25s var(--ease-out);
}
.nav-links a:hover,.nav-links a.active-link{color:var(--maroon)}
.nav-links a:hover::after,.nav-links a.active-link::after{transform:scaleX(1)}
.nav-give{
  background:var(--gold);color:var(--ink);
  padding:9px 20px;font-size:12px;font-weight:700;
  letter-spacing:.06em;text-transform:uppercase;transition:background .2s,transform .2s;
}
.nav-give::after{display:none}
.nav-give:hover{background:var(--gold-light);color:var(--ink);transform:translateY(-1px)}

.ham{
  display:flex;flex-direction:column;justify-content:center;gap:5px;
  width:32px;height:32px;background:none;border:none;cursor:pointer;padding:4px;
  position:relative;z-index:996;
}
@media(min-width:1024px){.ham{display:none}}
.ham span{display:block;height:1.5px;background:var(--maroon);transition:all .3s;border-radius:2px}
.ham span:nth-child(1){width:22px}.ham span:nth-child(2){width:15px}.ham span:nth-child(3){width:22px}
.ham.open span:nth-child(1){width:20px;transform:rotate(45deg) translate(4.8px,4.8px)}
.ham.open span:nth-child(2){opacity:0}
.ham.open span:nth-child(3){width:20px;transform:rotate(-45deg) translate(4.8px,-4.8px)}

.mobile-nav{
  position:fixed;top:0;left:0;right:0;bottom:0;z-index:995;
  background:var(--ivory);
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:0;
  opacity:0;visibility:hidden;pointer-events:none;
  transition:opacity .35s var(--ease),visibility .35s var(--ease);
}
.mobile-nav.open{opacity:1;visibility:visible;pointer-events:all}
.mobile-nav-brand{
  display:flex;align-items:center;gap:12px;cursor:pointer;
  margin-bottom:32px;padding-bottom:32px;
  border-bottom:1px solid var(--ivory-bd);
  width:100%;max-width:320px;justify-content:center;
}
.mobile-nav-brand img{height:52px;width:52px;border-radius:50%;object-fit:cover;border:2px solid var(--gold);flex-shrink:0}
.mobile-nav-brand-text{display:flex;flex-direction:column;line-height:1.2}
.mobile-nav-brand-text strong{font-family:var(--display);font-size:16px;font-weight:700;color:var(--maroon)}
.mobile-nav-brand-text span{font-size:10px;color:var(--ink-light);letter-spacing:.06em;text-transform:uppercase;margin-top:2px}
.mobile-nav a{
  font-family:var(--display);font-size:clamp(24px,5.5vw,36px);font-weight:400;font-style:italic;
  color:var(--ink);text-decoration:none;padding:14px 0;width:100%;text-align:center;
  border-bottom:1px solid var(--ivory-bd);transition:color .2s;cursor:pointer;
}
.mobile-nav a:first-of-type{border-top:1px solid var(--ivory-bd)}
.mobile-nav a:hover{color:var(--maroon)}
.mob-give{
  margin-top:28px;background:var(--gold);color:var(--ink);
  font-family:var(--body);font-size:13px;font-weight:600;
  letter-spacing:.1em;text-transform:uppercase;padding:16px 48px;
  border:none;font-style:normal;width:auto;
}
/* FIX #7: mob-give hover was inheriting color:var(--maroon) from .mobile-nav a:hover
   which is dark-on-gold — force ink color to stay readable */
.mob-give:hover{background:var(--gold-light);color:var(--ink)}

/* BUTTONS */
.btn{
  display:inline-flex;align-items:center;gap:8px;
  font-family:var(--body);font-size:14px;font-weight:600;
  letter-spacing:.08em;text-transform:uppercase;
  padding:15px 34px;text-decoration:none;border:none;cursor:pointer;
  transition:all .25s var(--ease);
}
@media(min-width:768px){.btn{font-size:15px;padding:17px 40px}}
.btn-maroon{background:var(--maroon);color:var(--white)}
.btn-maroon:hover{background:var(--maroon-mid);transform:translateY(-2px);box-shadow:0 8px 28px rgba(123,28,28,.3)}
.btn-gold{background:var(--gold);color:var(--white)}
.btn-gold:hover{background:var(--gold-light);transform:translateY(-2px);box-shadow:0 8px 28px rgba(201,150,58,.3)}
.btn-outline{background:transparent;color:var(--maroon);border:1.5px solid var(--maroon)}
.btn-outline:hover{background:var(--maroon);color:var(--white);transform:translateY(-2px)}
.btn-ghost-dark{background:transparent;color:rgba(255,255,255,.75);border:1.5px solid rgba(255,255,255,.25)}
.btn-ghost-dark:hover{border-color:var(--gold);color:var(--gold)}

/* SHARED */
.section{padding:80px 20px}
@media(min-width:768px){.section{padding:108px 48px}}
@media(min-width:1200px){.section{padding:120px 72px}}
.container{max-width:1100px;margin:0 auto}
.container-sm{max-width:800px;margin:0 auto}
.eyebrow{
  display:inline-flex;align-items:center;gap:12px;
  font-size:12px;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);margin-bottom:20px;
}
.eyebrow::before{content:'';display:block;width:24px;height:1px;background:currentColor}
.headline{font-family:var(--display);font-size:clamp(38px,5.5vw,62px);font-weight:700;line-height:1.05;color:var(--ink);margin-bottom:24px}
.headline em{font-style:italic;color:var(--maroon)}
.new-here-left .headline em{color:var(--gold)}
.subhead{font-size:clamp(16px,2vw,19px);color:var(--ink-light);line-height:1.8;max-width:600px}
.gold-bar{width:48px;height:2px;background:var(--gold);margin:24px 0}

/* REVEAL */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .75s var(--ease-out),transform .75s var(--ease-out)}
.reveal.in{opacity:1;transform:none}
.d1{transition-delay:.1s}.d2{transition-delay:.2s}.d3{transition-delay:.3s}.d4{transition-delay:.4s}

/* PAGE HERO */
.page-hero{
  background:var(--maroon-deep);padding:120px 20px 72px;text-align:center;
  position:relative;overflow:hidden;
}
.page-hero::before{
  content:'';position:absolute;inset:0;z-index:0;
  background:linear-gradient(to bottom,rgba(12,10,8,.55) 0%,rgba(12,10,8,.75) 50%,rgba(12,10,8,.88) 100%);
  pointer-events:none;
}
@media(min-width:768px){.page-hero{padding:140px 48px 88px}}
.page-hero::after{
  content:'';position:absolute;inset:0;opacity:.04;pointer-events:none;
  background-image:
    repeating-linear-gradient(0deg,transparent,transparent 60px,rgba(255,255,255,.2) 60px,rgba(255,255,255,.2) 61px),
    repeating-linear-gradient(90deg,transparent,transparent 60px,rgba(255,255,255,.2) 60px,rgba(255,255,255,.2) 61px);
}
.page-hero-img{position:absolute;inset:0;z-index:0}
.page-hero-img img{width:100%;height:100%;object-fit:cover;opacity:.2}
.page-eyebrow{
  position:relative;z-index:1;display:inline-flex;align-items:center;gap:14px;
  font-size:12px;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);margin-bottom:20px;
}
.page-eyebrow::before,.page-eyebrow::after{content:'';display:block;width:24px;height:1px;background:currentColor;opacity:.6}
.page-title{position:relative;z-index:1;font-family:var(--display);font-size:clamp(40px,7vw,76px);font-weight:700;color:rgba(255,255,255,.95);line-height:1.04}
.page-title em{font-style:italic;color:var(--gold)}
.page-sub{position:relative;z-index:1;font-family:var(--display);font-style:italic;font-size:clamp(16px,2vw,21px);color:rgba(255,255,255,.4);margin-top:16px}

/* TOAST */
.toast{
  position:fixed;bottom:28px;right:24px;z-index:9999;
  background:var(--maroon);color:var(--white);padding:14px 22px;
  font-size:15px;border-left:3px solid var(--gold);
  transform:translateY(16px);opacity:0;transition:all .3s var(--ease);pointer-events:none;
}
.toast.show{transform:none;opacity:1}

/* SCROLL TOP */
.scroll-top{
  position:fixed;bottom:90px;right:20px;z-index:990;
  width:44px;height:44px;background:var(--maroon);color:var(--white);
  border:none;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;
  opacity:0;pointer-events:none;transform:translateY(8px);
  transition:all .3s var(--ease);box-shadow:0 4px 18px rgba(0,0,0,.2);
}
.scroll-top.show{opacity:1;pointer-events:auto;transform:none}
.scroll-top:hover{background:var(--maroon-mid);transform:translateY(-2px)}
.scroll-top svg{width:18px;height:18px}

/* WHATSAPP FLOAT */
.wa-float{
  position:fixed;bottom:24px;right:20px;z-index:991;
  width:56px;height:56px;background:#25D366;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 4px 20px rgba(37,211,102,.4);
  text-decoration:none;transition:transform .25s,box-shadow .25s;
}
.wa-float:hover{transform:scale(1.08);box-shadow:0 6px 28px rgba(37,211,102,.5)}
.wa-float svg{width:28px;height:28px;fill:white}

/* ============ HOME HERO ============ */
.hero{
  min-height:100svh;display:flex;flex-direction:column;align-items:center;justify-content:center;
  text-align:center;padding:90px 20px 60px;background:var(--maroon-deep);position:relative;overflow:hidden;z-index:1;
}
.hero::before{
  content:'';position:absolute;inset:0;pointer-events:none;z-index:1;
  background:linear-gradient(to bottom,rgba(12,10,8,.55),rgba(12,10,8,.85));
  animation:pulse 8s ease-in-out infinite;
}
@keyframes pulse{
  0%,100%{opacity:0.85}
  50%{opacity:0.95}
}
@keyframes float{
  0%{transform:translateY(0) rotate(0deg)}
  10%{opacity:0.2}
  90%{opacity:0.2}
  100%{transform:translateY(-100vh) rotate(360deg)}
}
.hero-particles{position:absolute;inset:0;pointer-events:none;z-index:2;overflow:hidden}
.particle{
  position:absolute;font-size:1.5rem;opacity:0.2;color:var(--gold);
  animation:float 15s linear infinite;
}
.particle svg{width:1.5rem;height:1.5rem}
.particle-1{top:20%;left:10%;animation-delay:0s}
.particle-2{top:40%;right:15%;animation-delay:3s}
.particle-3{top:60%;left:20%;animation-delay:6s}
.particle-4{top:30%;right:10%;animation-delay:9s}
.particle-5{bottom:20%;left:15%;animation-delay:12s}
/* FIX: moved transition to the base rule so hover-out also animates */
.hero-title{
  font-family:var(--display);font-size:clamp(40px,9vw,104px);font-weight:700;
  letter-spacing:-.02em;line-height:.98;color:rgba(255,255,255,.96);
  opacity:0;animation:fadeUp .9s var(--ease) .3s both;position:relative;z-index:3;
  transition:text-shadow 0.3s ease;
}
.hero-title:hover{
  text-shadow:0 0 20px rgba(201,150,58,0.3),0 0 40px rgba(201,150,58,0.2);
}
.hero-title em{font-style:italic;color:var(--gold)}
.hero-tagline{
  font-family:var(--display);font-style:italic;font-size:clamp(18px,2.5vw,26px);
  color:rgba(255,255,255,.9);margin-top:20px;opacity:0;animation:fadeUp .9s var(--ease) .4s both;position:relative;z-index:2;
}
.hero-logos{display:none}
.hero-img{position:absolute;inset:0;z-index:0}
.hero-img img{width:100%;height:100%;object-fit:cover;opacity:.45}
.hero-badge{
  display:inline-flex;align-items:center;gap:14px;
  color:var(--gold);font-size:12px;font-weight:600;letter-spacing:.22em;text-transform:uppercase;
  margin-bottom:28px;opacity:0;animation:fadeUp .9s var(--ease) .2s both;position:relative;z-index:2;
}
.hero-badge::before,.hero-badge::after{content:'';display:block;width:32px;height:1px;background:currentColor;opacity:.6}
.hero-rule{width:44px;height:1px;background:var(--gold);margin:32px auto;opacity:0;animation:fadeUp .9s var(--ease) .45s both;position:relative;z-index:2}
.hero-actions{display:flex;flex-wrap:wrap;gap:14px;justify-content:center;opacity:0;animation:fadeUp .9s var(--ease) .5s both;position:relative;z-index:2}
.hero-motto{
  font-family:var(--display);font-style:italic;font-size:clamp(13px,1.5vw,16px);
  color:rgba(255,255,255,.8);margin-top:40px;opacity:0;animation:fadeUp .9s var(--ease) .6s both;position:relative;z-index:2;
}
@keyframes fadeUp{from{opacity:0;transform:translateY(22px)}to{opacity:1;transform:none}}

/* TIMES STRIP */
.times-strip{background:var(--gold);padding:0}
.times-inner{max-width:1100px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr}
@media(min-width:768px){.times-inner{grid-template-columns:repeat(4,1fr)}}
.time-cell{padding:20px 16px;text-align:center;border-right:1px solid rgba(255,255,255,.2);border-bottom:1px solid rgba(255,255,255,.2);transition:background .3s ease,transform .2s ease}
@media(min-width:768px){.time-cell{padding:26px 24px;border-bottom:none}}
.time-cell:hover{background:rgba(255,255,255,.08);transform:translateY(-2px)}
.time-cell:nth-child(2),.time-cell:nth-child(4){border-right:none}
/* nth-child(2) gets its border-right restored on desktop since 4 columns means it's no longer at the edge */
@media(min-width:768px){.time-cell:nth-child(2){border-right:1px solid rgba(255,255,255,.2)}.time-cell:last-child{border-right:none}}
.time-label{font-size:10px;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:rgba(255,255,255,.65);margin-bottom:6px}
.time-name{font-family:var(--display);font-size:clamp(15px,2vw,19px);font-weight:600;color:var(--white);margin-bottom:3px}
.time-val{font-size:14px;color:rgba(255,255,255,.75)}

/* WELCOME / CTA SECTION */
.welcome{background:var(--ivory-dk)}
.welcome-inner{text-align:center;max-width:720px;margin:0 auto}
.welcome-quote{font-family:var(--display);font-style:italic;font-size:clamp(23px,3vw,30px);color:var(--maroon);line-height:1.4;margin-bottom:24px}

/* ABOUT HOME */
.about{background:var(--ivory)}
.about-layout{display:grid;gap:48px;align-items:center}
@media(min-width:900px){.about-layout{grid-template-columns:1fr 1fr;gap:80px}}
.about-img{aspect-ratio:4/3;overflow:hidden;background:var(--ivory-dk);border:1px solid var(--ivory-bd);position:relative;display:flex;align-items:center;justify-content:center;transition:box-shadow .4s ease,border-color .4s ease}
.about-img::after{content:'';position:absolute;inset:10px;border:1px solid rgba(201,150,58,.2);pointer-events:none}
.about-img img{width:100%;height:100%;object-fit:cover;transition:transform .5s cubic-bezier(.25,.46,.45,.94)}
.about-img:hover{box-shadow:0 12px 32px rgba(0,0,0,.12);border-color:var(--ivory)}
.about-img:hover img{transform:scale(1.04)}
.about-img span{color:var(--ink-light);font-size:12px;letter-spacing:.1em;text-transform:uppercase;opacity:.5}
.stat-row{display:flex;gap:28px;flex-wrap:wrap;margin-top:40px;padding-top:36px;border-top:1px solid var(--ivory-bd)}
.stat-num{font-family:var(--display);font-size:clamp(38px,5vw,52px);font-weight:400;color:var(--ink);line-height:1}
.stat-unit{color:var(--gold)}
.stat-desc{font-size:14px;color:var(--ink-light);margin-top:6px}

/* VISION */
.vision{background:var(--charcoal);position:relative;overflow:hidden}
.vision::before{content:'';position:absolute;top:0;right:0;width:500px;height:500px;pointer-events:none;background:radial-gradient(ellipse at 80% 20%,rgba(201,150,58,.06) 0%,transparent 60%)}
.vision .eyebrow{color:var(--gold)}
.vision .headline{color:rgba(255,255,255,.92)}
.vision .headline em{color:var(--gold)}
.vision-list{margin-top:48px;display:flex;flex-direction:column}
.vision-item{display:flex;gap:20px;align-items:flex-start;padding:24px 0;border-top:1px solid rgba(255,255,255,.06)}
.vision-item:last-child{border-bottom:1px solid rgba(255,255,255,.06)}
.vi-num{font-family:var(--display);font-size:30px;font-weight:400;color:rgba(201,150,58,.3);line-height:1;min-width:38px;padding-top:2px}
.vi-text{font-size:clamp(15px,1.8vw,17px);line-height:1.8;color:rgba(255,255,255,.55)}
.vi-text strong{color:rgba(255,255,255,.8);font-weight:500}
.vi-ref{font-family:var(--display);font-style:italic;color:var(--gold);opacity:.65;font-size:14px;margin-left:8px}

/* WEEKLY SCHEDULE */
.schedule{background:var(--ivory)}
.sched-grid{display:grid;gap:0;border:1px solid var(--ivory-bd);margin-top:48px}
@media(min-width:600px){.sched-grid{grid-template-columns:1fr 1fr}}
@media(min-width:1000px){.sched-grid{grid-template-columns:1fr 1fr 1fr}}
.sched-day{padding:28px 24px;background:var(--ivory);border-bottom:1px solid var(--ivory-bd);border-right:1px solid var(--ivory-bd);transition:background .3s ease,box-shadow .3s ease,transform .2s ease}
@media(min-width:768px){.sched-day{padding:36px 32px}}
.sched-day:hover{background:var(--ivory-dk);box-shadow:inset 0 1px 8px rgba(201,150,58,.12);transform:translateY(-1px)}
.sched-day-name{font-family:var(--display);font-size:clamp(18px,2.5vw,22px);font-weight:700;color:var(--maroon);margin-bottom:16px;display:flex;align-items:center;gap:8px}
.sched-day-name::before{content:'';width:8px;height:8px;background:var(--gold);border-radius:50%;flex-shrink:0;transition:box-shadow .3s ease}
.sched-day:hover .sched-day-name::before{box-shadow:0 0 12px rgba(201,150,58,.6)}
.sched-item{display:flex;justify-content:space-between;align-items:baseline;gap:12px;padding:8px 0;border-bottom:1px solid var(--ivory-bd);font-size:15px}
.sched-item:last-child{border-bottom:none}
.sched-event{color:var(--ink-mid)}
.sched-time{font-size:13px;font-weight:600;color:var(--gold);white-space:nowrap}

/* NEW HERE */
.new-here-card{background:var(--maroon-deep);display:grid;position:relative;overflow:hidden}
.new-here-card::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--gold),transparent);opacity:.25}
@media(min-width:900px){.new-here-card{grid-template-columns:1fr 1fr}}
.new-here-left{padding:40px 24px}
@media(min-width:768px){.new-here-left{padding:60px 56px}}
.new-here-left .eyebrow{color:var(--gold)}
.new-here-left .headline{color:rgba(255,255,255,.92);font-size:clamp(30px,5vw,48px);margin-bottom:20px}
.new-here-left .subhead{color:rgba(255,255,255,.5);font-size:clamp(15px,1.8vw,17px);margin-bottom:40px;max-width:100%}
.faq{display:flex;flex-direction:column}
.faq-item{border-top:1px solid rgba(255,255,255,.06)}
.faq-item:last-child{border-bottom:1px solid rgba(255,255,255,.06)}
.faq-q{
  width:100%;background:none;border:none;cursor:pointer;text-align:left;padding:18px 0;
  display:flex;justify-content:space-between;align-items:center;gap:16px;
  font-family:var(--display);font-size:clamp(18px,2vw,18px);font-weight:400;color:rgba(255,255,255,.65);transition:color .25s ease,padding-left .25s ease;
}
.faq-q:hover{color:white;padding-left:8px}
.faq-toggle{
  width:24px;height:24px;border:1px solid rgba(255,255,255,.15);background:rgba(255,255,255,.04);
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
  transition:transform .3s cubic-bezier(.34,1.56,.64,1),background .25s ease,border-color .25s ease;color:rgba(255,255,255,.4);font-size:16px;
}
.faq-q:hover .faq-toggle{background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.25)}
.faq-item.open .faq-toggle{transform:rotate(45deg);background:rgba(201,150,58,.1);border-color:rgba(201,150,58,.4);color:var(--gold)}
.faq-a{font-size:clamp(14px,1.7vw,16px);line-height:1.8;color:rgba(255,255,255,.45);max-height:0;overflow:hidden;transition:max-height .4s var(--ease),padding .4s}
.faq-item.open .faq-a{max-height:200px;padding-bottom:20px}
.new-here-right{
  background:rgba(255,255,255,.02);border-left:1px solid rgba(255,255,255,.06);
  display:flex;flex-direction:column;align-items:flex-start;justify-content:flex-end;
  padding:40px 24px;position:relative;min-height:280px;
}
@media(min-width:768px){.new-here-right{padding:56px;min-height:360px}}
.new-here-img-placeholder{
  position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:12px;color:rgba(255,255,255,.08);font-size:11px;letter-spacing:.1em;text-transform:uppercase;
}
.new-here-img-placeholder img{width:100%;height:100%;object-fit:cover;opacity:.2}
.new-here-cta{position:relative;z-index:1}
.new-here-cta p{font-size:clamp(14px,1.7vw,16px);color:rgba(255,255,255,.5);line-height:1.8;margin-bottom:24px;max-width:300px}

/* MASONRY GALLERY */
.gallery-section{background:var(--ivory-dk);padding:80px 20px}
@media(min-width:768px){.gallery-section{padding:108px 48px}}
.gallery-grid{
  columns:2;column-gap:10px;margin-top:48px;
}
@media(min-width:640px){.gallery-grid{columns:3;column-gap:12px}}
@media(min-width:1024px){.gallery-grid{columns:4;column-gap:14px}}
.gallery-item{
  break-inside:avoid;margin-bottom:10px;overflow:hidden;
  cursor:pointer;position:relative;
  background:var(--ivory-bd);
}
@media(min-width:768px){.gallery-item{margin-bottom:12px}}
@media(min-width:1024px){.gallery-item{margin-bottom:14px}}
.gallery-item img{
  display:block;width:100%;height:auto;
  transition:transform .45s cubic-bezier(.25,.46,.45,.94),filter .45s ease;
  filter:grayscale(15%);
}
.gallery-item:hover img{transform:scale(1.05);filter:grayscale(0%) brightness(1.06)}
.gallery-item::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(to bottom,transparent 50%,rgba(123,28,28,.25));
  opacity:0;transition:opacity .35s ease;pointer-events:none;
}
.gallery-item:hover::after{opacity:1}
.gallery-zoom-icon{
  position:absolute;top:50%;left:50%;transform:translate(-50%,-50%) scale(.7);
  width:44px;height:44px;background:rgba(255,255,255,.9);border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  opacity:0;transition:opacity .3s ease,transform .3s ease;pointer-events:none;z-index:1;
}
.gallery-zoom-icon svg{width:18px;height:18px;color:var(--maroon)}
.gallery-item:hover .gallery-zoom-icon{opacity:1;transform:translate(-50%,-50%) scale(1)}
/* placeholder when image missing */
.gallery-item-placeholder{
  display:flex;align-items:center;justify-content:center;
  aspect-ratio:1;background:var(--ivory-bd);color:var(--ink-light);
  font-size:11px;letter-spacing:.1em;text-transform:uppercase;opacity:.5;
}

/* LIGHTBOX */
.lightbox{
  position:fixed;inset:0;z-index:9000;
  background:rgba(21,24,32,.96);
  display:flex;align-items:center;justify-content:center;
  opacity:0;visibility:hidden;pointer-events:none;
  transition:opacity .3s ease,visibility .3s ease;
}
.lightbox.open{opacity:1;visibility:visible;pointer-events:all}
.lightbox-img-wrap{
  position:relative;max-width:min(90vw,1100px);max-height:88vh;
  display:flex;align-items:center;justify-content:center;
}
.lightbox-img-wrap img{
  max-width:100%;max-height:88vh;object-fit:contain;
  opacity:0;transform:scale(.96);
  transition:opacity .3s ease .05s,transform .3s ease .05s;
  display:block;
}
.lightbox.open .lightbox-img-wrap img{opacity:1;transform:scale(1)}
.lightbox-close{
  position:fixed;top:20px;right:20px;
  width:44px;height:44px;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.15);
  border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;
  color:rgba(255,255,255,.85);transition:background .2s,transform .2s;z-index:9001;
}
.lightbox-close:hover{background:rgba(255,255,255,.2);transform:scale(1.1)}
.lightbox-close svg{width:18px;height:18px}
.lightbox-prev,.lightbox-next{
  position:fixed;top:50%;transform:translateY(-50%);
  width:48px;height:48px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.12);
  border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;
  color:rgba(255,255,255,.75);transition:background .2s,color .2s;z-index:9001;
}
.lightbox-prev{left:16px}.lightbox-next{right:16px}
@media(min-width:768px){.lightbox-prev{left:28px}.lightbox-next{right:28px}}
.lightbox-prev:hover,.lightbox-next:hover{background:rgba(255,255,255,.18);color:var(--white)}
.lightbox-prev svg,.lightbox-next svg{width:20px;height:20px}
.lightbox-counter{
  position:fixed;bottom:24px;left:50%;transform:translateX(-50%);
  font-size:12px;letter-spacing:.12em;color:rgba(255,255,255,.35);
  font-family:var(--body);font-weight:500;z-index:9001;
}
.lightbox-dots{
  position:fixed;bottom:48px;left:50%;transform:translateX(-50%);
  display:flex;gap:6px;z-index:9001;
}
.lightbox-dot{
  width:6px;height:6px;border-radius:50%;background:rgba(255,255,255,.25);
  cursor:pointer;transition:background .2s,transform .2s;border:none;padding:0;
}
.lightbox-dot.active{background:var(--gold);transform:scale(1.3)}

/* PASTOR */
.pastor{background:var(--ivory)}
.pastor-layout{display:grid;gap:56px;align-items:start}
@media(min-width:900px){.pastor-layout{grid-template-columns:380px 1fr;gap:80px}}
.pastor-img{aspect-ratio:3/4;overflow:hidden;background:var(--ivory-dk);border:1px solid var(--ivory-bd);position:relative;display:flex;align-items:center;justify-content:center}
.pastor-img::after{content:'';position:absolute;inset:10px;border:1px solid rgba(201,150,58,.2);pointer-events:none}
.pastor-img img{width:100%;height:100%;object-fit:cover}
.pastor-img span{color:var(--ink-light);font-size:12px;letter-spacing:.1em;text-transform:uppercase;opacity:.5}
.pastor-name{font-family:var(--display);font-size:clamp(32px,4.5vw,46px);font-weight:400;line-height:1.15;color:var(--ink);margin-bottom:8px}
.pastor-role{font-size:12px;letter-spacing:.15em;text-transform:uppercase;color:var(--gold);font-weight:600;margin-bottom:32px}
.pastor-bio{font-size:clamp(16px,1.9vw,18px);line-height:1.85;color:var(--ink-mid);margin-bottom:20px}

/* LEADERSHIP CARDS */
.lead-grid{display:grid;gap:16px;margin-top:56px;grid-template-columns:1fr 1fr}
@media(min-width:768px){.lead-grid{grid-template-columns:repeat(3,1fr);gap:20px}}
@media(min-width:1000px){.lead-grid{grid-template-columns:repeat(5,1fr)}}
.lead-card{
  position:relative;overflow:hidden;border-radius:8px;
  aspect-ratio:3/4;background:var(--ivory-dk);cursor:pointer;
  transition:transform .3s;
}
.lead-card:hover{transform:translateY(-4px)}
.lead-card-placeholder{
  width:100%;height:100%;display:flex;align-items:center;justify-content:center;
  background:linear-gradient(135deg,var(--ivory-dk),var(--ivory-bd));color:var(--ink-light);
}
.lead-card img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:1;filter:grayscale(100%) contrast(1.05);transition:filter .3s,transform .4s}
.lead-card:hover img{filter:grayscale(0%) contrast(1.1);transform:scale(1.04)}
.lead-card-placeholder svg{width:48px;height:48px;opacity:.2}
.lead-card-info{
  position:absolute;bottom:0;left:0;right:0;padding:20px 16px 16px;
  background:linear-gradient(to top,rgba(0,0,0,.85) 0%,rgba(0,0,0,.5) 60%,transparent 100%);
  z-index:2;
}
.lead-card-name{font-family:var(--display);font-size:clamp(15px,1.8vw,18px);font-weight:600;color:var(--white);margin-bottom:2px}
.lead-card-role{font-size:11px;color:var(--gold);letter-spacing:.08em;text-transform:uppercase;font-weight:500}

/* DEACON SECTION */
.deacon-section{background:var(--ivory-dk)}
.deacon-grid{display:grid;gap:0;border:1px solid var(--ivory-bd);margin-top:48px}
@media(min-width:600px){.deacon-grid{grid-template-columns:1fr 1fr}}
@media(min-width:900px){.deacon-grid{grid-template-columns:repeat(3,1fr)}}
.deacon-card{
  padding:32px 28px;background:var(--ivory);border-bottom:1px solid var(--ivory-bd);border-right:1px solid var(--ivory-bd);
  position:relative;overflow:hidden;transition:background .25s;
}
@media(min-width:768px){.deacon-card{padding:36px 32px}}
.deacon-card::after{content:'';position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--gold);transform:scaleY(0);transform-origin:top;transition:transform .3s var(--ease-out)}
.deacon-card:hover{background:var(--ivory-dk)}
.deacon-card:hover::after{transform:scaleY(1)}
.deacon-role-tag{font-size:11px;font-weight:600;letter-spacing:.15em;text-transform:uppercase;color:var(--gold);margin-bottom:8px}
.deacon-name{font-family:var(--display);font-size:clamp(17px,2vw,20px);font-weight:600;color:var(--ink);margin-bottom:12px;line-height:1.2}
.deacon-phone a{display:inline-flex;align-items:center;gap:8px;font-size:14px;color:var(--maroon);text-decoration:none;font-weight:500}
.deacon-phone a:hover{text-decoration:underline}
.deacon-phone svg{width:14px;height:14px;flex-shrink:0}

/* PHONE LINK ICON */
.phone-link{display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;color:var(--gold);cursor:pointer;transition:transform .25s,color .25s}
.phone-link:hover{color:var(--gold-light);transform:scale(1.15)}
.phone-link svg{width:16px;height:16px}

/* PROGRAMMES */
.prog-grid{display:grid;gap:0;border:1px solid var(--ivory-bd);margin-top:56px}
@media(min-width:600px){.prog-grid{grid-template-columns:1fr 1fr}}
.prog-card{
  padding:36px 28px;background:var(--ivory);border-bottom:1px solid var(--ivory-bd);border-right:1px solid var(--ivory-bd);
  position:relative;overflow:hidden;transition:background .25s;
}
@media(min-width:768px){.prog-card{padding:48px 40px}}
.prog-card::before{content:'';position:absolute;bottom:0;left:0;right:0;height:2px;background:var(--gold);transform:scaleX(0);transform-origin:left;transition:transform .3s var(--ease-out)}
.prog-card:hover{background:var(--ivory-dk)}
.prog-card:hover::before{transform:scaleX(1)}
.prog-icon{color:var(--gold);margin-bottom:20px}
.prog-icon svg{width:26px;height:26px}
.prog-name{font-family:var(--display);font-size:clamp(20px,2.5vw,26px);font-weight:700;color:var(--ink);margin-bottom:12px}
.prog-detail{font-size:clamp(15px,1.8vw,17px);line-height:1.8;color:var(--ink-mid)}
.prog-time{margin-top:14px;display:flex;align-items:center;gap:8px;font-size:14px;font-weight:600;color:var(--maroon)}
.prog-time svg{width:14px;height:14px;flex-shrink:0}

/* YEARLY */
.yearly{background:var(--charcoal)}
.yearly .headline{color:rgba(255,255,255,.92)}.yearly .headline em{color:var(--gold)}.yearly .eyebrow{color:var(--gold)}
.yearly-grid{display:grid;gap:0;border:1px solid rgba(255,255,255,.08);margin-top:48px}
@media(min-width:600px){.yearly-grid{grid-template-columns:1fr 1fr}}
.yearly-card{padding:40px 32px;background:rgba(255,255,255,.02);border-bottom:1px solid rgba(255,255,255,.08);border-right:1px solid rgba(255,255,255,.08);transition:background .25s}
@media(min-width:768px){.yearly-card{padding:52px 44px}}
.yearly-card:hover{background:rgba(255,255,255,.04)}
.yearly-icon{color:var(--gold);margin-bottom:20px}
.yearly-icon svg{width:28px;height:28px}
.yearly-name{font-family:var(--display);font-size:clamp(20px,2.5vw,26px);font-weight:700;color:rgba(255,255,255,.9);margin-bottom:12px}
.yearly-detail{font-size:clamp(15px,1.8vw,17px);color:rgba(255,255,255,.5);line-height:1.8}
.yearly-date{margin-top:16px;display:flex;align-items:center;gap:8px;font-size:14px;font-weight:600;color:var(--gold)}
.yearly-date svg{width:14px;height:14px;flex-shrink:0}

/* GIVE */
.give-section{background:var(--ivory-dk)}
.give-inner{max-width:1100px;margin:0 auto;display:grid;gap:60px;align-items:start}
@media(min-width:900px){.give-inner{grid-template-columns:1fr 1fr;gap:80px}}
.account-card{background:var(--maroon-deep);padding:40px 28px;border-top:3px solid var(--gold);position:relative}
@media(min-width:768px){.account-card{padding:40px 32px}}
.account-label{font-size:11px;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);margin-bottom:28px}
.acct-field-label{font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.4);margin-bottom:6px}
.acct-field-val{font-family:var(--display);font-size:clamp(17px,2.5vw,22px);font-weight:700;color:rgba(255,255,255,.9);margin-bottom:24px;line-height:1.2}
.acct-number{font-family:monospace;font-size:clamp(26px,4vw,40px);font-weight:700;color:var(--gold);letter-spacing:.12em;margin-bottom:6px}
.acct-bank{font-size:14px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:rgba(255,255,255,.5);margin-bottom:28px}
.copy-btn{
  display:inline-flex;align-items:center;gap:8px;cursor:pointer;
  background:rgba(201,150,58,.1);border:1px solid rgba(201,150,58,.25);color:var(--gold);
  padding:10px 20px;font-size:12px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;transition:all .2s;font-family:var(--body);
}
.copy-btn:hover{background:rgba(201,150,58,.2)}
.copy-btn svg{width:14px;height:14px}
.give-why h3{font-family:var(--display);font-size:clamp(22px,3vw,32px);font-weight:700;color:var(--ink);margin-bottom:16px}
.give-why p{font-size:clamp(15px,1.8vw,17px);color:var(--ink-mid);line-height:1.85;margin-bottom:20px}
.give-verse{background:var(--ivory);border-left:3px solid var(--gold);padding:20px 24px;margin-top:28px}
.give-verse blockquote{font-family:var(--display);font-style:italic;font-size:clamp(16px,2vw,19px);color:var(--maroon);line-height:1.55}
.give-verse cite{display:block;font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-light);margin-top:10px;font-style:normal}

/* CONTACT */
.contact-layout{display:grid;gap:56px;margin-top:56px;align-items:start}
@media(min-width:900px){.contact-layout{grid-template-columns:1fr 1fr;gap:80px}}
.form{display:flex;flex-direction:column;gap:20px}
.form-row{display:grid;grid-template-columns:1fr;gap:20px}
@media(min-width:480px){.form-row{grid-template-columns:1fr 1fr;gap:16px}}
.form-group{display:flex;flex-direction:column;gap:8px}
.form-label{font-size:12px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-mid)}
.form-input,.form-select,.form-textarea{
  padding:15px 17px;border:1px solid var(--ivory-bd);background:var(--ivory-dk);
  font-family:var(--body);font-size:16px;color:var(--ink);
  outline:none;transition:border-color .2s,box-shadow .2s;-webkit-appearance:none;border-radius:0;
}
.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--maroon);box-shadow:0 0 0 3px rgba(123,28,28,.08)}
.form-input::placeholder,.form-textarea::placeholder{color:var(--ink-light);opacity:.5}
.form-textarea{resize:vertical;min-height:130px;line-height:1.65}
.form-input:invalid:not(:placeholder-shown),.form-textarea:invalid:not(:placeholder-shown){border-color:var(--maroon);box-shadow:0 0 0 3px rgba(123,28,28,.06)}
.contact-info{display:flex;flex-direction:column}
.contact-info-row{display:flex;gap:18px;align-items:flex-start;padding:22px 0;border-bottom:1px solid var(--ivory-bd)}
.contact-info-row:first-child{padding-top:0}.contact-info-row:last-child{border-bottom:none}
.ci-icon{width:44px;height:44px;background:var(--ivory-dk);border:1px solid var(--ivory-bd);display:flex;align-items:center;justify-content:center;color:var(--gold);flex-shrink:0}
.ci-icon svg{width:18px;height:18px}
.ci-label{font-size:11px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--ink);margin-bottom:6px}
.ci-val{font-size:clamp(14px,1.8vw,16px);color:var(--ink-mid);line-height:1.65}
.ci-val a{color:var(--maroon);text-decoration:none;font-weight:500;transition:color .2s ease,text-decoration .2s ease}
.ci-val a:hover{color:var(--maroon);text-decoration:underline;text-decoration-thickness:2px;text-underline-offset:4px}
.socials{display:flex;gap:10px;margin-top:28px}
.social-link{width:44px;height:44px;background:var(--ivory-dk);border:1px solid var(--ivory-bd);display:flex;align-items:center;justify-content:center;color:var(--ink-mid);text-decoration:none;transition:all .3s cubic-bezier(.25,.46,.45,.94)}
.social-link svg{width:16px;height:16px;transition:transform .3s ease}
.social-link:hover{background:var(--maroon);border-color:var(--maroon);color:white;transform:translateY(-3px);box-shadow:0 8px 20px rgba(139,0,0,.25)}

/* 404 */
.four04{min-height:100svh;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:120px 20px;background:var(--maroon-deep)}
.four04-num{font-family:var(--display);font-size:clamp(100px,20vw,200px);font-weight:700;color:rgba(201,150,58,.15);line-height:1}
.four04 h2{font-family:var(--display);font-size:clamp(24px,4vw,40px);color:rgba(255,255,255,.9);margin-top:-20px;margin-bottom:16px}
.four04 p{color:rgba(255,255,255,.45);font-size:17px;margin-bottom:32px}

/* FOOTER */
footer{background:var(--charcoal);padding:64px 20px 40px;position:relative}
@media(min-width:768px){footer{padding:80px 48px 48px}}
footer::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--gold),transparent);opacity:.25}
.footer-inner{max-width:1100px;margin:0 auto}
.footer-top{display:grid;grid-template-columns:1fr 1fr;gap:28px;padding-bottom:48px;border-bottom:1px solid rgba(255,255,255,.06);margin-bottom:32px}
@media(min-width:768px){.footer-top{display:flex;flex-wrap:wrap;gap:48px;justify-content:space-between;padding-bottom:56px;margin-bottom:40px}}
.footer-brand{grid-column:1/-1}
.footer-brand p{font-family:var(--display);font-size:clamp(20px,2.5vw,24px);font-weight:400;color:rgba(255,255,255,.85);margin-bottom:10px}
.footer-brand span{font-size:12px;color:rgba(255,255,255,.3);letter-spacing:.1em;text-transform:uppercase}
.footer-col h6{font-size:10px;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);margin-bottom:18px;opacity:.8}
.footer-col a{display:block;font-size:14px;color:rgba(255,255,255,.4);text-decoration:none;margin-bottom:12px;transition:color .2s;cursor:pointer}
.footer-col a:hover{color:rgba(255,255,255,.75)}
.footer-col p.footer-plain{font-size:14px;color:rgba(255,255,255,.4);margin-bottom:12px}
.footer-bottom{display:flex;flex-direction:column;gap:12px;align-items:center;text-align:center}
@media(min-width:768px){.footer-bottom{flex-direction:row;flex-wrap:wrap;gap:16px;justify-content:space-between}}
.footer-copy{font-size:12px;color:rgba(255,255,255,.2)}
.footer-nbc{display:flex;align-items:center;gap:8px;font-size:12px;color:rgba(255,255,255,.3)}
.footer-nbc img{height:26px;width:26px;border-radius:50%;object-fit:cover;opacity:.5}

/* ---- Church History Timeline ---- */
/* FIX #3: Removed duplicate .history-timeline rule that previously appeared
   twice. Only one definition remains here. */
.history-timeline{position:relative;margin-top:40px;padding-left:0}
.history-timeline::before{content:'';position:absolute;left:110px;top:0;bottom:0;width:2px;background:linear-gradient(180deg,var(--gold),var(--maroon));opacity:.3}
@media(max-width:600px){.history-timeline::before{left:0}}

.ht-item{display:grid;grid-template-columns:110px 1fr;gap:0 28px;margin-bottom:36px;position:relative}
@media(max-width:600px){.ht-item{grid-template-columns:1fr;gap:6px;padding-left:20px}}
.ht-item::after{content:'';position:absolute;left:104px;top:6px;width:14px;height:14px;background:var(--gold);border-radius:50%;border:2px solid var(--ivory-dk);box-shadow:0 0 0 3px rgba(185,147,80,.2)}
@media(max-width:600px){.ht-item::after{left:-7px;top:4px}}
.ht-date{font-family:var(--display);font-size:13px;font-weight:600;color:var(--gold);text-align:right;padding-top:2px;padding-right:28px;line-height:1.3;white-space:nowrap}
@media(max-width:600px){.ht-date{text-align:left;padding-right:0}}
.ht-body{background:var(--ivory);border-left:3px solid var(--gold);border-radius:0 8px 8px 0;padding:16px 20px;box-shadow:0 2px 12px rgba(0,0,0,.05)}
.ht-body strong{font-family:var(--display);font-size:clamp(17px,2vw,17px);font-weight:700;color:var(--maroon);display:block;margin-bottom:6px}
.ht-body p strong{display:inline;margin-bottom:0;font-size:inherit}
.ht-body p{font-size:clamp(14px,1.8vw,15.5px);color:var(--ink-mid);line-height:1.75;margin:0}
.ht-list{margin:8px 0 0 18px;padding:0;list-style:disc;font-size:clamp(13.5px,1.7vw,15px);color:var(--ink-mid);line-height:1.75}
.ht-list li{margin-bottom:4px}

/* Timeline Show More
   JS sets inline height from scrollHeight for a reliable cross-browser
   expand. overflow:hidden stays on always; opacity fades in alongside.
   max-height is intentionally NOT used — it breaks on mobile WebKit when
   absolutely-positioned children (the dot ::after) affect scrollHeight. */
.hidden-timeline{
  height:0;
  overflow:hidden;
  opacity:0;
  /* Transition height is driven by JS inline style, opacity via class */
  transition:opacity 0.5s var(--ease-out);
}
/* FIX #2: Hide dot on collapsed items so it doesn't bleed past overflow */
.hidden-timeline::after{
  opacity:0;
  transition:opacity 0.3s var(--ease-out);
}
.timeline-more{text-align:center;margin-top:32px}
#showMoreBtn{min-width:220px}

/* JS adds this class after setting inline height, triggering the fade */
.hidden-timeline.tl-visible{
  opacity:1;
}
/* Restore dot once expanded */
.hidden-timeline.tl-visible::after{
  opacity:1;
}
.timeline-more.hidden{display:none}
