/* ═══════════════════════════════════════════
   LEGACY CHURCH — DESIGN SYSTEM
   Colors: #0D0E0F / #F4F4ED / #5C7B54
   Fonts: Archivo / Cormorant Garamond
   ═══════════════════════════════════════════ */
@import url('https://fonts.googleapis.com/css2?family=Archivo:wght@100;200;300;400;500;600;700;800;900&family=Cormorant+Garamond:ital,wght@0,300;0,400;0,500;0,600;1,300;1,400;1,500;1,600&display=swap');

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

:root{
  --dark:#0D0E0F;--dark2:#131415;--dark3:#1a1b1d;
  --cream:#F4F4ED;--cream-m:rgba(244,244,237,.5);--cream-d:rgba(244,244,237,.2);
  --green:#5C7B54;--green-l:#7a9e70;--green-d:#4a6344;
  --white:#fff;
  --fm:'Archivo',sans-serif;--fs:'Cormorant Garamond',serif;
  --ease:cubic-bezier(.16,1,.3,1);
  --radius:6px;
}

html{scroll-behavior:smooth;overflow-x:hidden;background:var(--dark)}
body{font-family:var(--fm);color:var(--cream);background:var(--dark);overflow-x:hidden;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}
img{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}

/* ─── UTILITIES ─── */
.container{max-width:1200px;margin:0 auto;padding:0 6vw}
.sc{font-family:var(--fs);font-style:italic;font-weight:400;text-transform:none;color:var(--green-l);letter-spacing:0}
.hero-content .sc,.page-hero .sc{color:var(--cream);text-shadow:0 2px 12px rgba(0,0,0,.4)}
.page-hero .label,.hero .label{color:var(--green-l) !important;text-shadow:0 1px 3px rgba(0,0,0,.8),0 0 12px rgba(0,0,0,.4)}
.section-dark .label,.section-dark2 .label{color:var(--green-l) !important}
.section-dark .sc,.section-dark2 .sc,.page-hero .sc,.hero .sc{text-shadow:0 1px 4px rgba(255,255,255,.25),0 2px 8px rgba(0,0,0,.4)}
.section-dark{background:var(--dark);color:var(--cream)}
.section-cream{background:var(--cream);color:var(--dark)}
.section-dark2{background:var(--dark2);color:var(--cream)}
.text-center{text-align:center}

/* ─── TYPOGRAPHY ─── */
h1{font-size:clamp(2.5rem,7vw,5.5rem);font-weight:800;letter-spacing:-.04em;text-transform:uppercase;line-height:.95}
h2{font-size:clamp(1.8rem,4vw,3rem);font-weight:800;letter-spacing:-.03em;text-transform:uppercase;line-height:1}
h3{font-size:clamp(1.2rem,2vw,1.6rem);font-weight:700;letter-spacing:-.02em;text-transform:uppercase;line-height:1.1}
.label{font-size:.6rem;letter-spacing:.25em;text-transform:uppercase;font-weight:700;color:var(--green);word-spacing:.3em}
.body-text{color:var(--cream-m);font-weight:300;line-height:1.9;font-size:.92rem;max-width:520px}
.section-cream .body-text{color:rgba(13,14,15,.5)}
.section-cream .label{color:var(--green-d)}
.section-cream h2,.section-cream h3{color:var(--dark)}
.section-cream .photo-card .overlay .label{color:var(--green)}
.section-cream .photo-card .overlay h3{color:var(--cream)}
.section-cream .photo-card .overlay p{color:var(--cream-m)}

