
:root{
  --navy:#111f49;
  --navy-2:#172a62;
  --red:#d11b2b;
  --white:#ffffff;
  --text:#0f172a;
  --muted:#5b6475;
  --bg:#f7f8fc;
  --line:rgba(17,31,73,.12);
  --shadow:0 22px 60px rgba(7,14,35,.12);
  --radius:24px;
  --radius-sm:16px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:"Inter",system-ui,-apple-system,sans-serif;
  color:var(--text);
  background:#fff;
  line-height:1.6;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.container{width:min(1180px, calc(100% - 32px)); margin:0 auto}
.site-header{
  position:sticky; top:0; z-index:40; background:rgba(255,255,255,.92);
  backdrop-filter: blur(12px); border-bottom:1px solid var(--line);
}
.nav-wrap{display:flex; align-items:center; justify-content:space-between; min-height:82px; gap:16px}
.brand img{height:62px; width:auto}
.site-nav{display:flex; align-items:center; gap:24px; font-weight:600}
.site-nav a{position:relative}
.site-nav a:not(.nav-cta)::after{
  content:""; position:absolute; left:0; bottom:-8px; width:0; height:2px; background:var(--red); transition:.3s ease;
}
.site-nav a:not(.nav-cta):hover::after{width:100%}
.nav-cta{
  padding:12px 18px; border-radius:999px; background:var(--navy); color:#fff; box-shadow:inset 0 0 0 2px var(--red);
}
.mobile-toggle{display:none; background:none; border:0; font-size:30px; color:var(--navy)}

.hero{
  position:relative; overflow:hidden;
  background:
    radial-gradient(circle at 80% 20%, rgba(209,27,43,.15), transparent 28%),
    linear-gradient(180deg, #f8f9ff 0%, #ffffff 100%);
  padding:86px 0 56px;
}
.hero::before{
  content:""; position:absolute; inset:0; pointer-events:none;
  background:
    linear-gradient(90deg, transparent 0 95%, rgba(209,27,43,.12) 95% 96%, transparent 96%),
    linear-gradient(180deg, transparent 0 92%, rgba(17,31,73,.06) 92% 93%, transparent 93%);
}
.hero-grid{display:grid; grid-template-columns:1.25fr .8fr; gap:34px; align-items:center}
.eyebrow,.section-kicker{
  display:inline-flex; align-items:center; gap:10px;
  font-size:.86rem; text-transform:uppercase; letter-spacing:.14em; color:var(--navy); font-weight:800;
}
.eyebrow::before,.section-kicker::before{
  content:""; width:32px; height:2px; background:var(--red); display:inline-block;
}
.hero h1, .subhero h1{
  font-size:clamp(2.4rem, 5vw, 4.8rem); line-height:.98; margin:12px 0 18px;
  letter-spacing:-.04em; max-width:12ch; text-transform:uppercase;
}
.hero p{font-size:1.05rem; color:var(--muted); max-width:62ch}
.hero-actions{display:flex; flex-wrap:wrap; gap:14px; margin:26px 0 22px}
.btn{
  display:inline-flex; align-items:center; justify-content:center; min-height:52px;
  padding:0 20px; border-radius:999px; font-weight:800; transition:transform .2s ease, box-shadow .2s ease;
}
.btn:hover{transform:translateY(-2px)}
.btn-primary{background:var(--navy); color:#fff; box-shadow:inset 0 0 0 2px var(--red), 0 16px 30px rgba(17,31,73,.18)}
.btn-secondary{background:#fff; color:var(--navy); border:1px solid var(--line)}
.trust-points{
  list-style:none; padding:0; margin:0; display:grid; grid-template-columns:repeat(3, minmax(0,1fr)); gap:12px;
}
.trust-points li{
  background:#fff; border:1px solid var(--line); border-radius:16px; padding:14px 16px; font-weight:600; box-shadow:var(--shadow);
}
.hero-card{
  position:relative; min-height:100%;
}
.hero-card-inner{
  background:linear-gradient(180deg, #15275d 0%, #0f1f4b 100%);
  color:#fff; border-radius:28px; padding:28px; box-shadow:var(--shadow); position:relative; overflow:hidden;
}
.hero-card-inner::after{
  content:""; position:absolute; inset:12px; border:1px solid rgba(255,255,255,.12); border-radius:22px; pointer-events:none;
}
.hero-stat{
  display:flex; flex-direction:column; gap:6px; padding:18px 0; border-bottom:1px solid rgba(255,255,255,.1)
}
.hero-stat:last-of-type{margin-bottom:18px}
.hero-stat strong{font-size:1.5rem}
.hero-stat span{color:rgba(255,255,255,.78)}
.checkatrade-badge{
  display:grid; gap:4px; background:#fff; color:var(--navy); padding:20px; border-radius:22px;
  box-shadow:inset 0 0 0 2px var(--red);
}
.badge-top,.badge-bottom{font-size:.82rem; text-transform:uppercase; letter-spacing:.12em; font-weight:800; color:var(--muted)}
.checkatrade-badge strong{font-size:1.6rem}

.section{padding:88px 0}
.section-alt{background:var(--bg)}
.section-dark{
  background:linear-gradient(180deg, #101d45 0%, #0a1532 100%);
  color:#fff;
}
.section-heading{max-width:760px; margin-bottom:34px}
.section-heading h2, .intro-grid h2, .map-grid h2, .cta-grid h2, .prose h2{
  font-size:clamp(1.9rem, 3vw, 3rem); line-height:1.05; margin:10px 0 12px; letter-spacing:-.03em;
}
.section-heading p, .intro-grid p, .map-grid p, .cta-grid p, .prose p{color:var(--muted)}
.section-heading.light p{color:rgba(255,255,255,.72)}
.intro-grid{
  display:grid; grid-template-columns:1.1fr .9fr; gap:34px; align-items:start;
}
.feature-panel{
  display:grid; gap:18px;
}
.feature-box{
  background:#fff; border:1px solid var(--line); padding:24px; border-radius:22px; box-shadow:var(--shadow); position:relative;
}
.feature-box::before{
  content:""; position:absolute; left:0; top:18px; bottom:18px; width:3px; background:var(--red); border-radius:999px;
}
.feature-box strong{display:block; color:var(--navy); margin-bottom:6px; padding-left:14px}
.feature-box span{display:block; padding-left:14px; color:var(--muted)}

.card-grid, .area-grid{
  display:grid; grid-template-columns:repeat(3, minmax(0,1fr)); gap:20px;
}
.service-card, .area-card{
  background:#fff; border:1px solid var(--line); border-radius:24px; padding:24px; box-shadow:var(--shadow);
  transition:transform .2s ease, border-color .2s ease, box-shadow .2s ease;
}
.service-card:hover, .area-card:hover{transform:translateY(-6px); border-color:rgba(209,27,43,.35)}
.service-card h3, .area-card h3{margin:0 0 8px; font-size:1.2rem}
.service-card p, .area-card p{margin:0 0 16px; color:var(--muted)}
.service-card span, .area-card span{font-weight:800; color:var(--navy)}

.review-slider{
  position:relative; display:grid; grid-template-columns:auto 1fr auto; gap:18px; align-items:center;
}
.slides{
  position:relative; min-height:280px;
}
.review-slide{
  display:none; background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.12); padding:34px; border-radius:28px;
  box-shadow:var(--shadow);
}
.review-slide.active{display:block}
.review-slide p{font-size:1.15rem; line-height:1.8; color:rgba(255,255,255,.92); margin:0 0 18px}
.review-meta strong{display:block; font-size:1.05rem}
.review-meta span{color:rgba(255,255,255,.68)}
.slider-btn{
  width:52px; height:52px; border-radius:50%; border:1px solid rgba(255,255,255,.18);
  background:rgba(255,255,255,.08); color:#fff; font-size:32px; cursor:pointer;
}
.review-dots{display:flex; gap:10px; justify-content:center; margin-top:20px}
.review-dots button{
  width:11px; height:11px; border-radius:50%; border:0; background:rgba(255,255,255,.28); cursor:pointer;
}
.review-dots button.active{background:#fff}

.map-grid{
  display:grid; grid-template-columns:.9fr 1.1fr; gap:28px; align-items:stretch;
}
.map-frame{
  background:#fff; border:1px solid var(--line); border-radius:28px; overflow:hidden; min-height:460px; box-shadow:var(--shadow)
}
.map-frame iframe{width:100%; height:100%; min-height:460px; border:0}

.cta-section{background:var(--bg)}
.cta-grid{
  display:grid; grid-template-columns:.85fr 1.15fr; gap:28px; align-items:start;
}
.lead-form{
  background:#fff; border:1px solid var(--line); border-radius:28px; padding:24px; box-shadow:var(--shadow);
  display:grid; grid-template-columns:1fr 1fr; gap:14px;
}
.lead-form input, .lead-form textarea{
  width:100%; border:1px solid var(--line); border-radius:16px; min-height:54px; padding:0 16px; font:inherit; outline:none;
}
.lead-form textarea{grid-column:1/-1; min-height:150px; padding:14px 16px; resize:vertical}
.lead-form button, .lead-form .form-note{grid-column:1/-1}
.form-note{margin:0; color:var(--muted)}

.subhero{
  padding:84px 0 34px;
  background:linear-gradient(180deg, #f8f9ff 0%, #ffffff 100%);
  border-bottom:1px solid var(--line)
}
.prose{max-width:820px}
.inline-cta{margin-top:20px}

.site-footer{
  background:#09142f; color:#fff; padding-top:56px;
}
.footer-grid{
  display:grid; grid-template-columns:1fr .7fr .8fr; gap:28px; align-items:start;
}
.footer-logo{height:66px; width:auto; margin-bottom:12px}
.site-footer h4{margin:0 0 12px}
.site-footer ul{margin:0; padding:0; list-style:none}
.site-footer li{margin:0 0 10px}
.site-footer p, .site-footer a{color:rgba(255,255,255,.82)}
.footer-bottom{padding:18px 0 30px; border-top:1px solid rgba(255,255,255,.1); margin-top:24px}

.sticky-bar{
  position:fixed; left:50%; transform:translateX(-50%); bottom:14px; z-index:50;
  display:flex; gap:12px; background:rgba(9,20,47,.95); padding:10px; border-radius:999px; box-shadow:0 18px 40px rgba(9,20,47,.3);
}
.sticky-bar a{
  color:#fff; padding:10px 16px; font-weight:800; border-radius:999px;
}
.sticky-bar a:first-child{background:var(--red)}
.sticky-bar a:last-child{background:var(--navy)}

@media (max-width: 980px){
  .hero-grid, .intro-grid, .map-grid, .cta-grid, .footer-grid, .card-grid, .area-grid{grid-template-columns:1fr}
  .trust-points{grid-template-columns:1fr}
  .lead-form{grid-template-columns:1fr}
  .brand img{height:54px}
}
@media (max-width: 760px){
  .mobile-toggle{display:block}
  .site-nav{
    position:absolute; right:16px; top:76px; background:#fff; border:1px solid var(--line); border-radius:20px; padding:16px;
    box-shadow:var(--shadow); display:none; flex-direction:column; align-items:flex-start; min-width:220px;
  }
  .site-nav.open{display:flex}
  .hero{padding-top:54px}
  .hero h1, .subhero h1{max-width:none}
  .review-slider{grid-template-columns:1fr}
  .slider-btn{display:none}
  .sticky-bar{left:12px; right:12px; transform:none; justify-content:space-between}
}
