/* ===========================================================
   Land Heroes — shared styles (styles.css)
   Used by all landing pages: index, county pages, situation pages.
   =========================================================== */
:root{
  --bg:#f6f6f1; --card:#fff; --ink:#16203a; --soft:#5a6478;
  --navy:#002868; --navy-dk:#001b47; --red:#bf0a30; --red-dk:#9d0825;
  --line:#e6e7ec; --shadow:0 18px 50px -24px rgba(0,40,104,.4);
  --shadow-sm:0 8px 24px -16px rgba(0,40,104,.4); --r:16px; --maxw:1140px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Hanken Grotesk',system-ui,sans-serif;color:var(--ink);background:var(--bg);line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden}
h1,h2,h3{font-family:'Fraunces',Georgia,serif;line-height:1.1;font-weight:600;color:var(--navy);letter-spacing:-.01em}
a{color:inherit;text-decoration:none}
svg{display:block}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}
.eyebrow{font-size:.76rem;font-weight:800;letter-spacing:.2em;text-transform:uppercase;color:var(--red)}
.pad{padding:72px 0}

.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5em;cursor:pointer;border:0;font-family:inherit;font-weight:700;font-size:1rem;padding:.9em 1.7em;border-radius:999px;transition:transform .18s,background .18s,box-shadow .18s}
.btn-primary{background:var(--red);color:#fff;box-shadow:0 10px 22px -10px rgba(191,10,48,.6)}
.btn-primary:hover{background:var(--red-dk);transform:translateY(-2px)}
.btn-ghost{background:transparent;color:var(--navy);border:1.5px solid rgba(0,40,104,.25)}
.btn-ghost:hover{border-color:var(--navy);background:rgba(0,40,104,.05)}
.btn-block{width:100%}

/* header */
header{position:sticky;top:0;z-index:50}
.bar{display:flex;align-items:center;justify-content:space-between;gap:18px;background:rgba(246,246,241,.86);backdrop-filter:blur(12px);border-bottom:1px solid var(--line);padding:12px 0}
.brand{display:flex;align-items:center;gap:11px}
.brand .mark{width:42px;height:42px;flex:0 0 auto}
.brand .name{font-family:'Fraunces',serif;font-weight:600;font-size:1.4rem;color:var(--navy);line-height:1}
.brand .tag{display:block;font-size:.58rem;font-weight:800;letter-spacing:.2em;color:var(--red);margin-top:3px}
nav.main{display:flex;gap:26px}
nav.main a{font-weight:600;font-size:.95rem;color:var(--soft)}
nav.main a:hover{color:var(--navy)}
.hcta{display:flex;align-items:center;gap:16px}
.phone{display:inline-flex;align-items:center;gap:7px;font-weight:700;color:var(--navy)}

/* breadcrumb */
.crumb{background:#eef1f7;font-size:.84rem;color:var(--soft)}
.crumb .wrap{padding-top:10px;padding-bottom:10px}
.crumb a{color:var(--navy);font-weight:600}
.crumb span{margin:0 8px;opacity:.5}

/* hero (interior pages) */
.ihero{background:linear-gradient(180deg,#eef1f7 0%,var(--bg) 70%);padding:54px 0 64px}
.ihero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:46px;align-items:start}
.ihero h1{font-size:clamp(2.1rem,4.4vw,3.2rem)}
.ihero h1 em{font-style:normal;color:var(--red)}
.ihero .lede{font-size:1.12rem;color:var(--soft);margin:18px 0 24px;max-width:42ch}
.trust{display:flex;flex-direction:column;gap:9px;margin-top:22px}
.trust span{display:inline-flex;align-items:center;gap:9px;font-weight:600;font-size:.95rem;color:var(--navy)}
.ck{flex:0 0 auto;width:19px;height:19px;border-radius:50%;background:var(--navy);color:#fff;display:grid;place-items:center;font-size:.62rem}

/* form card */
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--shadow);padding:28px 26px}
.card h2{font-size:1.4rem;margin-bottom:3px}
.card .sub{font-size:.9rem;color:var(--soft);margin-bottom:16px}
.field{margin-bottom:11px}
.field label{display:block;font-size:.74rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--soft);margin-bottom:5px}
.field input{width:100%;font-family:inherit;font-size:1rem;color:var(--ink);padding:.7em .85em;border:1.4px solid var(--line);border-radius:10px;background:#fff;transition:.15s}
.field input:focus{outline:0;border-color:var(--navy);box-shadow:0 0 0 3px rgba(0,40,104,.12)}
.g2{display:grid;grid-template-columns:1fr 1fr;gap:11px}
.consent{display:flex;gap:9px;align-items:flex-start;margin:8px 0 14px;font-size:.72rem;color:var(--soft);line-height:1.45}
.consent input{margin-top:3px;flex:0 0 auto;width:16px;height:16px;accent-color:var(--red)}
.note{font-size:.72rem;color:var(--soft);text-align:center;margin-top:9px}
.success{display:none;text-align:center;padding:26px 8px}
.success .big{width:56px;height:56px;border-radius:50%;background:var(--navy);color:#fff;display:grid;place-items:center;font-size:1.5rem;margin:0 auto 14px}

/* prose body */
.prose{max-width:740px;margin:0 auto}
.prose h2{font-size:1.7rem;margin:34px 0 12px}
.prose h2:first-child{margin-top:0}
.prose p{margin-bottom:16px;color:#2c3548}
.prose ul{margin:0 0 18px 2px;list-style:none;display:grid;gap:10px}
.prose ul li{display:flex;gap:11px;align-items:flex-start}
.prose ul li .ck{margin-top:3px}
.bandcta{background:var(--navy);color:#fff;text-align:center;border-radius:var(--r);padding:34px 26px;margin:34px 0}
.bandcta h2{color:#fff;font-size:1.5rem;margin-bottom:8px}
.bandcta p{color:#b7c2da;margin-bottom:18px}

/* link grid (hubs / related) */
.head{max-width:640px;margin:0 auto 36px;text-align:center}
.head h2{font-size:clamp(1.7rem,3.4vw,2.3rem);margin-top:10px}
.head p{color:var(--soft);margin-top:12px}
.lgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.lgrid a{background:var(--card);border:1px solid var(--line);border-radius:12px;padding:16px 18px;box-shadow:var(--shadow-sm);font-weight:600;color:var(--navy);transition:transform .18s,border-color .18s;display:flex;justify-content:space-between;align-items:center;gap:10px}
.lgrid a:hover{transform:translateY(-3px);border-color:var(--navy)}
.lgrid a span{color:var(--red);font-weight:800}

/* faq */
.faqw{max-width:760px;margin:0 auto}
.faq{background:var(--card);border:1px solid var(--line);border-radius:12px;margin-bottom:11px;overflow:hidden}
.faq button{width:100%;text-align:left;background:none;border:0;cursor:pointer;font-family:'Fraunces',serif;font-size:1.06rem;font-weight:600;color:var(--navy);padding:18px 20px;display:flex;justify-content:space-between;align-items:center;gap:14px}
.faq .pm{flex:0 0 auto;width:25px;height:25px;border-radius:50%;border:1.5px solid var(--red);color:var(--red);display:grid;place-items:center;font-size:1.05rem;transition:.25s}
.faq.open .pm{background:var(--red);color:#fff;transform:rotate(45deg)}
.faq .ans{max-height:0;overflow:hidden;transition:max-height .3s ease}
.faq .ans p{padding:0 20px 18px;color:var(--soft)}

/* footer */
footer{background:var(--navy-dk);color:#9fb0cf;padding:40px 0 24px;margin-top:10px}
.frow{display:flex;justify-content:space-between;align-items:center;gap:20px;flex-wrap:wrap;margin-bottom:22px}
.fbrand{display:flex;align-items:center;gap:10px}
.fbrand .mark{width:38px;height:38px}
.fbrand .name{font-family:'Fraunces',serif;font-size:1.25rem;color:#fff}
.flinks{display:flex;gap:22px;flex-wrap:wrap}
.flinks a{font-size:.93rem;color:#9fb0cf}.flinks a:hover{color:#fff}
.fbot{border-top:1px solid rgba(255,255,255,.12);padding-top:18px;font-size:.8rem;color:#7587a8;display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap}
.fbot .disc{max-width:60ch}

@media(max-width:900px){
  .ihero-grid{grid-template-columns:1fr;gap:34px}
  .lgrid{grid-template-columns:1fr 1fr}
}
@media(max-width:560px){
  .g2{grid-template-columns:1fr}.pad{padding:54px 0}.brand .tag{display:none}
  .lgrid{grid-template-columns:1fr}.frow{flex-direction:column;align-items:flex-start}
}

/* state header logo (replaces old mascot/mark) */
.brand .hlogo{height:52px;width:auto;display:block}
@media(max-width:680px){.brand .hlogo{height:42px}}

/* ---- homepage hero: balanced desktop layout + mascot ---- */
.ihero-copy{display:flex;flex-direction:column;align-items:flex-start}
.ihero-copy .hero-mascot{height:130px;width:auto;margin-bottom:14px}
.ihero .hero-btn{margin-top:24px}
.lgrid.lgrid-2{grid-template-columns:repeat(2,1fr);max-width:760px;margin:0 auto}
@media(max-width:900px){
  .ihero-copy .hero-mascot{height:104px}
  .lgrid.lgrid-2{grid-template-columns:1fr 1fr}
}
@media(max-width:560px){
  .lgrid.lgrid-2{grid-template-columns:1fr}
  .ihero .hero-btn{width:100%}
}


/* =======================================================
   Mobile navigation (CSS-only hamburger) + responsive fixes
   ======================================================= */
.bar{position:relative;flex-wrap:nowrap}
.navtoggle{display:none}
.hamburger{display:none}
/* On desktop the wrapper is transparent so brand | nav | cta keep original layout */
.navwrap{display:contents}

.hamburger{flex-direction:column;justify-content:center;gap:5px;width:44px;height:44px;cursor:pointer;border-radius:10px;flex:0 0 auto}
.hamburger span{display:block;width:24px;height:2.5px;background:var(--navy);border-radius:2px;transition:transform .25s,opacity .2s;margin:0 auto}

@media(max-width:900px){
  .hamburger{display:flex}
  .navwrap{display:none;position:absolute;top:100%;left:0;right:0;flex-direction:column;align-items:stretch;gap:14px;
    background:rgba(246,246,241,.98);backdrop-filter:blur(12px);border-bottom:1px solid var(--line);
    box-shadow:var(--shadow-sm);padding:16px 24px 22px}
  .navtoggle:checked ~ .navwrap{display:flex}
  .navwrap nav.main{display:flex;flex-direction:column;gap:0}
  .navwrap nav.main a{padding:13px 2px;font-size:1.05rem;border-bottom:1px solid var(--line)}
  .navwrap .hcta{display:flex;flex-direction:column;align-items:stretch;gap:12px;margin-top:4px}
  .navwrap .hcta .phone{display:inline-flex;justify-content:center;font-size:1.08rem;padding:8px}
  .navwrap .hcta .btn{width:100%}
  /* hamburger -> X */
  .navtoggle:checked ~ .hamburger span:nth-child(1){transform:translateY(7.5px) rotate(45deg)}
  .navtoggle:checked ~ .hamburger span:nth-child(2){opacity:0}
  .navtoggle:checked ~ .hamburger span:nth-child(3){transform:translateY(-7.5px) rotate(-45deg)}
}

/* keep the brand logo readable but compact on phones */
@media(max-width:680px){.brand .hlogo{height:40px}}
@media(max-width:380px){.brand .hlogo{height:34px}}

/* tighter section padding + comfortable type on small screens */
@media(max-width:560px){
  .wrap{padding:0 18px}
  .card{padding:22px 18px}
  .ihero{padding:36px 0 44px}
  .bandcta{padding:26px 20px}
}


/* ---- sticky mobile call/offer bar ---- */
.mobcta{display:none}
@media(max-width:900px){
  .mobcta{display:flex;gap:10px;position:fixed;left:0;right:0;bottom:0;z-index:60;
    padding:10px 14px calc(10px + env(safe-area-inset-bottom,0px));
    background:rgba(255,255,255,.97);backdrop-filter:blur(10px);
    border-top:1px solid var(--line);box-shadow:0 -10px 26px -18px rgba(0,40,104,.55)}
  .mobcta a{display:inline-flex;align-items:center;justify-content:center;gap:7px;
    font-family:inherit;font-weight:700;font-size:1rem;padding:.85em 1em;border-radius:999px}
  .mobcta .call{flex:0 0 34%;background:#fff;color:var(--navy);border:1.6px solid rgba(0,40,104,.28)}
  .mobcta .offer{flex:1;background:var(--red);color:#fff;box-shadow:0 8px 18px -10px rgba(191,10,48,.6)}
  .mobcta .call svg{flex:0 0 auto}
  body{padding-bottom:72px}
}
