/* ============================================================
   Hill Country Church (PCA) — shared stylesheet
   Fonts: Poppins (headings/nav/buttons) + Inter (body).
   Brand greens from the logo. "Modern layout, classic soul."
   Shared across index.html + all inner pages.
   ============================================================ */

:root{
  --ink:#232826; --muted:#6e766f;
  --cream:#f3f7f3; --paper:#ffffff;
  --sage:#7fb89a; --sage-dk:#5f9a7e;
  --lime:#8cc63f; --lime-dk:#6f9f2c;
  --forest:#2f4f42; --forest-dk:#243d33;
  --line:#e2e9e2; --maxw:1200px;
}
*{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}
:target{scroll-margin-top:96px;}
body{font-family:'Inter',system-ui,sans-serif;color:var(--ink);background:var(--paper);line-height:1.6;-webkit-font-smoothing:antialiased;}
h1,h2,h3,h4{font-family:'Poppins',sans-serif;font-weight:600;line-height:1.13;letter-spacing:-0.01em;}
a{color:inherit;text-decoration:none;}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px;}
.eyebrow{text-transform:uppercase;letter-spacing:.18em;font-size:.85rem;font-weight:600;color:var(--lime-dk);margin-bottom:14px;}
.btn{display:inline-block;padding:14px 30px;border-radius:3px;font-weight:600;font-size:.88rem;font-family:'Poppins',sans-serif;
  letter-spacing:.01em;transition:all .2s ease;cursor:pointer;border:2px solid transparent;text-align:center;}
