:root {
  --ls-navy: #10243d;
  --ls-navy-deep: #08192d;
  --ls-graphite: #263443;
  --ls-green: #b9e34b;
  --ls-green-dark: #789d16;
  --ls-white: #ffffff;
  --ls-cream: #f4f6f1;
  --ls-line: #dce2dc;
  --ls-text: #182331;
  --ls-muted: #607080;
  --ls-radius: 18px;
  --ls-shadow: 0 18px 50px rgba(8, 25, 45, .1);
}

* { box-sizing: border-box; }
img, svg, video, iframe { max-width: 100%; }
html { scroll-behavior: smooth; overflow-x: hidden; }
html, body.ls-core-active { width: 100%; max-width: 100%; }
body.ls-core-active { margin: 0; overflow-x: hidden; background: var(--ls-white); color: var(--ls-text); font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif; }
.ls-core-active .site-header, .ls-core-active .main-navigation, .ls-core-active .site-footer, .ls-core-active .page-header, .ls-core-active .entry-header { display: none !important; }
body.ls-core-active #page.grid-container,
body.ls-core-active #content.site-content,
body.ls-core-active #primary.content-area,
body.ls-core-active #main.site-main,
body.ls-core-active #main > article,
body.ls-core-active #main .inside-article,
body.ls-core-active #main .entry-content {
  width: 100% !important;
  max-width: none !important;
  min-width: 0;
  margin: 0 !important;
  padding: 0 !important;
}
body.ls-core-active #page.grid-container { display: block; }
body.ls-core-active #content.site-content { display: block; }
body.ls-core-active #primary.content-area { float: none; flex: 0 0 100%; }
body.ls-core-active #main.site-main > * { margin-bottom: 0; }
.ls-site { width: 100%; max-width: 100%; min-height: 100vh; margin: 0; font-size: 17px; line-height: 1.65; }
.ls-site > main, .ls-header, .ls-hero, .ls-page-hero, .ls-section, .ls-metrics, .ls-footer { width: 100%; max-width: 100%; }
.ls-site h1, .ls-site h2, .ls-site h3, .ls-site p { margin-top: 0; }
.ls-site h1, .ls-site h2, .ls-site h3 { color: var(--ls-navy); line-height: 1.08; letter-spacing: -.035em; font-weight: 800; }
.ls-site h1 { max-width: 850px; margin-bottom: 24px; font-size: clamp(2.55rem, 8.5vw, 5.4rem); }
.ls-site h2 { margin-bottom: 18px; font-size: clamp(2rem, 5vw, 3.5rem); }
.ls-site h3 { font-size: 1.35rem; }
.ls-site a { color: inherit; text-decoration: none; }
.ls-container { width: calc(100% - 36px); max-width: 1180px; margin-left: auto; margin-right: auto; }
.ls-container--narrow { max-width: 820px; }
.ls-section { padding: 76px 0; }
.ls-section--faq { padding-bottom: 48px; }
.ls-section--faq + .ls-section--contact { padding-top: 48px; }
.ls-section--soft { background: var(--ls-cream); }
.ls-section--dark { background: var(--ls-navy-deep); color: #dfe9f2; }
.ls-section--dark h2, .ls-section--dark h3 { color: var(--ls-white); }
.ls-section--dark .ls-eyebrow { color: var(--ls-green); }
.ls-heading { max-width: 720px; margin-bottom: 38px; }
.ls-heading > p:last-child { color: var(--ls-muted); font-size: 1.05rem; }
.ls-section--dark .ls-heading > p:last-child { color: #b8c7d5; }
.ls-eyebrow { margin-bottom: 12px; color: var(--ls-green-dark); font-size: .78rem; font-weight: 800; letter-spacing: .16em; text-transform: uppercase; }
.ls-lead { max-width: 700px; color: #dce8f2; font-size: clamp(1.08rem, 2vw, 1.3rem); }
.ls-header { position: relative; z-index: 20; background: var(--ls-white); border-bottom: 1px solid var(--ls-line); }
.ls-header__inner { min-height: 72px; display: flex; align-items: center; justify-content: space-between; gap: 18px; }
.ls-brand { display: flex; align-items: center; gap: 11px; color: var(--ls-navy); font-weight: 800; line-height: 1.1; }
.ls-brand small { display: block; margin-top: 4px; color: var(--ls-muted); font-size: .66rem; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; }
.ls-brand__mark { width: 42px; height: 42px; display: grid; place-items: center; flex: none; border-radius: 12px; background: var(--ls-navy); color: var(--ls-green); font-size: .85rem; }
.ls-nav { display: none; gap: 20px; align-items: center; font-size: .88rem; font-weight: 700; }
.ls-nav a { padding: 25px 0; border-bottom: 3px solid transparent; }
.ls-nav a:hover, .ls-nav a.is-active { border-color: var(--ls-green-dark); }
.ls-header .ls-btn--small { display: none; }
.ls-mobile-menu { margin-left: auto; position: relative; }
.ls-mobile-menu summary { min-height: 44px; padding: 9px 12px; display: flex; align-items: center; gap: 9px; border: 1px solid var(--ls-line); border-radius: 10px; color: var(--ls-navy); cursor: pointer; font-size: .86rem; font-weight: 800; list-style: none; }
.ls-mobile-menu summary::-webkit-details-marker { display: none; }
.ls-mobile-menu__icon { width: 20px; display: grid; gap: 4px; }
.ls-mobile-menu__icon i { height: 2px; display: block; border-radius: 2px; background: var(--ls-navy); }
.ls-mobile-menu[open] summary { border-color: var(--ls-green-dark); background: var(--ls-cream); }
.ls-mobile-nav { position: absolute; z-index: 30; top: calc(100% + 10px); right: 0; width: min(310px, calc(100vw - 28px)); padding: 12px; display: grid; gap: 4px; border: 1px solid var(--ls-line); border-radius: 14px; background: var(--ls-white); box-shadow: var(--ls-shadow); }
.ls-mobile-nav > a:not(.ls-btn) { padding: 11px 12px; border-radius: 8px; color: var(--ls-navy); font-weight: 750; }
.ls-mobile-nav > a:not(.ls-btn):hover, .ls-mobile-nav > a.is-active { background: var(--ls-cream); }
.ls-mobile-nav__call { width: 100%; margin-top: 6px; }
.ls-btn { min-height: 52px; padding: 14px 22px; display: inline-flex; align-items: center; justify-content: center; border: 2px solid var(--ls-green); border-radius: 12px; background: var(--ls-green); color: var(--ls-navy-deep) !important; font-weight: 800; line-height: 1.2; box-shadow: none; transition: background-color .18s ease, border-color .18s ease, color .18s ease, transform .18s ease; }
.ls-btn:hover { border-color: #cdf56a; background: #cdf56a; transform: translateY(-1px); }
.ls-btn:focus-visible, .ls-text-link:focus-visible, .ls-nav a:focus-visible, .ls-sticky-call:focus-visible { outline: 3px solid var(--ls-white); outline-offset: 4px; }
.ls-btn--small { min-height: 44px; padding: 10px 16px; font-size: .88rem; }
.ls-btn--light { border-color: var(--ls-white); background: var(--ls-white); color: var(--ls-navy) !important; }
.ls-btn--outline { border-color: var(--ls-navy); background: transparent; color: var(--ls-navy) !important; }
.ls-btn--outline:hover { border-color: var(--ls-navy); background: var(--ls-navy); color: var(--ls-white) !important; }
.ls-text-link { display: inline-flex; align-items: center; gap: 8px; color: currentColor; font-weight: 800; text-decoration: underline; text-decoration-color: var(--ls-green-dark); text-decoration-thickness: 3px; text-underline-offset: 6px; }
.ls-text-link:hover { text-decoration-color: var(--ls-green); }
.ls-actions { display: flex; flex-direction: column; align-items: flex-start; gap: 20px; margin-top: 30px; }
.ls-hero { position: relative; overflow: hidden; background: var(--ls-navy); color: var(--ls-white); }
.ls-hero::after { content: ""; position: absolute; right: -120px; top: -180px; width: 460px; height: 460px; border: 80px solid rgba(185, 227, 75, .09); border-radius: 50%; }
.ls-hero__grid { position: relative; z-index: 1; min-height: auto; padding-top: 62px; padding-bottom: 62px; display: grid; align-items: center; gap: 38px; }
.ls-hero h1 { color: var(--ls-white); }
.ls-hero__content { max-width: 800px; }
.ls-hero__panel { padding: 26px; border: 1px solid rgba(255,255,255,.16); border-radius: var(--ls-radius); background: rgba(255,255,255,.07); backdrop-filter: blur(10px); }
.ls-hero__panel > span { display: block; color: var(--ls-green); font-size: .75rem; font-weight: 800; letter-spacing: .15em; text-transform: uppercase; }
.ls-hero__panel > strong { display: block; margin: 8px 0 20px; color: var(--ls-white); font-size: 1.4rem; line-height: 1.2; }
.ls-hero__panel ul { margin: 0; padding: 0; list-style: none; }
.ls-hero__panel li { padding: 10px 0 10px 25px; position: relative; border-top: 1px solid rgba(255,255,255,.12); }
.ls-hero__panel li::before { content: ""; position: absolute; left: 2px; top: 20px; width: 8px; height: 8px; border-radius: 50%; background: var(--ls-green); }
.ls-hero--pro { background: linear-gradient(125deg, var(--ls-navy-deep) 0%, #173758 100%); }
.ls-page-hero { padding: 90px 0; background: var(--ls-navy); color: var(--ls-white); }
.ls-page-hero h1 { color: var(--ls-white); }
.ls-grid { display: grid; gap: 20px; }
.ls-card { min-width: 0; min-height: 0; padding: 28px; position: relative; display: grid; grid-template-rows: auto auto 1fr; align-content: start; border: 1px solid var(--ls-line); border-radius: var(--ls-radius); background: var(--ls-white); box-shadow: 0 8px 30px rgba(8,25,45,.045); transition: border-color .18s ease, box-shadow .18s ease, transform .18s ease; }
.ls-card:hover { border-color: #b9cb94; box-shadow: var(--ls-shadow); transform: translateY(-2px); }
.ls-card__number { display: block; margin-bottom: 22px; color: var(--ls-green-dark); font-size: .78rem; font-weight: 900; letter-spacing: .12em; }
.ls-service-badge { width: 38px; min-height: 26px; padding: 4px 7px; display: inline-flex; align-items: center; justify-content: center; border: 1px solid #c8dc94; border-radius: 999px; background: #eff7d7; color: #56740b; line-height: 1; }
.ls-card h3 { margin-bottom: 12px; }
.ls-card p { margin: 0; align-self: start; color: var(--ls-muted); }
.ls-split { display: grid; gap: 42px; align-items: center; }
.ls-benefits { display: grid; gap: 1px; overflow: hidden; border-radius: var(--ls-radius); background: rgba(255,255,255,.12); }
.ls-benefits div { padding: 24px; display: flex; gap: 20px; background: rgba(255,255,255,.055); }
.ls-benefits strong { color: var(--ls-green); }
.ls-benefits span { color: var(--ls-white); font-weight: 700; }
.ls-steps { counter-reset: ls-step; }
.ls-steps article { min-width: 0; padding: 26px; position: relative; border: 1px solid var(--ls-line); border-top: 5px solid var(--ls-navy); border-radius: 0 0 var(--ls-radius) var(--ls-radius); background: var(--ls-white); }
.ls-steps article > span { width: 36px; height: 36px; margin-bottom: 20px; display: grid; place-items: center; border-radius: 50%; background: var(--ls-green); color: var(--ls-navy-deep); font-weight: 900; }
.ls-steps article h3 { margin-bottom: 10px; }
.ls-steps article p { margin-bottom: 0; color: var(--ls-muted); }
.ls-map { min-height: 310px; padding: 30px; display: grid; place-content: center; text-align: center; border: 2px dashed #aeb9ad; border-radius: var(--ls-radius); background: #e8ece4; color: var(--ls-graphite); }
.ls-map__pin { width: 54px; height: 54px; margin: 0 auto 16px; display: grid; place-items: center; border-radius: 50% 50% 50% 0; transform: rotate(-45deg); background: var(--ls-navy); color: var(--ls-green); font-size: 1.6rem; font-weight: 300; }
.ls-map__pin::first-letter { transform: rotate(45deg); }
.ls-map p { max-width: 430px; margin: 0; font-weight: 700; }
.ls-faq-list { border-top: 1px solid var(--ls-line); }
.ls-faq { border-bottom: 1px solid var(--ls-line); }
.ls-faq summary { padding: 22px 44px 22px 0; position: relative; cursor: pointer; color: var(--ls-navy); font-size: 1.1rem; font-weight: 800; list-style: none; }
.ls-faq summary::after { content: "+"; position: absolute; right: 5px; top: 16px; color: var(--ls-green-dark); font-size: 1.8rem; }
.ls-faq[open] summary::after { content: "−"; }
.ls-faq p { padding: 0 40px 20px 0; color: var(--ls-muted); }
.ls-cta { padding: 32px; display: flex; flex-direction: column; align-items: stretch; gap: 24px; border-radius: var(--ls-radius); background: var(--ls-green); color: var(--ls-navy-deep); }
.ls-cta > div { max-width: 720px; }
.ls-cta h2 { max-width: 700px; margin-bottom: 10px; color: var(--ls-navy-deep); }
.ls-cta p { margin-bottom: 0; }
.ls-cta .ls-eyebrow { color: #4a6507; }
.ls-contact { margin-top: 20px; display: grid; gap: 1px; overflow: hidden; border: 1px solid var(--ls-line); border-radius: var(--ls-radius); background: var(--ls-line); }
.ls-contact > div { padding: 22px; display: flex; flex-direction: column; background: var(--ls-white); }
.ls-contact span, .ls-contact-panel > span, .ls-footer span { color: var(--ls-muted); font-size: .72rem; font-weight: 800; letter-spacing: .13em; text-transform: uppercase; }
.ls-contact a, .ls-contact strong { overflow-wrap: anywhere; color: var(--ls-navy); font-size: 1.08rem; }
.ls-contact-panel { padding: 34px; border-radius: var(--ls-radius); background: var(--ls-navy); color: #dbe6ef; }
.ls-contact-panel > span { color: var(--ls-green); }
.ls-contact-panel h2 { margin: 10px 0; color: var(--ls-white); }
.ls-contact-panel a { color: var(--ls-green); font-size: clamp(1.85rem, 6vw, 2.6rem); font-weight: 900; line-height: 1.15; }
.ls-note { margin-top: 24px; color: var(--ls-muted); font-size: .9rem; }
.ls-service-list { margin: 12px 0 0; padding: 0; display: grid; gap: 8px 18px; list-style: none; }
.ls-service-list li { margin: 0; padding-left: 17px; position: relative; }
.ls-service-list li::before { content: ""; position: absolute; left: 0; top: .72em; width: 6px; height: 6px; border-radius: 50%; background: var(--ls-green-dark); transform: translateY(-50%); }
.ls-metrics { padding: 24px 0; background: var(--ls-green); color: var(--ls-navy-deep); }
.ls-metrics .ls-container { display: grid; gap: 18px; }
.ls-metrics div div { display: flex; align-items: baseline; gap: 10px; }
.ls-metrics strong { font-size: 1.5rem; }
.ls-metrics span { font-size: .82rem; font-weight: 700; }
.ls-pro-list { display: grid; gap: 10px; }
.ls-pro-list__item { min-width: 0; padding: 18px 20px; display: flex; align-items: center; gap: 16px; border: 1px solid rgba(255,255,255,.14); border-radius: 12px; background: rgba(255,255,255,.055); }
.ls-pro-list__item strong { width: 38px; min-height: 26px; display: inline-flex; align-items: center; justify-content: center; flex: none; border-radius: 999px; background: var(--ls-green); color: var(--ls-navy-deep); font-size: .76rem; font-weight: 900; letter-spacing: .08em; line-height: 1; }
.ls-pro-list__item span { min-width: 0; color: var(--ls-white); font-weight: 800; }
.ls-city-card { margin: 0 0 30px; padding: 24px; display: flex; flex-direction: column; border: 1px solid var(--ls-line); border-left: 6px solid var(--ls-green-dark); border-radius: var(--ls-radius); background: var(--ls-white); box-shadow: 0 8px 30px rgba(8,25,45,.045); }
.ls-city-card span { color: var(--ls-green-dark); font-size: .72rem; font-weight: 800; letter-spacing: .13em; text-transform: uppercase; }
.ls-city-card strong { margin: 6px 0; color: var(--ls-navy); font-size: 1.4rem; }
.ls-city-card small { color: var(--ls-muted); font-weight: 700; }
.ls-area-cities { margin: 0 0 16px; display: flex; flex-wrap: wrap; gap: 10px; }
.ls-city-chip { min-height: 36px; padding: 7px 13px; display: inline-flex; align-items: center; border: 1px solid var(--ls-line); border-radius: 999px; background: var(--ls-white); color: var(--ls-graphite); font-size: .88rem; font-weight: 750; line-height: 1.2; }
.ls-city-chip--linked { border-color: var(--ls-green-dark); background: var(--ls-green); color: var(--ls-navy-deep) !important; }
.ls-city-chip--linked:hover { background: #cdf56a; }
.ls-area-note { margin: 0 0 24px; color: var(--ls-muted); font-size: .92rem; }
.ls-center { margin: 34px 0 0; display: flex; justify-content: center; text-align: center; }
.ls-services-cta-wrap { margin-top: 32px; display: flex; justify-content: center; }
.ls-footer { padding: 62px 0 calc(98px + env(safe-area-inset-bottom)); background: #071523; color: #c5d1db; }
.ls-footer__grid { display: grid; gap: 34px; }
.ls-footer strong { color: var(--ls-white); font-size: 1.2rem; }
.ls-footer p { max-width: 380px; margin: 8px 0 0; }
.ls-footer__grid > div { min-width: 0; display: flex; flex-direction: column; align-items: flex-start; gap: 3px; }
.ls-footer a { color: var(--ls-white); font-weight: 700; overflow-wrap: anywhere; }
.ls-footer__bottom { margin-top: 44px; padding-top: 22px; display: flex; flex-direction: column; gap: 7px; border-top: 1px solid #253544; color: #8293a2; }
.ls-sticky-call { position: fixed; z-index: 50; right: 14px; bottom: max(14px, env(safe-area-inset-bottom)); left: 14px; width: min(440px, calc(100% - 28px)); min-height: 54px; margin-inline: auto; display: flex; align-items: center; justify-content: center; border: 2px solid rgba(8,25,45,.18); border-radius: 14px; background: var(--ls-green); color: var(--ls-navy-deep) !important; font-weight: 900; box-shadow: 0 12px 35px rgba(0,0,0,.28); }
.ls-sticky-call:hover { background: #cdf56a; }

@media (min-width: 700px) {
  .ls-section { padding: 104px 0; }
  .ls-section--faq { padding-bottom: 62px; }
  .ls-section--faq + .ls-section--contact { padding-top: 62px; }
  .ls-actions { flex-direction: row; align-items: center; }
  .ls-grid--3 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .ls-contact { grid-template-columns: minmax(0, .85fr) minmax(0, 1.15fr) minmax(0, 1.5fr); }
  .ls-metrics .ls-container { grid-template-columns: repeat(3, minmax(0, 1fr)); }
  .ls-service-list { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .ls-cta { padding: 44px; flex-direction: row; align-items: center; justify-content: space-between; }
  .ls-cta .ls-btn { width: auto; flex: none; }
  .ls-footer__grid { grid-template-columns: 1.5fr 1fr 1fr; }
  .ls-footer__bottom { flex-direction: row; justify-content: space-between; }
}

@media (max-width: 700px) {
  .ls-services-cta-wrap { margin-top: 24px; }
}

@media (min-width: 980px) {
  .ls-nav { display: flex; }
  .ls-header .ls-btn--small { display: inline-flex; }
  .ls-mobile-menu { display: none; }
  .ls-hero__grid { min-height: 660px; padding-top: 88px; padding-bottom: 88px; grid-template-columns: minmax(0, 1.6fr) minmax(300px, .7fr); gap: 64px; }
  .ls-grid--3 { grid-template-columns: repeat(3, minmax(0, 1fr)); }
  .ls-card { min-height: 210px; }
  .ls-split { grid-template-columns: repeat(2, minmax(0, 1fr)); gap: clamp(56px, 7vw, 88px); }
  .ls-contact-layout { grid-template-columns: minmax(0, 1.35fr) minmax(330px, .85fr); gap: clamp(42px, 5vw, 68px); }
  .ls-contact-layout .ls-contact { grid-template-columns: minmax(0, .8fr) minmax(0, 1.15fr) minmax(0, 1.45fr); }
  .ls-contact-layout .ls-contact-panel { align-self: stretch; display: flex; flex-direction: column; justify-content: center; }
  .ls-sticky-call { display: none; }
  .ls-footer { padding-bottom: 62px; }
}

@media (max-width: 420px) {
  .ls-brand > span:last-child { max-width: 145px; font-size: .84rem; }
  .ls-brand small { font-size: .56rem; }
  .ls-container { width: min(100% - 28px, 1180px); }
  .ls-container--narrow { width: min(100% - 28px, 820px); }
  .ls-hero__grid { padding-top: 52px; padding-bottom: 54px; }
  .ls-hero__panel, .ls-card, .ls-contact-panel, .ls-cta { padding: 24px; }
  .ls-btn { width: 100%; }
  .ls-actions .ls-text-link { align-self: center; }
}

@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  .ls-btn, .ls-card { transition: none; }
}
