/* --- Design tokens & base --- */
:root{--bg:#f6f9ff;--paper:#fff;--ink:#0f172a;--muted:#64748b;--blue-600:#1d4ed8;--ring:rgba(37,99,235,.20);--radius:16px;--shadow:0 18px 40px rgba(15,23,42,.12);--shadow-soft:0 10px 24px rgba(0,0,0,.08);--maxw:1180px}
*{box-sizing:border-box}
html,body{height:100%}
body{margin:0;font-family:Inter, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial;color:var(--ink);background:linear-gradient(180deg,#eff4ff 0%,#f9fbff 60%,#fff 100%);line-height:1.65;font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.container{max-width:var(--maxw);margin-inline:auto;padding:18px}

/* --- Header --- */
.site-header{background:#fff;border-bottom:1px solid #e5e7eb;position:sticky;top:0;z-index:40}
.nav{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:16px}
.brand{display:inline-flex;align-items:center;gap:10px;font-weight:800}
.brand-name{font-weight:800;font-size:20px}
.logo{width:26px;height:26px;color:var(--blue-600)}
.main-nav{display:flex;gap:24px;justify-content:center}
.nav-link{color:#111827}
.nav-link:hover{color:var(--blue-600)}
.nav-cta{display:flex;align-items:center;gap:12px}
.phone{display:inline-flex;align-items:center;gap:8px;padding:8px 10px;color:#111827}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.6rem;border-radius:999px;padding:.6rem 1rem;font-weight:800;border:1px solid transparent;transition:.15s ease filter,.1s ease transform}
.btn:hover{filter:brightness(.98);transform:translateY(-1px)}
.btn-emergency{background:#0f172a;color:#fff}

/* --- Icons (SVG) --- */
.icon{width:18px;height:18px;display:inline-block;vertical-align:middle;flex:0 0 18px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.star{width:16px;height:16px;color:#f59e0b;display:inline-block}

/* --- Hero --- */
.hero{padding:56px 0 48px}
.hero-wrap{display:grid;grid-template-columns:1.05fr .95fr;gap:34px;align-items:center}
.pill{display:inline-block;font-size:12px;background:#eef2ff;color:#1e3a8a;padding:6px 10px;border-radius:999px;border:1px solid #e0e7ff}
.hero-title{font-weight:900;font-size:clamp(34px,6.4vw,64px);line-height:1.08;letter-spacing:.2px;margin:10px 0 10px;color:#0b1220}
.hero-lead{color:var(--muted);max-width:640px}
.hero-ctas{display:flex;gap:12px;margin:18px 0 12px;flex-wrap:wrap}
.btn-primary-lg{background:var(--blue-600);color:#fff;padding:.8rem 1.2rem;border-radius:12px}
.btn-outline-lg{background:#fff;color:var(--ink);border:1.5px solid #d1d5db;padding:.8rem 1.2rem;border-radius:12px}
.hero-bullets{display:flex;gap:22px;flex-wrap:wrap;align-items:center;margin-top:8px}
.bullet{display:inline-flex;align-items:center;gap:8px;color:#111827;font-weight:600}
.hero-right{position:relative}
.hero-photo{border-radius:18px;box-shadow:var(--shadow);background:#f3f4f6;object-fit:cover;width:100%;aspect-ratio:4/3}
.experience-card{position:absolute;bottom:-16px;left:24px;background:#fff;border-radius:12px;box-shadow:var(--shadow-soft);padding:18px 20px;display:flex;flex-direction:column;align-items:center}
.experience-card strong{font-size:28px;color:var(--blue-600)}
.experience-card span{font-size:12px;color:var(--muted)}

/* --- Services --- */
.services{padding:40px 0 70px; background: #f2f6ff;}
.section-intro{text-align:center;max-width:780px;margin:0 auto 18px}
.section-title{font-weight:900;font-size:clamp(28px,4vw,42px);margin:8px 0}
.section-lead{color:var(--muted)}
.card-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-top:18px}
.service-card{background:#fff;border:1px solid #e5e7eb;border-radius:16px;box-shadow:var(--shadow-soft);overflow:hidden;display:flex;flex-direction:column}
.service-media{position:relative;padding:14px 14px 0}
.service-media img{width:100%;height:180px;object-fit:cover;border-radius:12px}
.service-badge{position:absolute;top:10px;left:22px;background:#eef2ff;color:#1e3a8a;border:1px solid #e0e7ff;border-radius:10px;padding:6px 8px;box-shadow:var(--shadow-soft);display:inline-flex;align-items:center}
.service-body{padding:14px 16px 16px}
.service-body h3{margin:6px 0 6px}
.service-body p{margin:0 0 12px;color:var(--muted)}
.service-list{margin:0 0 14px 0; padding-left:18px; list-style:disc; list-style-position:outside}
.service-list li{margin:6px 0}
.btn-subtle{background:#fff;border:1.5px solid #e5e7eb;border-radius:12px;padding:.7rem 1rem;display:inline-flex;align-items:center;gap:8px}

/* --- Banner --- */
.banner{background:#f2f6ff;color:#fff;padding:34px 0}
.banner-inner{display:flex;flex-direction:column;align-items:center;gap:12px;text-align:center;background:#1d4ed8;border-radius:20px;padding:30px 24px;box-shadow:var(--shadow-soft)}
.btn-light{background:#fff;color:#111827;border-radius:12px;padding:.75rem 1.1rem;font-weight:800}

/* --- About --- */
.about{padding:56px 0}
.about-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:22px;align-items:start}
.about-text h2{font-size:clamp(28px,3.8vw,40px);margin:10px 0}
.checklist{columns:2;margin:12px 0 0 0}
.checklist li{margin:8px 0;list-style:none;position:relative;padding-left:24px}
.checklist li::before{content:"";position:absolute;left:4px;top:.6em;width:.55em;height:.55em;border:2px solid #16a34a;border-left:0;border-top:0;transform:rotate(45deg)}
.about-stats{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.stat-card{background:#f8fbff;border:1px solid #e6efff;border-radius:14px;padding:18px;box-shadow:var(--shadow-soft);display:flex;align-items:center;gap:10px}
.stat-card strong{font-size:26px;color:var(--blue-600)}
.stat-card span{color:var(--muted)}
.review-card{grid-column:1/-1;background:linear-gradient(180deg,#fff7e6,#fff);border:1px solid #fde68a;border-radius:14px;padding:18px;box-shadow:var(--shadow-soft)}
.review-card .stars{display:flex;gap:2px}

/* --- Reviews --- */
.reviews{padding:40px 0 20px;background:#f6f8fb}
.review-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:18px}
.review{background:#fff;border:1px solid #e5e7eb;border-radius:16px;box-shadow:var(--shadow-soft);padding:18px}
.review-stars{display:flex;gap:2px}
.review blockquote{margin:0 0 14px;color:#1f2937}
.review-meta{display:flex;align-items:center;gap:10px}
.review-meta span{background:#eef2ff;color:#1e3a8a;border:1px solid #e0e7ff;border-radius:999px;padding:4px 8px;font-size:12px}
.metrics{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin:22px 0 0}
.metric{background:#fff;border:1px solid #e5e7eb;border-radius:16px;padding:20px;box-shadow:var(--shadow-soft);text-align:center}
.metric strong{font-size:28px;color:var(--blue-600)}
.metric span{color:var(--muted)}

/* --- CTA --- */
.cta{padding:56px 0 40px;text-align:center}
.cta-inner{max-width:780px;margin:0 auto}
.cta h2{font-size:clamp(28px,3.8vw,40px);margin:8px 0}
.cta p{color:var(--muted)}

/* --- Contact --- */
.contact{padding:10px 0 70px}
.contact-grid{display:grid;grid-template-columns:1.2fr .8fr;gap:18px;align-items:start}
.form-card{background:#fff;border:1px solid #e5e7eb;border-radius:16px;box-shadow:var(--shadow-soft);padding:18px}
.form{display:grid;gap:12px}
.row.two{display:grid;grid-template-columns:1fr 1fr;gap:12px}
label{display:grid;gap:6px;font-weight:700}
input,select,textarea{width:100%;padding:14px 14px;border-radius:12px;border:1px solid #d1d5db;background:#fff;color:#111827;outline:none;font-size:1rem}
input:focus,select:focus,textarea:focus{border-color:var(--blue-600);box-shadow:0 0 0 6px var(--ring)}
.contact-side{display:grid;gap:16px}
.emergency-card{display:grid;grid-template-columns:auto 1fr;gap:12px;background:#1d4ed8;color:#fff;padding:18px;border-radius:16px;box-shadow:var(--shadow-soft)}
.info-card,.area-card{background:#fff;border:1px solid #e5e7eb;border-radius:16px;box-shadow:var(--shadow-soft);padding:18px}
.info-list{display:grid;gap:12px;margin:0;padding:0;list-style:none}
.info-list li{display:grid;grid-template-columns:auto 1fr;gap:10px;align-items:start}

/* --- Footer --- */
.footer{background:#0b1220;color:#fff;padding:28px 0}
.footer-inner{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap}
.f-brand{display:flex;align-items:center;gap:10px}
.f-links a{color:#cbd5e1;margin-left:12px}
.f-links a:hover{color:#fff}
.muted{color:#64748b}

/* --- Responsive --- */
@media (max-width:1080px){.card-grid{grid-template-columns:repeat(2,1fr)}.about-grid{grid-template-columns:1fr}.review-grid{grid-template-columns:1fr 1fr}.contact-grid{grid-template-columns:1fr}}
@media (max-width:680px){.hero-wrap{grid-template-columns:1fr}.main-nav{display:none}.metrics{grid-template-columns:1fr}.card-grid{grid-template-columns:1fr}.row.two{grid-template-columns:1fr}}

.star{fill:currentColor}

/* HERO ICON COLORS */
.hero-bullets .bullet:nth-child(1) .icon{ color:#16a34a; }   /* green-600 for CheckCircle */
.hero-bullets .bullet:nth-child(2) .icon{ color:#1d4ed8; }   /* blue-600 for Clock */
.hero-bullets .bullet:nth-child(3) .icon{ color:#1d4ed8; }   /* blue-600 for Shield */

/* Service cards: align visuals with new layout */
/* Hide legacy badge overlay */
.services .section-intro{background:transparent;border:none;padding:0}
.service-badge{display:none}

.service-list li::marker{ color:#1d4ed8; }

.banner-icon .icon{width:60px;height:60px}

.banner-text .btn{margin-top:10px}

.banner-icon{display:flex;align-items:center;justify-content:center}
.banner-icon .icon{stroke:#fff;}
.banner-text h3{margin:6px 0 6px}

.about-stats{align-items:stretch}
.stat-card{display:flex;flex-direction:column;align-items:center;text-align:center;gap:8px}
.stat-card .icon{width:28px;height:28px;color:#1d4ed8;margin-bottom:4px}

/* Icon checklist (Lucide) */
.iconlist{columns:2; list-style:none; padding:0; margin:12px 0 0 0}
.iconlist li{break-inside:avoid; display:flex; align-items:flex-start; gap:10px; padding:0; margin:8px 0}
.iconlist .icon{color:#16a34a; width:18px; height:18px; margin-top:2px; stroke-width:2}
/* Remove old pseudo check */
.checklist li::before{content:none}

.review{display:flex;flex-direction:column}
.review blockquote{flex:1}
.review-meta{margin-top:auto;display:flex;align-items:center;gap:10px;justify-content:space-between}
.metrics{align-items:stretch}
.metric{display:flex;flex-direction:column;align-items:center;justify-content:center}

/* Banner icon sizing */
.banner-icon{
  width:40px;
  height:40px;
  border:0px solid #fff;
  border-radius:9999px;
  display:flex;
  align-items:center;
  justify-content:center;
  margin-bottom:8px;
}
.banner-icon .icon{
  width:40px;
  height:40px;
  stroke:#fff;
}

.form-guard {
  position: absolute;
  left: -9999px;
  width: 1px;
  height: 1px;
  overflow: hidden;
}

.form-guard input {
  opacity: 0;
  pointer-events: none;
}