/* ─── BUTTONS ─── */
.btn{display:inline-flex;align-items:center;gap:.5rem;padding:.9rem 2rem;font-size:.68rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase;font-family:var(--fm);border-radius:var(--radius);transition:all .3s var(--ease);cursor:pointer;border:none}
.btn-green{background:var(--green);color:var(--cream)}
.btn-green:hover{background:var(--green-l);transform:translateY(-2px);box-shadow:0 8px 25px rgba(92,123,84,.3)}
.btn-white{background:var(--cream);color:var(--dark)}
.btn-white:hover{transform:translateY(-2px);box-shadow:0 8px 25px rgba(244,244,237,.15)}
.btn-outline{background:transparent;color:var(--cream);border:1px solid var(--cream-d)}
.btn-outline:hover{border-color:var(--green);color:var(--green);transform:translateY(-2px)}
.btn-dark{background:var(--dark);color:var(--cream)}
.btn-dark:hover{background:var(--dark2);transform:translateY(-2px);box-shadow:0 8px 25px rgba(0,0,0,.2)}
.section-cream .btn-outline{color:var(--dark);border-color:rgba(13,14,15,.15)}
.section-cream .btn-outline:hover{border-color:var(--green);color:var(--green)}

/* ─── NAV ─── */
.nav{position:fixed;top:0;left:0;right:0;z-index:100;display:flex;justify-content:space-between;align-items:center;padding:1.2rem 3rem;transition:all .5s var(--ease)}
.nav.scrolled{background:rgba(13,14,15,.97);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);padding:.65rem 3rem;border-bottom:1px solid rgba(92,123,84,.08)}
.nav-logo{height:36px;transition:height .3s var(--ease)}
.nav.scrolled .nav-logo{height:26px}
.nav-links{display:flex;gap:1.8rem;align-items:center;list-style:none}
.nav-links a{font-size:.62rem;font-weight:600;letter-spacing:.2em;text-transform:uppercase;transition:color .25s}
.nav-links a:hover{color:var(--green)}
.nav-cta{background:var(--green);color:var(--cream);padding:.5rem 1.3rem;border-radius:var(--radius);font-size:.62rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;transition:all .3s}
.nav-cta:hover{background:var(--green-l)}

/* Nav dropdowns */
.nav-links li{position:relative;padding-bottom:.5rem;margin-bottom:-.5rem}
.nav-dropdown{position:absolute;top:100%;left:50%;transform:translateX(-50%) translateY(6px);background:rgba(13,14,15,.97);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid rgba(244,244,237,.06);border-radius:var(--radius);padding:.6rem 0;min-width:190px;opacity:0;pointer-events:none;transition:opacity .25s var(--ease),transform .25s var(--ease);text-align:center;z-index:110}
.nav-links li:hover .nav-dropdown{opacity:1;pointer-events:all;transform:translateX(-50%) translateY(0)}
.nav-dropdown a{display:block;padding:.55rem 1.4rem;font-size:.58rem;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--cream-d);transition:color .2s,background .2s;white-space:nowrap}
.nav-dropdown a:hover{color:var(--cream);background:rgba(244,244,237,.06)}

/* Hamburger */
.hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:6px;z-index:101}
.hamburger span{width:22px;height:1.5px;background:var(--cream);transition:all .3s var(--ease);transform-origin:center}
.hamburger.on span:nth-child(1){transform:rotate(45deg) translate(4px,4.5px)}
.hamburger.on span:nth-child(2){opacity:0}
.hamburger.on span:nth-child(3){transform:rotate(-45deg) translate(4px,-4.5px)}

/* Mobile menu */
.mobile-menu{display:none;position:fixed;inset:0;background:var(--dark);z-index:99;flex-direction:column;justify-content:center;align-items:center;gap:1.4rem;opacity:0;pointer-events:none;transition:opacity .35s var(--ease)}
.mobile-menu.on{opacity:1;pointer-events:all}
.mobile-menu a{font-family:var(--fm);font-size:.8rem;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:var(--cream);transition:color .2s}
.mobile-menu a:hover,.mobile-menu a:active{color:var(--green-l)}
.mobile-menu .mobile-sub{display:none;flex-direction:column;gap:.6rem;padding:.4rem 0 .2rem;overflow:hidden;max-height:0;opacity:0;transition:max-height .35s var(--ease),opacity .25s var(--ease)}
.mobile-menu .mobile-sub.open{display:flex;max-height:300px;opacity:1}
.mobile-menu .mobile-sub a{font-size:.65rem;color:var(--cream-m);letter-spacing:.25em}
.mobile-menu .mobile-sub a:hover,.mobile-menu .mobile-sub a:active{color:var(--green-l)}
.mobile-menu .mobile-parent{display:flex;align-items:center;gap:.4rem;cursor:pointer}
.mobile-menu .mobile-parent::after{content:'';width:6px;height:6px;border-right:1.5px solid var(--cream-m);border-bottom:1.5px solid var(--cream-m);transform:rotate(45deg);transition:transform .3s var(--ease);flex-shrink:0}
.mobile-menu .mobile-parent.open::after{transform:rotate(-135deg)}

