/* ============================================================
   RHODES SEAMLESS GUTTERS — Southern Maryland
   Trusted / local / conversion · Sora + Mulish
   White + soft sky · brand blue · warm-red CTA
   ============================================================ */

:root{
  --bg:#FFFFFF;
  --sky:#F1F7FC;        /* soft sky-tint panel */
  --sky-2:#E3EEF8;
  --blue:#1B4E8E;       /* brand */
  --blue-2:#15406F;
  --blue-deep:#0E2C4F;
  --navy:#12233A;       /* darkest band */
  --red:#CB1A1A;        /* accent / primary CTA — matches his brand red */
  --red-2:#A51414;
  --gold:#F4A833;       /* review stars */
  --ink:#16273B;        /* headings */
  --text:#48586A;       /* body */
  --muted:#73828F;
  --line:rgba(16,40,70,.13);
  --line-2:rgba(16,40,70,.07);
  --on-blue:#DCEAF7;

  --display:"Sora", system-ui, sans-serif;
  --body:"Mulish", system-ui, sans-serif;

  --wrap:1200px;
  --gutter:clamp(20px,5vw,56px);
  --radius:10px;
  --radius-lg:20px;
  --ease:cubic-bezier(.2,.7,.2,1);
  --shadow:0 22px 56px -26px rgba(16,40,70,.32);
  --shadow-sm:0 2px 5px rgba(16,40,70,.05), 0 16px 34px -24px rgba(16,40,70,.24);
}

*,*::before,*::after{ box-sizing:border-box; }
*{ margin:0; }
html{ -webkit-text-size-adjust:100%; scroll-behavior:smooth; }
@media (prefers-reduced-motion:reduce){ html{ scroll-behavior:auto; } }
body{
  font-family:var(--body); background:var(--bg); color:var(--text);
  line-height:1.65; font-size:17px; font-weight:400;
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility; overflow-x:clip;
}
img,svg{ display:block; max-width:100%; }
a{ color:inherit; text-decoration:none; }
button{ font:inherit; color:inherit; cursor:pointer; background:none; border:0; }
ul{ list-style:none; padding:0; }
[hidden]{ display:none !important; }

/* ---------------- type ---------------- */
h1,h2,h3,h4{ font-family:var(--display); color:var(--ink); font-weight:700; line-height:1.08; letter-spacing:-.02em; }
h1{ font-size:clamp(2.5rem,5.4vw,4.2rem); letter-spacing:-.03em; }
h2{ font-size:clamp(2rem,3.6vw,3rem); }
h3{ font-size:clamp(1.2rem,1.7vw,1.45rem); font-weight:650; letter-spacing:-.01em; }
h4{ font-size:1.05rem; font-weight:700; }
p{ max-width:62ch; }
strong{ color:var(--ink); font-weight:700; }
.lead{ font-size:clamp(1.08rem,1.5vw,1.28rem); color:var(--text); line-height:1.6; max-width:56ch; }
.eyebrow{ font-family:var(--display); font-size:.8rem; font-weight:700; letter-spacing:.14em; text-transform:uppercase; color:var(--blue); display:inline-flex; align-items:center; gap:.7em; }
.eyebrow.red{ color:var(--red); }
.eyebrow.center{ justify-content:center; }
.muted{ color:var(--muted); }

/* ---------------- layout ---------------- */
.wrap{ width:100%; max-width:var(--wrap); margin-inline:auto; padding-inline:var(--gutter); }
.section{ padding:clamp(60px,8vw,118px) 0; position:relative; }
.section--tight{ padding:clamp(46px,6vw,80px) 0; }
.section.sky{ background:var(--sky); }
.head{ max-width:60ch; }
.head.center{ margin-inline:auto; text-align:center; }
.head.center .eyebrow{ justify-content:center; }
.head h2{ margin:.5rem 0 .8rem; }

