/* ============================================================
   Lapeer Property Services — shared stylesheet
   ============================================================ */
:root{
  --navy:#0C2B4F;
  --navy-800:#0A2444;
  --navy-700:#103a66;
  --blue:#1A5FB8;
  --red:#C8102E;
  --red-600:#A60D26;
  --ink:#15212E;
  --slate:#5A6B7B;
  --line:#E4E9EF;
  --bg:#FFFFFF;
  --bg-soft:#F4F6F9;
  --bg-softer:#EEF2F7;
  --maxw:1240px;
  --radius:14px;
  --shadow:0 14px 40px -18px rgba(12,43,79,.32);
  --shadow-sm:0 6px 18px -10px rgba(12,43,79,.30);
}
*{box-sizing:border-box;}
html{scroll-behavior:smooth;scroll-padding-top:120px;overflow-x:clip;}
body{
  margin:0;
  font-family:"Barlow",system-ui,sans-serif;
  color:var(--ink);
  background:var(--bg);
  -webkit-font-smoothing:antialiased;
  line-height:1.5;
  overflow-x:clip;
}
h1,h2,h3,h4{font-family:"Archivo",system-ui,sans-serif;margin:0;line-height:1.05;letter-spacing:-.01em;}
a{color:inherit;text-decoration:none;}
/* Prevent long unbreakable tokens (emails, URLs) from forcing horizontal overflow on mobile */
a[href^="mailto:"]{overflow-wrap:anywhere;word-break:break-word;}
img{display:block;max-width:100%;}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px;}
.eyebrow{
  font-family:"Archivo",sans-serif;font-weight:700;font-size:13px;letter-spacing:.18em;
  text-transform:uppercase;color:var(--red);
}
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:9px;
  font-family:"Archivo",sans-serif;font-weight:700;font-size:15px;letter-spacing:.01em;
  padding:14px 26px;border-radius:10px;cursor:pointer;border:2px solid transparent;
  transition:transform .15s ease, background .15s ease, color .15s ease, border-color .15s ease;
  white-space:nowrap;
}
.btn:hover{transform:translateY(-2px);}
.btn-red{background:var(--red);color:#fff;}
.btn-red:hover{background:var(--red-600);}
.btn-navy{background:var(--navy);color:#fff;}
.btn-navy:hover{background:var(--navy-700);}
.btn-ghost{background:transparent;color:#fff;border-color:rgba(255,255,255,.55);}
.btn-ghost:hover{background:rgba(255,255,255,.12);border-color:#fff;}
.btn-outline-navy{background:#fff;color:var(--navy);border-color:var(--line);}
.btn-outline-navy:hover{border-color:var(--navy);}

/* ---------- Top utility bar ---------- */
.topbar{background:var(--navy-800);color:rgba(255,255,255,.82);font-size:14px;}
.topbar .wrap{display:flex;align-items:center;justify-content:space-between;height:42px;gap:18px;}
.topbar a{display:inline-flex;align-items:center;gap:8px;transition:color .15s;white-space:nowrap;}
.topbar a:hover{color:#fff;}
.topbar .tb-left{display:flex;gap:24px;align-items:center;}
.topbar .tb-soc{display:flex;gap:14px;align-items:center;}
.topbar svg{width:15px;height:15px;flex:none;}
.tb-mail{color:rgba(255,255,255,.82);}
@media(max-width:820px){ .topbar .tb-mail{display:none;} }

/* ---------- Header / nav ---------- */
header.site{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.96);backdrop-filter:blur(8px);border-bottom:1px solid var(--line);}
header.site .wrap{display:flex;align-items:center;justify-content:space-between;height:78px;gap:24px;}
.brand{display:flex;align-items:center;gap:14px;}
.brand .mark{
  width:54px;height:54px;border-radius:11px;flex:none;position:relative;overflow:hidden;
  background:linear-gradient(135deg,var(--navy) 0 50%,var(--red) 50% 100%);
  display:flex;align-items:center;justify-content:center;
  font-family:"Archivo",sans-serif;font-weight:900;color:#fff;font-size:21px;letter-spacing:.02em;
  box-shadow:inset 0 0 0 2px rgba(255,255,255,.15);
}
.brand .mark span{position:relative;text-shadow:0 1px 2px rgba(0,0,0,.35);}
.brand .bt{display:flex;flex-direction:column;line-height:1.05;}
.brand .bt b{font-family:"Archivo",sans-serif;font-weight:800;font-size:17px;color:var(--navy);letter-spacing:-.01em;white-space:nowrap;}
.brand .bt small{font-size:11px;letter-spacing:.13em;text-transform:uppercase;color:var(--slate);font-weight:600;white-space:nowrap;}
@media(max-width:420px){ .brand .bt small{display:none;} .brand .bt b{font-size:15px;} }
nav.main{display:flex;align-items:center;gap:6px;}
nav.main a{
  font-family:"Archivo",sans-serif;font-weight:600;font-size:15px;color:var(--ink);
  padding:9px 13px;border-radius:8px;transition:background .15s,color .15s;
}
nav.main a:hover{background:var(--bg-soft);color:var(--navy);}
nav.main a.active{color:var(--navy);background:var(--bg-soft);}
.hdr-cta{display:flex;align-items:center;gap:14px;}
.navtoggle{display:none;background:none;border:0;cursor:pointer;padding:8px;}
.navtoggle span{display:block;width:24px;height:2px;background:var(--navy);margin:5px 0;border-radius:2px;}
@media(max-width:1080px){
  nav.main{display:none;}
  .hdr-cta .btn{display:none;}
  .navtoggle{display:block;}
}

/* ---------- Hero (home) ---------- */
.hero{background:var(--navy);color:#fff;position:relative;overflow:hidden;}
.hero::after{content:"";position:absolute;inset:0;background:
  radial-gradient(900px 500px at 12% -10%, rgba(26,95,184,.45), transparent 60%);pointer-events:none;}
.hero .wrap{position:relative;z-index:1;display:grid;grid-template-columns:1.05fr .95fr;gap:56px;align-items:center;padding-top:64px;padding-bottom:64px;}
.hero h1{font-size:clamp(40px,5vw,62px);font-weight:900;letter-spacing:-.02em;margin:18px 0 0;}
.hero h1 .accent{color:#fff;}
.hero .lead{margin:20px 0 0;font-size:18px;color:rgba(255,255,255,.78);max-width:46ch;}
.chips{display:flex;flex-wrap:wrap;gap:10px;margin:26px 0 0;}
.chip{
  display:inline-flex;align-items:center;gap:8px;font-family:"Archivo",sans-serif;font-weight:600;font-size:14px;
  padding:9px 14px;border-radius:999px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.16);
}
.chip .dot{width:7px;height:7px;border-radius:50%;background:var(--red);flex:none;}
.hero-cta{display:flex;flex-wrap:wrap;gap:14px;margin:34px 0 0;align-items:center;}
.hero-phone{display:inline-flex;align-items:center;gap:10px;font-family:"Archivo",sans-serif;font-weight:800;font-size:18px;color:#fff;}
.hero-phone svg{width:18px;height:18px;}
.hero-media{position:relative;}
.hero-media img{width:100%;height:430px;object-fit:cover;border-radius:14px;box-shadow:var(--shadow);}
@media(max-width:920px){
  .hero .wrap{grid-template-columns:1fr;gap:36px;}
  .hero-media img{height:320px;}
}

/* ---------- Page hero (subpages) ---------- */
.pagehero{background:var(--navy);color:#fff;position:relative;overflow:hidden;}
.pagehero::after{content:"";position:absolute;inset:0;background:
  radial-gradient(900px 500px at 85% -20%, rgba(26,95,184,.42), transparent 60%);pointer-events:none;}
.pagehero .wrap{position:relative;z-index:1;padding:58px 28px 56px;}
.crumb{display:flex;gap:9px;align-items:center;font-family:"Archivo",sans-serif;font-weight:600;font-size:12.5px;letter-spacing:.08em;color:rgba(255,255,255,.55);text-transform:uppercase;}
.crumb a:hover{color:#fff;}
.crumb svg{width:13px;height:13px;opacity:.6;}
.pagehero h1{font-size:clamp(34px,4.6vw,54px);font-weight:900;letter-spacing:-.02em;margin:16px 0 0;max-width:18ch;}
.pagehero p{margin:16px 0 0;font-size:18px;color:rgba(255,255,255,.78);max-width:62ch;}
.pagehero .hero-cta{margin-top:28px;}

/* ---------- Section frame ---------- */
section.block{padding:84px 0;}
section.block.tight{padding:64px 0;}
.block.soft{background:var(--bg-soft);}
.sec-head{display:flex;align-items:flex-end;justify-content:space-between;gap:24px;margin-bottom:40px;flex-wrap:wrap;}
.sec-head.center{justify-content:center;text-align:center;flex-direction:column;align-items:center;}
.sec-head h2{font-size:clamp(30px,3.6vw,42px);font-weight:800;color:var(--navy);}
.sec-head p{margin:10px 0 0;color:var(--slate);font-size:17px;max-width:54ch;}
.sec-head.center p{max-width:60ch;}

/* ---------- Feature cards (home/winter) ---------- */
.feat-grid{display:grid;grid-template-columns:1fr 1fr;gap:26px;}
.feat{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;
  box-shadow:var(--shadow-sm);display:flex;flex-direction:column;transition:transform .18s,box-shadow .18s;
}
.feat:hover{transform:translateY(-4px);box-shadow:var(--shadow);}
.feat .ph{width:100%;height:230px;}
.feat img{width:100%;height:230px;object-fit:cover;}
.feat .body{padding:28px 28px 30px;display:flex;flex-direction:column;flex:1;}
.feat .tag{font-family:"Archivo",sans-serif;font-weight:700;font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--red);}
.feat h3{font-size:25px;font-weight:800;color:var(--navy);margin:8px 0 0;}
.feat .sub{color:var(--slate);font-size:16px;margin:6px 0 0;}
.feat ul{list-style:none;margin:18px 0 0;padding:0;display:grid;gap:11px;}
.feat ul li{display:flex;gap:11px;align-items:flex-start;font-size:16px;color:var(--ink);font-weight:500;}
.feat ul li svg{width:18px;height:18px;flex:none;margin-top:2px;color:var(--blue);}
.feat .foot{margin-top:auto;padding-top:24px;}
@media(max-width:820px){ .feat-grid{grid-template-columns:1fr;} }

/* ---------- Three image cards (home landscape preview) ---------- */
.land{background:var(--navy);color:#fff;}
.land .sec-head h2{color:#fff;}
.land .sec-head p{color:rgba(255,255,255,.72);}
.land-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;}
.lcard{position:relative;border-radius:var(--radius);overflow:hidden;min-height:340px;display:flex;flex-direction:column;justify-content:flex-end;box-shadow:var(--shadow);}
.lcard img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;border-radius:0;}
.lcard .veil{position:absolute;inset:0;background:linear-gradient(to top, rgba(168,13,38,.92) 0%, rgba(168,13,38,.62) 40%, rgba(12,43,79,.18) 100%);z-index:1;}
.lcard .lc-body{position:relative;z-index:2;padding:26px;}
.lcard h3{font-size:23px;font-weight:800;text-transform:uppercase;letter-spacing:.01em;}
.lcard p{margin:8px 0 0;font-size:16px;color:rgba(255,255,255,.92);font-weight:500;}
.lcard .lc-link{display:inline-flex;align-items:center;gap:7px;margin-top:16px;font-family:"Archivo",sans-serif;font-weight:700;font-size:14px;letter-spacing:.04em;text-transform:uppercase;color:#fff;}
.lcard .lc-link svg{width:15px;height:15px;transition:transform .15s;}
.lcard:hover .lc-link svg{transform:translateX(4px);}
@media(max-width:820px){ .land-grid{grid-template-columns:1fr;} }

/* ---------- Split detail row (winter) ---------- */
.split{display:grid;grid-template-columns:1fr 1fr;gap:50px;align-items:center;}
.split + .split{margin-top:72px;}
.split .media{position:relative;}
.split .media img{width:100%;height:430px;object-fit:cover;border-radius:var(--radius);box-shadow:var(--shadow);display:block;}
.split.rev .media{order:2;}
.split .tag{font-family:"Archivo",sans-serif;font-weight:700;font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--red);}
.split h2{font-size:clamp(26px,3.2vw,38px);font-weight:800;color:var(--navy);margin:10px 0 0;}
.split .lead{color:var(--slate);font-size:17px;margin:12px 0 0;max-width:48ch;}
@media(max-width:900px){
  .split{grid-template-columns:1fr;gap:30px;}
  .split + .split{margin-top:48px;}
  .split.rev .media{order:0;}
  .split .media img{height:300px;}
}

/* ---------- Checklist ---------- */
.checklist{list-style:none;margin:22px 0 0;padding:0;display:grid;gap:13px;}
.checklist li{display:flex;gap:12px;align-items:flex-start;font-size:17px;font-weight:500;color:var(--ink);}
.checklist li svg{width:20px;height:20px;color:var(--blue);flex:none;margin-top:2px;}
.checklist.cols{grid-template-columns:1fr 1fr;gap:13px 26px;}
@media(max-width:560px){ .checklist.cols{grid-template-columns:1fr;} }

/* ---------- Category band (summer) ---------- */
.cat{padding:78px 0;border-bottom:1px solid var(--line);}
.cat.alt{background:var(--bg-soft);}
.cat .row{display:grid;grid-template-columns:.92fr 1.08fr;gap:54px;align-items:center;}
.cat.rev .catmedia{order:2;}
.catmedia{position:relative;}
.catmedia img{width:100%;height:390px;object-fit:cover;border-radius:var(--radius);box-shadow:var(--shadow);display:block;}
.cat .num{font-family:"Archivo",sans-serif;font-weight:800;font-size:14px;letter-spacing:.2em;color:var(--red);}
.cat h2{font-size:clamp(26px,3.2vw,38px);color:var(--navy);margin:8px 0 0;}
.cat .blurb{color:var(--slate);font-size:17px;margin:13px 0 0;max-width:52ch;}
.itemgrid{display:grid;grid-template-columns:1fr 1fr;gap:13px;margin-top:26px;}
.item{display:flex;gap:11px;align-items:center;background:#fff;border:1px solid var(--line);border-radius:11px;padding:15px 17px;font-family:"Archivo",sans-serif;font-weight:600;font-size:15.5px;color:var(--navy);box-shadow:var(--shadow-sm);}
.item svg{width:18px;height:18px;color:var(--blue);flex:none;}
@media(max-width:900px){
  .cat .row{grid-template-columns:1fr;gap:30px;}
  .cat .row .catcopy{order:0;}
  .cat .row .catmedia{order:1;}
  .cat.rev .catmedia{order:1;}
  .catmedia img{height:300px;}
}
@media(max-width:560px){ .itemgrid{grid-template-columns:1fr;} }

/* ---------- Branded tile (stands in for a missing photo) ---------- */
.brandtile{position:relative;overflow:hidden;width:100%;height:390px;border-radius:var(--radius);box-shadow:var(--shadow);background:linear-gradient(135deg,var(--navy) 0%,var(--navy-700) 100%);display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;color:#fff;padding:30px;}
.brandtile::before{content:"";position:absolute;inset:0;background:radial-gradient(620px 320px at 80% -10%, rgba(26,95,184,.5), transparent 60%);}
.brandtile::after{content:"";position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.05) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.05) 1px,transparent 1px);background-size:42px 42px;}
.brandtile > *{position:relative;z-index:1;}
.bt-badge{width:88px;height:88px;border-radius:50%;border:3px solid rgba(255,255,255,.25);display:flex;align-items:center;justify-content:center;margin-bottom:22px;background:rgba(255,255,255,.06);}
.bt-badge svg{width:42px;height:42px;color:#fff;}
.bt-label{font-family:"Archivo",sans-serif;font-weight:800;font-size:12px;letter-spacing:.2em;text-transform:uppercase;color:#fff;opacity:.65;}
.bt-title{font-family:"Archivo",sans-serif;font-weight:800;font-size:24px;margin-top:8px;}
.bt-items{font-size:15px;color:rgba(255,255,255,.7);margin-top:12px;letter-spacing:.01em;max-width:30ch;}
@media(max-width:900px){ .brandtile{height:300px;} }

/* ---------- Residential hub cards ---------- */
.hubgrid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px;}
.hub{--c:var(--navy);--ct:var(--bg-softer);background-color:#fff;background-image:radial-gradient(135% 115% at 100% 100%, color-mix(in srgb, var(--c) 13%, transparent), transparent 46%),radial-gradient(color-mix(in srgb, var(--c) 6%, transparent) 1px, transparent 1.5px);background-size:auto, 20px 20px;border:1px solid var(--line);border-top:4px solid var(--c);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;transition:transform .18s,box-shadow .18s;}
.hub:hover{transform:translateY(-4px);box-shadow:var(--shadow);}
.hub .hubtop{display:flex;align-items:center;gap:15px;padding:24px 28px 22px;background:linear-gradient(180deg, color-mix(in srgb, var(--c) 16%, #fff), var(--ct));border-bottom:1px solid color-mix(in srgb, var(--c) 16%, var(--line));}
.hub .ic{width:50px;height:50px;border-radius:13px;background:var(--c);display:flex;align-items:center;justify-content:center;color:#fff;flex:none;box-shadow:0 8px 18px -8px var(--c);}
.hub .ic svg{width:25px;height:25px;}
.hub h3{font-size:21px;color:var(--navy);}
.hub .tag{font-family:"Archivo",sans-serif;font-weight:700;font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--c);margin-bottom:3px;}
.hub .body{padding:20px 28px 28px;display:flex;flex-direction:column;flex:1;}
.hub ul{list-style:none;margin:0;padding:0;display:grid;gap:10px;}
.hub ul li{display:flex;gap:10px;align-items:flex-start;font-size:15.5px;font-weight:500;}
.hub ul li svg{width:17px;height:17px;color:var(--c);flex:none;margin-top:3px;}
.hub .foot{margin-top:auto;padding-top:20px;}
.hub .foot .btn{transition:transform .15s ease,background .15s ease,color .15s ease,border-color .15s ease;}
.hub:hover .foot .btn{background:var(--c);color:#fff;border-color:var(--c);}
/* per-category color identity */
.hub--winter{--c:#1A5FB8;--ct:#EAF1FB;}
.hub--lawn{--c:#1F8A5B;--ct:#E7F4EC;}
.hub--hard{--c:#C26B36;--ct:#FAEEE5;}
.hub--build{--c:#B0852A;--ct:#F7F0DC;}
.hub--earth{--c:#5C6B74;--ct:#EBEFF1;}
.hub--home{--c:#C8102E;--ct:#FCEAEE;}
@media(max-width:820px){ .hubgrid{grid-template-columns:1fr;} }
/* Home "Everything We Handle" — 6 cards: 3-up desktop, 2-up tablet, 1-up phone */
.hubgrid--3{grid-template-columns:repeat(3,1fr);}
@media(max-width:980px){ .hubgrid--3{grid-template-columns:repeat(2,1fr);} }
@media(max-width:640px){ .hubgrid--3{grid-template-columns:1fr;} }

/* ---------- Stat / trust strip ---------- */
.trust{display:grid;grid-template-columns:repeat(4,1fr);gap:22px;}
.trust .t{padding:6px 0;}
.trust .t b{font-family:"Archivo",sans-serif;font-weight:900;font-size:clamp(30px,3.4vw,42px);color:var(--navy);display:block;letter-spacing:-.02em;}
.trust .t span{font-size:15px;color:var(--slate);font-weight:500;}
@media(max-width:720px){ .trust{grid-template-columns:1fr 1fr;gap:28px;} }

/* ---------- CTA band ---------- */
.cta{position:relative;overflow:hidden;color:#fff;text-align:center;}
.cta img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;border-radius:0;z-index:0;}
.cta .veil{position:absolute;inset:0;background:linear-gradient(rgba(10,36,68,.86),rgba(10,36,68,.9));z-index:1;}
.cta .inner{position:relative;z-index:2;padding:78px 28px;max-width:760px;margin:0 auto;}
.cta h2{font-size:clamp(28px,3.4vw,40px);font-weight:800;}
.cta p{margin:14px auto 0;color:rgba(255,255,255,.82);font-size:18px;max-width:48ch;}
.cta .phone{display:inline-flex;align-items:center;gap:12px;margin:26px 0 0;font-family:"Archivo",sans-serif;font-weight:900;font-size:clamp(34px,5vw,52px);letter-spacing:-.01em;}
.cta .phone svg{width:34px;height:34px;}
.cta .cta-btns{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;margin-top:28px;}

/* ---------- Contact ---------- */
.contact-grid{display:grid;grid-template-columns:1.3fr .82fr;gap:48px;align-items:start;}
.form{display:grid;gap:18px;}
.field{display:flex;flex-direction:column;gap:7px;}
.field label{font-family:"Archivo",sans-serif;font-weight:700;font-size:13px;letter-spacing:.04em;text-transform:uppercase;color:var(--navy);}
.field input,.field select,.field textarea{font-family:"Barlow",sans-serif;font-size:16px;padding:13px 15px;border:1.5px solid var(--line);border-radius:10px;background:#fff;color:var(--ink);transition:border-color .15s,box-shadow .15s;width:100%;}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 3px rgba(26,95,184,.12);}
.field textarea{resize:vertical;min-height:140px;}
.form .row2{display:grid;grid-template-columns:1fr 1fr;gap:18px;}
.form .submitrow{display:flex;align-items:center;gap:16px;flex-wrap:wrap;margin-top:4px;}
.form .note{font-size:13.5px;color:var(--slate);}
.info{background:var(--navy);color:#fff;border-radius:var(--radius);padding:36px 32px;box-shadow:var(--shadow);position:relative;overflow:hidden;}
.info::after{content:"";position:absolute;inset:0;background:radial-gradient(500px 300px at 110% -10%, rgba(26,95,184,.5), transparent 60%);pointer-events:none;}
.info > *{position:relative;z-index:1;}
.info h3{font-size:23px;}
.info .isub{color:rgba(255,255,255,.72);font-size:15.5px;margin:10px 0 4px;}
.info .line{display:flex;gap:14px;align-items:flex-start;margin-top:22px;}
.info .line svg{width:20px;height:20px;color:#fff;flex:none;margin-top:2px;opacity:.85;}
.info .line b{display:block;font-family:"Archivo",sans-serif;font-size:12px;letter-spacing:.08em;text-transform:uppercase;color:rgba(255,255,255,.55);font-weight:700;margin-bottom:3px;}
.info .line a,.info .line span{font-size:17px;color:#fff;}
.info .line a:hover{color:rgba(255,255,255,.8);}
@media(max-width:820px){ .contact-grid{grid-template-columns:1fr;gap:32px;} .form .row2{grid-template-columns:1fr;} }

/* ---------- Footer ---------- */
footer.site{background:var(--navy-800);color:rgba(255,255,255,.7);}
footer.site .wrap{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:40px;padding:62px 28px 40px;}
footer .fbrand b{font-family:"Archivo",sans-serif;font-weight:800;color:#fff;font-size:20px;display:block;}
footer .fbrand p{margin:12px 0 0;font-size:15px;max-width:38ch;}
footer h4{font-family:"Archivo",sans-serif;font-size:13px;letter-spacing:.16em;text-transform:uppercase;color:rgba(255,255,255,.55);margin-bottom:16px;}
footer ul{list-style:none;margin:0;padding:0;display:grid;gap:11px;}
footer ul a{font-size:15px;transition:color .15s;}
footer ul a:hover{color:#fff;}
footer .fsoc{display:flex;gap:12px;margin-top:18px;}
footer .fsoc a{width:38px;height:38px;border-radius:9px;background:rgba(255,255,255,.08);display:flex;align-items:center;justify-content:center;transition:background .15s;}
footer .fsoc a:hover{background:var(--red);}
footer .fsoc svg{width:17px;height:17px;}
.copyright{border-top:1px solid rgba(255,255,255,.1);}
.copyright .wrap{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:20px 28px;font-size:14px;flex-wrap:wrap;}
@media(max-width:820px){ footer.site .wrap{grid-template-columns:1fr 1fr;} }
@media(max-width:520px){ footer.site .wrap{grid-template-columns:1fr;} }

/* ---------- Floating widgets ---------- */
.reviews{
  position:fixed;left:18px;bottom:18px;z-index:60;background:#fff;border:1px solid var(--line);
  border-radius:12px;box-shadow:var(--shadow);display:flex;align-items:center;gap:12px;padding:12px 16px;
}
.reviews .g{width:30px;height:30px;flex:none;}
.reviews .rv-num{font-family:"Archivo",sans-serif;font-weight:800;font-size:17px;color:var(--ink);display:flex;align-items:center;gap:7px;}
.reviews .stars{color:#F4A100;font-size:14px;letter-spacing:1px;}
.reviews small{display:block;font-size:12px;color:var(--slate);letter-spacing:.04em;text-transform:uppercase;font-weight:600;margin-top:2px;}
.chatbtn{
  position:fixed;right:18px;bottom:18px;z-index:60;background:var(--red);color:#fff;border:0;cursor:pointer;
  font-family:"Archivo",sans-serif;font-weight:700;font-size:15px;border-radius:12px;padding:14px 20px;
  display:inline-flex;align-items:center;gap:10px;box-shadow:var(--shadow);transition:background .15s,transform .15s;
}
.chatbtn:hover{background:var(--red-600);transform:translateY(-2px);}
.chatbtn svg{width:18px;height:18px;}
@media(max-width:560px){ .reviews{left:12px;bottom:12px;padding:9px 12px;} .reviews small{display:none;} .chatbtn{right:12px;bottom:12px;} .chatbtn .lbl{display:none;} }

/* ---------- Mobile drawer ---------- */
.drawer{position:fixed;inset:0;z-index:80;background:rgba(10,36,68,.5);opacity:0;pointer-events:none;transition:opacity .2s;overflow:hidden;}
.drawer.open{opacity:1;pointer-events:auto;}
.drawer .panel{position:absolute;top:0;right:0;height:100%;width:min(82vw,340px);background:#fff;box-shadow:var(--shadow);transform:translateX(100%);transition:transform .25s;padding:26px 24px;display:flex;flex-direction:column;gap:6px;overflow-y:auto;}
.drawer.open .panel{transform:none;}
.drawer .panel a{font-family:"Archivo",sans-serif;font-weight:600;font-size:18px;padding:14px 8px;border-bottom:1px solid var(--line);color:var(--navy);}
.drawer .panel .btn{margin-top:18px;}
.drawer .close{align-self:flex-end;background:none;border:0;font-size:26px;cursor:pointer;color:var(--slate);line-height:1;margin-bottom:6px;}

/* ============================================================
   Mobile refinements & overflow safety
   ============================================================ */
/* Allow grid/flex children to shrink below their content width so long
   words/emails wrap instead of forcing the whole page wider than the screen */
footer.site .wrap > *{min-width:0;}
footer ul a{overflow-wrap:anywhere;word-break:break-word;}
.contact-grid > *{min-width:0;}
.info .line{min-width:0;}
.info .line > div{min-width:0;}
.info .line a,.info .line span{overflow-wrap:anywhere;word-break:break-word;}
.feat .foot .btn,.hub .foot .btn{max-width:100%;}

@media(max-width:600px){
  /* tighter gutters reclaim horizontal space on phones */
  .wrap{padding:0 18px;}
  .pagehero .wrap{padding:46px 18px 44px;}
  footer.site .wrap{padding:48px 18px 32px;}
  .copyright .wrap{padding:18px 18px;}
  section.block{padding:58px 0;}
  section.block.tight{padding:46px 0;}
  .cta .inner{padding:58px 20px;}
  .pagehero p,.hero .lead{font-size:16.5px;}
  /* phone number in CTA bands can be wide — scale it down so it never clips */
  .cta .phone{font-size:30px;gap:10px;}
  .cta .phone svg{width:26px;height:26px;}
  /* full-width tap targets on card footers and hero buttons */
  .feat .foot .btn,.hub .foot .btn{width:100%;}
  .hero-cta .btn,.cta-btns .btn{width:100%;}
  .hero-cta,.cta-btns{width:100%;}
  .hero-phone{justify-content:center;width:100%;}
}
@media(max-width:380px){
  .cta .phone{font-size:26px;}
}