/* ─── HERO (reusable) ─── */
.hero{position:relative;height:100vh;min-height:650px;display:flex;align-items:center;justify-content:center;overflow:hidden}
.hero-bg{position:absolute;inset:0}
.hero-bg img,.hero-bg video{width:100%;height:100%;object-fit:cover;object-position:center center}
.hero-overlay{position:absolute;inset:0;background:radial-gradient(ellipse at 50% 40%,rgba(13,14,15,.4) 0%,rgba(13,14,15,.75) 100%)}
.hero-content{position:relative;z-index:2;text-align:center;padding:0 2rem;max-width:800px}
.hero-content .label{margin-bottom:1.5rem;display:block}
.hero-content h1{margin-bottom:.8rem}
.hero-content .hero-sub{font-size:.65rem;letter-spacing:.4em;text-transform:uppercase;color:var(--green);font-weight:600;margin-bottom:2.5rem;word-spacing:.6em}
.hero-btns{display:flex;gap:.8rem;justify-content:center;flex-wrap:wrap}

/* Page hero (shorter, for subpages) */
.page-hero{position:relative;height:50vh;min-height:360px;display:flex;align-items:center;justify-content:center;overflow:hidden}
.page-hero .hero-bg img{object-position:center 45%}
.page-hero .hero-overlay{background:rgba(13,14,15,.7)}
.page-hero h1{font-size:clamp(2rem,5vw,3.5rem);margin-bottom:.5rem}
.page-hero .hero-sub{margin-bottom:0}

/* Hero service badge */
.hero-badge{position:absolute;bottom:2.5rem;left:50%;transform:translateX(-50%);z-index:2;background:rgba(13,14,15,.65);backdrop-filter:blur(12px);border:1px solid rgba(92,123,84,.12);border-radius:50px;padding:.55rem 1.8rem;display:flex;align-items:center;gap:1.2rem;font-size:.58rem;letter-spacing:.15em;text-transform:uppercase;font-weight:500;white-space:nowrap}
.hero-badge .pulse{width:6px;height:6px;border-radius:50%;background:var(--green);flex-shrink:0;animation:pulse 2s infinite}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(1.6)}}

/* ─── FLOATING VISIT BUTTON ─── */
.float-visit{position:fixed;bottom:2rem;right:2rem;z-index:90;background:var(--green);color:var(--cream);padding:.7rem 1.6rem;border-radius:50px;font-size:.6rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;box-shadow:0 8px 30px rgba(92,123,84,.35);transition:all .3s;opacity:0;transform:translateY(20px);pointer-events:none}
.float-visit.show{opacity:1;transform:translateY(0);pointer-events:all}
.float-visit:hover{background:var(--green-l);transform:translateY(-2px);box-shadow:0 12px 40px rgba(92,123,84,.45)}

/* ─── CARD SYSTEM ─── */
.card-grid{display:grid;gap:1.2rem}
.card-grid-2{grid-template-columns:repeat(2,1fr)}
.card-grid-3{grid-template-columns:repeat(3,1fr)}
.card-grid-4{grid-template-columns:repeat(4,1fr)}

/* Photo card with overlay */
.photo-card{position:relative;overflow:hidden;border-radius:var(--radius)}
.photo-card img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease)}
.photo-card:hover img{transform:scale(1.05)}
.photo-card .overlay{position:absolute;inset:0;background:linear-gradient(0deg,rgba(13,14,15,.85) 0%,transparent 50%);display:flex;flex-direction:column;justify-content:flex-end;padding:1.8rem}
.photo-card .overlay .label{margin-bottom:.3rem;color:var(--green-l) !important;text-shadow:0 1px 3px rgba(0,0,0,.8),0 0 12px rgba(0,0,0,.4)}
.photo-card .overlay h3{margin-bottom:.2rem;color:var(--cream) !important}
.photo-card .overlay p{font-size:.78rem;color:var(--cream-m) !important;font-weight:300;line-height:1.4;max-width:280px;opacity:0;transform:translateY(6px);transition:all .4s var(--ease)}
.photo-card:hover .overlay p{opacity:1;transform:translateY(0)}