.btn-lime{background:var(--lime);color:#1d3209;border-color:var(--lime);}
.btn-lime:hover{background:var(--lime-dk);border-color:var(--lime-dk);color:#fff;}
.btn-forest{background:var(--forest);color:#fff;border-color:var(--forest);}
.btn-forest:hover{background:var(--forest-dk);border-color:var(--forest-dk);}
.btn-outline-w{background:transparent;color:#fff;border-color:rgba(255,255,255,.65);}
.btn-outline-w:hover{background:#fff;color:var(--forest);}
.btn-outline-g{background:transparent;color:var(--forest);border-color:var(--forest);}
.btn-outline-g:hover{background:var(--forest);color:#fff;}

/* ---------- Photo placeholder styling ---------- */
.ph{background:linear-gradient(135deg,#9fc9b4,#5f9a7e);position:relative;overflow:hidden;}
.ph:after{content:attr(data-label);position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
  text-align:center;padding:20px;color:rgba(255,255,255,.92);font-size:.8rem;letter-spacing:.04em;font-weight:500;text-transform:uppercase;}

/* ---------- Top visitor banner ---------- */
.announce{background:var(--lime);color:#1d3209;text-align:center;padding:10px 22px;font-size:.9rem;font-weight:500;}
.announce a{font-weight:700;text-decoration:underline;}
.announce a:hover{color:var(--forest);}

/* ---------- Header ---------- */
header{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.96);backdrop-filter:blur(8px);border-bottom:1px solid var(--line);}
.nav{display:flex;align-items:center;justify-content:space-between;height:78px;}
.nav .brand{display:flex;align-items:center;gap:13px;}
.nav .brand img{height:52px;width:auto;display:block;}
.nav .brand .bt{font-family:'Poppins',sans-serif;font-weight:700;font-size:1.12rem;color:var(--ink);line-height:1.05;}
.nav .brand .bt small{display:block;font-weight:500;font-size:.58rem;letter-spacing:.15em;text-transform:uppercase;color:var(--sage-dk);margin-top:3px;}
.nav-links{display:flex;align-items:center;gap:28px;list-style:none;}
.nav-links a{font-family:'Poppins',sans-serif;font-size:.95rem;font-weight:500;color:var(--ink);transition:color .2s;}
.nav-links a:hover{color:var(--sage-dk);}
.nav-links a.active{color:var(--sage-dk);}
.nav-links .btn{padding:9px 22px;font-size:.8rem;}
.menu-btn{display:none;background:none;border:none;font-size:1.6rem;cursor:pointer;color:var(--ink);}

/* ---------- Hero (homepage) ---------- */
.hero{position:relative;min-height:calc(100vh - 118px);display:flex;align-items:center;color:#fff;overflow:hidden;}
.hero .ph{position:absolute;inset:0;z-index:1;}
.hero:before{content:"";position:absolute;inset:0;z-index:2;background:linear-gradient(180deg,rgba(35,40,38,.32),rgba(35,40,38,.55));}
.hero-inner{position:relative;z-index:3;max-width:var(--maxw);margin:0 auto;padding:90px 28px;width:100%;}
.hero .eyebrow{color:#e7f3d4;}
.hero h1{font-weight:700;font-size:clamp(2.7rem,6.2vw,5rem);max-width:15ch;margin-bottom:22px;text-shadow:0 2px 36px rgba(0,0,0,.25);}
.hero p.lead{font-size:1.2rem;max-width:44ch;color:rgba(255,255,255,.94);margin-bottom:34px;}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap;}

/* ---------- Page hero (inner pages) ---------- */
.pagehero{position:relative;color:#fff;overflow:hidden;background:linear-gradient(150deg,var(--forest),var(--forest-dk));}
.pagehero.photo .ph{position:absolute;inset:0;z-index:1;}
.pagehero.photo:before{content:"";position:absolute;inset:0;z-index:2;background:linear-gradient(180deg,rgba(35,40,38,.42),rgba(35,40,38,.62));}
.pagehero-inner{position:relative;z-index:3;max-width:var(--maxw);margin:0 auto;padding:96px 28px;width:100%;}
.pagehero .eyebrow{color:#e7f3d4;}
.pagehero h1{font-weight:700;font-size:clamp(2.3rem,5vw,3.6rem);max-width:18ch;margin-bottom:18px;}
.pagehero p.lead{font-size:1.18rem;max-width:54ch;color:rgba(255,255,255,.92);}

/* ---------- Generic content sections ---------- */
.section{padding:88px 0;}
.section.cream{background:var(--cream);}
.section.forest{background:var(--forest);color:#fff;}
.section-head{text-align:center;max-width:680px;margin:0 auto 56px;}
.section-head h2{font-size:clamp(2.2rem,4.6vw,3.2rem);margin-bottom:16px;}
.section-head p{color:var(--muted);font-size:1.1rem;}
.section.forest .section-head p{color:rgba(255,255,255,.82);}

/* prose blocks */
.prose{max-width:760px;margin:0 auto;}
.prose h2{font-size:clamp(1.9rem,3.6vw,2.5rem);margin:0 0 18px;}
.prose h3{font-size:1.35rem;margin:36px 0 10px;color:var(--forest);}
.prose p{margin-bottom:18px;font-size:1.05rem;}
.prose p.lead{font-size:1.2rem;color:var(--forest);}
.prose ul{margin:0 0 18px 22px;}
.prose li{margin-bottom:8px;}
.prose a.inline{color:var(--lime-dk);font-weight:600;text-decoration:underline;}
.pastor{display:grid;grid-template-columns:0.85fr 1fr;gap:42px;align-items:center;max-width:1000px;margin:0 auto;}
.pastor-photo img{width:100%;height:auto;border-radius:10px;display:block;box-shadow:0 16px 44px rgba(47,79,66,.16);}
.pastor-bio h3{font-family:'Poppins',sans-serif;font-size:1.7rem;margin-bottom:14px;}
.pastor-bio p{color:var(--ink);font-size:1.02rem;line-height:1.65;margin-bottom:14px;}
@media(max-width:760px){.pastor{grid-template-columns:1fr;gap:24px;}}
.session-grid{display:flex;flex-wrap:wrap;justify-content:center;align-items:center;gap:56px;max-width:900px;margin:0 auto;}
.session-grid ul{list-style:none;margin:0;padding:0;}
.session-grid li{padding:7px 0;font-size:1.05rem;}
.session-logo{text-align:center;}
.session-logo img{width:100%;max-width:240px;height:auto;}
@media(max-width:760px){.session-grid{gap:30px;}}

/* two-column split (text + image / facts) */
.split{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center;}
.split .ph{height:420px;border-radius:8px;}
.split .steeple-box{background:var(--cream);border:1px solid var(--line);border-radius:8px;display:flex;align-items:center;justify-content:center;padding:40px;min-height:420px;}
.split .steeple-box img{max-height:340px;width:auto;mix-blend-mode:multiply;}

/* feature list (worship steps, beliefs, etc.) */
.featlist{max-width:820px;margin:0 auto;display:grid;gap:22px;}
.feat{display:grid;grid-template-columns:auto 1fr;gap:22px;align-items:start;background:#fff;border:1px solid var(--line);border-radius:8px;padding:26px 30px;}
.feat .num{font-family:'Poppins',sans-serif;font-weight:700;font-size:1.5rem;color:var(--lime-dk);line-height:1;background:var(--cream);border-radius:50%;width:54px;height:54px;display:flex;align-items:center;justify-content:center;}
.feat h3{font-size:1.3rem;margin-bottom:6px;}
.feat p{color:var(--muted);font-size:1rem;}

/* info / fact cards */
.infogrid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px;}
.infocard{background:#fff;border:1px solid var(--line);border-radius:8px;padding:32px 30px;}
.infocard h3{font-size:1.35rem;margin-bottom:10px;}
.infocard p{color:var(--muted);font-size:1rem;margin-bottom:8px;}

/* call-to-action band */
.ctaband{background:var(--forest);color:#fff;text-align:center;padding:84px 0;}
.ctaband h2{font-size:clamp(2rem,4vw,2.7rem);margin-bottom:14px;}
.ctaband p{color:rgba(255,255,255,.85);max-width:50ch;margin:0 auto 28px;}
.cta-row{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;}

/* ---------- Join Us (homepage) ---------- */
.joinus{padding:104px 0;background:var(--cream);}
.joinus .section-head{margin-bottom:56px;}
.joinus .section-head h2{font-size:clamp(2.4rem,5vw,3.5rem);}
.join-grid{display:grid;grid-template-columns:1fr 1fr;gap:32px;}
.join-col{background:#fff;border:1px solid var(--line);border-radius:8px;overflow:hidden;box-shadow:0 16px 44px rgba(47,79,66,.07);}
.join-col .ph{height:230px;}
.join-body{padding:34px 36px 38px;}
.join-body h3{font-size:2.1rem;margin-bottom:14px;}
.join-body .when{font-family:'Poppins',sans-serif;font-weight:600;font-size:1.2rem;margin-bottom:6px;}
.join-body .sub{color:var(--muted);margin-bottom:24px;font-size:.98rem;}

/* Online card cover — cropped logo emblem + SermonAudio line below */
.online-cover{background:#4f657a;display:flex;flex-direction:column;
  align-items:center;justify-content:center;gap:18px;padding:22px;text-align:center;}
.online-cover .sa-logo{width:80%;max-width:300px;height:auto;}
.online-cover .sa-live{font-family:'Poppins',sans-serif;font-weight:600;font-size:.72rem;letter-spacing:.1em;
  text-transform:uppercase;color:var(--muted);display:inline-flex;align-items:center;gap:8px;}
.online-cover .sa-live .dot{width:8px;height:8px;border-radius:50%;background:#e0392b;
  box-shadow:0 0 0 3px rgba(224,57,43,.16);}

/* ---------- Military / Fort Hood band ---------- */
.military{position:relative;color:#fff;overflow:hidden;padding:120px 0;text-align:center;}
.military .ph{position:absolute;inset:0;z-index:0;}
.military:before{content:"";position:absolute;inset:0;z-index:1;background:linear-gradient(rgba(15,32,25,.06),rgba(15,32,25,.30));}
.military .wrap{position:relative;z-index:2;max-width:760px;}
.military .eyebrow{color:#dff0c9;text-shadow:0 1px 10px rgba(0,0,0,.5);}
.military h2{font-size:clamp(2.1rem,4.6vw,3.1rem);margin-bottom:18px;text-shadow:0 2px 16px rgba(0,0,0,.5);}
.military p{font-size:1.14rem;color:rgba(255,255,255,.93);margin-bottom:30px;text-shadow:0 1px 12px rgba(0,0,0,.55);}

/* ---------- The Latest (homepage) ---------- */
.latest{padding:104px 0;background:var(--paper);}
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:28px;}
.card{border:1px solid var(--line);border-radius:8px;overflow:hidden;transition:transform .2s,box-shadow .2s;background:#fff;}
.card:hover{transform:translateY(-4px);box-shadow:0 18px 40px rgba(47,79,66,.1);}
.card .ph{height:190px;}
.card .steeple-ph{height:190px;background:#fff;display:flex;align-items:center;justify-content:center;}
.card .steeple-ph img{height:168px;width:auto;mix-blend-mode:multiply;}
.card-body{padding:26px 28px 30px;}
.card-body h3{font-size:1.5rem;margin-bottom:8px;}
.card-body p{color:var(--muted);font-size:.95rem;margin-bottom:16px;}
.card-body a.more{font-family:'Poppins',sans-serif;font-weight:600;font-size:.85rem;color:var(--sage-dk);}
.card-body a.more:after{content:" →";}

/* ---------- Newsletter ---------- */
.news{padding:96px 0;background:var(--forest);color:#fff;text-align:center;}
.news h2{font-size:clamp(2rem,4vw,2.7rem);margin-bottom:12px;}
.news p{color:rgba(255,255,255,.82);max-width:46ch;margin:0 auto 30px;}
.news form{display:flex;gap:12px;max-width:480px;margin:0 auto;flex-wrap:wrap;justify-content:center;}
.news input{flex:1;min-width:220px;padding:14px 18px;border-radius:3px;border:none;font-family:'Inter',sans-serif;font-size:.95rem;}
.news .fineprint{margin-top:16px;font-size:.82rem;color:rgba(255,255,255,.6);}

/* ---------- Footer ---------- */
footer{background:var(--forest-dk);color:rgba(255,255,255,.74);padding:72px 0 32px;font-size:.92rem;}
.foot-grid{display:grid;grid-template-columns:1.7fr 1.1fr 1fr 1.1fr;gap:40px;margin-bottom:46px;}
footer h4{text-transform:uppercase;letter-spacing:.16em;font-size:.72rem;color:var(--lime);margin-bottom:18px;font-weight:600;font-family:'Poppins',sans-serif;}
.foot-logo{font-family:'Poppins',sans-serif;font-weight:700;color:#fff;font-size:1.3rem;line-height:1.15;}
.foot-logo small{display:block;font-family:'Inter',sans-serif;font-weight:500;font-size:.68rem;letter-spacing:.18em;color:var(--sage);text-transform:uppercase;margin-top:6px;}
footer ul{list-style:none;}
footer li{margin-bottom:10px;}
footer a:hover{color:#fff;}
.foot-bottom{border-top:1px solid rgba(255,255,255,.12);padding-top:22px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:8px;font-size:.8rem;color:rgba(255,255,255,.5);}

/* ---------- Responsive ---------- */
@media(max-width:880px){
  .nav-links{position:fixed;inset:78px 0 auto 0;background:#fff;flex-direction:column;gap:0;padding:8px 0;border-bottom:1px solid var(--line);display:none;box-shadow:0 14px 30px rgba(0,0,0,.06);}
  .nav-links.open{display:flex;}
  .nav-links li{width:100%;text-align:center;}
  .nav-links li a{display:block;padding:14px;}
  .nav-links li .btn{display:inline-block;margin:8px 0;}
  .menu-btn{display:block;}
  .join-grid{grid-template-columns:1fr;}
  .cards{grid-template-columns:1fr;}
  .split{grid-template-columns:1fr;gap:32px;}
  .split .ph,.split .steeple-box{min-height:300px;height:300px;}
  .infogrid{grid-template-columns:1fr;}
  .foot-grid{grid-template-columns:1fr 1fr;gap:30px;}
}
@media(max-width:520px){.foot-grid{grid-template-columns:1fr;}.feat{grid-template-columns:1fr;gap:12px;}}

/* ============================================================
   PAGE-SPECIFIC COMPONENTS (added 2026-06-06)
   Welcome visit-hero · Connect find-us · About strategic map
   ============================================================ */

/* ---- Welcome: photo hero with right-side service info + jump buttons ---- */
.pagehero.photo.visithero:before{background:linear-gradient(rgba(18,31,24,.58),rgba(18,31,24,.66));}
.visithero-inner{display:grid;grid-template-columns:1.35fr .9fr;gap:48px;align-items:center;}
.visithero-text h1{margin-bottom:18px;}
.visithero-text p.lead{margin-bottom:0;}
.visithero-text .hero-cta{margin-top:30px;}
.visithero-info{text-align:right;color:#fff;}
.visithero-info .vhi-when{font-family:'Poppins',sans-serif;font-weight:600;font-size:clamp(1.3rem,2.2vw,1.7rem);line-height:1.22;text-shadow:0 2px 18px rgba(0,0,0,.45);}
.visithero-info .vhi-addr{margin-top:12px;font-size:1.02rem;line-height:1.5;color:rgba(255,255,255,.92);text-shadow:0 2px 16px rgba(0,0,0,.5);}
@media(max-width:820px){.visithero-inner{grid-template-columns:1fr;gap:24px;}.visithero-info{text-align:left;}}

/* ---- Connect: Find Us (icon contact rows + map) ---- */
.findus{display:grid;grid-template-columns:1fr 1.1fr;gap:52px;align-items:center;}
.findus-info .eyebrow{margin-bottom:12px;}
.findus-info h2{font-size:clamp(2rem,4vw,2.7rem);margin-bottom:26px;}
.contact-rows{list-style:none;margin:0 0 30px;padding:0;}
.contact-rows li{display:flex;gap:16px;align-items:flex-start;padding:15px 0;border-bottom:1px solid var(--line);}
.contact-rows li:last-child{border-bottom:none;}
.contact-rows .ci{flex:none;width:44px;height:44px;border-radius:50%;background:var(--cream);display:flex;align-items:center;justify-content:center;}
.contact-rows .ci svg{width:21px;height:21px;}
.contact-rows .ck{display:block;font-family:'Poppins',sans-serif;font-weight:600;font-size:.78rem;text-transform:uppercase;letter-spacing:.09em;color:var(--sage-dk);margin-bottom:3px;}
.contact-rows .cv{display:block;color:var(--ink);font-size:1.04rem;line-height:1.45;}
.contact-rows .cv a{color:var(--sage-dk);font-weight:600;}
.contact-rows .cv a:hover{text-decoration:underline;}
.findus-map iframe{width:100%;height:440px;border:0;border-radius:12px;box-shadow:0 16px 44px rgba(47,79,66,.14);display:block;}
@media(max-width:860px){.findus{grid-template-columns:1fr;gap:34px;}.findus-map iframe{height:330px;}}

/* ---- About: light divider between session list and pastor block ---- */
.team-divider{border:0;border-top:1px solid var(--line);max-width:1000px;margin:56px auto;}
</content>
