/* The Dry Boys of Albany — site.css | v2.3 build */
/* All non-critical styles; critical styles are inlined in each page <head> */

/* === Resets and base === */
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{margin:0;padding-bottom:70px;font-family:var(--font-body);color:var(--text);line-height:1.65;background:var(--white);font-size:16px}
img{max-width:100%;height:auto;display:block}
a{color:var(--primary-dark);text-decoration:none}
h1,h2,h3,h4{font-family:var(--font-display);font-weight:700;line-height:1.15;margin:0 0 .5em;letter-spacing:-.01em}
p{margin:0 0 1em}
.container{max-width:1240px;margin:0 auto;padding:0 24px}
.skip-link{position:absolute;top:-40px;left:0;background:#000;color:#fff;padding:8px 16px;z-index:10000;text-decoration:none}
.skip-link:focus{top:0}
:focus-visible{outline:3px solid var(--accent);outline-offset:2px}

/* === Announcement bar === */
.announce{background:var(--primary-dark);color:rgba(255,255,255,.85);font-size:13px;padding:8px 0}
.announce .container{display:flex;justify-content:space-between;align-items:center;gap:16px}
.announce .left{display:flex;align-items:center;gap:10px}
.announce .dot{width:8px;height:8px;background:#34d399;border-radius:50%;box-shadow:0 0 0 0 rgba(52,211,153,.6);animation:pulse 2s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(52,211,153,.6)}70%{box-shadow:0 0 0 8px rgba(52,211,153,0)}100%{box-shadow:0 0 0 0 rgba(52,211,153,0)}}
.announce .right{display:flex;gap:20px;align-items:center}
.announce a{color:#fff;font-weight:600}
.announce a:hover{color:var(--accent)}
@media(max-width:768px){.announce{display:none}}

/* === Nav === */
.nav{position:sticky;top:0;z-index:100;background:#fff;border-bottom:1px solid var(--border);box-shadow:0 1px 3px rgba(0,0,0,.04)}
.nav .container{display:flex;align-items:center;justify-content:space-between;padding-top:14px;padding-bottom:14px;gap:24px}
.nav-logo{display:flex;align-items:center;gap:12px;flex-shrink:0}
.nav-logo img{height:52px;width:auto}
.nav-logo-text{display:none;flex-direction:column}
.nav-logo-text strong{font-family:var(--font-display);font-size:18px;color:var(--primary-dark);line-height:1}
.nav-logo-text span{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:1.5px}
@media(min-width:1100px){.nav-logo-text{display:flex}}
.nav-links{display:none;gap:24px;align-items:center;list-style:none;margin:0;padding:0}
@media(min-width:1024px){.nav-links{display:flex}}
.nav-links a{font-size:13px;font-weight:600;color:var(--text);position:relative;padding:6px 0;text-transform:uppercase;letter-spacing:.5px}
.nav-links a:hover,.nav-links a.active{color:var(--primary)}
.nav-links a::after{content:"";position:absolute;bottom:0;left:0;width:0;height:2px;background:var(--accent);transition:width .25s}
.nav-links a:hover::after,.nav-links a.active::after{width:100%}
.nav-cta{display:flex;gap:12px;align-items:center}
.nav-phone{display:none;font-family:var(--font-display);color:var(--primary-dark);font-size:18px;font-weight:700;letter-spacing:.5px}
@media(min-width:1024px){.nav-phone{display:inline-block}}

/* === Buttons === */
.btn{display:inline-flex;align-items:center;gap:8px;padding:12px 22px;font-family:var(--font-display);font-weight:700;text-transform:uppercase;letter-spacing:1.2px;font-size:13px;border-radius:0;border:none;cursor:pointer;transition:transform .2s,box-shadow .2s,background .2s;text-decoration:none;line-height:1}
.btn-primary{background:var(--accent);color:#fff}
.btn-primary:hover{background:var(--accent-dark);transform:translateY(-1px);box-shadow:0 10px 20px -8px rgba(255,107,53,.5)}
.btn-ghost{background:transparent;color:#fff;border:2px solid rgba(255,255,255,.4)}
.btn-ghost:hover{background:rgba(255,255,255,.1);border-color:#fff}
.btn-dark{background:var(--primary-dark);color:#fff}
.btn-dark:hover{background:var(--primary-mid);transform:translateY(-1px)}
.btn-light{background:#fff;color:var(--primary-dark);border:2px solid var(--primary-dark)}
.btn-light:hover{background:var(--primary-dark);color:#fff}
.btn-lg{padding:16px 30px;font-size:14px}

/* === Hamburger / mobile menu === */
.hamburger{display:flex;flex-direction:column;gap:5px;padding:10px;border:none;background:none;cursor:pointer}
@media(min-width:1024px){.hamburger{display:none}}
.hamburger span{width:24px;height:2px;background:var(--primary-dark);transition:.25s}
.hamburger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.hamburger.open span:nth-child(2){opacity:0}
.hamburger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
.mobile-menu{display:none;position:fixed;top:0;left:0;right:0;bottom:0;background:var(--primary-dark);z-index:99;padding:100px 24px 40px;overflow-y:auto}
.mobile-menu.open{display:block}
.mobile-menu ul{list-style:none;padding:0;margin:0 0 30px}
.mobile-menu li{border-bottom:1px solid rgba(255,255,255,.1)}
.mobile-menu a{display:block;padding:18px 0;color:#fff;font-family:var(--font-display);font-size:18px;text-transform:uppercase;letter-spacing:1px}

/* === Hero (homepage) === */
.hero{position:relative;overflow:hidden;min-height:680px;display:flex;align-items:center;color:#fff;isolation:isolate}
.hero-bg-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(120deg,rgba(10,37,64,.92) 0%,rgba(10,37,64,.78) 50%,rgba(13,58,102,.65) 100%);z-index:1}
.hero-pattern{position:absolute;inset:0;z-index:1;opacity:.15;background-image:radial-gradient(circle at 20% 20%,rgba(63,184,232,.4) 0%,transparent 40%),radial-gradient(circle at 80% 80%,rgba(63,184,232,.3) 0%,transparent 40%)}
.hero-content{position:relative;z-index:2;width:100%;padding:60px 0}
.hero-grid{display:grid;grid-template-columns:1fr;gap:40px;align-items:center}
@media(min-width:1024px){.hero-grid{grid-template-columns:1.2fr 1fr;gap:60px}}
.hero-eyebrow{display:inline-flex;align-items:center;gap:10px;font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:3px;color:var(--primary-light);margin-bottom:20px}
.hero-eyebrow::before{content:"";width:40px;height:1px;background:var(--primary-light)}
.hero h1{font-size:clamp(36px,5.5vw,64px);line-height:1.05;margin-bottom:22px;font-weight:700}
.hero h1 em{font-style:italic;font-family:var(--font-serif);font-weight:500;color:var(--primary-light);display:block;font-size:.6em;margin-top:6px}
.hero-sub{font-size:18px;line-height:1.6;color:rgba(255,255,255,.9);margin-bottom:28px;max-width:620px}
.hero-trust{display:flex;flex-wrap:wrap;gap:10px 20px;margin-bottom:32px;font-size:14px}
.hero-trust span{display:inline-flex;align-items:center;gap:6px;color:rgba(255,255,255,.85)}
.hero-trust span::before{content:"✓";color:var(--primary-light);font-weight:700}
.hero-ctas{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:40px}
.hero-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;max-width:560px;padding-top:24px;border-top:1px solid rgba(255,255,255,.15)}
.hero-stat{text-align:left}
.hero-stat-num{font-family:var(--font-display);font-size:30px;font-weight:700;color:#fff;line-height:1;letter-spacing:-.02em}
.hero-stat-num .plus{color:var(--accent);font-size:.75em}
.hero-stat-label{font-size:11px;text-transform:uppercase;letter-spacing:1.5px;color:rgba(255,255,255,.7);margin-top:6px;line-height:1.3}

/* === Lead form (canonical v2.3 two-step wizard) === */
.lead-form{background:#fff;color:var(--text);padding:30px;border-radius:2px;box-shadow:0 30px 80px -20px rgba(0,0,0,.5);position:relative}
.lead-form::before{content:"";position:absolute;top:-1px;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--accent) 0%,var(--primary) 100%)}
.lead-form-title{font-family:var(--font-display);font-size:24px;color:var(--primary-dark);margin-bottom:6px}
.lead-form-sub{font-size:13px;color:var(--muted);margin-bottom:18px}
.lead-form label{display:block;font-size:12px;font-weight:600;color:var(--text);margin-bottom:10px;text-transform:uppercase;letter-spacing:.5px}
.lead-form label input,.lead-form label select,.lead-form label textarea{display:block;width:100%;margin-top:6px;padding:12px 14px;border:1.5px solid var(--border);border-radius:2px;font-family:inherit;font-size:14px;background:#fff;text-transform:none;letter-spacing:0;font-weight:400;transition:border-color .2s}
.lead-form label input:focus,.lead-form label select:focus,.lead-form label textarea:focus{outline:none;border-color:var(--primary)}
.lead-form button{width:100%;margin-top:6px;justify-content:center}
.form-step-actions{display:flex;gap:10px;margin-top:6px;align-items:stretch;flex-wrap:nowrap}
.form-step-actions .back-btn{flex:0 0 auto;width:auto;background:transparent;color:var(--muted);border:1.5px solid var(--border);padding:14px 18px;font-size:12px;white-space:nowrap}
.form-step-actions .back-btn:hover{border-color:var(--primary-dark);color:var(--primary-dark);background:transparent;transform:none;box-shadow:none}
.form-step-actions .submit-btn{flex:1 1 auto;width:auto;min-width:0}
.next-btn{width:100%;justify-content:center}
.hc-note{text-align:center;font-size:12px;color:var(--muted);margin:14px 0 0}
.hc-error{margin-top:14px;padding:12px;background:#fee;color:#c00;border-radius:2px;font-size:13px}
/* Honeypot per v2.3 spec */
._gotcha{position:absolute;left:-9999px;top:-9999px;width:1px;height:1px;opacity:0}
.form-step[hidden]{display:none}
.form-step{display:block}
/* Progress bar */
.form-progress{margin-bottom:18px}
.form-progress-label{display:flex;justify-content:space-between;font-size:11px;text-transform:uppercase;letter-spacing:1.5px;color:var(--muted);margin-bottom:8px;font-weight:600}
.form-progress-hint{color:var(--primary)}
.form-progress-bar{height:3px;background:var(--border);border-radius:2px;overflow:hidden}
.form-progress-fill{height:100%;width:50%;background:var(--accent);transition:width .3s ease}
.form-progress.step-2 .form-progress-fill{width:100%}
.lead-form-divider{text-align:center;font-size:11px;color:var(--muted);margin:18px 0 8px;text-transform:uppercase;letter-spacing:2px;position:relative}
.lead-form-divider::before,.lead-form-divider::after{content:"";position:absolute;top:50%;width:30%;height:1px;background:var(--border)}
.lead-form-divider::before{left:0}.lead-form-divider::after{right:0}
.lead-form-call{text-align:center;display:block;font-family:var(--font-display);font-size:28px;color:var(--primary-dark);font-weight:700;letter-spacing:.5px}
.lead-form-call:hover{color:var(--accent)}

/* === Proof bar === */
.proof-bar{background:var(--primary-dark);color:#fff;padding:40px 0;position:relative;border-top:4px solid var(--accent)}
.proof-grid{display:grid;grid-template-columns:1fr;gap:30px;align-items:center}
@media(min-width:900px){.proof-grid{grid-template-columns:repeat(4,1fr) 1.4fr;gap:30px}}
.proof-stat{text-align:center;border-right:1px solid rgba(255,255,255,.1);padding-right:20px}
.proof-stat:last-of-type{border-right:none}
@media(max-width:899px){.proof-stat{border-right:none;border-bottom:1px solid rgba(255,255,255,.1);padding:0 0 20px;display:flex;justify-content:space-between;align-items:center}}
.proof-stat-num{font-family:var(--font-display);font-size:36px;color:var(--primary-light);line-height:1;letter-spacing:-.02em}
.proof-stat-label{font-size:11px;text-transform:uppercase;letter-spacing:1.8px;color:rgba(255,255,255,.75);margin-top:6px}
.proof-quote{font-family:var(--font-serif);font-style:italic;font-size:17px;line-height:1.5;color:rgba(255,255,255,.95);padding-left:20px;border-left:3px solid var(--accent);position:relative}
.proof-quote cite{display:block;font-family:var(--font-body);font-style:normal;font-size:12px;text-transform:uppercase;letter-spacing:1.5px;color:var(--primary-light);margin-top:10px;font-weight:700}

/* === Sections === */
section{padding:90px 0}
@media(max-width:768px){section{padding:60px 0}}
.eyebrow{display:inline-flex;align-items:center;gap:10px;font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:3px;color:var(--accent);margin-bottom:16px}
.eyebrow::before{content:"";width:30px;height:1px;background:var(--accent)}
.section-title{font-size:clamp(32px,4vw,46px);color:var(--primary-dark);margin-bottom:18px;max-width:780px;line-height:1.1}
.section-lead{font-size:17px;color:var(--muted);max-width:680px;margin-bottom:50px;line-height:1.65}
.dark-section{background:var(--primary-dark);color:#fff}
.dark-section .section-title{color:#fff}
.dark-section .section-lead{color:rgba(255,255,255,.75)}
.dark-section .eyebrow{color:var(--primary-light)}
.dark-section .eyebrow::before{background:var(--primary-light)}
.cream-section{background:var(--cream)}

/* === About === */
.about-grid{display:grid;grid-template-columns:1fr;gap:50px;align-items:center}
@media(min-width:1024px){.about-grid{grid-template-columns:1fr 1.15fr;gap:70px}}
.about-visual{position:relative}
.about-visual-main{border-radius:2px;overflow:hidden;box-shadow:0 30px 60px -20px rgba(10,37,64,.3)}
.about-visual-main img{width:100%;height:auto}
.about-badge{position:absolute;top:20px;left:-10px;background:var(--accent);color:#fff;padding:18px 24px;text-align:center;box-shadow:0 15px 30px -5px rgba(255,107,53,.5);transform:rotate(-2deg)}
.about-badge strong{display:block;font-family:var(--font-display);font-size:30px;line-height:1}
.about-badge span{font-size:10px;text-transform:uppercase;letter-spacing:2px;display:block;margin-top:4px}
.about-accent{position:absolute;bottom:-30px;right:-10px;width:45%;border-radius:2px;overflow:hidden;box-shadow:0 20px 40px -10px rgba(10,37,64,.4);border:6px solid #fff;display:none}
@media(min-width:768px){.about-accent{display:block}}
.about-content h2 em{font-style:italic;font-family:var(--font-serif);color:var(--primary);font-weight:500}
.about-body p{font-size:16px;color:var(--text);margin-bottom:18px}
.about-body p.lead{font-size:18px;color:var(--text);font-weight:500;line-height:1.55}
.pillars{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin:30px 0}
.pillar{padding:18px 0 18px 18px;border-left:3px solid var(--primary)}
.pillar strong{display:block;font-family:var(--font-display);font-size:15px;color:var(--primary-dark);text-transform:uppercase;letter-spacing:1px;margin-bottom:4px}
.dark-section .pillar strong{color:#fff}
.pillar span{font-size:13px;color:var(--muted);line-height:1.5}
.dark-section .pillar span{color:rgba(255,255,255,.7)}
.signature{margin-top:30px;padding-top:24px;border-top:1px solid var(--border)}
.signature-name{font-family:var(--font-serif);font-style:italic;font-size:28px;color:var(--primary-dark);line-height:1}
.signature-title{font-size:12px;text-transform:uppercase;letter-spacing:2px;color:var(--muted);margin-top:6px}

/* === Services grid (homepage) === */
.services-grid{display:grid;grid-template-columns:1fr;gap:20px}
@media(min-width:640px){.services-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1024px){.services-grid{grid-template-columns:repeat(4,1fr);grid-auto-rows:280px}}
.service-card{position:relative;overflow:hidden;background:var(--primary-dark);color:#fff;cursor:pointer;min-height:280px;isolation:isolate;transition:transform .3s}
.service-card:hover{transform:translateY(-4px)}
.service-card img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0;transition:transform .6s ease,filter .6s ease;filter:brightness(.55)}
.service-card:hover img{transform:scale(1.08);filter:brightness(.4)}
.service-card::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 40%,rgba(10,37,64,.95) 100%);z-index:1}
.service-card-inner{position:relative;z-index:2;height:100%;display:flex;flex-direction:column;justify-content:space-between;padding:24px}
.service-num{font-family:var(--font-display);font-size:14px;color:var(--primary-light);letter-spacing:3px;font-weight:700}
.service-bottom h3{font-family:var(--font-display);font-size:22px;color:#fff;margin-bottom:6px;line-height:1.15}
.service-bottom p{font-size:13px;color:rgba(255,255,255,.75);line-height:1.5;margin-bottom:14px;max-height:0;overflow:hidden;transition:max-height .4s ease,margin .4s ease}
.service-card:hover .service-bottom p{max-height:80px;margin-bottom:14px}
.service-link{display:inline-flex;align-items:center;gap:8px;font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:1.5px;color:var(--accent)}
.service-link svg{transition:transform .3s}
.service-card:hover .service-link svg{transform:translateX(4px)}
@media(min-width:1024px){
  .service-card.featured{grid-column:span 2;grid-row:span 2;min-height:580px}
  .service-card.featured .service-bottom h3{font-size:32px}
  .service-card.featured .service-bottom p{max-height:none;margin-bottom:14px;font-size:14px}
}

/* === Process === */
.process-grid{display:grid;grid-template-columns:1fr;gap:30px;position:relative;margin-top:30px}
@media(min-width:768px){.process-grid{grid-template-columns:repeat(4,1fr);gap:24px}
  .process-grid::before{content:"";position:absolute;top:36px;left:10%;right:10%;height:1px;background:linear-gradient(90deg,transparent,rgba(63,184,232,.4) 20%,rgba(63,184,232,.4) 80%,transparent)}
}
.process-step{position:relative}
.process-num{width:72px;height:72px;border-radius:50%;background:var(--primary-dark);border:2px solid var(--primary-light);display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-size:26px;color:var(--primary-light);margin-bottom:22px;position:relative;z-index:2}
.process-step:hover .process-num{background:var(--accent);border-color:var(--accent);color:#fff}
.process-step h3{font-family:var(--font-display);font-size:20px;color:#fff;margin-bottom:8px;text-transform:uppercase;letter-spacing:.5px}
.dark-section .process-step h3{color:#fff}
.process-step p{font-size:14px;color:rgba(255,255,255,.7);line-height:1.6}

/* === Gallery === */
.gallery-grid{display:grid;grid-template-columns:1fr;gap:16px}
@media(min-width:768px){.gallery-grid{grid-template-columns:2fr 1fr 1fr;grid-template-rows:220px 220px;gap:16px}
  .gallery-item:first-child{grid-row:span 2}
  .gallery-item img{height:100%}
}
.gallery-item{position:relative;overflow:hidden;background:var(--primary-dark);aspect-ratio:4/3}
@media(min-width:768px){.gallery-item{aspect-ratio:auto}}
.gallery-item img{width:100%;height:100%;object-fit:cover;transition:transform .6s}
.gallery-item:hover img{transform:scale(1.08)}
.gallery-item::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 50%,rgba(10,37,64,.9) 100%);opacity:0;transition:opacity .3s}
.gallery-item:hover::after{opacity:1}
.gallery-caption{position:absolute;bottom:0;left:0;right:0;padding:18px;color:#fff;transform:translateY(10px);opacity:0;transition:.3s;z-index:2;font-family:var(--font-serif);font-style:italic;font-size:16px}
.gallery-item:hover .gallery-caption{transform:translateY(0);opacity:1}

/* === Reviews === */
.reviews-grid{display:grid;grid-template-columns:1fr;gap:24px}
@media(min-width:768px){.reviews-grid{grid-template-columns:repeat(3,1fr)}}
.review{background:#fff;padding:32px 28px;position:relative;border-top:3px solid var(--accent);box-shadow:0 2px 10px rgba(10,37,64,.05)}
.review-stars{color:#f4b301;font-size:16px;letter-spacing:3px;margin-bottom:16px}
.review-text{font-family:var(--font-serif);font-style:italic;font-size:17px;line-height:1.6;color:var(--text);margin-bottom:20px;position:relative}
.review-text::before{content:"\201C";position:absolute;top:-20px;left:-6px;font-family:Georgia,serif;font-size:60px;color:var(--primary-pale);line-height:1;font-style:normal;z-index:0}
.review-text span{position:relative;z-index:1}
.review-attr{border-top:1px solid var(--border);padding-top:16px;display:flex;justify-content:space-between;align-items:flex-end;gap:10px}
.review-name{font-family:var(--font-display);font-weight:700;color:var(--primary-dark);font-size:15px;text-transform:uppercase;letter-spacing:.5px}
.review-where{font-size:12px;color:var(--muted);margin-top:2px}
.review-badge{font-size:10px;text-transform:uppercase;letter-spacing:1.5px;color:var(--primary);font-weight:700;white-space:nowrap}
.reviews-summary{text-align:center;margin-top:40px;font-size:15px;color:var(--muted)}
.reviews-summary strong{color:var(--primary-dark);font-family:var(--font-display);font-size:22px;display:block;margin-bottom:4px}

/* === FAQ === */
.faq-grid{display:grid;grid-template-columns:1fr;gap:14px}
@media(min-width:900px){.faq-grid{grid-template-columns:1fr 1fr;gap:14px 28px}}
.faq-item{background:var(--primary-pale);border-left:3px solid var(--primary);transition:background .2s}
.faq-item[open]{background:#fff;box-shadow:0 4px 20px rgba(10,37,64,.08);border-left-color:var(--accent)}
.faq-item summary{list-style:none;cursor:pointer;padding:20px 24px;font-family:var(--font-display);font-size:16px;color:var(--primary-dark);display:flex;justify-content:space-between;align-items:flex-start;gap:16px;font-weight:700;line-height:1.35}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::after{content:"+";font-size:26px;color:var(--accent);font-weight:300;line-height:1;flex-shrink:0;transition:transform .2s}
.faq-item[open] summary::after{content:"−"}
.faq-answer{padding:0 24px 22px;font-size:15px;line-height:1.7;color:var(--text)}
.faq-answer strong{color:var(--primary-dark)}
.faq-mid-cta{grid-column:1/-1;background:var(--primary-dark);color:#fff;padding:30px;text-align:center;margin:10px 0}
.faq-mid-cta p{font-family:var(--font-display);font-size:20px;margin:0 0 14px;color:#fff}
.faq-end-cta{grid-column:1/-1;text-align:center;padding:40px 20px;margin-top:20px;background:#fff;border:1px dashed var(--border)}
.faq-end-cta span{display:block;font-size:12px;text-transform:uppercase;letter-spacing:2px;color:var(--muted);margin-bottom:10px}
.faq-end-cta a{font-family:var(--font-display);font-size:42px;color:var(--primary-dark);letter-spacing:.5px;font-weight:700}
.faq-end-cta a:hover{color:var(--accent)}

/* === Service area / counties === */
.counties-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:2px;background:rgba(255,255,255,.1);margin-top:30px}
@media(min-width:640px){.counties-grid{grid-template-columns:repeat(3,1fr)}}
@media(min-width:1024px){.counties-grid{grid-template-columns:repeat(4,1fr)}}
.county{background:var(--primary-dark);padding:22px 18px;transition:background .2s}
.county:hover{background:var(--primary-mid)}
.county strong{display:block;font-family:var(--font-display);color:#fff;font-size:17px;letter-spacing:.3px;margin-bottom:4px}
.county span{display:block;font-size:12px;color:var(--primary-light);text-transform:uppercase;letter-spacing:1.5px}

/* === CTA banner === */
.cta-banner{background:linear-gradient(135deg,var(--accent) 0%,#ff8a5c 100%);color:#fff;padding:70px 0;position:relative;overflow:hidden}
.cta-banner::before{content:"";position:absolute;top:0;right:0;width:60%;height:100%;background:radial-gradient(circle at 70% 50%,rgba(255,255,255,.15) 0%,transparent 60%)}
.cta-grid{display:grid;grid-template-columns:1fr;gap:30px;align-items:center;position:relative;z-index:1}
@media(min-width:900px){.cta-grid{grid-template-columns:1.2fr 1fr}}
.cta-banner h2{font-size:clamp(28px,3.6vw,42px);color:#fff;margin-bottom:10px}
.cta-banner p{font-size:17px;color:rgba(255,255,255,.95);margin:0}
.cta-right{text-align:center}
@media(min-width:900px){.cta-right{text-align:right}}
.cta-phone-label{font-size:12px;text-transform:uppercase;letter-spacing:3px;color:rgba(255,255,255,.85);margin-bottom:8px;font-weight:700}
.cta-phone{display:inline-block;font-family:var(--font-display);font-size:clamp(34px,4.5vw,48px);color:#fff;font-weight:700;letter-spacing:.5px;line-height:1;margin-bottom:16px}
.cta-phone:hover{color:var(--primary-dark)}

/* === Contact section (homepage section 13) === */
.contact-grid{display:grid;grid-template-columns:1fr;gap:50px;align-items:start}
@media(min-width:1024px){.contact-grid{grid-template-columns:1fr 1.1fr;gap:60px}}
.contact-info{font-size:16px}
.contact-info h3{font-family:var(--font-display);font-size:20px;color:var(--primary-dark);text-transform:uppercase;letter-spacing:1px;margin:30px 0 12px;padding-bottom:10px;border-bottom:2px solid var(--primary)}
.contact-info h3:first-child{margin-top:0}
.contact-info ul{list-style:none;padding:0;margin:0;line-height:2}
.contact-info ul li strong{color:var(--primary-dark)}
.contact-info a{color:var(--primary);font-weight:600}
.contact-info a:hover{color:var(--accent)}
.contact-detail{display:flex;align-items:flex-start;gap:14px;margin-bottom:18px;font-size:15px}
.contact-detail-icon{width:40px;height:40px;background:var(--primary-pale);border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--primary)}
.contact-detail strong{display:block;font-family:var(--font-display);text-transform:uppercase;letter-spacing:1px;font-size:11px;color:var(--muted);margin-bottom:2px}
.contact-detail-text{font-family:var(--font-display);font-size:18px;color:var(--primary-dark);font-weight:700}
.contact-detail-text a{color:inherit}

/* === Footer === */
footer{background:#061a2e;color:rgba(255,255,255,.7);padding:70px 0 0;font-size:14px}
.footer-grid{display:grid;grid-template-columns:1fr;gap:40px;margin-bottom:50px}
@media(min-width:768px){.footer-grid{grid-template-columns:1fr 1fr;gap:36px}}
@media(min-width:1024px){.footer-grid{grid-template-columns:1.5fr 1fr 1fr 1fr 1.2fr;gap:32px}}
.footer-col h4{font-family:var(--font-display);color:#fff;font-size:14px;text-transform:uppercase;letter-spacing:2px;margin-bottom:20px;padding-bottom:12px;border-bottom:1px solid rgba(255,255,255,.1)}
.footer-col ul{list-style:none;padding:0;margin:0}
.footer-col li{margin-bottom:10px}
.footer-col.footer-col-compact li{margin-bottom:7px;font-size:13.5px;line-height:1.4}
.footer-col.footer-col-compact a{color:rgba(255,255,255,.65)}
.footer-col.footer-col-compact a:hover{color:var(--primary-light)}
.footer-col a{color:rgba(255,255,255,.7)}
.footer-col a:hover{color:var(--primary-light)}
.footer-brand img{height:56px;margin-bottom:20px;background:#fff;padding:10px;border-radius:2px}
.footer-tagline{font-family:var(--font-serif);font-style:italic;font-size:17px;color:var(--primary-light);margin-bottom:20px}
.footer-nap{line-height:1.8;font-size:14px}
.footer-nap strong{color:#fff;display:block;font-family:var(--font-display);font-size:16px;margin-bottom:6px}
.footer-nap a{color:rgba(255,255,255,.85);font-weight:600}
.footer-creds{display:flex;gap:14px;align-items:center;margin-top:22px;flex-wrap:wrap}
.footer-creds img{height:38px;background:#fff;padding:4px;border-radius:2px}
.footer-bottom{border-top:1px solid rgba(255,255,255,.1);padding:24px 0;font-size:12px;color:rgba(255,255,255,.5);display:flex;flex-wrap:wrap;justify-content:space-between;gap:16px}
.footer-bottom a{color:rgba(255,255,255,.7)}

/* === Sticky phone bar === */
.sticky-phone-bar{position:fixed;bottom:0;left:0;right:0;background:var(--primary-dark);border-top:1px solid rgba(var(--accent-rgb),.3);padding:12px 20px;display:flex;align-items:center;justify-content:space-between;z-index:200;gap:12px}
.spb-label{font-size:9px;color:rgba(255,255,255,.5);letter-spacing:2px;text-transform:uppercase;display:block;margin-bottom:2px}
.spb-phone{font-family:var(--font-serif);font-size:22px;color:#fff;text-decoration:none;font-weight:600}
.spb-phone:hover{color:var(--accent)}
.spb-btn{font-size:9px;font-weight:700;background:var(--accent);color:#fff;padding:12px 18px;letter-spacing:2px;text-transform:uppercase;text-decoration:none;display:inline-flex;align-items:center;gap:6px;flex-shrink:0}
.spb-btn:hover{background:var(--accent-dark)}

/* === Inner-page hero === */
.page-hero{position:relative;overflow:hidden;color:#fff;isolation:isolate;padding:90px 0 70px}
.page-hero-bg{position:absolute;inset:0;z-index:0}
.page-hero-bg img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.page-hero-overlay{position:absolute;inset:0;background:linear-gradient(120deg,rgba(10,37,64,.92) 0%,rgba(10,37,64,.78) 100%);z-index:1}
.page-hero-content{position:relative;z-index:2;text-align:center}
.page-hero h1{font-size:clamp(34px,5vw,56px);line-height:1.1;margin-bottom:14px;color:#fff}
.page-hero-sub{font-size:18px;color:rgba(255,255,255,.85);max-width:680px;margin:0 auto 24px;line-height:1.55}
.breadcrumbs{font-size:12px;color:rgba(255,255,255,.6);text-transform:uppercase;letter-spacing:2px;margin-bottom:18px}
.breadcrumbs a{color:rgba(255,255,255,.85)}
.breadcrumbs a:hover{color:var(--accent)}

/* === Two-column inner content === */
.split-grid{display:grid;grid-template-columns:1fr;gap:50px}
@media(min-width:1024px){.split-grid{grid-template-columns:2fr 1fr;gap:70px}}
.split-grid.reverse{direction:rtl}
.split-grid.reverse > *{direction:ltr}
.split-content h2{font-size:32px;color:var(--primary-dark);margin-top:40px;margin-bottom:14px}
.split-content h2:first-child{margin-top:0}
.split-content h3{font-size:22px;color:var(--primary-dark);margin-top:30px;margin-bottom:10px}
.split-content p{font-size:16px;line-height:1.75;color:var(--text);margin-bottom:18px}
.split-content ul{padding-left:24px;margin-bottom:24px}
.split-content ul li{margin-bottom:10px;line-height:1.65;font-size:16px}
.split-content ul li::marker{color:var(--accent)}
.split-content blockquote{border-left:4px solid var(--accent);padding:8px 0 8px 24px;margin:30px 0;font-family:var(--font-serif);font-style:italic;font-size:20px;color:var(--primary-dark);line-height:1.45}
.aside-card{background:var(--primary-pale);padding:28px;position:sticky;top:90px}
.aside-card h3{font-family:var(--font-display);font-size:18px;color:var(--primary-dark);text-transform:uppercase;letter-spacing:1px;margin-bottom:14px;padding-bottom:12px;border-bottom:2px solid var(--primary)}
.aside-card ul{list-style:none;padding:0;margin:0 0 20px}
.aside-card ul li{padding:8px 0;border-bottom:1px solid rgba(0,0,0,.05);font-size:14px}
.aside-card ul li:last-child{border-bottom:none}
.aside-card a{color:var(--primary-dark);font-weight:600}
.aside-card a:hover{color:var(--accent)}

/* === Why-choose-us cards === */
.why-grid{display:grid;grid-template-columns:1fr;gap:24px;margin-top:40px}
@media(min-width:640px){.why-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1024px){.why-grid{grid-template-columns:repeat(3,1fr)}}
.why-card{background:#fff;padding:30px 26px;border-top:3px solid var(--primary);box-shadow:0 4px 20px rgba(10,37,64,.06);transition:transform .2s,box-shadow .2s}
.why-card:hover{transform:translateY(-4px);box-shadow:0 12px 30px rgba(10,37,64,.12)}
.why-icon{width:54px;height:54px;background:var(--primary-pale);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--primary);margin-bottom:18px}
.why-card h3{font-family:var(--font-display);font-size:18px;color:var(--primary-dark);text-transform:uppercase;letter-spacing:.8px;margin-bottom:10px;line-height:1.25}
.why-card p{font-size:14px;color:var(--muted);line-height:1.65;margin:0}

/* === Blog list === */
.blog-grid{display:grid;grid-template-columns:1fr;gap:30px}
@media(min-width:768px){.blog-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1024px){.blog-grid{grid-template-columns:repeat(3,1fr)}}
.blog-card{background:#fff;border:1px solid var(--border);overflow:hidden;transition:transform .2s,box-shadow .2s;display:flex;flex-direction:column}
.blog-card:hover{transform:translateY(-4px);box-shadow:0 12px 30px rgba(10,37,64,.12)}
.blog-card-img{aspect-ratio:16/10;overflow:hidden;background:var(--primary-dark)}
.blog-card-img img{width:100%;height:100%;object-fit:cover;transition:transform .6s}
.blog-card:hover .blog-card-img img{transform:scale(1.06)}
.blog-card-body{padding:24px;flex:1;display:flex;flex-direction:column}
.blog-card-cat{font-size:11px;text-transform:uppercase;letter-spacing:2px;color:var(--accent);font-weight:700;margin-bottom:8px}
.blog-card h3{font-family:var(--font-display);font-size:20px;line-height:1.25;margin-bottom:10px;color:var(--primary-dark)}
.blog-card p{font-size:14px;color:var(--muted);line-height:1.65;margin-bottom:16px;flex:1}
.blog-card-link{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:1.5px;color:var(--primary)}

/* === Testimonials page list === */
.testimonials-list{display:grid;grid-template-columns:1fr;gap:24px;max-width:880px;margin:0 auto}
@media(min-width:768px){.testimonials-list{grid-template-columns:repeat(2,1fr)}}

/* === Equipment grid === */
.equipment-grid{display:grid;grid-template-columns:1fr;gap:24px;margin-top:40px}
@media(min-width:640px){.equipment-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1024px){.equipment-grid{grid-template-columns:repeat(3,1fr)}}
.equipment-card{background:#fff;padding:0;border:1px solid var(--border);overflow:hidden;display:flex;flex-direction:column}
.equipment-card-img{aspect-ratio:4/3;overflow:hidden;background:var(--primary-dark)}
.equipment-card-img img{width:100%;height:100%;object-fit:cover}
.equipment-card-body{padding:22px;flex:1;display:flex;flex-direction:column}
.equipment-card h3{font-family:var(--font-display);font-size:18px;color:var(--primary-dark);margin-bottom:8px}
.equipment-card p{font-size:14px;color:var(--muted);line-height:1.6;margin-bottom:12px;flex:1}
.equipment-card .price{font-family:var(--font-display);color:var(--primary);font-size:14px;text-transform:uppercase;letter-spacing:1px;font-weight:700}

/* === Utilities === */
.text-center{text-align:center}
.mt-0{margin-top:0}
.mb-0{margin-bottom:0}

/* === Mobile responsive tweaks === */
@media(max-width:520px){
  .hero-stats{grid-template-columns:repeat(3,1fr);gap:10px}
  .hero-stat-num{font-size:24px}
  .lead-form{padding:24px 20px}
  .spb-phone{font-size:18px}
  .spb-label{font-size:8px}
  .page-hero{padding:60px 0 50px}
}
@media(max-width:380px){
  /* Very narrow phones — stack form action buttons */
  .form-step-actions{flex-direction:column}
  .form-step-actions .back-btn,.form-step-actions .submit-btn{width:100%}
}