/* Info card (white, for cream sections) */
.info-card{background:var(--white);border-radius:10px;overflow:hidden;transition:transform .3s,box-shadow .3s;display:flex;flex-direction:column}
.info-card:hover{transform:translateY(-4px);box-shadow:0 16px 40px rgba(0,0,0,.08)}
.info-card .card-img{height:220px;overflow:hidden}
.info-card .card-img img{width:100%;height:100%;object-fit:cover;object-position:center center;transition:transform .5s var(--ease)}
.info-card:hover .card-img img{transform:scale(1.05)}
.info-card .card-body{padding:1.2rem 1.3rem 1rem}
.info-card .card-body .label{display:block;margin-bottom:.3rem}
.info-card .card-body h3{font-size:.95rem;margin-bottom:.3rem;color:var(--dark)}
.info-card .card-body p{font-size:.75rem;color:rgba(13,14,15,.4);font-weight:400;line-height:1.5}
.info-card .card-foot{padding:0 1.3rem 1.2rem;margin-top:auto;font-size:.6rem;letter-spacing:.15em;text-transform:uppercase;color:var(--green);font-weight:600}

/* ─── STAFF CARD ─── */
.staff-card{text-align:center}
.staff-card .staff-img{width:100%;aspect-ratio:3/4;overflow:hidden;border-radius:var(--radius);margin-bottom:1rem}
.staff-card .staff-img img{width:100%;height:100%;object-fit:cover;object-position:center center;transition:transform .5s var(--ease)}
.staff-card:hover .staff-img img{transform:scale(1.03)}
.staff-card h3{font-size:.9rem;text-transform:uppercase;letter-spacing:.02em;margin-bottom:.2rem}
.staff-card .role{font-size:.6rem;letter-spacing:.2em;text-transform:uppercase;color:var(--green);font-weight:600}

/* ─── STAFF BIO LAYOUT ─── */
.staff-bio-grid{display:grid;grid-template-columns:1fr 1.3fr;gap:3rem;align-items:center}
.staff-bio-img{border-radius:var(--radius);overflow:hidden}
.staff-bio-img img{width:100%;aspect-ratio:3/4;object-fit:cover;object-position:center 25%;transition:transform .5s var(--ease)}
.staff-bio-grid:hover .staff-bio-img img{transform:scale(1.03)}

/* ─── SECTION SPACING ─── */
.section{padding:5rem 0}
.section-lg{padding:7rem 0}

/* ─── FOOTER ─── */
.footer{padding:3.5rem 6vw 1.5rem;border-top:1px solid rgba(244,244,237,.05)}
.footer-grid{display:flex;justify-content:space-between;align-items:flex-start;flex-wrap:wrap;gap:2rem;margin-bottom:2.5rem}
.footer-brand .nav-logo{margin-bottom:.8rem}
.footer-brand p{font-size:.72rem;color:var(--cream-d);font-weight:300;max-width:240px;line-height:1.6}
.footer-social{display:flex;gap:.5rem;margin-top:1rem}
.footer-social a{width:30px;height:30px;border:1px solid rgba(244,244,237,.06);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--cream-d);transition:all .3s}
.footer-social a:hover{border-color:var(--green);color:var(--green)}
.footer-links{display:flex;gap:3rem}
.footer-links div a{display:block;font-size:.72rem;color:var(--cream-d);margin-bottom:.4rem;font-weight:300;transition:color .3s}
.footer-links div a:hover{color:var(--cream)}
.footer-bottom{padding-top:1.5rem;border-top:1px solid rgba(244,244,237,.03);text-align:center}
.footer-bottom p{font-size:.55rem;color:rgba(244,244,237,.15);font-weight:300;letter-spacing:.05em}

