:root{
  --blue-900:#063a68;
  --blue-800:#0a4f8a;
  --blue-700:#0c5ea7;
  --orange:#f59e0b;
  --orange-2:#fb923c;
  --bg:#f2f5f9;
  --card:#ffffff;
  --ink:#0f172a;
  --muted:#475569;
  --border:#dbe3ee;
  --shadow:0 10px 26px rgba(2,6,23,.10);
  --radius:14px;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
  background:var(--bg);
  color:var(--ink);
  line-height:1.55;
}
a{color:inherit}
.container{max-width:1100px;margin:0 auto;padding:0 18px}

/* HEADER */
.header{
  background:#fff;
  border-bottom:1px solid var(--border);
}
.header .row{
  display:flex;align-items:center;justify-content:space-between;gap:14px;
  padding:12px 0;
}
.brand{display:flex;align-items:center;gap:12px;text-decoration:none}
.brand img{height:72px;width:auto;display:block}
.phone-pill{
  display:inline-flex;align-items:center;gap:10px;
  padding:10px 14px;
  border-radius:999px;
  background:linear-gradient(180deg,var(--orange),var(--orange-2));
  color:#fff;
  text-decoration:none;
  font-weight:900;
  box-shadow:0 8px 18px rgba(245,158,11,.35);
  border:1px solid rgba(255,255,255,.25);
}
.phone-pill small{display:block;font-weight:800;opacity:.92}
.phone-pill .icon{font-size:18px}
.phone-pill .phone-text{white-space:nowrap}
.phone-pill .num{white-space:nowrap}

/* HERO BAND */
.hero-band{
  background:linear-gradient(180deg,var(--blue-800),var(--blue-900));
  color:#fff;
  padding:26px 0 18px;
}
.hero-band .title{
  font-size:clamp(22px,2.8vw,34px);
  font-weight:900;
  margin:0 0 8px;
}
.hero-band .subtitle{
  margin:0;
  opacity:.95;
  color:#eaf2ff;
  font-weight:650;
}
.hero-band .subline{
  margin:10px 0 0;
  opacity:.92;
  color:#d7e8ff;
  font-size:14px;
}

/* MAIN */
.main{
  padding:16px 0 34px;
}
.grid{
  display:grid;
  grid-template-columns: 1.25fr .75fr;
  gap:16px;
}
@media(max-width:980px){.grid{grid-template-columns:1fr}}

