:root {
    --blue-950: #052642;
    --blue-900: #004f99;
    --blue-800: #0063bd;
    --blue-700: #0876d8;
    --blue-500: #1e9bf0;
    --blue-100: #eaf5ff;
    --ink: #223041;
    --muted: #5f6f82;
    --soft: #f4f6fb;
    --white: #ffffff;
    --shadow: 0 18px 45px rgba(15, 42, 71, .12);
    --shadow-strong: 0 24px 70px rgba(0, 0, 0, .28);
    --radius: 22px;
    --max: 1180px;
    --header-height: 88px;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
    margin: 0;
    font-family: Arial, Helvetica, sans-serif;
    color: var(--ink);
    background: var(--white);
    line-height: 1.6;
}
img, svg { max-width: 100%; display: block; }
a { color: inherit; text-decoration: none; }
p { margin: 0 0 1rem; }
h1, h2, h3 { margin: 0 0 1rem; line-height: 1.15; font-weight: 600; }
h1 { font-size: clamp(2.45rem, 6vw, 5.4rem); color: var(--white); letter-spacing: -.052em; text-shadow: 0 16px 44px rgba(0,0,0,.3); }
h2 { font-size: clamp(1.7rem, 3vw, 2.85rem); }
h3 { font-size: 1.15rem; }

.container { width: min(var(--max), calc(100% - 40px)); margin-inline: auto; }
.narrow { max-width: 850px; text-align: center; }
.section-pad { padding: clamp(70px, 9vw, 125px) 0; }
.dark-title { color: var(--ink); text-shadow: none; letter-spacing: -.04em; }
.skip-link { position: fixed; left: 1rem; top: 1rem; z-index: 1000; transform: translateY(-160%); background: var(--white); color: var(--ink); padding: .65rem 1rem; border-radius: 999px; box-shadow: var(--shadow); }
.skip-link:focus { transform: translateY(0); }