/* ─── EVENT CARDS (PCO auto-loaded) ─── */
.event-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:1.2rem}
.event-card{background:var(--white);border-radius:10px;overflow:hidden;transition:transform .3s var(--ease),box-shadow .3s;display:flex;flex-direction:column;border:1px solid rgba(13,14,15,.06)}
.event-card:hover{transform:translateY(-4px);box-shadow:0 16px 40px rgba(0,0,0,.08)}
.event-card-img{aspect-ratio:16/9;overflow:hidden}
.event-card-img img{width:100%;height:100%;object-fit:cover;transition:transform .5s var(--ease)}
.event-card:hover .event-card-img img{transform:scale(1.05)}
.event-card-body{padding:1rem 1.2rem 1.2rem}
.event-card-body h3{font-size:.85rem;font-weight:700;letter-spacing:-.01em;text-transform:none;line-height:1.3;color:var(--dark);margin-bottom:.3rem}
.event-card-date{font-size:.72rem;color:rgba(13,14,15,.45);font-weight:400;margin-bottom:.6rem}
.event-card-badges{display:flex;flex-wrap:wrap;gap:.4rem}
.event-badge{font-size:.55rem;font-weight:600;letter-spacing:.05em;padding:.25rem .6rem;border-radius:4px;border:1px solid rgba(13,14,15,.1);color:rgba(13,14,15,.5)}
.event-badge.featured{background:rgba(245,158,11,.08);border-color:rgba(245,158,11,.2);color:#b45309}
.event-badge.signup{color:rgba(13,14,15,.45)}

/* ─── GIVE OPTIONS ─── */
.give-option{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.8rem;padding:2rem 1.5rem;background:var(--white);border-radius:10px;color:var(--dark);transition:transform .3s var(--ease),box-shadow .3s;text-align:center}
.give-option:hover{transform:translateY(-4px);box-shadow:0 16px 40px rgba(0,0,0,.08)}
.give-option svg{color:var(--green);flex-shrink:0}
.give-option span{font-size:.65rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase}

/* ─── PARALLAX & MOTION ─── */
.hero-bg img,.hero-bg video,.photo-strip img{will-change:transform;transition:none}
.hero-content,.hero-badge,.hero-overlay{will-change:transform,opacity,filter}
.info-card,.feature-item,.give-option{transition:transform .4s var(--ease),box-shadow .4s;will-change:transform}
.photo-card img{transition:transform .5s var(--ease)}
.photo-card .overlay{transition:transform .4s var(--ease)}
.btn{transition:transform .3s var(--ease),background .3s,box-shadow .3s}
.section{will-change:clip-path}
.staff-bio-img img{will-change:transform,filter;transition:none}

/* Word-by-word hero reveal */
@keyframes wordReveal{
  from{opacity:0;transform:translateY(50px) rotateX(-70deg) scale(0.85);filter:blur(8px)}
  to{opacity:1;transform:translateY(0) rotateX(0) scale(1);filter:blur(0)}
}
.word-reveal{display:inline-block;animation:wordReveal .8s calc(0.3s + var(--i) * 0.08s) both var(--ease)}
.hero-content h1,.page-hero h1{perspective:800px;overflow:visible}

/* Character reveal for labels */
@keyframes charReveal{
  from{opacity:0;transform:translateY(10px) scale(0.8)}
  to{opacity:1;transform:translateY(0) scale(1)}
}

/* Scroll progress bar */
.scroll-progress{position:fixed;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--green),var(--green-l));z-index:200;transform-origin:left;transform:scaleX(0);pointer-events:none}

/* Hero particles */
.hero-particles{position:absolute;inset:0;z-index:1;overflow:hidden;pointer-events:none}
.particle{position:absolute;left:var(--x);top:var(--y);width:var(--size);height:var(--size);background:rgba(244,244,237,0.12);border-radius:50%;animation:particleFloat var(--duration) var(--delay) infinite linear}
@keyframes particleFloat{
  0%{transform:translate(0,0) scale(1);opacity:0}
  10%{opacity:1}
  90%{opacity:1}
  100%{transform:translate(var(--drift),-100vh) scale(0);opacity:0}
}