.card{
  background:var(--card);
  border:1px solid var(--border);
  border-radius:var(--radius);
  box-shadow:var(--shadow);
}
.card.pad{padding:16px}
.h2{margin:0 0 10px;font-size:22px;font-weight:900;color:#0b1b2c}
.p{margin:0 0 12px;color:var(--muted)}

.services{
  display:grid;
  grid-template-columns: repeat(5, 1fr);
  gap:10px;
}
@media(max-width:980px){.services{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.services{grid-template-columns:1fr}}
.service{
  text-align:center;
  padding:12px 10px;
  border-radius:12px;
  border:1px solid var(--border);
  background:linear-gradient(180deg,#fff,#f7fbff);
}
.service .ico{
  width:100%;
  height:90px;
  margin:0 auto 8px;
  border-radius:12px;
  overflow:hidden;
  display:flex;align-items:center;justify-content:center;
  background:linear-gradient(180deg,#ffffff,#f4f8ff);
  border:1px solid #d6e8ff;
}
.service .ico img{
  width:100%;
  height:100%;
  object-fit:contain;
  display:block;
}
.service b{display:block;font-size:13px}
.service small{display:block;color:var(--muted);font-size:12px}

.cta{
  display:flex;align-items:center;justify-content:center;gap:10px;
  margin-top:14px;
  padding:12px 14px;
  border-radius:999px;
  background:linear-gradient(180deg,var(--blue-700),var(--blue-900));
  color:#fff;
  text-decoration:none;
  font-weight:900;
  box-shadow:0 10px 24px rgba(6,58,104,.25);
  border:1px solid rgba(255,255,255,.18);
}

/* FLOATING CONTACT BUTTONS (mobile-first usability) */
.float-actions{
  position:fixed;
  right:14px;
  bottom:14px;
  display:flex;
  flex-direction:column;
  gap:10px;
  z-index:9999;
}
.float-btn{
  display:flex;
  align-items:center;
  gap:10px;
  padding:12px 14px;
  border-radius:999px;
  text-decoration:none;
  color:#fff;
  font-weight:900;
  box-shadow:0 14px 26px rgba(2,6,23,.18);
  border:1px solid rgba(255,255,255,.18);
  backdrop-filter:saturate(1.2);
}
.float-ico{font-size:18px;line-height:1}
.float-txt{white-space:nowrap;font-size:13px}
.float-btn--wa{background:linear-gradient(180deg,#22c55e,#16a34a)}
.float-btn--call{background:linear-gradient(180deg,var(--orange),var(--orange-2))}
.float-btn--fix{background:linear-gradient(180deg,var(--blue-700),var(--blue-900))}

/* On desktop keep subtle (still available) */
@media(min-width:980px){
  .float-actions{right:18px;bottom:18px}
  .float-btn{opacity:.92}
  .float-btn:hover{opacity:1;transform:translateY(-1px)}
}

.form label{display:block;font-weight:800;margin:10px 0 6px;color:#102a43}
input,select,textarea{
  width:100%;
  padding:11px 12px;
  border-radius:12px;
  border:1px solid var(--border);
  font:inherit;
  background:#fff;
}
textarea{min-height:120px;resize:vertical}
.form .row2{display:grid;grid-template-columns:1fr 1fr;gap:10px}
@media(max-width:700px){.form .row2{grid-template-columns:1fr}}
.btn{
  width:100%;
  margin-top:10px;
  padding:12px 14px;
  border-radius:12px;
  border:none;
  background:linear-gradient(180deg,var(--orange),var(--orange-2));
  color:#fff;
  font-weight:900;
  cursor:pointer;
  box-shadow:0 10px 22px rgba(245,158,11,.28);
}
.bullets{margin:10px 0 0;padding:0 0 0 16px;color:#24425f}
.bullets li{margin:6px 0}
.small{font-size:12px;color:var(--muted);margin-top:10px}

.footer{
  padding:18px 0 40px;
  color:#5b7288;
  font-size:13px;
}
.footer a{color:#5b7288}

/* --- Enhancements v5 (responsive + onepage conversion) --- */
.container{max-width:1200px}

.header-actions{display:flex;align-items:center;gap:10px;flex-wrap:wrap;justify-content:flex-end}
.phone-pill{white-space:nowrap}
.phone-text{font-weight:900}
.phone-text .num{letter-spacing:.2px}
.phone-pill--secondary{
  background:linear-gradient(180deg,#2b73c6,#0a4f8a);
  box-shadow:0 8px 18px rgba(10,79,138,.25);
}
@media(max-width:640px){
  .brand img{height:42px}
  .header .row{gap:10px}
  .header-actions{width:100%;justify-content:space-between}
  .phone-pill{padding:9px 12px;font-size:14px}
}

.services-block{padding:18px 0 8px}
.services-head{margin-bottom:10px}

/* Make service cards more tappable on mobile */
.service{transition:transform .12s ease, box-shadow .12s ease}
.service:hover{transform:translateY(-1px)}
.service .ico{height:96px}
@media(max-width:980px){.service .ico{height:110px}}

.cta-row{display:flex;gap:10px;flex-wrap:wrap;margin-top:14px}
.cta-row .cta{flex:1;min-width:220px}
.cta--outline{
  background:#fff;
  color:var(--blue-900);
  border:1px solid #cfe2ff;
  box-shadow:none;
}

.trust-row{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-top:14px}
.trust{border:1px solid var(--border);border-radius:12px;padding:10px 12px;background:linear-gradient(180deg,#fff,#f8fbff)}
.trust b{display:block}
.trust span{display:block;color:var(--muted);font-size:13px;margin-top:2px}
@media(max-width:900px){.trust-row{grid-template-columns:1fr}}

.brandbox{margin-top:14px;border-top:1px dashed #d8e6f5;padding-top:12px}
.h3{margin:0 0 6px;font-size:18px;font-weight:900;color:#0b1b2c}

/* Contact section split */
.contact-block{padding:10px 0 22px}
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;align-items:stretch}
@media(max-width:980px){.contact-grid{grid-template-columns:1fr}}

.contact-media{position:relative;border-radius:12px;overflow:hidden;border:1px solid #d6e8ff;background:#eef6ff;min-height:320px}
.contact-media img{width:100%;height:100%;object-fit:cover;display:block}
.contact-media .badge{
  position:absolute;left:12px;bottom:12px;
  background:rgba(6,58,104,.92);
  color:#fff;font-weight:900;
  padding:8px 10px;border-radius:999px;
  border:1px solid rgba(255,255,255,.25);
}

.quick-calls{display:flex;gap:10px;flex-wrap:wrap;margin:8px 0 6px}
.quick{
  display:inline-flex;align-items:center;gap:8px;
  padding:10px 12px;border-radius:12px;
  background:#f3f7ff;border:1px solid #d6e8ff;
  text-decoration:none;font-weight:900;color:#0b2b4a;
  white-space:nowrap;
}
@media(max-width:520px){.quick{width:100%;justify-content:center}}

/* FAQ */
.faq-block{padding:8px 0 34px}
.faq{border:1px solid var(--border);border-radius:12px;padding:10px 12px;background:#fff;margin:10px 0}
.faq summary{cursor:pointer;font-weight:900;color:#0b2b4a}
.faq p{margin:8px 0 0;color:var(--muted)}

/* Remove legacy grid spacing if any pages still use it */
.grid{grid-template-columns:1fr}


/* v5 logo sizing + layout */
@media(max-width:720px){
  .brand img{height:56px}
  .header .row{padding:10px 0}
  .phone-pill{padding:9px 12px}
  .phone-pill .phone-text{font-size:13px}
}

/* v5 how + areas */
.how{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
@media(max-width:980px){.how{grid-template-columns:1fr}}
.how-step{border:1px solid var(--border);border-radius:12px;padding:12px;background:linear-gradient(180deg,#fff,#f7fbff)}
.how-step p{margin:6px 0 0;color:var(--muted)}
.areas{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
@media(max-width:980px){.areas{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.areas{grid-template-columns:1fr}}
.area{border:1px solid var(--border);border-radius:12px;padding:10px 12px;background:#fff}
.area b{display:block}
.area span{display:block;color:var(--muted);font-size:13px}


/* --- SEO pages extras --- */
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin:16px 0}
@media (max-width: 900px){.grid-2{grid-template-columns:1fr}}
.steps{margin:0;padding-left:18px}
.steps li{margin:10px 0}
.steps span{color:#4b5563}
.areas{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
@media (max-width: 900px){.areas{grid-template-columns:1fr}}
.areas__item{background:#f8fafc;border:1px solid #e5e7eb;border-radius:12px;padding:12px}
.faq-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
@media (max-width: 900px){.faq-grid{grid-template-columns:1fr}}
.faq{border:1px solid #e5e7eb;border-radius:12px;background:#fff;padding:10px}
.faq summary{cursor:pointer;font-weight:700}
.faq-a{padding-top:8px;color:#374151}
.linklist{margin:0;padding-left:18px}
.linklist li{margin:6px 0}
.topnav{display:flex;gap:14px;align-items:center;margin-left:12px}
.topnav a{color:#0b3a77;text-decoration:none;font-weight:600}
@media (max-width: 900px){.topnav{display:none}}


/* logo-size-override */
.brand img{height:84px;width:auto;max-width:none;}
@media (max-width: 992px){.brand img{height:64px;}}
@media (max-width: 576px){.brand img{height:56px;}}

/* city chips */
.city-chips{display:flex;flex-wrap:wrap;gap:8px;align-items:center;margin:10px 0 16px;}
.city-chips__label{font-weight:700;color:var(--muted);}
.city-chips .chip{display:inline-block;padding:6px 10px;border-radius:999px;background:#fff;border:1px solid rgba(0,0,0,.08);text-decoration:none;color:inherit;font-weight:600;font-size:14px;}
.city-chips .chip:hover{border-color:rgba(0,0,0,.18);}

/* AI answer engine snippet */
.ai-snippet{padding:18px 0;}
.ai-snippet__box{background:#fff;border:1px solid rgba(0,0,0,.08);border-radius:16px;padding:18px;box-shadow:0 10px 25px rgba(0,0,0,.06);}
.ai-snippet__list{margin:10px 0 0;padding-left:18px;}
.ai-snippet__list li{margin:6px 0;}


/* --- SEO/UX fixes --- */
html{font-size:16px}
.phone-pill{white-space:nowrap}
.brand img{height:84px!important}
@media (max-width:768px){.brand img{height:60px!important}}
/* increase tap targets */
a, button{min-height:44px}
.topnav a{padding:12px 14px}


/* MOBILE-UX-PATCH */
:root{font-size:16px;}
.phone-pill{min-height:44px;}
.fab a{min-width:52px;min-height:52px;}
.brand img{height:84px!important;}
@media (max-width: 768px){.brand img{height:60px!important;}}
