:root {
  --bg: #030604;
  --bg-soft: #07110b;
  --panel: #0d1811;
  --panel-strong: #132018;
  --text: #f7fff9;
  --muted: #c7d4cb;
  --line: rgba(255, 255, 255, 0.14);
  --green: #078f33;
  --green-bright: #12b84a;
  --red: #c60012;
  --red-dark: #8f000b;
  --white: #ffffff;
  --shadow: 0 24px 70px rgba(0, 0, 0, 0.35);
  font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { margin: 0; background: var(--bg); color: var(--text); font-size: 16px; line-height: 1.6; }
img { display: block; max-width: 100%; height: auto; }
a { color: inherit; }
.skip-link { position: absolute; left: 1rem; top: -4rem; z-index: 10; padding: 0.7rem 1rem; background: var(--red); color: var(--white); border-radius: 6px; }
.skip-link:focus { top: 1rem; }
.container { width: min(1160px, calc(100% - 40px)); margin: 0 auto; }
.site-header { position: sticky; top: 0; z-index: 10; background: rgba(3, 6, 4, 0.92); border-bottom: 1px solid var(--line); backdrop-filter: blur(14px); }
.header-inner { display: grid; grid-template-columns: minmax(160px, 230px) 1fr auto; gap: 1.4rem; align-items: center; min-height: 94px; }
.brand { display: inline-flex; align-items: center; text-decoration: none; }
.brand img { width: 170px; }
.site-nav { display: flex; justify-content: center; gap: 1.5rem; font-size: 0.94rem; color: var(--muted); }
.site-nav a { text-decoration: none; padding: 0.4rem 0; }
.site-nav a:hover, .site-nav a[aria-current="page"] { color: var(--white); }
.header-actions { display: flex; align-items: center; gap: 0.8rem; }
.phone-link { font-weight: 800; text-decoration: none; white-space: nowrap; }
.button { display: inline-flex; align-items: center; justify-content: center; min-height: 46px; padding: 0.75rem 1.05rem; border-radius: 6px; border: 1px solid transparent; font-weight: 850; line-height: 1.1; text-decoration: none; transition: transform 160ms ease, background 160ms ease, border-color 160ms ease; }
.button:hover { transform: translateY(-1px); }
.button-primary { background: var(--red); color: var(--white); box-shadow: 0 12px 28px rgba(198, 0, 18, 0.26); }
.button-primary:hover { background: #d60b18; }
.button-secondary { background: transparent; border-color: rgba(255, 255, 255, 0.25); color: var(--white); }
.button-secondary:hover { border-color: var(--green-bright); }
.hero { padding: 5.2rem 0 4rem; background: radial-gradient(circle at 14% 18%, rgba(18, 184, 74, 0.12), transparent 28%), radial-gradient(circle at 82% 8%, rgba(198, 0, 18, 0.10), transparent 30%), linear-gradient(110deg, rgba(7, 143, 51, 0.22), transparent 44%), linear-gradient(180deg, rgba(198, 0, 18, 0.08), transparent 38%); }
.hero-compact { padding: 4.4rem 0 3.4rem; }
.hero-grid { display: grid; grid-template-columns: minmax(0, 1.05fr) minmax(300px, 0.95fr); gap: 3rem; align-items: center; }
.hero-copy { max-width: 700px; }
.eyebrow { display: inline-flex; align-items: center; gap: 0.5rem; margin-bottom: 0.8rem; color: var(--green-bright); font-size: 0.78rem; font-weight: 900; letter-spacing: 0; text-transform: uppercase; }
.eyebrow::before { content: ""; width: 34px; height: 2px; background: var(--red); }
h1, h2, h3, p { margin-top: 0; }
h1 { max-width: 780px; margin-bottom: 1rem; font-size: clamp(2.6rem, 7vw, 5.2rem); line-height: 0.98; letter-spacing: 0; }
h2 { margin-bottom: 0.85rem; font-size: clamp(2rem, 4vw, 3.2rem); line-height: 1.05; letter-spacing: 0; }
h3 { margin-bottom: 0.45rem; font-size: 1.12rem; line-height: 1.25; }
.hero-lede, .section-lede { color: var(--muted); font-size: 1.1rem; }
.hero-actions, .cta-actions { display: flex; flex-wrap: wrap; gap: 0.85rem; margin: 1.5rem 0 1rem; }
.micro-trust { color: var(--muted); font-size: 0.95rem; }
.hero-visual { position: relative; isolation: isolate; overflow: hidden; display: grid; place-items: center; min-height: 430px; padding: clamp(1.5rem, 4vw, 3rem); border: 1px solid rgba(18, 184, 74, 0.24); border-radius: 22px; background: radial-gradient(circle at 32% 30%, rgba(18, 184, 74, 0.22), transparent 34%), radial-gradient(circle at 72% 72%, rgba(198, 0, 18, 0.15), transparent 34%), linear-gradient(145deg, rgba(13, 24, 17, 0.90), rgba(3, 6, 4, 0.70)); box-shadow: 0 30px 90px rgba(0, 0, 0, 0.44), 0 0 70px rgba(7, 143, 51, 0.08), inset 0 1px 0 rgba(255, 255, 255, 0.07); }
.hero-visual::before { content: ""; position: absolute; inset: 18px; z-index: -2; border: 1px solid rgba(255, 255, 255, 0.06); border-radius: 18px; background: linear-gradient(90deg, rgba(255, 255, 255, 0.035) 1px, transparent 1px), linear-gradient(180deg, rgba(255, 255, 255, 0.025) 1px, transparent 1px); background-size: 42px 42px; mask-image: radial-gradient(circle at center, black, transparent 72%); }
.hero-visual::after { content: ""; position: absolute; right: 10%; top: 22%; z-index: -1; width: 260px; height: 260px; border-radius: 999px; background: rgba(18, 184, 74, 0.18); filter: blur(58px); }
.hero-visual img { position: relative; z-index: 1; width: min(360px, 76%); filter: drop-shadow(0 22px 40px rgba(0, 0, 0, 0.45)); }
.hero-callout { display: grid; gap: 1rem; padding: 1.3rem; border: 1px solid var(--line); border-left: 4px solid var(--red); border-radius: 8px; background: var(--panel); }
.section { padding: 4rem 0; }
.section-muted { background: var(--bg-soft); }
.section-head { max-width: 760px; margin-bottom: 2rem; }
.grid { display: grid; gap: 1rem; }
.grid-3 { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.grid-4 { grid-template-columns: repeat(4, minmax(0, 1fr)); }
.card, .area-card, .service-card { border: 1px solid var(--line); border-radius: 8px; background: var(--panel); }
.card, .service-card { padding: 1.25rem; }
.service-card { border-top: 3px solid var(--green); }
.service-card:nth-child(2n) { border-top-color: var(--red); }
.area-card { min-height: 62px; display: flex; align-items: center; justify-content: space-between; gap: 1rem; padding: 1rem 1.1rem; font-weight: 850; text-decoration: none; }
.area-card::after { content: ">"; color: var(--red); }
.area-card:hover { border-color: var(--green-bright); background: var(--panel-strong); }
.steps { counter-reset: step; }
.step { position: relative; padding-left: 3.5rem; }
.step::before { counter-increment: step; content: counter(step); position: absolute; left: 1.25rem; top: 1.25rem; width: 30px; height: 30px; display: grid; place-items: center; border-radius: 50%; background: var(--red); color: var(--white); font-weight: 900; }
.check-list, .nearby-list { display: grid; gap: 0.65rem; margin: 0; padding: 0; list-style: none; }
.check-list li, .nearby-list li { padding-left: 1.4rem; position: relative; }
.check-list li::before, .nearby-list li::before { content: ""; position: absolute; left: 0; top: 0.62rem; width: 8px; height: 8px; border-radius: 50%; background: var(--green-bright); }
.faq-list { display: grid; gap: 0.8rem; }
details { border: 1px solid var(--line); border-radius: 8px; background: var(--panel); padding: 1rem 1.1rem; }
summary { cursor: pointer; font-weight: 850; }
details p { margin: 0.8rem 0 0; color: var(--muted); }
.cta-band { padding: 3rem 0; background: var(--red-dark); }
.cta-inner { display: flex; justify-content: space-between; gap: 2rem; align-items: center; }
.cta-inner p { color: rgba(255, 255, 255, 0.86); margin-bottom: 0; }
.final-cta { padding: clamp(2.5rem, 6vw, 4.6rem) 0; background: linear-gradient(115deg, rgba(7, 143, 51, 0.28), rgba(198, 0, 18, 0.13)), rgba(255, 255, 255, 0.035); border-block: 1px solid var(--line); }
.final-cta-inner { display: flex; align-items: center; justify-content: space-between; gap: 1.2rem; }
.final-cta h2 { margin-bottom: 0.5rem; }
.final-cta p { margin: 0; color: var(--muted); }
.site-footer { padding: clamp(2.5rem, 6vw, 4rem) 0; border-top: 1px solid var(--line); background: #020302; }
.footer-grid { display: grid; grid-template-columns: 1.35fr 0.8fr 1.05fr 0.7fr; gap: 1.4rem; align-items: start; }
.footer-grid img { width: 180px; margin-bottom: 1rem; }
.site-footer h2 { font-size: 1rem; margin-bottom: 0.8rem; }
.site-footer p { color: var(--muted); max-width: 360px; }
.site-footer a { display: block; color: var(--muted); margin-bottom: 0.45rem; text-decoration: none; }
.site-footer a:hover { color: var(--green-bright); }
address { color: var(--muted); font-style: normal; }
.footer-inner { display: grid; grid-template-columns: 1fr auto; gap: 2rem; align-items: start; }
.footer-links { display: flex; flex-wrap: wrap; gap: 1rem; color: var(--muted); }
.footer-links a { text-decoration: none; }
.mobile-call-bar { position: fixed; left: 0; right: 0; bottom: 0; z-index: 30; display: grid; grid-template-columns: 1fr; gap: 1px; padding: 0.55rem; background: rgba(3, 6, 4, 0.92); border-top: 1px solid var(--line); backdrop-filter: blur(18px); }
.mobile-call-bar a { display: flex; align-items: center; justify-content: center; min-height: 52px; border-radius: 6px; background: var(--red); color: var(--white); font-weight: 900; text-align: center; text-decoration: none; }
@media (min-width: 940px) { .mobile-call-bar { display: none; } }
@media (min-width: 881px) {
  .hero:not(.hero-compact) .hero-grid { grid-template-columns: minmax(0, 0.9fr) minmax(460px, 1fr); gap: clamp(3.8rem, 5vw, 5rem); }
  .hero:not(.hero-compact) .hero-copy { max-width: 590px; }
  .hero:not(.hero-compact) h1 { max-width: 590px; font-size: clamp(3rem, 5.2vw, 4.45rem); line-height: 1.04; }
}
@media (max-width: 880px) {
  .header-inner { grid-template-columns: auto 1fr; min-height: auto; padding: 0.75rem 0; }
  .brand img { width: 136px; }
  .site-nav { justify-content: flex-end; flex-wrap: wrap; gap: 0.7rem; font-size: 0.86rem; }
  .header-actions { grid-column: 1 / -1; justify-content: space-between; }
  .hero-grid, .grid-3, .grid-4, .cta-inner, .footer-inner { grid-template-columns: 1fr; }
  .footer-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .final-cta-inner { align-items: stretch; flex-direction: column; }
  .hero { padding-top: 2.2rem; }
  .hero-compact { padding-top: 2.2rem; }
  .hero-visual { min-height: 300px; border-radius: 18px; }
  .hero-visual img { width: min(310px, 72%); }
}
@media (max-width: 680px) {
  body { padding-bottom: 78px; }
  .container { width: min(100% - 24px, 1160px); }
  .site-nav { display: none; }
  .header-inner { grid-template-columns: 1fr; }
  .header-actions { display: none; }
  .brand, .brand img { width: 136px; }
  .hero { padding: 2.2rem 0 2.4rem; }
  .hero-compact { padding: 2.2rem 0 2.4rem; }
  .hero-grid { gap: 1.35rem; }
  .hero-visual { display: none; }
  .hero-actions .button { width: 100%; min-height: 48px; }
  .button { width: 100%; }
  h1 { font-size: clamp(2.35rem, 10.4vw, 3.05rem); line-height: 1.02; }
  h2 { font-size: clamp(1.75rem, 8vw, 2.35rem); }
  .eyebrow { font-size: 0.72rem; letter-spacing: 0.04em; }
  .eyebrow::before { width: 28px; }
  .hero-lede, .section-lede { font-size: 1rem; }
  .micro-trust { font-size: 0.94rem; }
  .section { padding: 3rem 0; }
  .footer-grid { grid-template-columns: 1fr; }
  .site-footer { padding-bottom: 6.5rem; }
}