/* Image curtain reveal */
.image-uncover{position:relative;overflow:hidden}
.image-uncover img{will-change:transform,filter;transition:none}
.uncover-curtain{position:absolute;inset:0;background:var(--dark);transform-origin:right center;will-change:transform;z-index:2;pointer-events:none}
.section-cream .uncover-curtain{background:var(--cream)}

/* Counter-scroll photo rows */
.counter-scroll-section{overflow:hidden;padding:4rem 0;background:var(--dark)}
.counter-scroll-row{display:flex;gap:.8rem;padding:.4rem 0;will-change:transform;white-space:nowrap}
.counter-scroll-row img{height:280px;width:auto;min-width:340px;border-radius:var(--radius);object-fit:cover;object-position:center center;flex-shrink:0;filter:brightness(.7);transition:filter .3s}
.counter-scroll-row img:hover{filter:brightness(1)}

/* Velocity skew */
.info-card,.feature-item,.give-option,.staff-bio-grid{--skew:0deg}

/* Enhanced scroll reveal */
.rv{opacity:0;transform:translateY(35px) skewY(1deg);transition:opacity .7s var(--ease),transform .7s var(--ease),filter .7s var(--ease);filter:blur(4px)}
.rv.v{opacity:1;transform:translateY(0) skewY(0);filter:blur(0)}
.d1{transition-delay:.08s}.d2{transition-delay:.16s}.d3{transition-delay:.24s}.d4{transition-delay:.32s}

/* ─── RESPONSIVE GRID HELPERS ─── */
.grid-sermon{display:grid;grid-template-columns:1.4fr 1fr;gap:3rem;align-items:center}
.grid-event{display:grid;grid-template-columns:auto 1fr;gap:3rem;align-items:center}
.grid-event-img{width:380px;border-radius:var(--radius);overflow:hidden;display:block;flex-shrink:0}
.grid-pastor{display:grid;grid-template-columns:1fr 1.2fr;gap:4rem;align-items:center}
.photo-strip{display:grid;gap:0;overflow:hidden}
.photo-strip-5{grid-template-columns:repeat(5,1fr);height:35vh;min-height:240px}
.photo-strip-4{grid-template-columns:repeat(4,1fr)}
.photo-strip-3{grid-template-columns:repeat(3,1fr);height:45vh;min-height:300px}
.photo-strip img{width:100%;height:100%;object-fit:cover;object-position:center center}
.photo-strip-dim img{filter:brightness(.6)}
.give-banner{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:2rem;padding-left:6vw;padding-right:6vw}

/* ─── EXPECT GRID (homepage 4-col photo cards) ─── */
.expect-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:0}
.expect-grid .photo-card{height:50vh;min-height:300px}

/* ─── FAQ / FEATURE LIST ─── */
.feature-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem}
.feature-item{padding:2rem;background:var(--white);border-radius:10px;transition:transform .3s,box-shadow .3s}
.feature-item:hover{transform:translateY(-3px);box-shadow:0 12px 30px rgba(0,0,0,.06)}
.feature-item .feature-icon{width:48px;height:48px;background:rgba(92,123,84,.08);border-radius:10px;display:flex;align-items:center;justify-content:center;margin-bottom:1rem;color:var(--green)}
.feature-item h3{font-size:.85rem;margin-bottom:.4rem;color:var(--dark)}
.feature-item p{font-size:.78rem;color:rgba(13,14,15,.45);font-weight:400;line-height:1.5;text-transform:none;letter-spacing:0}

/* ─── QUOTE / PULL QUOTE ─── */
.pull-quote{font-family:var(--fs);font-style:italic;font-size:clamp(1.3rem,2.5vw,1.8rem);line-height:1.5;color:var(--cream);max-width:600px;margin:0 auto;text-align:center}
.pull-quote cite{display:block;margin-top:1rem;font-family:var(--fm);font-style:normal;font-size:.6rem;letter-spacing:.2em;text-transform:uppercase;color:var(--green);font-weight:600}
.section-cream .pull-quote{color:var(--dark)}
.section-cream .pull-quote cite{color:var(--green-d)}