.site-header {
    position: fixed;
    inset: 0 0 auto;
    z-index: 100;
    color: var(--white);
    background: linear-gradient(180deg, rgba(2, 22, 38, .96), rgba(5, 38, 66, .84));
    border-bottom: 1px solid rgba(255,255,255,.13);
    backdrop-filter: blur(16px);
    -webkit-backdrop-filter: blur(16px);
    box-shadow: 0 12px 34px rgba(0, 0, 0, .18);
}
.nav-wrap { min-height: var(--header-height); display: flex; align-items: center; justify-content: space-between; gap: 22px; }
.brand { display: inline-flex; flex-direction: column; gap: 2px; line-height: 1; text-transform: uppercase; flex: 0 0 auto; }
.brand-mark { display: inline-block; font-size: 2rem; font-weight: 800; letter-spacing: .05em; }
.brand-mark::first-letter { color: #f2353a; }
.brand-small { font-size: .64rem; letter-spacing: .42em; opacity: .9; }
.site-nav { display: flex; align-items: center; justify-content: center; gap: clamp(16px, 2.4vw, 32px); font-size: .95rem; margin-left: auto; }
.site-nav > a, .dropdown-toggle { opacity: .88; position: relative; padding: 9px 0; }
.site-nav > a::after, .dropdown-toggle::after { content: ''; position: absolute; left: 0; right: 0; bottom: 2px; height: 2px; border-radius: 999px; background: var(--blue-500); transform: scaleX(0); transform-origin: center; transition: transform .2s ease; }
.site-nav > a:hover, .site-nav > a:focus-visible, .dropdown-toggle:hover, .dropdown-toggle:focus-visible, .site-nav .is-current > .dropdown-toggle, .site-nav > a.is-current { opacity: 1; }
.site-nav > a:hover::after, .site-nav > a:focus-visible::after, .dropdown-toggle:hover::after, .dropdown-toggle:focus-visible::after, .site-nav > a.is-current::after, .nav-dropdown.is-current .dropdown-toggle::after { transform: scaleX(1); }
.nav-dropdown { position: relative; }
.nav-dropdown::before { content: ''; position: absolute; left: -24px; right: -24px; top: 100%; height: 20px; z-index: 1; }
.dropdown-toggle { display: inline-flex; align-items: center; gap: 6px; border: 0; background: transparent; color: inherit; font: inherit; cursor: pointer; }
.dropdown-menu { position: absolute; z-index: 5; top: calc(100% + 10px); left: 50%; transform: translateX(-50%) translateY(8px); min-width: 230px; display: grid; gap: 4px; padding: 12px; border-radius: 18px; background: rgba(3, 35, 61, .97); border: 1px solid rgba(255,255,255,.14); box-shadow: var(--shadow-strong); opacity: 0; pointer-events: none; transition: opacity .18s ease, transform .18s ease; }
.dropdown-menu a { padding: 10px 12px; border-radius: 12px; color: rgba(255,255,255,.88); }
.dropdown-menu a:hover, .dropdown-menu a:focus-visible { background: rgba(255,255,255,.1); color: var(--white); }
.nav-dropdown:hover .dropdown-menu, .nav-dropdown:focus-within .dropdown-menu, .nav-dropdown.is-open .dropdown-menu { opacity: 1; pointer-events: auto; transform: translateX(-50%) translateY(0); }
.nav-toggle { display: none; align-items: center; gap: 10px; border: 1px solid rgba(255,255,255,.42); background: rgba(255,255,255,.08); color: var(--white); border-radius: 999px; padding: .62rem .92rem; cursor: pointer; }
.nav-toggle-lines, .nav-toggle-lines::before, .nav-toggle-lines::after { width: 18px; height: 2px; border-radius: 999px; background: currentColor; display: block; }
.nav-toggle-lines { position: relative; }
.nav-toggle-lines::before, .nav-toggle-lines::after { content: ''; position: absolute; left: 0; }
.nav-toggle-lines::before { top: -6px; }
.nav-toggle-lines::after { top: 6px; }
.nav-phone { display: inline-flex; align-items: center; justify-content: center; gap: 8px; min-height: 42px; padding: .58rem .95rem; border-radius: 999px; background: var(--blue-500); color: var(--white); font-weight: 800; box-shadow: 0 12px 28px rgba(30,155,240,.25); white-space: nowrap; flex: 0 0 auto; }
.nav-phone:hover, .nav-phone:focus-visible { background: var(--blue-700); }
.nav-phone-icon { width: 19px; height: 19px; }

.icon, .quick-svg, .service-svg, .hero-kicker-icon, .proof-icon, .btn-icon, .text-link-icon, .area-icon, .footer-inline-icon, .contact-icon, .nav-phone-icon, .back-top-icon { fill: none; stroke: currentColor; stroke-width: 2; stroke-linecap: round; stroke-linejoin: round; }

.hero { position: relative; min-height: 820px; display: grid; align-items: center; overflow: hidden; background: #102c23; isolation: isolate; }
.hero::after, .page-hero::after { content: ''; position: absolute; inset: auto 0 0; z-index: 2; height: 160px; background: linear-gradient(0deg, rgba(0,0,0,.28), transparent); pointer-events: none; }
.hero-slides, .hero-slide, .hero-slide::before { position: absolute; inset: 0; }
.hero-slides { z-index: 0; }
.hero-slide { opacity: 0; transform: scale(1.05); background-position: center; background-size: cover; background-repeat: no-repeat; transition: opacity 1s ease, transform 7s ease; }
.hero-slide::before { content: ''; background: linear-gradient(90deg, rgba(2,18,31,.76) 0%, rgba(2,18,31,.52) 35%, rgba(2,18,31,.12) 67%, rgba(2,18,31,.2) 100%); }
.hero-slide.is-active { opacity: 1; transform: scale(1); }
.hero-shade { position: absolute; z-index: 1; inset: 0; background: radial-gradient(circle at 18% 38%, rgba(30,155,240,.2), transparent 34%), linear-gradient(180deg, rgba(0,0,0,.08), rgba(0,0,0,.32)); pointer-events: none; }
.hero-inner { position: relative; z-index: 3; display: grid; grid-template-columns: minmax(0, 1.1fr) minmax(290px, .58fr); align-items: center; gap: clamp(32px, 6vw, 92px); color: var(--white); padding-top: var(--header-height); }
.hero-copy-block, .page-hero-copy { max-width: 760px; }
.hero-copy-block { padding-top: 42px; }
.hero-kicker { display: inline-flex; align-items: center; gap: 10px; color: rgba(255,255,255,.96); background: rgba(255,255,255,.12); border: 1px solid rgba(255,255,255,.25); padding: .7rem 1rem; border-radius: 999px; margin-bottom: 20px; font-size: .92rem; backdrop-filter: blur(10px); -webkit-backdrop-filter: blur(10px); }
.hero-kicker-icon { width: 22px; height: 22px; color: var(--blue-500); }
.eyebrow { color: var(--blue-500); font-size: .85rem; font-weight: 700; letter-spacing: .12em; text-transform: uppercase; margin-bottom: .85rem; }
.hero-copy { max-width: 680px; font-size: 1.14rem; color: rgba(255,255,255,.92); text-shadow: 0 10px 32px rgba(0,0,0,.36); }
.hero-actions { display: flex; flex-wrap: wrap; gap: 14px; margin-top: 30px; }
.btn { display: inline-flex; align-items: center; justify-content: center; gap: 9px; min-height: 48px; padding: .82rem 1.45rem; border-radius: 999px; font-weight: 700; font-size: .95rem; transition: transform .2s ease, box-shadow .2s ease, background .2s ease; }
.btn:hover, .btn:focus-visible { transform: translateY(-2px); }
.btn-primary { background: linear-gradient(135deg, var(--blue-500), var(--blue-700)); color: var(--white); box-shadow: 0 12px 24px rgba(30, 155, 240, .32); }
.btn-ghost { color: var(--white); border: 1px solid rgba(255,255,255,.42); background: rgba(255,255,255,.08); backdrop-filter: blur(10px); -webkit-backdrop-filter: blur(10px); }
.btn-light { color: var(--blue-900); background: var(--white); box-shadow: 0 10px 28px rgba(0,0,0,.1); }
.btn-icon { width: 18px; height: 18px; }
.hero-side-panel { align-self: end; margin-bottom: clamp(30px, 7vw, 90px); padding: 26px; border-radius: 28px; background: rgba(5, 38, 66, .68); border: 1px solid rgba(255,255,255,.18); box-shadow: var(--shadow-strong); backdrop-filter: blur(16px); -webkit-backdrop-filter: blur(16px); }
.hero-side-label { margin: 0 0 16px; color: rgba(255,255,255,.74); font-size: .78rem; font-weight: 800; letter-spacing: .14em; text-transform: uppercase; }
.proof-row { display: flex; align-items: flex-start; gap: 12px; padding: 14px 0; border-top: 1px solid rgba(255,255,255,.13); color: rgba(255,255,255,.92); font-weight: 700; }
.proof-row:first-of-type { border-top: 0; padding-top: 0; }
.proof-row:last-child { padding-bottom: 0; }
.proof-icon { width: 24px; height: 24px; color: var(--blue-500); flex: 0 0 auto; }
.slider-controls { grid-column: 1 / -1; display: inline-flex; align-items: center; justify-content: center; justify-self: start; gap: 10px; margin-top: -48px; padding: 8px 10px; border-radius: 999px; background: rgba(255,255,255,.14); border: 1px solid rgba(255,255,255,.24); backdrop-filter: blur(12px); -webkit-backdrop-filter: blur(12px); }
.slider-dot { width: 10px; height: 10px; border: 0; border-radius: 999px; padding: 0; cursor: pointer; background: rgba(255,255,255,.62); transition: width .25s ease, background .25s ease; }
.slider-dot.is-active { width: 34px; background: var(--white); }

.page-hero { position: relative; min-height: 620px; display: grid; align-items: center; overflow: hidden; background: #102c23; isolation: isolate; }
.page-hero::before { content: ''; position: absolute; inset: 0; background-image: linear-gradient(90deg, rgba(1, 18, 31, .76) 0%, rgba(1,18,31,.52) 42%, rgba(1,22,36,.12) 78%), var(--hero-image); background-size: cover; background-position: center; z-index: 0; }
.page-hero-inner { position: relative; z-index: 3; color: var(--white); padding-top: var(--header-height); }
.page-hero-copy { padding-top: 34px; }

.quick-strip { position: relative; z-index: 4; margin-top: -1px; background: var(--blue-800); color: var(--white); }
.quick-grid { display: grid; grid-template-columns: repeat(4, 1fr); }
.quick-card { padding: 30px clamp(22px, 3vw, 42px); min-height: 155px; background: rgba(255,255,255,.04); }
.quick-card:nth-child(even) { background: rgba(0,0,0,.08); }
.quick-icon { width: 42px; height: 42px; display: grid; place-items: center; margin-bottom: 14px; border-radius: 14px; background: rgba(255,255,255,.12); color: var(--white); }
.quick-svg { width: 27px; height: 27px; }
.quick-card h2 { margin-bottom: 6px; font-size: 1.08rem; font-weight: 700; }
.quick-card p { max-width: 300px; margin: 0; font-size: .92rem; color: rgba(255,255,255,.84); }
.quick-contact { background: var(--blue-900) !important; display: flex; flex-direction: column; justify-content: center; gap: 14px; }
.quick-contact p { font-size: 1.1rem; color: var(--white); }
.intro p { color: var(--muted); }
.soft-bg { background: var(--soft); }
.split-grid { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(32px, 6vw, 90px); align-items: center; }
.image-card { min-height: 520px; border-radius: var(--radius); background: linear-gradient(180deg, rgba(3, 18, 24, .03), rgba(3, 18, 24, .14)), url('../img/rats.webp') center / cover no-repeat; box-shadow: var(--shadow); }
.copy-card { max-width: 560px; }
.copy-card p { color: var(--muted); }
.copy-card-offset { grid-column: 2; }
.section-heading { max-width: 780px; margin: 0 auto 48px; text-align: center; }
.section-heading p:not(.eyebrow) { color: var(--muted); }
.service-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.compact-grid { grid-template-columns: repeat(3, 1fr); }
.service-card { padding: 34px; border-radius: var(--radius); background: var(--white); box-shadow: var(--shadow); min-height: 245px; transition: transform .22s ease, box-shadow .22s ease; }
.service-card:hover, .service-card:focus-visible { transform: translateY(-5px); box-shadow: 0 24px 56px rgba(15, 42, 71, .16); }
.link-card { display: block; }
.service-icon { width: 54px; height: 54px; display: grid; place-items: center; margin-bottom: 18px; color: var(--blue-700); border-radius: 17px; background: linear-gradient(135deg, var(--blue-100), rgba(30,155,240,.12)); }
.service-svg { width: 34px; height: 34px; }
.service-card p { color: var(--muted); }
.text-link { display: inline-flex; align-items: center; gap: 7px; margin-top: 8px; color: var(--blue-700); font-weight: 700; }
.text-link-icon { width: 17px; height: 17px; }
.banner-section { padding: clamp(85px, 13vw, 160px) 0; color: var(--white); background: linear-gradient(135deg, rgba(0, 84, 159, .95), rgba(0, 103, 197, .95)), radial-gradient(circle at 20% 20%, rgba(255,255,255,.18), transparent 35%); text-align: center; }
.banner-inner p { max-width: 650px; margin-inline: auto; color: rgba(255,255,255,.86); }
.area-link-grid { display: grid; grid-template-columns: repeat(5, 1fr); gap: 14px; }
.area-link-card { min-height: 64px; display: flex; align-items: center; gap: 10px; padding: 15px 16px; border-radius: 16px; background: var(--white); box-shadow: var(--shadow); font-weight: 700; color: var(--ink); transition: transform .2s ease, box-shadow .2s ease; }
.area-link-card:hover, .area-link-card:focus-visible { transform: translateY(-3px); box-shadow: 0 20px 48px rgba(15,42,71,.14); }
.area-icon { width: 21px; height: 21px; color: var(--blue-700); flex: 0 0 auto; }
.small-area-grid { grid-template-columns: repeat(5, 1fr); }
.cta { padding-top: 0; }
.cta-card { display: flex; align-items: center; justify-content: space-between; gap: 30px; padding: clamp(34px, 5vw, 60px); border-radius: var(--radius); background: linear-gradient(135deg, var(--blue-950), var(--blue-700)); color: var(--white); box-shadow: var(--shadow); }
.cta-card p:not(.eyebrow) { max-width: 700px; color: rgba(255,255,255,.86); }

.detail-grid { display: grid; grid-template-columns: minmax(0, 1.6fr) minmax(280px, .75fr); gap: clamp(28px, 5vw, 70px); align-items: start; }
.detail-main p { color: var(--muted); font-size: 1.04rem; }
.detail-card, .info-card, .area-column-card { padding: clamp(28px, 4vw, 42px); border-radius: var(--radius); background: var(--white); box-shadow: var(--shadow); }
.detail-card { position: sticky; top: calc(var(--header-height) + 24px); }
.detail-card p, .info-card p { color: var(--muted); }
.two-columns, .contact-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; }
.tick-list { list-style: none; margin: 0; padding: 0; display: grid; gap: 14px; }
.tick-list li { position: relative; padding-left: 30px; color: var(--muted); }
.tick-list li::before { content: '✓'; position: absolute; left: 0; top: 0; width: 21px; height: 21px; border-radius: 50%; display: grid; place-items: center; background: var(--blue-100); color: var(--blue-700); font-weight: 800; font-size: .8rem; }

.lead-paragraph { font-size: 1.12rem !important; color: var(--ink) !important; }
.local-note-list { list-style: none; margin: 20px 0 24px; padding: 0; display: grid; gap: 12px; }
.local-note-list li { position: relative; padding-left: 27px; color: var(--muted); font-size: .96rem; }
.local-note-list li::before { content: ''; position: absolute; left: 0; top: .45em; width: 10px; height: 10px; border-radius: 50%; background: var(--blue-500); box-shadow: 0 0 0 6px var(--blue-100); }
.area-call-card .btn { width: 100%; justify-content: center; }
.issue-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 20px; }
.issue-card { position: relative; min-height: 230px; padding: 30px; border-radius: var(--radius); background: var(--white); box-shadow: var(--shadow); border: 1px solid rgba(15,42,71,.06); overflow: hidden; }
.issue-card::after { content: ''; position: absolute; right: -32px; top: -32px; width: 110px; height: 110px; border-radius: 50%; background: var(--blue-100); opacity: .75; }
.issue-marker { width: 38px; height: 38px; display: block; border-radius: 14px; margin-bottom: 18px; background: linear-gradient(135deg, var(--blue-500), var(--blue-900)); box-shadow: 0 14px 28px rgba(8,118,216,.2); }
.issue-card h3 { position: relative; z-index: 1; }
.issue-card p { position: relative; z-index: 1; margin: 0; color: var(--muted); }
.area-columns-page { display: grid; grid-template-columns: repeat(2, 1fr); gap: 24px; }
.area-column-links { display: grid; grid-template-columns: repeat(2, 1fr); gap: 10px; }
.area-column-links a { display: flex; align-items: center; gap: 8px; padding: 11px 12px; border-radius: 13px; background: var(--soft); font-weight: 700; }
.contact-line { display: inline-flex; align-items: center; gap: 10px; color: var(--blue-700); font-weight: 700; }
.contact-icon { width: 22px; height: 22px; }

.faq-layout { display: grid; grid-template-columns: minmax(260px, .75fr) minmax(0, 1.25fr); gap: clamp(28px, 5vw, 72px); align-items: start; }
.faq-intro { position: sticky; top: calc(var(--header-height) + 24px); }
.faq-intro p:not(.eyebrow) { color: var(--muted); }
.faq-list { display: grid; gap: 14px; }
.faq-item { border-radius: 18px; background: var(--white); box-shadow: var(--shadow); border: 1px solid rgba(15,42,71,.06); overflow: hidden; }
.faq-section:not(.soft-bg) .faq-item { background: var(--soft); box-shadow: none; border-color: rgba(15,42,71,.08); }
.faq-item summary { cursor: pointer; list-style: none; position: relative; padding: 22px 58px 22px 24px; font-weight: 800; color: var(--ink); }
.faq-item summary::-webkit-details-marker { display: none; }
.faq-item summary::after { content: '+'; position: absolute; right: 22px; top: 50%; transform: translateY(-50%); width: 30px; height: 30px; border-radius: 50%; display: grid; place-items: center; background: var(--blue-100); color: var(--blue-700); font-size: 1.3rem; line-height: 1; }
.faq-item[open] summary::after { content: '−'; }
.faq-item p { padding: 0 24px 24px; margin: 0; color: var(--muted); }

.site-footer { padding: 70px 0 28px; background: var(--blue-900); color: var(--white); }
.footer-grid { display: grid; grid-template-columns: 1.4fr repeat(5, 1fr); gap: 30px; }
.footer-about p, .footer-bottom, .footer-col li, .footer-col a { color: rgba(255,255,255,.8); }
.footer-col a:hover, .footer-col a:focus-visible, .footer-service-links a:hover, .footer-service-links a:focus-visible { color: var(--white); text-decoration: underline; text-underline-offset: 4px; }
.footer-col h3, .footer-about h2 { font-size: 1rem; margin-bottom: 14px; font-weight: 700; }
.footer-col ul { list-style: none; padding: 0; margin: 0; }
.footer-col li { margin-bottom: 8px; font-size: .92rem; }
.footer-phone { display: inline-flex; align-items: center; gap: 8px; font-weight: 700; }
.footer-inline-icon { width: 18px; height: 18px; }
.footer-service-links { display: flex; flex-wrap: wrap; gap: 10px; border-top: 1px solid rgba(255,255,255,.16); margin-top: 38px; padding-top: 22px; }
.footer-service-links a { display: inline-flex; align-items: center; gap: 7px; padding: 9px 12px; border-radius: 999px; background: rgba(255,255,255,.1); color: rgba(255,255,255,.88); font-size: .92rem; }
.footer-bottom { display: flex; justify-content: space-between; gap: 20px; border-top: 1px solid rgba(255,255,255,.16); margin-top: 24px; padding-top: 22px; font-size: .85rem; }
.footer-bottom p { margin: 0; }
.back-to-top { position: fixed; right: 28px; bottom: 28px; z-index: 90; width: 54px; height: 54px; border-radius: 50%; display: grid; place-items: center; color: var(--white); background: var(--blue-700); box-shadow: 0 12px 30px rgba(0,0,0,.22); opacity: 0; visibility: hidden; transform: translateY(10px); transition: opacity .2s ease, transform .2s ease, visibility .2s ease; }
.back-to-top.is-visible { opacity: 1; visibility: visible; transform: translateY(0); }
.back-top-icon { width: 22px; height: 22px; transform: rotate(-90deg); }

@media (max-width: 1120px) {
    .site-nav { gap: 18px; font-size: .9rem; }
    .nav-phone { padding-inline: .78rem; }
    .area-link-grid { grid-template-columns: repeat(3, 1fr); }
    .issue-grid { grid-template-columns: repeat(2, 1fr); }
    .footer-grid { grid-template-columns: 1.5fr repeat(3, 1fr); }
}
@media (max-width: 980px) {
    :root { --header-height: 76px; }
    .nav-toggle { display: inline-flex; order: 3; }
    .nav-phone { order: 2; margin-left: auto; }
    .site-nav { position: fixed; top: calc(var(--header-height) + 12px); left: 20px; right: 20px; display: none; flex-direction: column; align-items: stretch; gap: 4px; padding: 18px; background: rgba(3, 35, 61, .98); border: 1px solid rgba(255,255,255,.14); border-radius: 18px; box-shadow: var(--shadow-strong); margin-left: 0; }
    .site-nav.is-open { display: flex; }
    .site-nav > a, .dropdown-toggle { width: 100%; padding: 12px; text-align: left; border-radius: 12px; }
    .site-nav > a::after, .dropdown-toggle::after { display: none; }
    .site-nav > a:hover, .dropdown-toggle:hover, .site-nav > a.is-current, .nav-dropdown.is-current .dropdown-toggle { background: rgba(255,255,255,.1); }
    .dropdown-toggle { justify-content: space-between; }
    .nav-dropdown::before { display: none; }
    .dropdown-menu { position: static; transform: none; min-width: 0; display: none; opacity: 1; pointer-events: auto; margin: 4px 0 8px; padding: 8px; background: rgba(255,255,255,.07); box-shadow: none; }
    .nav-dropdown:hover .dropdown-menu, .nav-dropdown:focus-within .dropdown-menu { transform: none; }
    .nav-dropdown.is-open .dropdown-menu { display: grid; transform: none; }
    .hero { min-height: 760px; }
    .hero-inner { grid-template-columns: 1fr; align-content: center; gap: 30px; }
    .hero-side-panel { align-self: auto; margin: 0; max-width: 620px; }
    .slider-controls { margin-top: 0; }
    .hero-proof, .quick-grid, .service-grid, .split-grid, .footer-grid, .detail-grid, .two-columns, .contact-grid, .area-columns-page, .faq-layout { grid-template-columns: 1fr 1fr; }
    .copy-card-offset { grid-column: auto; }
    .footer-about { grid-column: 1 / -1; }
    .detail-card, .faq-intro { position: static; }
}
@media (max-width: 680px) {
    .container { width: min(100% - 28px, var(--max)); }
    .brand-mark { font-size: 1.65rem; }
    .brand-small { font-size: .56rem; letter-spacing: .32em; }
    .nav-wrap { gap: 10px; }
    .nav-phone { min-height: 40px; padding: .5rem .72rem; font-size: .86rem; }
    .hero { min-height: 780px; }
    .hero-inner, .page-hero-inner { padding-top: calc(var(--header-height) + 24px); }
    .hero-copy-block, .page-hero-copy { text-align: left; }
    .hero-kicker { border-radius: 20px; max-width: 100%; line-height: 1.35; }
    .hero-actions { width: 100%; }
    .hero-actions .btn { flex: 1 1 100%; }
    .hero-side-panel { padding: 20px; border-radius: 22px; }
    .quick-grid, .service-grid, .split-grid, .footer-grid, .detail-grid, .two-columns, .contact-grid, .area-link-grid, .small-area-grid, .area-columns-page, .area-column-links, .faq-layout, .issue-grid { grid-template-columns: 1fr; }
    .quick-card { min-height: auto; }
    .image-card { min-height: 320px; }
    .page-hero { min-height: 590px; }
    .cta-card, .footer-bottom { flex-direction: column; align-items: flex-start; }
    .back-to-top { right: 18px; bottom: 18px; width: 50px; height: 50px; }
}
@media (max-width: 440px) {
    .nav-phone span { display: none; }
    .nav-phone { width: 42px; padding: 0; }
    .nav-toggle-text { display: none; }
    .nav-toggle { width: 42px; justify-content: center; padding: .6rem; }
}
@media (prefers-reduced-motion: reduce) {
    *, *::before, *::after { animation-duration: .01ms !important; animation-iteration-count: 1 !important; scroll-behavior: auto !important; transition-duration: .01ms !important; }
}