/* ---------------- buttons ---------------- */
.btn{
  display:inline-flex; align-items:center; gap:.55em; line-height:1;
  font-family:var(--display); font-weight:650; font-size:1rem; letter-spacing:-.01em;
  padding:1.02em 1.7em; border-radius:999px; white-space:nowrap;
  background:var(--red); color:#fff; border:2px solid var(--red);
  transition:transform .2s var(--ease), box-shadow .25s var(--ease), background .2s, border-color .2s, color .2s;
  box-shadow:0 12px 26px -12px rgba(224,73,47,.5);
}
.btn svg{ width:1.1em; height:1.1em; transition:transform .25s var(--ease); }
.btn:hover{ background:var(--red-2); border-color:var(--red-2); transform:translateY(-2px); box-shadow:0 16px 32px -12px rgba(224,73,47,.6); }
.btn:hover svg{ transform:translateX(3px); }
.btn--blue{ background:var(--blue); border-color:var(--blue); box-shadow:0 12px 26px -14px rgba(27,78,142,.55); }
.btn--blue:hover{ background:var(--blue-2); border-color:var(--blue-2); box-shadow:0 16px 32px -14px rgba(27,78,142,.6); }
.btn--ghost{ background:transparent; color:var(--blue); border-color:var(--line); box-shadow:none; }
.btn--ghost:hover{ background:var(--sky); color:var(--blue-2); border-color:var(--blue); box-shadow:none; }
.btn--white{ background:#fff; color:var(--blue); border-color:#fff; box-shadow:0 12px 30px -14px rgba(0,0,0,.3); }
.btn--white:hover{ background:#fff; color:var(--red); border-color:#fff; }
.btn--ghost-light{ background:transparent; color:#fff; border-color:rgba(255,255,255,.4); box-shadow:none; }
.btn--ghost-light:hover{ background:rgba(255,255,255,.1); border-color:#fff; box-shadow:none; }
.btn--lg{ font-size:1.08rem; padding:1.14em 2em; }
.btn-row{ display:flex; flex-wrap:wrap; gap:14px; align-items:center; }

.stars{ display:inline-flex; gap:2px; color:var(--gold); }
.stars svg{ width:18px; height:18px; }

/* ---------------- top bar ---------------- */
.topbar{ background:var(--blue-deep); color:var(--on-blue); font-size:.84rem; }
.topbar .wrap{ display:flex; align-items:center; justify-content:space-between; gap:14px; min-height:42px; padding-block:7px; }
.topbar .l{ display:inline-flex; align-items:center; gap:8px; font-weight:600; }
.topbar .l svg{ width:15px; color:#fff; }
.topbar .r{ display:flex; align-items:center; gap:22px; }
.topbar a{ font-weight:700; color:#fff; display:inline-flex; align-items:center; gap:.4em; }
.tb-short{ display:none; }  /* shown only on phones (max-width:560px) */
.topbar a svg{ width:14px; }

/* ---------------- header ---------------- */
.site-header{ position:sticky; top:0; z-index:100; background:rgba(255,255,255,.9); backdrop-filter:saturate(1.3) blur(10px); border-bottom:1px solid transparent; transition:border-color .3s, box-shadow .3s; }
.site-header.scrolled{ border-bottom-color:var(--line); box-shadow:0 10px 30px -24px rgba(16,40,70,.4); }
.nav{ display:flex; align-items:center; gap:30px; min-height:80px; }
.brand{ display:flex; align-items:center; gap:12px; margin-right:auto; }
.brand .mk{ width:46px; height:46px; flex:none; }
.brand .wm{ font-family:var(--display); font-weight:800; line-height:1; letter-spacing:-.02em; color:var(--blue); font-size:1.18rem; display:flex; flex-direction:column; }
.brand .wm span{ color:var(--ink); font-weight:700; font-size:.66rem; letter-spacing:.18em; text-transform:uppercase; margin-top:5px; }
.brand-logo{ height:48px; width:auto; display:block; }
.foot-brand .brand-logo{ height:54px; }
@media (max-width:560px){ .brand-logo{ height:40px; } }
.nav-links{ display:flex; align-items:center; gap:28px; }
.nav-links > li > a{ font-family:var(--display); font-size:.95rem; font-weight:600; color:var(--ink); padding:8px 0; position:relative; display:inline-flex; align-items:center; gap:5px; transition:color .2s; }
.nav-links > li > a:hover{ color:var(--blue); }
.nav-links .caret{ width:14px; opacity:.6; }
/* dropdown */
.has-sub{ position:relative; }
.submenu{ position:absolute; top:calc(100% + 10px); left:50%; transform:translateX(-50%) translateY(8px); min-width:248px; background:#fff; border:1px solid var(--line); border-radius:var(--radius-lg); box-shadow:var(--shadow); padding:10px; opacity:0; visibility:hidden; transition:.24s var(--ease); z-index:50; }
.has-sub:hover .submenu, .has-sub:focus-within .submenu{ opacity:1; visibility:visible; transform:translateX(-50%) translateY(0); }
.submenu a{ display:block; padding:11px 14px; border-radius:var(--radius); font-size:.92rem; font-weight:600; color:var(--ink); transition:background .15s, color .15s; }
.submenu a:hover{ background:var(--sky); color:var(--blue); }
.submenu .grp{ font-family:var(--display); font-size:.68rem; font-weight:700; letter-spacing:.14em; text-transform:uppercase; color:var(--muted); padding:12px 14px 6px; }
.nav-cta{ display:flex; align-items:center; gap:18px; }
.drawer-cta{ display:none; }  /* mobile drawer only — shown in the max-width:860px block */
.nav-phone{ font-family:var(--display); font-weight:700; font-size:1rem; color:var(--blue); display:inline-flex; align-items:center; gap:.5em; white-space:nowrap; }
.nav-phone svg{ width:17px; color:var(--red); }
.nav-toggle{ display:none; width:48px; height:44px; border:1px solid var(--line); border-radius:var(--radius); position:relative; }
.nav-toggle span,.nav-toggle span::before,.nav-toggle span::after{ content:""; position:absolute; width:22px; height:2px; background:var(--ink); border-radius:2px; transition:.25s var(--ease); }
.nav-toggle span{ left:12px; top:21px; } .nav-toggle span::before,.nav-toggle span::after{ left:0; }
.nav-toggle span::before{ top:-7px; } .nav-toggle span::after{ top:7px; }
body.nav-open .nav-toggle span{ background:transparent; }
body.nav-open .nav-toggle span::before{ top:0; transform:rotate(45deg); }
body.nav-open .nav-toggle span::after{ top:0; transform:rotate(-45deg); }
.nav-backdrop,.nav-close{ display:none; }

/* ---------------- hero ---------------- */
.hero{ background:linear-gradient(180deg, var(--sky), #fff); position:relative; overflow:hidden; padding:clamp(40px,5vw,74px) 0 clamp(56px,7vw,96px); }
.hero::before{ content:""; position:absolute; inset:0; background:radial-gradient(120% 95% at 90% -12%, rgba(27,78,142,.13), transparent 55%); pointer-events:none; }
.hero::after{ content:""; position:absolute; right:-60px; top:-60px; width:340px; height:340px; border-radius:50%; border:1.5px solid rgba(27,78,142,.08); pointer-events:none; }
.hero .wrap{ position:relative; z-index:1; }
.hero-grid{ display:grid; grid-template-columns:1.06fr .94fr; gap:clamp(34px,5vw,64px); align-items:center; }
.hero h1{ font-size:clamp(2.35rem,4.7vw,3.7rem); line-height:1.04; letter-spacing:-.022em; margin:1.15rem 0 0; }
.hero h1 .accent{ display:block; color:var(--blue); font-size:.54em; font-weight:700; margin-top:.34em; letter-spacing:-.006em; }
.hero h1 .accent::before{ content:""; display:inline-block; width:34px; height:3px; border-radius:2px; background:var(--red); vertical-align:middle; margin:-.18em .55em 0 0; }
.hero .lead{ margin-top:1.3rem; max-width:52ch; }
.hero .btn-row{ margin-top:2rem; }
.hero-trust{ margin-top:2.2rem; display:flex; flex-wrap:wrap; align-items:center; gap:10px 22px; }
.hero-trust .rev{ display:flex; flex-direction:column; gap:3px; }
.hero-trust .rev small{ font-size:.82rem; color:var(--muted); font-weight:600; }
.hero-trust .sep{ width:1px; height:34px; background:var(--line); }
.hero-trust .tb{ display:inline-flex; align-items:center; gap:8px; font-size:.9rem; font-weight:700; color:var(--ink); }
.hero-trust .tb svg{ width:20px; color:var(--blue); flex:none; }
.hero-media{ position:relative; }
.hero-frame{ position:relative; border-radius:var(--radius-lg); overflow:hidden; aspect-ratio:5/4; box-shadow:var(--shadow); }
.hero-frame img{ width:100%; height:100%; object-fit:cover; }
.hero-badge{ position:absolute; left:-16px; bottom:26px; background:#fff; border-radius:16px; box-shadow:var(--shadow); padding:16px 20px; display:flex; align-items:center; gap:13px; }
.hero-badge .yrs{ font-family:var(--display); font-weight:800; font-size:2rem; color:var(--red); line-height:1; }
.hero-badge .lbl{ font-size:.78rem; color:var(--muted); font-weight:600; line-height:1.25; }
.hero-badge .lbl b{ color:var(--ink); display:block; font-size:.9rem; }

/* ---------------- trust strip ---------------- */
.strip{ background:var(--blue-deep); color:#fff; }
.strip .wrap{ display:grid; grid-template-columns:repeat(4,1fr); gap:24px; padding-block:30px; }
.strip .item{ display:flex; align-items:center; gap:13px; }
.strip .item svg{ width:30px; color:#7FB2E4; flex:none; }
.strip .item b{ font-family:var(--display); font-weight:700; display:block; font-size:1rem; }
.strip .item span{ font-size:.84rem; color:var(--on-blue); }

/* ---------------- services (icon cards) ---------------- */
.svc-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:22px; }
.svc{ background:#fff; border:1px solid var(--line); border-radius:var(--radius-lg); padding:32px 28px; transition:transform .3s var(--ease), box-shadow .3s var(--ease), border-color .3s; display:flex; flex-direction:column; }
.svc:hover{ transform:translateY(-6px); box-shadow:var(--shadow); border-color:transparent; }
.svc .ic{ width:60px; height:60px; border-radius:16px; background:var(--sky); display:grid; place-items:center; margin-bottom:20px; transition:background .3s; }
.svc:hover .ic{ background:var(--blue); }
.svc .ic svg{ width:30px; color:var(--blue); transition:color .3s; }
.svc:hover .ic svg{ color:#fff; }
.svc h3{ margin-bottom:.5rem; }
.svc p{ font-size:.95rem; color:var(--text); }
.svc .more{ margin-top:18px; display:inline-flex; align-items:center; gap:.45em; font-family:var(--display); font-size:.85rem; font-weight:700; color:var(--blue); }
.svc .more svg{ width:1em; transition:transform .25s var(--ease); }
.svc:hover .more svg{ transform:translateX(4px); }

/* ---------------- split (about / feature) ---------------- */
.split{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(34px,5vw,72px); align-items:center; }
.split.rev .media{ order:2; }
.media{ position:relative; }
.media .frame{ border-radius:var(--radius-lg); overflow:hidden; box-shadow:var(--shadow); aspect-ratio:4/3; }
.media .frame img{ width:100%; height:100%; object-fit:cover; }
.checks{ display:flex; flex-direction:column; gap:14px; margin-top:24px; }
.checks li{ display:flex; gap:13px; align-items:flex-start; }
.checks .ic{ width:26px; height:26px; flex:none; border-radius:50%; background:rgba(27,78,142,.1); display:grid; place-items:center; margin-top:1px; }
.checks .ic svg{ width:14px; color:var(--blue); }
.checks b{ color:var(--ink); }

/* ---------------- service areas ---------------- */
.areas{ display:grid; grid-template-columns:repeat(4,1fr); gap:18px; }
.area{ background:#fff; border:1px solid var(--line); border-radius:var(--radius-lg); padding:26px 24px; transition:transform .3s var(--ease), border-color .3s, box-shadow .3s; }
.area:hover{ transform:translateY(-4px); border-color:var(--blue); box-shadow:var(--shadow-sm); }
.area svg{ width:26px; color:var(--red); margin-bottom:14px; }
.area h3{ font-size:1.12rem; margin-bottom:.3rem; }
.area p{ font-size:.88rem; color:var(--muted); }

/* ---------------- reviews ---------------- */
.reviews{ display:grid; grid-template-columns:repeat(3,1fr); gap:22px; }
.review{ background:#fff; border:1px solid var(--line); border-radius:var(--radius-lg); padding:28px; box-shadow:var(--shadow-sm); }
.review .stars{ margin-bottom:14px; }
.review p{ font-size:1rem; color:var(--ink); line-height:1.6; }
.review .by{ margin-top:18px; font-size:.88rem; font-weight:700; color:var(--blue); }
.review .by span{ color:var(--muted); font-weight:500; }

/* ---------------- CTA band ---------------- */
.cta{ background:var(--blue); color:#fff; position:relative; overflow:hidden; }
.cta::before{ content:""; position:absolute; right:-80px; top:-80px; width:380px; height:380px; border-radius:50%; background:rgba(255,255,255,.06); }
.cta::after{ content:""; position:absolute; left:-60px; bottom:-120px; width:300px; height:300px; border-radius:50%; background:rgba(224,73,47,.18); }
.cta .wrap{ position:relative; text-align:center; }
.cta h2{ color:#fff; max-width:20ch; margin:.6rem auto 1rem; }
.cta p{ color:var(--on-blue); margin:0 auto; }
.cta .btn-row{ justify-content:center; margin-top:2rem; }

/* ---------------- footer ---------------- */
.site-footer{ background:var(--navy); color:#9DB0C2; }
.foot-top{ display:grid; grid-template-columns:1.7fr 1fr 1fr 1.1fr; gap:38px; padding-block:clamp(48px,6vw,80px); }
.foot-brand .brand .wm{ color:#fff; } .foot-brand .brand .wm span{ color:#9DB0C2; }
.foot-brand p{ font-size:.92rem; margin-top:16px; max-width:34ch; }
.foot-brand .stars{ margin-top:16px; }
.foot-col h4{ color:#fff; font-family:var(--display); font-size:.78rem; font-weight:700; letter-spacing:.14em; text-transform:uppercase; margin-bottom:18px; }
.foot-col ul{ display:flex; flex-direction:column; gap:11px; }
.foot-col a{ font-size:.93rem; transition:color .2s; } .foot-col a:hover{ color:#fff; }
.foot-contact .line{ display:flex; gap:11px; align-items:flex-start; font-size:.93rem; margin-bottom:13px; color:#C5D2DE; }
.foot-contact .line svg{ width:17px; color:#7FB2E4; flex:none; margin-top:3px; }
.foot-legal{ border-top:1px solid rgba(255,255,255,.1); padding-block:22px; display:flex; flex-wrap:wrap; align-items:center; justify-content:space-between; gap:10px; font-size:.82rem; color:#6E8090; }
.foot-legal a:hover{ color:#fff; }

/* ---------------- forms ---------------- */
.form{ background:#fff; border:1px solid var(--line); border-radius:var(--radius-lg); padding:clamp(24px,4vw,40px); box-shadow:var(--shadow-sm); }
.form .grid2{ display:grid; grid-template-columns:1fr 1fr; gap:18px; }
.field{ display:flex; flex-direction:column; gap:7px; margin-bottom:18px; }
.field label{ font-family:var(--display); font-size:.82rem; font-weight:650; color:var(--ink); }
.field .req{ color:var(--red); }
.field input,.field select,.field textarea{ width:100%; font:inherit; font-size:.98rem; color:var(--ink); background:var(--sky); border:1.5px solid var(--line); border-radius:var(--radius); padding:13px 15px; transition:border-color .2s, box-shadow .2s, background .2s; }
.field input:focus,.field select:focus,.field textarea:focus{ outline:none; border-color:var(--blue); background:#fff; box-shadow:0 0 0 3px rgba(27,78,142,.13); }
.field textarea{ resize:vertical; min-height:130px; }
.hp{ position:absolute; left:-9999px; width:1px; height:1px; overflow:hidden; }
.resp{ margin-top:14px; font-size:.92rem; color:var(--ink); }
.resp.err{ color:var(--red-2); }
.form-note{ font-size:.84rem; color:var(--muted); margin-top:14px; }
/* hide the floating reCAPTCHA badge sitewide; disclosure shown inline under each form (Google-compliant) */
.grecaptcha-badge{ visibility:hidden; }
.rc-note{ margin-top:14px; font-size:.74rem; line-height:1.5; color:var(--muted); }
.rc-note a{ color:var(--blue); text-decoration:underline; }

/* ---------------- reveals ---------------- */
.reveal{ opacity:0; transform:translateY(22px); transition:opacity .7s var(--ease), transform .7s var(--ease); }
.reveal.in{ opacity:1; transform:none; }
.reveal[data-d="1"]{ transition-delay:.08s; } .reveal[data-d="2"]{ transition-delay:.16s; }
.reveal[data-d="3"]{ transition-delay:.24s; } .reveal[data-d="4"]{ transition-delay:.32s; }
@media (prefers-reduced-motion:reduce){ .reveal{ opacity:1; transform:none; transition:none; } }

/* ---------------- responsive ---------------- */
@media (max-width:1000px){
  .hero-grid{ grid-template-columns:1fr; gap:40px; } .hero-media{ max-width:520px; }
  .svc-grid,.reviews{ grid-template-columns:repeat(2,1fr); }
  .strip .wrap{ grid-template-columns:repeat(2,1fr); gap:22px; }
  .areas{ grid-template-columns:repeat(2,1fr); }
  .split{ grid-template-columns:1fr; gap:36px; } .split.rev .media{ order:0; }
  .foot-top{ grid-template-columns:1fr 1fr; gap:30px; } .foot-brand{ grid-column:1 / -1; }
}
@media (max-width:860px){
  /* topbar: short label left + phone right across mobile/tablet so nothing wraps */
  .topbar .r .hide-sm{ display:none; }
  .topbar .wrap{ justify-content:space-between; gap:10px; }
  .topbar .l svg{ display:none; }
  .topbar .l{ font-size:.84rem; }
  .tb-full{ display:none; } .tb-short{ display:inline; }
  .topbar a{ white-space:nowrap; font-size:.88rem; }
  /* header must NOT create a stacking context / fixed-containing-block here,
     or the fixed drawer attaches to the header, gets blurred through, and
     can't receive clicks. Drop sticky + backdrop-filter on mobile. */
  .site-header{ position:static; backdrop-filter:none; -webkit-backdrop-filter:none; }
  .nav-links{ position:fixed; inset:0 0 0 auto; width:min(84vw,340px); background:#fff; flex-direction:column; align-items:stretch; justify-content:flex-start; gap:2px; padding:calc(env(safe-area-inset-top,0) + 84px) 20px 30px; transform:translateX(100%); transition:transform .34s var(--ease); z-index:120; box-shadow:-26px 0 70px -30px rgba(16,40,70,.4); overflow-y:auto; }
  body.nav-open .nav-links{ transform:none; }
  .nav-links > li:not(.drawer-cta){ border-bottom:1px solid var(--line-2); }
  .nav-links > li:not(.drawer-cta) > a{ padding:17px 8px; font-size:1.12rem; font-weight:700; border-radius:0; justify-content:space-between; }
  .nav-links .caret{ display:inline-block; width:20px; opacity:.45; transition:transform .3s var(--ease); }
  .has-sub.open > a{ color:var(--blue); }
  .has-sub.open > a .caret{ transform:rotate(180deg); opacity:.9; }
  /* accordion — submenu collapsed until parent .open */
  .submenu{ position:static; transform:none; visibility:visible; opacity:1; box-shadow:none; border:0; border-radius:0; margin:0; padding:0; min-width:0; max-height:0; overflow:hidden; transition:max-height .42s var(--ease); }
  .has-sub.open > .submenu{ max-height:1400px; }
  .submenu--mega{ display:block; padding:0; }
  .submenu--mega .mega-col{ padding:0 0 6px; }
  /* mobile: keep the Services list lean — county pages live in the footer, the
     homepage Service Areas section, and the desktop mega-menu */
  .submenu--mega .mega-col:not(:first-child){ display:none; }
  .submenu--mega .mega-col:first-child .grp{ display:none; }
  .submenu .grp{ display:block; border:0; margin:0; padding:15px 14px 5px; color:var(--red); }
  .submenu a{ padding:11px 16px; font-size:1rem; font-weight:600; color:var(--text); border-radius:var(--radius); }
  .submenu a:hover{ background:var(--sky); color:var(--blue); }
  .nav-toggle{ display:block; } .nav-phone{ display:none; } .nav-cta .btn{ display:none; }
  /* drawer CTA footer (appended by JS) */
  .drawer-cta{ margin-top:24px; padding-top:22px; border-top:1px solid var(--line); display:flex; flex-direction:column; gap:14px; }
  .drawer-cta .btn{ display:inline-flex; width:100%; justify-content:center; }
  .drawer-call{ display:inline-flex; align-items:center; justify-content:center; gap:.5em; font-family:var(--display); font-weight:800; font-size:1.08rem; color:var(--blue); padding:4px; }
  .drawer-call svg{ width:18px; color:var(--red); }
  .nav-backdrop{ display:block; position:fixed; inset:0; z-index:110; background:rgba(16,40,70,.4); -webkit-backdrop-filter:blur(4px); backdrop-filter:blur(4px); opacity:0; pointer-events:none; transition:opacity .3s; }
  body.nav-open .nav-backdrop{ opacity:1; pointer-events:auto; }
  .nav-close{ display:none; position:fixed; top:calc(env(safe-area-inset-top,0) + 18px); right:18px; z-index:122; width:44px; height:44px; border:1px solid var(--line); border-radius:var(--radius); background:#fff; align-items:center; justify-content:center; }
  body.nav-open .nav-close{ display:inline-flex; } .nav-close svg{ width:22px; color:var(--ink); }
  body.nav-open{ overflow:hidden; }
}
@media (max-width:560px){
  .svc-grid,.reviews,.areas,.strip .wrap{ grid-template-columns:1fr; }
  .form .grid2{ grid-template-columns:1fr; }
  .foot-top{ grid-template-columns:1fr; }
  .hero-badge{ left:0; }
}
@media (max-width:440px){
  /* tightest phones: shrink topbar + drop phone icon so the row never overflows */
  .topbar .wrap{ padding-inline:14px; gap:8px; }
  .topbar .l{ font-size:.76rem; }
  .topbar a{ font-size:.8rem; }
  .topbar a svg{ display:none; }
}

/* ---------------- photo service cards (his 8 services) ---------------- */
.svc-grid--photo{ grid-template-columns:repeat(4,1fr); gap:20px; }
.svc--photo{ position:relative; padding:0; border:0; min-height:400px; display:flex; flex-direction:column; justify-content:flex-end; align-items:stretch; overflow:hidden; border-radius:var(--radius-lg); isolation:isolate; box-shadow:var(--shadow-sm); }
.svc--photo:hover{ transform:translateY(-6px); box-shadow:var(--shadow); border-color:transparent; }
.svc--photo .ph{ position:absolute; inset:0; z-index:-2; }
.svc--photo .ph img{ width:100%; height:100%; object-fit:cover; transition:transform .65s var(--ease); }
.svc--photo:hover .ph img{ transform:scale(1.07); }
.svc--photo::after{ content:""; position:absolute; inset:0; z-index:-1; background:linear-gradient(180deg, rgba(10,26,46,0) 22%, rgba(10,26,46,.5) 52%, rgba(7,18,34,.96) 100%); }
.svc--photo .bd{ padding:24px 22px 22px; color:#fff; width:100%; }
.svc--photo .lbl{ font-family:var(--display); font-size:.68rem; font-weight:700; letter-spacing:.16em; text-transform:uppercase; color:#8FC0EE; display:block; margin-bottom:10px; }
.svc--photo .lbl b{ color:#fff; font-weight:800; }
.svc--photo h3{ color:#fff; font-size:1.22rem; margin-bottom:.5rem; letter-spacing:-.01em; }
.svc--photo p{ font-size:.9rem; color:rgba(255,255,255,.84); line-height:1.5; }
.svc--photo .more{ margin-top:16px; display:inline-flex; align-items:center; gap:.55em; font-family:var(--display); font-size:.73rem; font-weight:700; letter-spacing:.12em; text-transform:uppercase; color:#fff; }
.svc--photo .more svg{ width:15px; color:var(--red); transition:transform .25s var(--ease); }
.svc--photo:hover .more svg{ transform:translateX(5px); }

/* ---------------- benefits ---------------- */
.benefits{ display:grid; grid-template-columns:repeat(2,1fr); gap:18px; max-width:920px; margin:0 auto; }
.benefit{ background:#fff; border:1px solid var(--line); border-radius:var(--radius-lg); padding:24px 26px; display:flex; gap:16px; align-items:flex-start; box-shadow:var(--shadow-sm); }
.benefit .ic{ width:46px; height:46px; border-radius:13px; background:rgba(27,78,142,.1); display:grid; place-items:center; flex:none; }
.benefit .ic svg{ width:23px; color:var(--blue); }
.benefit h4{ margin-bottom:.25rem; }
.benefit p{ font-size:.93rem; color:var(--text); }

/* ---------------- video + bullets ---------------- */
.video-embed{ position:relative; max-width:860px; margin:0 auto; border-radius:var(--radius-lg); overflow:hidden; box-shadow:var(--shadow); aspect-ratio:16/9; background:#000; }
.video-embed iframe{ position:absolute; inset:0; width:100%; height:100%; border:0; }
.ticklist{ display:flex; flex-direction:column; gap:13px; }
.ticklist li{ display:flex; gap:12px; align-items:center; font-family:var(--display); font-weight:600; color:var(--ink); font-size:1.05rem; }
.ticklist .ic{ width:26px; height:26px; border-radius:50%; background:var(--red); display:grid; place-items:center; flex:none; }
.ticklist .ic svg{ width:14px; color:#fff; }

/* ---------------- areas served (town columns) ---------------- */
.areas-served{ display:grid; grid-template-columns:repeat(3,1fr); gap:38px 30px; }
.county h3{ color:#fff; margin-bottom:15px; padding-bottom:11px; border-bottom:2px solid rgba(255,255,255,.18); }
.county h3 a{ color:#fff; transition:color .2s; } .county h3 a:hover{ color:#7FB2E4; }
.county ul{ display:flex; flex-direction:column; gap:9px; }
.county li{ color:rgba(255,255,255,.84); font-size:.96rem; display:flex; gap:10px; align-items:center; }
.county li::before{ content:""; width:6px; height:6px; border-radius:50%; background:var(--red); flex:none; }

/* ---------------- contact band + map ---------------- */
.contact-band{ background:var(--blue-deep); color:#fff; }
.contact-band .grid{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(30px,5vw,60px); align-items:center; }
.contact-band h2{ color:#fff; }
.contact-band .phone{ font-family:var(--display); font-weight:800; font-size:clamp(2rem,3vw,2.6rem); color:#fff; display:inline-block; margin:16px 0 22px; }
.contact-band .rev-badge{ display:inline-flex; align-items:center; gap:10px; margin-top:6px; font-size:.92rem; color:var(--on-blue); }
.gmap{ border-radius:var(--radius-lg); overflow:hidden; box-shadow:var(--shadow); aspect-ratio:4/3; }
.gmap iframe{ width:100%; height:100%; border:0; display:block; }

@media (max-width:1000px){
  .svc-grid--photo{ grid-template-columns:repeat(2,1fr); }
  .areas-served{ grid-template-columns:repeat(2,1fr); }
  .benefits{ grid-template-columns:1fr; }
  .contact-band .grid{ grid-template-columns:1fr; } .contact-band .gmap{ order:-1; }
}
@media (max-width:560px){
  .svc-grid--photo,.areas-served{ grid-template-columns:1fr; }
}

/* ---------------- inner pages: banner + prose ---------------- */
.page-banner{ background:var(--blue-deep); color:#fff; position:relative; overflow:hidden; padding:clamp(48px,7vw,94px) 0 clamp(40px,5vw,64px); }
.page-banner.has-img .pb-img{ position:absolute; inset:0; z-index:0; }
.page-banner.has-img .pb-img img{ width:100%; height:100%; object-fit:cover; opacity:.2; }
.page-banner.has-img::after{ content:""; position:absolute; inset:0; background:linear-gradient(180deg, rgba(14,44,79,.62), rgba(14,44,79,.9)); }
.page-banner .wrap{ position:relative; z-index:2; }
.page-banner .eyebrow{ color:#7FB2E4; }
.page-banner h1{ color:#fff; margin:.6rem 0 0; max-width:22ch; }
.page-banner .lead{ color:var(--on-blue); margin-top:1.1rem; max-width:62ch; }
.breadcrumb{ display:flex; gap:.5em; align-items:center; font-size:.82rem; color:var(--on-blue); }
.breadcrumb a:hover{ color:#fff; } .breadcrumb .sep{ color:#7FB2E4; }

.prose{ max-width:70ch; }
.prose > * + *{ margin-top:1.05em; }
.prose h2{ margin-top:1.7em; font-size:clamp(1.55rem,2.4vw,2.1rem); }
.prose h3{ margin-top:1.35em; font-size:1.2rem; color:var(--ink); }
.prose p{ color:var(--text); }
.prose ul{ display:flex; flex-direction:column; gap:9px; margin-top:1em; }
.prose ul li{ position:relative; padding-left:26px; color:var(--text); }
.prose ul li::before{ content:""; position:absolute; left:0; top:.58em; width:9px; height:9px; border-radius:50%; background:var(--red); }
.prose strong{ color:var(--ink); }
.prose a{ color:var(--blue); font-weight:600; }
.prose .feat-img{ border-radius:var(--radius-lg); overflow:hidden; box-shadow:var(--shadow-sm); margin:1.6em 0; }
.prose .feat-img img{ width:100%; display:block; }

.content-grid{ display:grid; grid-template-columns:1.62fr 1fr; gap:clamp(34px,5vw,64px); align-items:start; }
.sidebar{ position:sticky; top:100px; display:flex; flex-direction:column; gap:18px; }
.scard{ background:var(--sky); border:1px solid var(--line); border-radius:var(--radius-lg); padding:26px; }
.scard.blue{ background:var(--blue); color:#fff; border-color:transparent; }
.scard h4{ font-family:var(--display); font-size:.78rem; letter-spacing:.14em; text-transform:uppercase; color:var(--red); margin-bottom:14px; }
.scard.blue h4{ color:#fff; }
.scard .line{ display:flex; gap:11px; align-items:flex-start; margin-bottom:12px; font-size:.95rem; }
.scard.blue .line{ color:#fff; } .scard .line svg{ width:18px; color:var(--red); flex:none; margin-top:2px; } .scard.blue .line svg{ color:#fff; }
.scard .line a:hover{ color:var(--red); } .scard.blue .line a:hover{ color:var(--on-blue); }
.scard ul{ display:flex; flex-direction:column; gap:10px; }
.scard ul a{ font-size:.93rem; font-weight:600; color:var(--ink); transition:color .2s; } .scard ul a:hover{ color:var(--red); }

@media (max-width:900px){ .content-grid{ grid-template-columns:1fr; } .sidebar{ position:static; } }

/* ---------------- mega-menu (Services) ---------------- */
.submenu--mega{ left:0; transform:translateX(0) translateY(8px); display:grid; grid-template-columns:repeat(2,minmax(196px,212px)); gap:8px 28px; padding:22px 26px; min-width:0; }
.has-sub:hover .submenu--mega, .has-sub:focus-within .submenu--mega{ transform:translateX(0) translateY(0); }
.submenu--mega .mega-col{ display:flex; flex-direction:column; }
.submenu--mega .grp{ padding:2px 8px 9px; margin-bottom:5px; border-bottom:1px solid var(--line); color:var(--red); }
.submenu--mega a{ padding:8px 8px; }

/* ---------------- testimonials ---------------- */
.reviews{ display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
.review{ background:#fff; border:1px solid var(--line); border-radius:var(--radius-lg); padding:30px 28px; box-shadow:var(--shadow-sm); display:flex; flex-direction:column; gap:15px; }
.review .qm{ font-family:var(--display); font-size:3.2rem; line-height:.5; color:var(--sky-2); height:24px; }
.review blockquote{ font-size:1rem; color:var(--text); line-height:1.62; flex:1; }
.review figcaption{ display:flex; flex-direction:column; gap:7px; }
.review .stars{ display:inline-flex; gap:2px; color:var(--gold); } .review .stars svg{ width:16px; }
.review .who{ font-family:var(--display); font-weight:700; color:var(--ink); font-size:.95rem; }

/* ---------------- pillars (why hire an expert) ---------------- */
.pillars{ display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
.pillar{ background:var(--sky); border:1px solid var(--line); border-radius:var(--radius-lg); padding:32px 28px; position:relative; overflow:hidden; }
.pillar::before{ content:""; position:absolute; top:0; left:0; right:0; height:4px; background:linear-gradient(90deg,var(--red),var(--red-2)); }
.pillar .pl{ display:flex; align-items:center; gap:13px; margin-bottom:15px; }
.pillar .pl .ic{ width:46px; height:46px; border-radius:13px; background:#fff; display:grid; place-items:center; color:var(--blue); flex:none; box-shadow:var(--shadow-sm); } .pillar .pl .ic svg{ width:23px; }
.pillar h3{ font-family:var(--display); font-size:1.06rem; color:var(--ink); }
.pillar p{ font-size:.95rem; color:var(--text); margin-top:2px; }

@media (max-width:900px){ .reviews,.pillars{ grid-template-columns:1fr; } }
@media (min-width:561px) and (max-width:900px){ .reviews,.pillars{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:860px){ .submenu--mega{ display:block; padding:0; } .submenu--mega .grp{ display:block; border:0; padding:12px 12px 4px; margin:0; } .submenu--mega .mega-col + .mega-col{ margin-top:4px; } }

/* ---------------- areas-we-serve band (photo background) ---------------- */
.areas-band{ position:relative; overflow:hidden; background:var(--blue-deep); }
.areas-band .areas-bg{ position:absolute; inset:0; z-index:0; }
.areas-band .areas-bg img{ width:100%; height:100%; object-fit:cover; }
.areas-band .areas-bg::after{ content:""; position:absolute; inset:0; background:linear-gradient(180deg, rgba(27,78,142,.85), rgba(14,44,79,.94)); }
.areas-band .wrap{ position:relative; z-index:1; }