/* ─── IMPACT CARDS (Give page) ─── */
.impact-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.impact-card{text-align:center;padding:2rem 1.5rem}
.impact-card .impact-num{font-size:clamp(2rem,4vw,3rem);font-weight:800;color:var(--green);line-height:1;margin-bottom:.5rem}
.impact-card p{font-size:.78rem;color:var(--cream-m);font-weight:300;line-height:1.5}
.section-cream .impact-card p{color:rgba(13,14,15,.5)}

/* ─── STICKY MOBILE CTA BAR ─── */
.mobile-cta-bar{display:none}

/* ─── MOBILE ACTIVE STATES ─── */
@media(hover:none)and (pointer:coarse){
  .btn:active{opacity:.85;transform:scale(.97) !important}
  .info-card:active,.feature-item:active,.give-option:active{transform:scale(.98) !important}
  .photo-card:active img{transform:scale(1.03)}
  /* Kill hover effects that cause sticky hover */
  .btn:hover{transform:none;box-shadow:none}
  .info-card:hover,.feature-item:hover,.give-option:hover{transform:none;box-shadow:none}
  /* Show photo card descriptions on touch devices (no hover available) */
  .photo-card .overlay p{opacity:1;transform:translateY(0)}
}

/* ─── RESPONSIVE ─── */
@media(max-width:1024px){
  .card-grid-4{grid-template-columns:repeat(2,1fr)}
  .card-grid-3{grid-template-columns:repeat(2,1fr)}
  .expect-grid{grid-template-columns:repeat(2,1fr)}
  .feature-grid{grid-template-columns:repeat(2,1fr)}
  .impact-grid{grid-template-columns:repeat(3,1fr)}
}

@media(max-width:768px){
  /* Blog cards stack on mobile */
  .info-card[style*="flex-direction:row"]{flex-direction:column !important}
  .info-card[style*="flex-direction:row"] .card-img{width:100% !important;min-width:0 !important;aspect-ratio:16/9 !important}

  /* Nav */
  .nav-links{display:none}
  .hamburger{display:flex;width:48px;height:48px;align-items:center;justify-content:center;-webkit-tap-highlight-color:transparent;touch-action:manipulation}
  .mobile-menu{display:flex}
  .nav{padding:1rem 1.25rem}
  .nav.scrolled{padding:.65rem 1.25rem}

  /* Hero — fix 100vh bug */
  .hero{min-height:100dvh}
  .page-hero{height:45vh;min-height:320px}
  .hero-badge{font-size:.5rem;gap:.7rem;padding:.45rem 1.2rem}
  .hero-content{padding:0 1.5rem}
  .hero-content h1{font-size:clamp(2.2rem,9vw,3.5rem)}

  /* Section spacing */
  .section{padding:3.5rem 0}
  .container{padding:0 1.25rem}

  /* Grids stack */
  .grid-sermon,.grid-event,.grid-pastor,.staff-bio-grid{grid-template-columns:1fr;gap:2rem}
  .staff-bio-grid[style*="direction:rtl"]{direction:ltr}
  .staff-bio-grid[style*="direction:rtl"]>div{direction:ltr}
  .grid-event-img{width:100%}
  .card-grid-4,.card-grid-3,.card-grid-2{grid-template-columns:1fr}

  /* Expect grid — horizontal scroll carousel on mobile */
  .expect-grid{display:flex;overflow-x:auto;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;gap:0;scrollbar-width:none;-ms-overflow-style:none}
  .expect-grid::-webkit-scrollbar{display:none}
  .expect-grid .photo-card{flex:0 0 85vw;height:55vh;min-height:320px;scroll-snap-align:start;border-radius:0}

  /* Photo strips — horizontal scroll */
  .photo-strip{display:flex;overflow-x:auto;scroll-snap-type:x proximity;-webkit-overflow-scrolling:touch;gap:.5rem;padding:0 1.25rem;scrollbar-width:none;height:auto;min-height:0}
  .photo-strip::-webkit-scrollbar{display:none}
  .photo-strip>div{flex:0 0 auto;height:200px;width:280px;scroll-snap-align:start;overflow:hidden;border-radius:var(--radius)}

  /* Counter scroll rows */
  .counter-scroll-section{padding:2.5rem 0}
  .counter-scroll-row img{height:220px;min-width:300px}

  /* Feature grid */
  .feature-grid{grid-template-columns:1fr;gap:1rem}
  .impact-grid{grid-template-columns:repeat(3,1fr);gap:.8rem}
  .impact-card{padding:1.5rem .8rem}
  .impact-card .impact-num{font-size:clamp(1.5rem,6vw,2.2rem)}

  /* Give options — 2 col on mobile */
  .give-banner{text-align:center;justify-content:center}
  .card-grid-3.rv{grid-template-columns:repeat(2,1fr) !important}

  /* Info card image height — proportional on mobile */
  .info-card .card-img{height:180px}

  /* Footer — enough room above CTA bar */
  .footer-grid{flex-direction:column}
  .footer-links{gap:2rem}
  .footer{padding-bottom:calc(5rem + env(safe-area-inset-bottom,0px))}

  /* Mobile menu — tap targets */
  .mobile-menu a{min-height:44px;display:inline-flex;align-items:center}
  .mobile-menu .mobile-sub a{min-height:36px}

  /* Sticky mobile CTA */
  .mobile-cta-bar{display:flex;position:fixed;bottom:0;left:0;right:0;z-index:99;background:rgba(13,14,15,.97);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-top:1px solid rgba(92,123,84,.15);padding:.75rem 1.25rem;padding-bottom:calc(.75rem + env(safe-area-inset-bottom,0px));gap:.6rem;transform:translateY(100%);transition:transform .35s var(--ease)}
  .mobile-cta-bar.visible{transform:translateY(0)}
  .mobile-cta-bar .btn{flex:1;text-align:center;min-height:48px;font-size:.7rem;padding:.8rem 1rem}
  body{padding-bottom:calc(70px + env(safe-area-inset-bottom,0px))}

  /* Float visit hidden on mobile (replaced by CTA bar) */
  .float-visit{display:none !important}

  /* Scroll progress thicker on mobile for thumb visibility */
  .scroll-progress{height:3px}

  /* Disable section clip-path on mobile for perf */
  .section{clip-path:none !important}
}

