
:root {
  --primary: #b91c1c;
  --secondary: #0284c7;
  --accent: #f97316;
  --bg: #f8fafc;
  --surface: #ffffff;
  --text: #1f2937;
  --muted: #6b7280;
  --radius: 12px;
  --shadow: 0 18px 50px rgba(185, 28, 28, .13);
  --max: 1180px;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: Inter, Arial, Helvetica, sans-serif;
  background: var(--bg);
  color: var(--text);
  line-height: 1.65;
}
a { color: var(--primary); }
.container { width: min(var(--max), 92%); margin: auto; }
.skip { position:absolute; left:-999px; top:auto; }
.skip:focus { left:1rem; top:1rem; background:#fff; padding:.7rem; z-index:9999; }

.topbar {
  background: var(--primary);
  color: #fff;
  font-size: .95rem;
}
.topbar-inner {
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:1rem;
  padding:.65rem 0;
}
.topbar a { color:#fff; text-decoration:none; font-weight:900; }

.site-header {
  background: rgba(255,255,255,.94);
  backdrop-filter: blur(14px);
  position: sticky;
  top:0;
  z-index:20;
  border-bottom:1px solid rgba(15,23,42,.08);
}
.header-dark .site-header { background: #0b1120; }
.header-dark .menu a, .header-dark .logo { color:#fff; }
.header-floating .site-header {
  top: .75rem;
  width: min(var(--max), 92%);
  margin: .75rem auto 0;
  border-radius: 999px;
  box-shadow: var(--shadow);
}
.header-block .site-header {
  border-bottom: 6px solid var(--secondary);
}

.nav {
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:1rem;
  padding:1rem 0;
}
.header-floating .nav { padding:.75rem 1.15rem; }
.logo {
  display:flex;
  align-items:center;
  gap:.65rem;
  font-weight:950;
  font-size:1.15rem;
  color:var(--primary);
  text-decoration:none;
  letter-spacing:-.02em;
}
.logo-mark {
  width:38px;
  height:38px;
  display:inline-grid;
  place-items:center;
  border-radius:12px;
  background:linear-gradient(135deg,var(--primary),var(--accent));
  color:#fff;
  font-weight:950;
}
.site-logo-img {
  width:44px;
  height:44px;
  object-fit:cover;
  border-radius:12px;
  box-shadow:0 8px 22px rgba(0,0,0,.12);
}
.menu {
  display:flex;
  gap:.8rem;
  align-items:center;
  flex-wrap:wrap;
}
.menu a {
  text-decoration:none;
  color:var(--text);
  font-weight:850;
  font-size:.95rem;
}
.menu .nav-cta {
  background:var(--secondary);
  color:#111;
  padding:.65rem .9rem;
  border-radius:999px;
}
.has-dropdown { position:relative; }
.has-dropdown .dropdown-trigger { display:inline-flex; align-items:center; gap:.25rem; }
.has-dropdown .caret { font-size:.7em; transition:transform .15s ease; }
.has-dropdown:hover .caret,
.has-dropdown:focus-within .caret { transform:rotate(180deg); }
.dropdown {
  position:absolute;
  top:100%;
  left:0;
  z-index:60;
  display:none;
  min-width:240px;
  max-height:70vh;
  overflow-y:auto;
  padding:.5rem;
  margin-top:.4rem;
  background:var(--surface);
  border:1px solid rgba(0,0,0,.08);
  border-radius:var(--radius);
  box-shadow:var(--shadow);
}
.has-dropdown:hover .dropdown,
.has-dropdown:focus-within .dropdown { display:block; }
.dropdown a {
  display:block;
  padding:.55rem .7rem;
  border-radius:10px;
  color:var(--text);
  font-size:.9rem;
  font-weight:700;
  white-space:nowrap;
}
.dropdown a:hover { background:var(--bg); color:var(--primary); }
.dropdown .dropdown-all {
  font-weight:850;
  color:var(--primary);
  border-bottom:1px solid rgba(0,0,0,.08);
  border-radius:10px 10px 0 0;
  margin-bottom:.25rem;
}
.header-dark .dropdown a { color:var(--text); }
.header-dark .dropdown .dropdown-all { color:var(--primary); }
.nav-toggle {
  position:absolute;
  width:1px;
  height:1px;
  opacity:0;
  pointer-events:none;
  margin:0;
}
.nav-toggle:focus-visible ~ .menu-toggle {
  outline:3px solid var(--secondary);
  outline-offset:2px;
}
.menu-toggle {
  display:none;
  width:46px;
  height:46px;
  cursor:pointer;
  align-items:center;
  justify-content:center;
  border-radius:12px;
  border:1px solid rgba(15,23,42,.12);
  color:var(--text);
  background:transparent;
}
.header-dark .menu-toggle { color:#fff; border-color:rgba(255,255,255,.25); }
.menu-toggle-bars,
.menu-toggle-bars::before,
.menu-toggle-bars::after {
  content:"";
  display:block;
  width:22px;
  height:2px;
  background:currentColor;
  border-radius:2px;
  transition:transform .2s ease, opacity .2s ease;
}
.menu-toggle-bars { position:relative; }
.menu-toggle-bars::before { position:absolute; top:-7px; left:0; }
.menu-toggle-bars::after { position:absolute; top:7px; left:0; }

.hero {
  position:relative;
  overflow:hidden;
  padding:5rem 0 4rem;
  background:
    radial-gradient(circle at 80% 20%, color-mix(in srgb, var(--secondary) 18%, transparent), transparent 30%),
    linear-gradient(135deg, var(--bg), var(--surface));
}
.hero::before {
  content:"";
  position:absolute;
  inset:auto -8rem -10rem auto;
  width:26rem;
  height:26rem;
  border-radius:999px;
  background: color-mix(in srgb, var(--primary) 12%, transparent);
}
.layout-dark .hero,
.layout-premium .hero {
  background:
    radial-gradient(circle at 75% 20%, color-mix(in srgb, var(--secondary) 25%, transparent), transparent 32%),
    linear-gradient(135deg, #020617, #111827);
  color:#fff;
}
.layout-emergency .hero {
  background:
    linear-gradient(135deg, color-mix(in srgb, var(--primary) 90%, #111), var(--primary));
  color:#fff;
}
.layout-banner .hero {
  text-align:center;
  border-bottom:8px solid var(--secondary);
}
.layout-industrial .hero {
  background:
    repeating-linear-gradient(135deg, rgba(0,0,0,.035) 0 10px, transparent 10px 20px),
    linear-gradient(135deg, var(--surface), var(--bg));
}
.layout-metro .hero {
  background:
    linear-gradient(135deg, color-mix(in srgb, var(--primary) 12%, var(--bg)), var(--surface));
}
.hero-inner {
  position:relative;
  display:grid;
  grid-template-columns: 1.08fr .92fr;
  gap:2rem;
  align-items:center;
}
.layout-banner .hero-inner {
  display:block;
  max-width:900px;
  text-align:center;
}
.layout-boxed .hero-card,
.layout-soft .hero-card,
.layout-split-card .hero-card {
  background:rgba(255,255,255,.92);
  padding:2rem;
  border-radius:var(--radius);
  box-shadow:var(--shadow);
}
.layout-dark .hero-card,
.layout-premium .hero-card,
.layout-emergency .hero-card {
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.15);
  color:#fff;
}
.eyebrow {
  display:inline-flex;
  align-items:center;
  gap:.45rem;
  color:var(--secondary);
  font-weight:950;
  text-transform:uppercase;
  letter-spacing:.08em;
  font-size:.82rem;
}
h1 {
  font-size:clamp(2.35rem,5.8vw,4.75rem);
  line-height:1;
  margin:.6rem 0 1rem;
  letter-spacing:-.055em;
}
h2 {
  font-size:clamp(1.55rem,3vw,2.25rem);
  line-height:1.16;
  letter-spacing:-.035em;
  margin-top:2.2rem;
}
h3 { line-height:1.25; letter-spacing:-.02em; }
.lead {
  font-size:1.22rem;
  color:var(--muted);
  max-width:68ch;
}
.layout-dark .lead,
.layout-premium .lead,
.layout-emergency .lead { color:rgba(255,255,255,.82); }

.btn {
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:.4rem;
  background:var(--primary);
  color:#fff!important;
  text-decoration:none;
  padding:.95rem 1.2rem;
  border-radius:999px;
  font-weight:950;
  margin:.35rem .45rem .35rem 0;
  box-shadow:0 14px 30px color-mix(in srgb, var(--primary) 24%, transparent);
}
.btn.secondary {
  background:var(--secondary);
  color:#111!important;
}
.btn.ghost {
  background:transparent;
  border:2px solid currentColor;
  box-shadow:none;
}
.hero-panel {
  background:var(--surface);
  border-radius:var(--radius);
  box-shadow:var(--shadow);
  padding:1.4rem;
  border:1px solid rgba(15,23,42,.08);
}
.layout-dark .hero-panel,
.layout-premium .hero-panel,
.layout-emergency .hero-panel {
  background:rgba(255,255,255,.1);
  border:1px solid rgba(255,255,255,.18);
  color:#fff;
}
.quick-list {
  display:grid;
  gap:.75rem;
  margin-top:1rem;
}
.quick-list span {
  display:flex;
  gap:.65rem;
  align-items:flex-start;
}
.quick-list span::before {
  content:"✓";
  display:inline-grid;
  place-items:center;
  width:1.4rem;
  height:1.4rem;
  border-radius:999px;
  background:var(--secondary);
  color:#111;
  font-weight:950;
  flex:0 0 auto;
}

.trust-strip {
  transform:translateY(-50%);
  position:relative;
  z-index:3;
}
.trust-strip-inner {
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:0;
  background:var(--surface);
  box-shadow:var(--shadow);
  border-radius:var(--radius);
  overflow:hidden;
  border:1px solid rgba(15,23,42,.08);
}
.trust-item {
  padding:1.1rem;
  border-right:1px solid rgba(15,23,42,.08);
}
.trust-item:last-child { border-right:0; }
.trust-item strong { display:block; font-size:1rem; }
.trust-item span { color:var(--muted); font-size:.92rem; }

.section { padding:3.75rem 0; }
.section.alt { background:var(--surface); }
.related-links { background:var(--surface); }
.related-links-list {
  list-style:none;
  margin:1rem 0 0;
  padding:0;
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(220px,1fr));
  gap:.6rem;
}
.related-links-list a {
  display:block;
  padding:.85rem 1rem;
  background:var(--bg);
  border:1px solid rgba(0,0,0,.06);
  border-radius:var(--radius);
  text-decoration:none;
  color:var(--primary);
  font-weight:600;
}
.related-links-list a:hover { background:var(--surface); }
.grid {
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:1rem;
}
.grid.two { grid-template-columns:repeat(2,1fr); }
.card {
  background:var(--surface);
  border:1px solid rgba(15,23,42,.08);
  border-radius:var(--radius);
  padding:1.35rem;
  box-shadow:0 10px 30px rgba(15,23,42,.045);
}
.card:hover {
  transform:translateY(-2px);
  transition:.2s ease;
  box-shadow:var(--shadow);
}
.alt .card { background:var(--bg); }
.service-card h3,
.service-card h2 { margin-top:0; }
.service-card a { text-decoration:none; }
.content {
  max-width:920px;
}
.content-image{display:block;width:100%;height:auto;margin:0 0 1.5rem;border-radius:var(--radius);box-shadow:var(--shadow);}
.hero-photo{
  display:block;
  width:100%;
  height:auto;
  aspect-ratio:3 / 2;
  object-fit:cover;
  border-radius:var(--radius);
  box-shadow:var(--shadow);
  margin:0 0 1.1rem;
}
.content p,
.content li {
  font-size:1.055rem;
}
.content > p:first-child {
  font-size:1.16rem;
  color:var(--muted);
}
.content ul,
.content ol {
  padding-left:1.35rem;
}
.content blockquote {
  margin:2rem 0;
  padding:1.2rem 1.4rem;
  border-left:6px solid var(--secondary);
  background:var(--surface);
  border-radius:0 var(--radius) var(--radius) 0;
}
.split-section {
  display:grid;
  grid-template-columns:1fr .85fr;
  gap:2rem;
  align-items:start;
}
.sidebar-box {
  position:sticky;
  top:7rem;
  background:linear-gradient(135deg,var(--primary),color-mix(in srgb,var(--primary) 70%,#000));
  color:#fff;
  padding:1.4rem;
  border-radius:var(--radius);
  box-shadow:var(--shadow);
}
.sidebar-box a { color:#fff; }

.cta-band {
  background:
    radial-gradient(circle at 85% 20%, color-mix(in srgb,var(--secondary) 30%,transparent), transparent 28%),
    linear-gradient(135deg,var(--primary),color-mix(in srgb,var(--primary) 80%,#000));
  color:#fff;
}
.cta-band .container {
  display:flex;
  justify-content:space-between;
  gap:2rem;
  align-items:center;
}
.cta-band p { color:rgba(255,255,255,.82); }

.form {
  display:grid;
  gap:.85rem;
}
.form input,
.form textlocation {
  width:100%;
  padding:.9rem;
  border:1px solid rgba(15,23,42,.14);
  border-radius:calc(var(--radius) / 1.8);
  font:inherit;
}
.map iframe {
  width:100%;
  min-height:420px;
  border:0;
  border-radius:var(--radius);
}

.footer {
  background:#0b1120;
  color:#dbeafe;
  padding:3.25rem 0 1rem;
}
.footer a { color:#fff; text-decoration:none; }
.footer-grid {
  display:grid;
  grid-template-columns:1.25fr 1fr 1fr;
  gap:2rem;
}
.footer ul { list-style:none; padding:0; margin:0; }
.footer li { margin:.45rem 0; }
.smallprint {
  margin-top:2rem;
  padding-top:1rem;
  border-top:1px solid rgba(255,255,255,.14);
  color:#94a3b8;
  font-size:.92rem;
}

@media(max-width:900px) {
  .topbar-inner,
  .hero-inner,
  .grid,
  .grid.two,
  .split-section,
  .footer-grid,
  .cta-band .container,
  .trust-strip-inner {
    display:block;
  }
  .nav {
    display:flex;
    flex-wrap:wrap;
    align-items:center;
    justify-content:space-between;
  }
  .menu-toggle { display:flex; }
  .header-floating .site-header {
    width:100%;
    margin:0;
    border-radius:0;
  }
  .menu {
    order:5;
    flex-basis:100%;
    width:100%;
    margin-top:1rem;
    display:none;
    grid-template-columns:1fr;
    gap:.5rem;
    max-height:calc(100vh - 130px);
    overflow-y:auto;
  }
  .nav-toggle:checked ~ .menu { display:grid; }
  .nav-toggle:checked ~ .menu-toggle .menu-toggle-bars { background:transparent; }
  .nav-toggle:checked ~ .menu-toggle .menu-toggle-bars::before { top:0; transform:rotate(45deg); }
  .nav-toggle:checked ~ .menu-toggle .menu-toggle-bars::after { top:0; transform:rotate(-45deg); }
  .menu a {
    padding:.45rem 0;
  }
  .has-dropdown { position:static; }
  .dropdown {
    position:static;
    display:block;
    min-width:0;
    max-height:none;
    margin:.25rem 0 .5rem .9rem;
    padding:.35rem;
    box-shadow:none;
    border:1px solid rgba(0,0,0,.08);
    border-radius:12px;
    background:var(--surface);
  }
  .has-dropdown .caret { display:none; }
  .trust-strip {
    transform:none;
    margin-top:1rem;
  }
  .trust-item {
    border-right:0;
    border-bottom:1px solid rgba(15,23,42,.08);
  }
  .hero {
    padding:3rem 0;
  }
  .sidebar-box {
    position:static;
    margin-top:1.5rem;
  }
}