@media(max-width:480px){
  .hero-btns{flex-direction:column;align-items:center;width:100%;padding:0 .5rem}
  .btn{width:100%;justify-content:center}
  .hero-badge{flex-wrap:wrap;justify-content:center;gap:.5rem .8rem;max-width:90vw;text-align:center;line-height:1.6}
  .hero-content h1{font-size:clamp(2rem,8.5vw,3rem)}

  /* Expect — full width swipe */
  .expect-grid .photo-card{flex:0 0 92vw}

  /* Give options 2-col */
  .card-grid-3{grid-template-columns:repeat(2,1fr) !important}

  /* Impact stays 3-col but tighter */
  .impact-grid{gap:.5rem}
  .impact-card{padding:1rem .5rem}
  .impact-card .impact-num{font-size:1.4rem}
  .impact-card p{font-size:.7rem}

  /* Staff bio image full width */
  .staff-bio-img{border-radius:0;margin:0 -1.25rem;width:calc(100% + 2.5rem)}

  /* Photo card overlay — more padding on small screens */
  .photo-card .overlay{padding:1.2rem}
  .photo-card .overlay h3{font-size:1rem}
}

/* ─── VERY SMALL SCREENS (iPhone SE) ─── */
@media(max-width:350px){
  .hero-content h1{font-size:1.8rem}
  .container{padding:0 1rem}
  .nav{padding:.8rem 1rem}
  .mobile-cta-bar{padding:.6rem 1rem;padding-bottom:calc(.6rem + env(safe-area-inset-bottom,0px))}
  .mobile-cta-bar .btn{font-size:.6rem;padding:.7rem .6rem}
}

/* ─── REDUCED MOTION ─── */
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms !important;animation-iteration-count:1 !important;transition-duration:.01ms !important;scroll-behavior:auto !important}
  .rv{opacity:1;transform:none;filter:none}
  .hero-particles{display:none}
  .section{clip-path:none !important}
}
