:root {
  --blue: #07569c;
  --blue-dark: #06355f;
  --blue-deep: #052b4e;
  --blue-light: #e8f3fb;
  --cyan: #03a4cf;
  --green: #4aa357;
  --ink: #102c43;
  --muted: #5e7181;
  --line: #dce6ec;
  --surface: #f5f9fb;
  --white: #fff;
  --shadow: 0 24px 70px rgba(12, 55, 87, .12);
  --radius: 22px;
  --container: 1180px;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; scroll-padding-top: 110px; }
body {
  position: relative;
  margin: 0;
  color: var(--ink);
  background: var(--white);
  font-family: Inter, ui-sans-serif, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  font-size: 16px;
  line-height: 1.65;
  -webkit-font-smoothing: antialiased;
}
body::before { content: ""; position: fixed; z-index: 0; inset: -35%; pointer-events: none; opacity: .3; background: repeating-linear-gradient(120deg, transparent 0 165px, rgba(3,164,207,.025) 166px 167px, rgba(3,164,207,.065) 168px, rgba(3,164,207,.025) 169px 170px, transparent 171px 325px); background-size: 720px 720px; animation: global-lines 24s linear infinite; }
body > * { position: relative; z-index: 1; }
img, svg { display: block; max-width: 100%; }
a { color: inherit; text-decoration: none; }
button, input, textarea { font: inherit; }
button, a { -webkit-tap-highlight-color: transparent; }
:focus-visible { outline: 3px solid #f3bd34; outline-offset: 4px; }
.container { width: min(calc(100% - 40px), var(--container)); margin-inline: auto; }
.sr-only { position: absolute; width: 1px; height: 1px; overflow: hidden; clip: rect(0, 0, 0, 0); white-space: nowrap; }
.skip-link { position: fixed; top: 10px; left: 10px; z-index: 1000; padding: 10px 16px; background: #fff; transform: translateY(-150%); }
.skip-link:focus { transform: translateY(0); }

.topbar { background: var(--blue-deep); color: #d9e9f5; font-size: 13px; }
.topbar-inner { min-height: 38px; display: flex; align-items: center; justify-content: space-between; gap: 20px; }
.topbar p { margin: 0; display: flex; align-items: center; gap: 8px; }
.status-dot { width: 7px; height: 7px; border-radius: 50%; background: #62d47b; box-shadow: 0 0 0 4px rgba(98, 212, 123, .14); }
.topbar-links { display: flex; gap: 28px; }
.topbar a:hover { color: #fff; }

.site-header { position: sticky; top: 0; z-index: 100; background: rgba(255, 255, 255, .95); backdrop-filter: blur(14px); border-bottom: 1px solid rgba(220, 230, 236, .8); transition: box-shadow .3s ease, background .3s ease; }
.site-header.is-compact { background: rgba(255,255,255,.985); box-shadow: 0 10px 35px rgba(12,55,87,.1); }
.nav-wrap { min-height: 86px; display: flex; align-items: center; justify-content: space-between; gap: 30px; transition: min-height .3s ease; }
.is-compact .nav-wrap { min-height: 70px; }
.brand { width: 150px; height: 64px; display: flex; align-items: center; overflow: hidden; transition: width .3s ease, height .3s ease; }
.brand img { width: 142px; height: auto; transition: width .3s ease; }
.is-compact .brand { width: 126px; height: 52px; }
.is-compact .brand img { width: 120px; }
.main-nav { display: flex; align-items: center; gap: 31px; font-size: 14px; font-weight: 650; }
.main-nav > a:not(.nav-call) { position: relative; padding: 31px 0; }
.main-nav > a:not(.nav-call)::after { content: ""; position: absolute; left: 0; right: 100%; bottom: 21px; height: 2px; background: var(--cyan); transition: right .25s; }
.main-nav > a:not(.nav-call):hover::after { right: 0; }
.is-compact .main-nav > a:not(.nav-call), .is-compact .nav-dropdown > button { padding-top: 23px; padding-bottom: 23px; }
.is-compact .main-nav > a:not(.nav-call)::after { bottom: 15px; }
.nav-dropdown { position: relative; }
.nav-dropdown > button { padding: 31px 0; display: flex; align-items: center; gap: 5px; color: var(--ink); background: none; border: 0; cursor: pointer; font-size: 14px; font-weight: 650; }
.nav-dropdown > button span { color: var(--blue); font-size: 15px; transition: transform .2s; }
.nav-dropdown > button[aria-expanded="true"] span { transform: rotate(180deg); }
.nav-dropdown-menu { position: absolute; top: calc(100% - 12px); right: 0; min-width: 165px; padding: 9px; display: none; background: #fff; border: 1px solid var(--line); border-radius: 12px; box-shadow: 0 18px 45px rgba(12,55,87,.15); }
.nav-dropdown.open .nav-dropdown-menu { display: grid; }
.nav-dropdown-menu a { padding: 9px 11px; border-radius: 7px; font-size: 13px; }
.nav-dropdown-menu a:hover { color: var(--blue); background: var(--blue-light); }
.nav-call { display: flex; align-items: center; gap: 9px; padding: 11px 17px; color: #fff; background: var(--blue); border-radius: 10px; box-shadow: 0 8px 20px rgba(7, 86, 156, .2); }
.nav-call { animation: call-pulse 3.8s ease-in-out infinite; transition: transform .22s ease, background .22s ease, box-shadow .22s ease; }
.nav-call:hover, .nav-call:focus-visible { background: #06477f; transform: translateY(-2px); box-shadow: 0 13px 28px rgba(7,86,156,.3); }
.nav-call svg, .button svg, .mobile-call-bar svg { width: 18px; fill: currentColor; }
.menu-toggle { display: none; border: 0; background: none; padding: 8px; }
.menu-toggle > span:not(.sr-only) { width: 26px; height: 2px; margin: 5px 0; display: block; background: var(--ink); transition: .25s; }

.hero { position: relative; overflow: hidden; padding: 84px 0 0; background: linear-gradient(135deg, #f7fbfe 0%, #eef7fc 58%, #fff 100%); }
.hero::before { content: ""; position: absolute; inset: 0; opacity: .42; background-image: linear-gradient(rgba(7,86,156,.035) 1px, transparent 1px), linear-gradient(90deg, rgba(7,86,156,.035) 1px, transparent 1px); background-size: 42px 42px; mask-image: linear-gradient(to right, #000, transparent 75%); }
.hero::after { content: ""; position: absolute; z-index: 0; inset: -35% -20%; pointer-events: none; opacity: .58; background: repeating-linear-gradient(120deg, transparent 0 115px, rgba(3,164,207,.035) 116px 117px, rgba(3,164,207,.09) 118px, rgba(3,164,207,.035) 119px 120px, transparent 121px 230px); background-size: 520px 520px; animation: move-lines 18s linear infinite; }
.hero-orb { position: absolute; border-radius: 50%; filter: blur(2px); }
.hero-orb-one { width: 340px; height: 340px; right: -100px; top: 20px; background: rgba(3,164,207,.09); }
.hero-orb-two { width: 230px; height: 230px; left: 42%; bottom: 40px; background: rgba(74,163,87,.07); }
.hero-grid { position: relative; z-index: 1; display: grid; grid-template-columns: 1.08fr .92fr; align-items: center; gap: 70px; min-height: 540px; }
.eyebrow { margin: 0 0 15px; color: var(--blue); font-size: 12px; font-weight: 800; letter-spacing: .15em; text-transform: uppercase; display: flex; align-items: center; gap: 10px; }
.eyebrow span { width: 27px; height: 2px; background: var(--cyan); }
.eyebrow.light { color: #8edcf2; }
h1, h2, h3 { margin-top: 0; line-height: 1.15; letter-spacing: -.035em; }
h1 { margin-bottom: 24px; font-size: clamp(44px, 5vw, 68px); color: var(--blue-deep); }
h1 em { color: var(--blue); font-style: normal; }
.hero-tagline { margin: -8px 0 17px; color: var(--blue); font-size: clamp(20px, 2.2vw, 27px); font-weight: 800; letter-spacing: .025em; }
.hero-lead { max-width: 630px; margin: 0 0 30px; color: var(--muted); font-size: 18px; line-height: 1.72; }
.hero-actions { display: flex; flex-wrap: wrap; gap: 13px; }
.button { position: relative; min-height: 52px; padding: 13px 21px; display: inline-flex; align-items: center; justify-content: center; gap: 10px; overflow: hidden; border: 0; border-radius: 10px; cursor: pointer; font-weight: 750; transition: transform .35s cubic-bezier(.2,.75,.25,1), box-shadow .35s ease, background .35s ease, border-color .35s ease; }
.button::after { content: ""; position: absolute; inset: 0; pointer-events: none; background: linear-gradient(110deg, transparent 20%, rgba(255,255,255,.24) 48%, transparent 76%); transform: translateX(-140%); transition: transform .65s ease; }
.button:hover, .button:focus-visible { transform: translateY(-4px) scale(1.015); }
.button:hover::after, .button:focus-visible::after { transform: translateX(140%); }
.button-primary { color: #fff; background: var(--blue); box-shadow: 0 12px 30px rgba(7, 86, 156, .24); }
.button-primary:hover, .button-primary:focus-visible { background: #064b88; box-shadow: 0 18px 42px rgba(7, 86, 156, .36), 0 0 0 4px rgba(3,164,207,.08); }
.button-secondary { color: var(--blue); background: #fff; border: 1px solid #cfdee8; }
.button-secondary:hover, .button-secondary:focus-visible { border-color: rgba(3,164,207,.55); box-shadow: 0 16px 36px rgba(12,55,87,.14), 0 0 0 4px rgba(3,164,207,.07); }
.hero-trust { margin-top: 37px; display: flex; gap: 34px; }
.hero-trust div { display: flex; flex-direction: column; position: relative; }
.hero-trust div + div::before { content: ""; position: absolute; left: -17px; top: 3px; width: 1px; height: 35px; background: #cfdee8; }
.hero-trust strong { color: var(--blue-deep); font-size: 15px; }
.hero-trust span { color: var(--muted); font-size: 12px; }
.hero-visual { position: relative; animation: hero-float 6s ease-in-out infinite; }
.visual-panel { position: relative; min-height: 455px; border-radius: 36px 36px 36px 100px; background: linear-gradient(145deg, #075b9f, #043c6d); box-shadow: 0 35px 80px rgba(4, 60, 109, .27); overflow: hidden; }
.visual-panel::before { content: ""; position: absolute; width: 310px; height: 310px; border: 1px solid rgba(255,255,255,.13); border-radius: 50%; right: -50px; top: -30px; box-shadow: 0 0 0 55px rgba(255,255,255,.025), 0 0 0 110px rgba(255,255,255,.02); }
.cross-pattern { position: absolute; inset: 0; opacity: .08; background-image: linear-gradient(90deg, transparent 47%, white 47%, white 53%, transparent 53%), linear-gradient(transparent 47%, white 47%, white 53%, transparent 53%); background-size: 42px 42px; mask-image: linear-gradient(135deg, #000, transparent 60%); }
.route-card { position: absolute; left: 42px; right: 42px; top: 47px; padding: 25px 25px 21px; background: rgba(255,255,255,.98); border-radius: 18px; box-shadow: 0 20px 50px rgba(0,0,0,.17); }
.route-label { color: var(--muted); font-size: 12px; font-weight: 700; text-transform: uppercase; letter-spacing: .1em; }
.route-line { margin: 21px 4px 8px; display: flex; align-items: center; }
.route-point { flex: 0 0 auto; width: 14px; height: 14px; border-radius: 50%; border: 4px solid; }
.start-point { border-color: var(--cyan); box-shadow: 0 0 0 5px rgba(3,164,207,.12); }
.end-point { border-color: var(--green); box-shadow: 0 0 0 5px rgba(74,163,87,.12); }
.route-dash { flex: 1; height: 2px; overflow: hidden; background: repeating-linear-gradient(90deg, #b5c8d4 0 6px, transparent 6px 11px); background-size: 22px 2px; animation: route-flow 2.2s linear infinite; }
.route-line svg { width: 42px; margin-inline: 10px; fill: var(--blue); }
.route-places { display: flex; justify-content: space-between; color: var(--muted); font-size: 11px; }
.visual-message { position: absolute; z-index: 2; left: 24px; right: 76px; top: 242px; padding: 16px 18px; display: flex; align-items: center; gap: 13px; border: 1px solid rgba(255,255,255,.17); border-radius: 14px; color: #fff; background: rgba(255,255,255,.1); backdrop-filter: blur(10px); }
.message-icon { width: 36px; height: 36px; display: grid; place-items: center; border-radius: 50%; color: #fff; background: var(--green); }
.message-icon svg { width: 22px; fill: currentColor; }
.visual-message div { display: flex; flex-direction: column; }
.visual-message strong { font-size: 14px; }
.visual-message div span { color: #cce2ef; font-size: 12px; }
.visual-call { position: absolute; z-index: 2; left: 50px; right: 50px; bottom: 39px; padding-top: 21px; display: flex; align-items: flex-end; justify-content: space-between; border-top: 1px solid rgba(255,255,255,.2); color: #fff; }
.visual-call span { max-width: 130px; color: #bcd8e9; font-size: 11px; line-height: 1.45; }
.visual-call a { font-size: 22px; font-weight: 800; letter-spacing: -.03em; }
.trust-strip { position: relative; margin-top: 72px; padding: 21px 0; display: flex; align-items: center; justify-content: space-between; gap: 25px; border-top: 1px solid #d8e5ec; }
.trust-strip p { margin: 0; color: var(--muted); font-size: 12px; font-weight: 700; text-transform: uppercase; letter-spacing: .08em; }
.trust-items { flex: 1; display: flex; justify-content: flex-end; gap: 30px; }
.trust-items span { display: flex; align-items: center; gap: 8px; color: #486272; font-size: 12px; font-weight: 650; }
.trust-items svg { width: 18px; fill: var(--blue); }

.section, .location-section { position: relative; overflow: hidden; }
.section { padding: 105px 0; }
.section::before, .location-section::before { content: ""; position: absolute; z-index: 0; inset: -45% -20%; pointer-events: none; opacity: .42; background: repeating-linear-gradient(120deg, transparent 0 145px, rgba(3,164,207,.025) 146px 147px, rgba(3,164,207,.07) 148px, rgba(3,164,207,.025) 149px 150px, transparent 151px 285px); background-size: 620px 620px; animation: move-lines 20s linear infinite; }
.section > .container, .location-section > .container { position: relative; z-index: 1; }
.process::before, .contact::before { opacity: .22; background: repeating-linear-gradient(120deg, transparent 0 145px, rgba(255,255,255,.025) 146px 147px, rgba(255,255,255,.1) 148px, rgba(255,255,255,.025) 149px 150px, transparent 151px 285px); }
.section-heading { max-width: 650px; margin-bottom: 49px; }
.section-heading.centered { margin-inline: auto; text-align: center; }
.section-heading.centered .eyebrow { justify-content: center; }
.section-heading h2, .about-copy h2, .contact-info h2 { margin-bottom: 18px; font-size: clamp(34px, 4vw, 48px); color: var(--blue-deep); }
.section-heading > p:last-child { margin: 0; color: var(--muted); font-size: 17px; }
.service-promise { background: #fff; }
.promise-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 17px; }
.promise-card { position: relative; min-height: 230px; padding: 29px 25px; overflow: hidden; outline: none; background: linear-gradient(145deg, #fff, #f7fbfd); border: 1px solid var(--line); border-radius: 18px; transition: transform .35s cubic-bezier(.2,.75,.25,1), box-shadow .35s ease, border-color .35s ease, background .35s ease; }
.promise-card:hover, .promise-card:focus-visible, .promise-card.press-feedback { transform: translateY(-10px) scale(1.02); border-color: rgba(3,164,207,.65); background: linear-gradient(145deg, #fff 5%, #e9f6fc 100%); box-shadow: 0 28px 65px rgba(7,86,156,.18), 0 0 0 4px rgba(3,164,207,.08), inset 0 1px 0 rgba(255,255,255,.8); }
.promise-card > span { position: absolute; right: 18px; top: 13px; color: rgba(7,86,156,.08); font-size: 48px; font-weight: 900; line-height: 1; }
.promise-card::before { content: ""; width: 38px; height: 4px; margin-bottom: 27px; display: block; background: linear-gradient(90deg, var(--blue), var(--cyan)); border-radius: 3px; box-shadow: 0 0 0 rgba(3,164,207,0); transition: width .35s ease, box-shadow .35s ease; }
.promise-card:hover::before, .promise-card:focus-visible::before, .promise-card.press-feedback::before { width: 54px; box-shadow: 0 0 16px rgba(3,164,207,.42); }
.promise-card h3 { margin-bottom: 11px; color: var(--blue-deep); font-size: 18px; transition: color .35s ease, font-weight .35s ease; }
.promise-card:hover h3, .promise-card:focus-visible h3, .promise-card.press-feedback h3 { color: var(--blue); font-weight: 800; }
.promise-card p { margin: 0; color: var(--muted); font-size: 13px; line-height: 1.6; }
.service-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 22px; }
.service-card { position: relative; min-height: 360px; padding: 35px 31px 29px; display: flex; flex-direction: column; color: var(--ink); background: #fff; border: 1px solid var(--line); border-radius: var(--radius); overflow: hidden; outline: none; transition: transform .32s cubic-bezier(.2,.75,.25,1), box-shadow .32s ease, border-color .32s ease, background .32s ease, color .32s ease; }
.service-card:hover, .service-card:focus-visible, .service-card.press-feedback { color: var(--ink); background: linear-gradient(145deg, #fff 3%, #e7f5fc 100%); border-color: rgba(3,164,207,.68); transform: translateY(-10px) scale(1.02); box-shadow: 0 30px 70px rgba(7,86,156,.2), 0 0 0 4px rgba(3,164,207,.09), inset 0 1px 0 rgba(255,255,255,.9); }
.card-number { position: absolute; right: 22px; top: 15px; color: rgba(7,86,156,.08); font-size: 72px; font-weight: 900; line-height: 1; }
.service-card:hover .card-number, .service-card:focus-visible .card-number, .service-card.press-feedback .card-number { color: rgba(7,86,156,.13); }
.service-icon { width: 58px; height: 58px; margin-bottom: 30px; display: grid; place-items: center; border-radius: 15px; color: var(--blue); background: var(--blue-light); }
.service-icon, .service-icon svg { transition: transform .32s ease, color .32s ease, background .32s ease; }
.service-icon svg { width: 30px; fill: currentColor; }
.service-card:hover .service-icon, .service-card:focus-visible .service-icon, .service-card.press-feedback .service-icon { color: #fff; background: linear-gradient(145deg, var(--blue), var(--cyan)); transform: scale(1.12) translateY(-3px); box-shadow: 0 12px 28px rgba(3,164,207,.34), 0 0 18px rgba(3,164,207,.2); }
.service-card:hover .service-icon svg, .service-card:focus-visible .service-icon svg, .service-card.press-feedback .service-icon svg { transform: scale(1.04); }
.service-card h3 { margin-bottom: 14px; font-size: 22px; transition: color .35s ease, font-weight .35s ease; }
.service-card:hover h3, .service-card:focus-visible h3, .service-card.press-feedback h3 { color: var(--blue); font-weight: 800; }
.service-card p { margin: 0; color: var(--muted); font-size: 15px; transition: color .32s ease; }
.service-card:hover p, .service-card:focus-visible p, .service-card.press-feedback p { color: #486879; }
.service-card a { margin-top: auto; padding-top: 22px; color: var(--blue); font-size: 13px; font-weight: 800; transition: color .32s ease, transform .32s ease; }
.service-card:hover a, .service-card:focus-visible a, .service-card.press-feedback a { color: var(--blue); transform: translateX(4px); }
.expanded-services { grid-template-columns: repeat(3, 1fr); }
.expanded-services .service-card { min-height: 340px; }
.service-disclaimer { max-width: 900px; margin: 27px auto 0; padding: 14px 18px; color: var(--muted); background: var(--surface); border-left: 3px solid var(--cyan); border-radius: 0 9px 9px 0; font-size: 12px; }

.why-us { background: var(--surface); }
.split-grid { display: grid; grid-template-columns: .9fr 1.1fr; align-items: center; gap: 95px; }
.about-visual { position: relative; padding: 18px 0 45px 18px; }
.about-shape { position: relative; min-height: 490px; padding: 55px 42px; display: flex; flex-direction: column; justify-content: flex-end; overflow: hidden; color: #fff; background: linear-gradient(145deg, #064b87, #052d50); border-radius: 120px 26px 26px 26px; box-shadow: 0 30px 70px rgba(7,86,156,.22); }
.about-shape::before { content: ""; position: absolute; inset: 0; background: radial-gradient(circle at 85% 10%, rgba(3,164,207,.45), transparent 36%), linear-gradient(120deg, transparent 45%, rgba(255,255,255,.04) 45%); }
.about-logo { position: absolute; top: 50px; left: 43px; width: 215px; }
.about-pulse { position: absolute; left: -30px; right: -30px; top: 190px; opacity: .23; }
.about-pulse path { fill: none; stroke: #fff; stroke-width: 4; }
.about-shape p { position: relative; z-index: 1; margin: 0; font-size: 31px; font-weight: 800; line-height: 1.2; letter-spacing: -.04em; }
.experience-badge { position: absolute; right: -30px; bottom: 0; width: 140px; height: 140px; display: flex; flex-direction: column; align-items: center; justify-content: center; color: var(--blue-deep); background: #fff; border: 1px solid var(--line); border-radius: 50%; box-shadow: var(--shadow); }
.experience-badge strong { font-size: 37px; line-height: 1; }
.experience-badge span { color: var(--muted); font-size: 12px; }
.about-copy .large-copy { color: #324d60; font-size: 18px; font-weight: 600; }
.about-copy > p:not(.eyebrow) { color: var(--muted); }
.benefit-list { margin-top: 32px; display: grid; grid-template-columns: 1fr 1fr; gap: 22px 25px; }
.benefit-list > div { display: flex; gap: 12px; }
.check { flex: 0 0 27px; width: 27px; height: 27px; display: grid; place-items: center; color: #fff; background: var(--green); border-radius: 50%; font-size: 13px; font-weight: 900; }
.benefit-list p { margin: 0; display: flex; flex-direction: column; line-height: 1.35; }
.benefit-list strong { font-size: 14px; }
.benefit-list small { margin-top: 4px; color: var(--muted); font-size: 12px; }

.team-section { background: #fff; }
.team-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 22px; }
.team-card { padding: 34px 31px; outline: none; background: var(--surface); border: 1px solid var(--line); border-radius: var(--radius); transition: transform .35s cubic-bezier(.2,.75,.25,1), box-shadow .35s ease, border-color .35s ease, background .35s ease; }
.team-card:hover, .team-card:focus-visible, .team-card.press-feedback { transform: translateY(-10px) scale(1.02); border-color: rgba(3,164,207,.65); background: linear-gradient(145deg, #fff, #e9f6fc); box-shadow: 0 30px 68px rgba(7,86,156,.19), 0 0 0 4px rgba(3,164,207,.08); }
.team-icon { width: 56px; height: 56px; margin-bottom: 25px; display: grid; place-items: center; color: #fff; background: linear-gradient(145deg, var(--blue), var(--cyan)); border-radius: 17px; box-shadow: 0 12px 25px rgba(7,86,156,.18); transition: transform .35s ease, box-shadow .35s ease, filter .35s ease; }
.team-icon svg { width: 28px; fill: currentColor; transition: transform .35s ease; }
.team-card:hover .team-icon, .team-card:focus-visible .team-icon, .team-card.press-feedback .team-icon { transform: translateY(-4px) scale(1.12); filter: saturate(1.16); box-shadow: 0 17px 34px rgba(3,164,207,.36), 0 0 20px rgba(3,164,207,.22); }
.team-card:hover .team-icon svg, .team-card:focus-visible .team-icon svg, .team-card.press-feedback .team-icon svg { transform: scale(1.06); }
.team-card h3 { margin-bottom: 12px; color: var(--blue-deep); font-size: 20px; transition: color .35s ease, font-weight .35s ease; }
.team-card:hover h3, .team-card:focus-visible h3, .team-card.press-feedback h3 { color: var(--blue); font-weight: 800; }
.team-card p { margin: 0; color: var(--muted); font-size: 14px; }
.team-note { max-width: 780px; margin: 24px auto 0; color: #748795; font-size: 11px; text-align: center; }

.process { color: #fff; background: var(--blue-deep); }
.process .section-heading h2 { color: #fff; }
.process-grid { display: grid; grid-template-columns: 1fr auto 1fr auto 1fr auto 1fr; align-items: center; gap: 15px; }
.process-step { min-height: 230px; padding: 31px; outline: none; border: 1px solid rgba(255,255,255,.12); border-radius: 18px; background: rgba(255,255,255,.045); transition: transform .35s cubic-bezier(.2,.75,.25,1), box-shadow .35s ease, background .35s ease, border-color .35s ease; }
.process-step:hover, .process-step:focus-visible, .process-step.press-feedback { transform: translateY(-10px) scale(1.02); background: linear-gradient(145deg, rgba(255,255,255,.12), rgba(3,164,207,.12)); border-color: rgba(110,216,242,.58); box-shadow: 0 26px 58px rgba(0,15,30,.3), 0 0 0 4px rgba(110,216,242,.08), inset 0 1px 0 rgba(255,255,255,.12); }
.step-number { width: 42px; height: 42px; margin-bottom: 25px; display: grid; place-items: center; color: var(--blue-deep); background: #fff; border-radius: 50%; font-weight: 900; transform: scale(.72); transition: transform .5s cubic-bezier(.2,.8,.2,1), box-shadow .35s ease, background .35s ease; }
.process-step.visible .step-number { transform: scale(1); }
.process-step:hover .step-number, .process-step:focus-visible .step-number, .process-step.press-feedback .step-number { transform: scale(1.12); background: #e9faff; box-shadow: 0 0 22px rgba(110,216,242,.42); }
.process-step h3 { margin-bottom: 12px; font-size: 20px; transition: color .35s ease; }
.process-step:hover h3, .process-step:focus-visible h3, .process-step.press-feedback h3 { color: #a5edfb; }
.process-step p { margin: 0; color: #b8d1e1; font-size: 14px; }
.step-arrow { color: #5e8ba8; font-size: 27px; animation: arrow-breathe 2s ease-in-out infinite; }

.reassurance { background: #fff; }
.reassurance-grid { display: grid; grid-template-columns: .9fr 1.1fr; gap: 25px; }
.quote-card { padding: 38px; color: #fff; background: linear-gradient(145deg, var(--blue), #064576); border-radius: var(--radius); }
.quote-mark { display: block; height: 54px; color: #75d7ef; font-family: Georgia, serif; font-size: 82px; line-height: 1; }
.quote-card > p { margin: 8px 0 30px; font-family: Georgia, serif; font-size: 24px; line-height: 1.5; }
.quote-author { display: flex; align-items: center; gap: 12px; }
.quote-author > span { width: 43px; height: 43px; display: grid; place-items: center; color: var(--blue); background: #fff; border-radius: 50%; font-size: 12px; font-weight: 900; }
.quote-author div { display: flex; flex-direction: column; }
.quote-author strong { font-size: 13px; }
.quote-author small { color: #b9d5e5; }
.stats-card { display: grid; grid-template-columns: repeat(3, 1fr); align-content: center; gap: 1px; padding: 35px; background: var(--surface); border: 1px solid var(--line); border-radius: var(--radius); }
.stats-card > div { min-height: 135px; padding: 22px; display: flex; flex-direction: column; justify-content: center; text-align: center; background: #fff; }
.stats-card > div:first-child { border-radius: 14px 0 0 14px; }
.stats-card > div:nth-child(3) { border-radius: 0 14px 14px 0; }
.stats-card strong { color: var(--blue); font-size: 31px; }
.stats-card span { color: var(--muted); font-size: 12px; line-height: 1.4; }
.placeholder-note, .form-note { grid-column: 1 / -1; margin: 18px 0 0; color: #6c7f8c; font-size: 11px; line-height: 1.5; }

.reviews-section { background: linear-gradient(145deg, #f7fbfd, #edf7fb); }
.reviews-layout { display: grid; grid-template-columns: .9fr 1.1fr; align-items: start; gap: 30px; }
.review-form, .reviews-display { padding: 35px; background: rgba(255,255,255,.96); border: 1px solid var(--line); border-radius: var(--radius); box-shadow: 0 24px 65px rgba(12,55,87,.1); backdrop-filter: blur(8px); }
.review-form { position: sticky; top: 95px; }
.site-reviews-panel { grid-column: 1 / -1; }
.site-reviews-panel[hidden] { display: none; }
.review-form-heading { margin-bottom: 27px; display: flex; align-items: center; gap: 15px; }
.review-form-icon { flex: 0 0 52px; width: 52px; height: 52px; display: grid; place-items: center; color: #fff; background: linear-gradient(145deg, var(--blue), var(--cyan)); border-radius: 15px; box-shadow: 0 12px 27px rgba(3,164,207,.25); }
.review-form-icon svg { width: 27px; fill: currentColor; }
.review-form-heading h3, .reviews-display-heading h3 { margin: 0 0 5px; color: var(--blue-deep); font-size: 25px; }
.review-form-heading p { margin: 0; color: var(--muted); font-size: 13px; }
.review-fields { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; }
.review-form label, .star-fieldset legend { color: #304b5d; font-size: 12px; font-weight: 750; }
.review-fields label > span[aria-hidden="true"], .review-comment-label > span[aria-hidden="true"], .star-fieldset legend > span { color: #cf3e3e; }
.review-form label small { color: var(--muted); font-size: 10px; font-weight: 500; }
.review-form input[type="text"], .review-form input[type="email"], .review-form textarea { width: 100%; margin-top: 6px; padding: 12px 13px; color: var(--ink); background: #fff; border: 1px solid #cddce5; border-radius: 9px; outline: none; transition: border-color .25s ease, box-shadow .25s ease, transform .25s ease; }
.review-form input[type="text"], .review-form input[type="email"] { height: 47px; }
.review-form textarea { resize: vertical; }
.review-form input[type="text"]:focus, .review-form input[type="email"]:focus, .review-form textarea:focus { border-color: var(--cyan); box-shadow: 0 0 0 4px rgba(3,164,207,.1); transform: translateY(-1px); }
.star-fieldset { margin: 22px 0; padding: 0; border: 0; }
.star-fieldset legend { margin-bottom: 7px; }
.star-rating { width: max-content; display: flex; flex-direction: row-reverse; justify-content: flex-end; gap: 6px; }
.star-rating input { position: absolute; width: 1px; height: 1px; opacity: 0; pointer-events: none; }
.star-rating label { display: block; color: #cad8e1; cursor: pointer; font-size: 38px; line-height: 1; filter: drop-shadow(0 2px 3px rgba(12,55,87,.08)); transition: color .22s ease, transform .22s cubic-bezier(.2,.75,.25,1), filter .22s ease; }
.star-rating label > span[aria-hidden="true"] { color: inherit; }
.star-rating label:hover, .star-rating label:hover ~ label, .star-rating input:checked ~ label { color: #f2b632; filter: drop-shadow(0 5px 8px rgba(242,182,50,.28)); }
.star-rating label:hover { transform: translateY(-3px) scale(1.17) rotate(-4deg); }
.star-rating input:focus-visible + label { outline: 3px solid #f3bd34; outline-offset: 4px; border-radius: 4px; }
.star-rating input:checked + label { animation: star-pop .36s cubic-bezier(.2,.8,.2,1); }
.field-help { margin: 7px 0 0; color: var(--muted); font-size: 10px; }
.review-comment-label { display: block; }
.review-consent { margin: 18px 0; display: flex; align-items: flex-start; gap: 10px; color: var(--muted) !important; font-size: 11px !important; font-weight: 500 !important; line-height: 1.55; }
.review-consent input { flex: 0 0 auto; margin-top: 3px; accent-color: var(--blue); }
.review-submit { width: 100%; }
.review-storage-note { margin: 14px 0 0; color: #6c7f8c; font-size: 10px; line-height: 1.5; }
.review-status { min-height: 22px; margin: 9px 0 0; color: var(--green); font-size: 12px; font-weight: 750; }
.review-status.is-error { color: #b73535; }
.reviews-display-heading { margin-bottom: 24px; display: flex; align-items: flex-end; justify-content: space-between; gap: 18px; }
.reviews-display-heading .eyebrow { margin-bottom: 8px; }
.review-count { flex: 0 0 auto; padding: 6px 10px; color: var(--blue); background: var(--blue-light); border-radius: 999px; font-size: 11px; font-weight: 800; }
.google-rating-summary { margin: -4px 0 24px; padding: 18px 20px; display: flex; align-items: center; gap: 12px; background: linear-gradient(135deg, #f3faff, #fff); border: 1px solid #d4e7f0; border-radius: 14px; }
.google-rating-summary[hidden] { display: none; }
.google-rating-summary > strong { color: var(--blue-deep); font-size: 31px; line-height: 1; }
.google-summary-stars { color: #f2b632; font-size: 19px; letter-spacing: 2px; white-space: nowrap; }
.google-rating-summary > span:last-child { color: var(--muted); font-size: 11px; line-height: 1.4; }
.reviews-list { display: grid; gap: 16px; }
.review-card { position: relative; padding: 24px; overflow: hidden; background: linear-gradient(145deg, #fff, #f7fbfd); border: 1px solid var(--line); border-radius: 17px; box-shadow: 0 12px 30px rgba(12,55,87,.06); animation: review-enter .55s cubic-bezier(.2,.75,.25,1) both; transition: transform .3s ease, border-color .3s ease, box-shadow .3s ease; }
.review-card:hover { transform: translateY(-5px); border-color: rgba(3,164,207,.45); box-shadow: 0 22px 48px rgba(7,86,156,.12), 0 0 0 3px rgba(3,164,207,.05); }
.review-card::after { content: "“"; position: absolute; right: 18px; top: -12px; color: rgba(7,86,156,.06); font-family: Georgia, serif; font-size: 100px; line-height: 1; }
.review-card-header { position: relative; z-index: 1; display: flex; align-items: flex-start; justify-content: space-between; gap: 16px; }
.review-author { display: flex; align-items: center; gap: 11px; }
.review-avatar { flex: 0 0 42px; width: 42px; height: 42px; display: grid; place-items: center; color: #fff; background: linear-gradient(145deg, var(--blue), var(--cyan)); border-radius: 50%; font-size: 13px; font-weight: 900; }
.review-author div { display: flex; flex-direction: column; }
.review-author strong { color: var(--blue-deep); font-size: 14px; }
.review-meta { color: var(--muted); font-size: 10px; }
.review-stars { color: #f2b632; font-size: 16px; letter-spacing: 2px; white-space: nowrap; }
.review-card blockquote { position: relative; z-index: 1; margin: 18px 0 0; color: #4f6878; font-size: 14px; line-height: 1.7; }
.review-source-link { position: relative; z-index: 1; width: max-content; margin-top: 14px; display: inline-flex; color: var(--blue); font-size: 10px; font-weight: 800; text-decoration: underline; text-decoration-color: rgba(7,86,156,.25); text-underline-offset: 3px; }
.review-source-link:hover, .review-source-link:focus-visible { color: var(--cyan-dark); text-decoration-color: currentColor; }
.reviews-empty { min-height: 260px; padding: 35px; display: flex; flex-direction: column; align-items: center; justify-content: center; text-align: center; background: var(--surface); border: 1px dashed #bfd2dd; border-radius: 17px; }
.reviews-empty[hidden] { display: none; }
.reviews-empty > span { margin-bottom: 7px; color: #9dbacb; font-size: 49px; line-height: 1; }
.reviews-empty strong { color: var(--blue-deep); }
.reviews-empty p { max-width: 390px; margin: 7px 0 0; color: var(--muted); font-size: 12px; }
.google-attribution { width: max-content; margin: 22px 0 0 auto; padding: 9px 12px; display: flex; align-items: center; gap: 5px; color: #536b7a; background: #fff; border: 1px solid #d7e4eb; border-radius: 9px; font-size: 11px; transition: color .25s ease, border-color .25s ease, transform .25s ease, box-shadow .25s ease; }
.google-attribution strong { color: #4285f4; font-size: 13px; }
.google-attribution:hover, .google-attribution:focus-visible { color: var(--blue); border-color: rgba(7,86,156,.35); box-shadow: 0 8px 20px rgba(12,55,87,.08); transform: translateY(-2px); }

.faq { background: var(--surface); }
.faq-grid { display: grid; grid-template-columns: .75fr 1.25fr; gap: 90px; }
.text-link { color: var(--blue); font-size: 14px; font-weight: 800; }
.accordion details { border-top: 1px solid #cbdbe4; }
.accordion details:last-child { border-bottom: 1px solid #cbdbe4; }
.accordion summary { position: relative; padding: 22px 42px 22px 0; cursor: pointer; list-style: none; color: var(--blue-deep); font-weight: 750; }
.accordion summary::-webkit-details-marker { display: none; }
.accordion summary span::before, .accordion summary span::after { content: ""; position: absolute; top: 32px; right: 4px; width: 15px; height: 2px; background: var(--blue); transition: transform .2s; }
.accordion summary span::after { transform: rotate(90deg); }
.accordion details[open] summary span::after { transform: rotate(0); }
.accordion details p { margin: -5px 40px 23px 0; color: var(--muted); font-size: 14px; }

.contact { padding: 0; background: linear-gradient(90deg, var(--blue-deep) 0 50%, var(--surface) 50%); }
.contact-shell { display: grid; grid-template-columns: 1fr 1.1fr; }
.contact-info { padding: 90px 80px 90px 0; color: #fff; }
.contact-info h2 { color: #fff; }
.contact-info > p:not(.eyebrow) { color: #bad0df; }
.contact-main { margin: 32px 0; padding: 20px 18px; display: flex; align-items: center; gap: 16px; border: 1px solid rgba(255,255,255,.14); border-radius: 14px; background: rgba(255,255,255,.035); transition: transform .35s cubic-bezier(.2,.75,.25,1), box-shadow .35s ease, background .35s ease, border-color .35s ease; }
.contact-main:hover, .contact-main:focus-visible { transform: translateY(-7px) scale(1.015); background: linear-gradient(145deg, rgba(255,255,255,.11), rgba(3,164,207,.1)); border-color: rgba(110,216,242,.5); box-shadow: 0 24px 48px rgba(0,18,34,.28), 0 0 0 4px rgba(110,216,242,.07); }
.contact-icon { width: 45px; height: 45px; display: grid; place-items: center; color: var(--blue-deep); background: #fff; border-radius: 50%; transition: transform .35s ease, box-shadow .35s ease; }
.contact-icon svg { width: 21px; fill: currentColor; transition: transform .35s ease; }
.contact-main:hover .contact-icon, .contact-main:focus-visible .contact-icon { transform: scale(1.12); box-shadow: 0 0 22px rgba(110,216,242,.35); }
.contact-main:hover .contact-icon svg, .contact-main:focus-visible .contact-icon svg { transform: rotate(-7deg) scale(1.05); }
.contact-main > span:last-child { display: flex; flex-direction: column; }
.contact-main small { color: #a8c6d9; font-size: 11px; }
.contact-main strong { font-size: 26px; letter-spacing: -.02em; }
.contact-list { margin: 0; padding: 0; display: grid; gap: 18px; list-style: none; }
.contact-list li { padding: 12px 13px; display: flex; gap: 13px; color: #d4e2ec; background: rgba(255,255,255,.025); border: 1px solid transparent; border-radius: 11px; outline: none; font-size: 14px; transition: transform .35s ease, box-shadow .35s ease, background .35s ease, border-color .35s ease; }
.contact-list li:hover, .contact-list li:focus-visible, .contact-list li.press-feedback { transform: translateY(-5px) scale(1.01); background: rgba(255,255,255,.08); border-color: rgba(110,216,242,.4); box-shadow: 0 18px 38px rgba(0,18,34,.22), 0 0 0 3px rgba(110,216,242,.06); }
.contact-list svg { flex: 0 0 20px; width: 20px; margin-top: 3px; fill: #62cde7; transition: transform .35s ease, filter .35s ease; }
.contact-list li:hover svg, .contact-list li:focus-visible svg, .contact-list li.press-feedback svg { transform: translateY(-2px) scale(1.14); filter: drop-shadow(0 0 6px rgba(110,216,242,.48)); }
.contact-form { padding: 75px 0 75px 80px; transition: filter .35s ease; }
.contact-form:hover, .contact-form:focus-within { filter: drop-shadow(0 18px 30px rgba(7,86,156,.08)); }
.form-heading h3 { margin-bottom: 8px; color: var(--blue-deep); font-size: 27px; }
.form-heading p { margin: 0 0 27px; color: var(--muted); font-size: 14px; }
.form-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 19px; }
.form-grid label { color: #304b5d; font-size: 12px; font-weight: 750; }
.form-grid label > span { color: #d34040; }
.form-grid input, .form-grid textarea { width: 100%; margin-top: 6px; padding: 12px 13px; color: var(--ink); background: #fff; border: 1px solid #cddce5; border-radius: 8px; outline: none; transition: border .2s, box-shadow .2s; }
.form-grid input { height: 47px; }
.form-grid textarea { resize: vertical; }
.form-grid input:focus, .form-grid textarea:focus { border-color: var(--cyan); box-shadow: 0 0 0 3px rgba(3,164,207,.12); }
.full-width { grid-column: 1 / -1; }
.consent { margin: 17px 0; display: flex; align-items: flex-start; gap: 10px; color: var(--muted); font-size: 11px; line-height: 1.5; }
.consent input { margin-top: 3px; accent-color: var(--blue); }
.consent a { color: var(--blue); text-decoration: underline; }
.form-button { width: 100%; }

.location-section { padding: 85px 0; background: #fff; }
.location-grid { display: grid; grid-template-columns: .7fr 1.3fr; align-items: center; gap: 70px; }
.location-copy h2 { margin-bottom: 16px; color: var(--blue-deep); font-size: clamp(32px, 4vw, 44px); }
.location-copy > p:not(.eyebrow) { color: var(--muted); }
.location-button { width: auto; margin-top: 12px; }
.map-placeholder { position: relative; min-height: 330px; overflow: hidden; background: #eaf1f3; border: 1px solid #d4e0e5; border-radius: var(--radius); }
.map-placeholder::before, .map-placeholder::after { content: ""; position: absolute; inset: -20%; background: repeating-linear-gradient(28deg, transparent 0 48px, rgba(255,255,255,.85) 49px 58px, transparent 59px 115px); transform: rotate(-8deg); }
.map-placeholder::after { background: repeating-linear-gradient(112deg, transparent 0 75px, rgba(255,255,255,.6) 76px 84px, transparent 85px 155px); transform: rotate(10deg); }
.map-roads { position: absolute; inset: 0; opacity: .7; background-image: linear-gradient(90deg, transparent 49%, #cfe0e5 50%, transparent 51%), linear-gradient(transparent 49%, #cfe0e5 50%, transparent 51%); background-size: 80px 80px; }
.map-pin { position: absolute; z-index: 2; left: 53%; top: 42%; width: 55px; height: 55px; display: grid; place-items: center; color: #fff; background: var(--blue); border: 6px solid #fff; border-radius: 50% 50% 50% 8px; box-shadow: 0 12px 25px rgba(7,86,156,.3); transform: rotate(-45deg); }
.map-pin svg { width: 25px; fill: currentColor; transform: rotate(45deg); }
.map-label { position: absolute; z-index: 3; left: calc(53% + 43px); top: calc(42% + 5px); padding: 9px 12px; display: flex; flex-direction: column; background: #fff; border-radius: 8px; box-shadow: 0 9px 25px rgba(12,55,87,.14); font-size: 11px; }
.map-label span { color: var(--muted); }
.map-placeholder small { position: absolute; z-index: 3; left: 16px; bottom: 14px; padding: 5px 8px; color: #647987; background: rgba(255,255,255,.9); border-radius: 5px; font-size: 9px; }

.site-footer { position: relative; overflow: hidden; padding: 72px 0 0; color: #c2d2dc; background: #031f37; }
.site-footer::before { content: ""; position: absolute; z-index: 0; inset: -60% -20%; pointer-events: none; opacity: .15; background: repeating-linear-gradient(120deg, transparent 0 145px, rgba(255,255,255,.03) 146px 147px, rgba(110,216,242,.12) 148px, rgba(255,255,255,.03) 149px 150px, transparent 151px 285px); background-size: 620px 620px; animation: move-lines 23s linear infinite; }
.site-footer > .container { position: relative; z-index: 1; }
.footer-grid { display: grid; grid-template-columns: 1.6fr .75fr 1fr .85fr; gap: 55px; padding-bottom: 55px; }
.footer-brand img { width: 190px; }
.footer-brand p { max-width: 330px; color: #8fa8b8; font-size: 13px; }
.site-footer h2 { margin-bottom: 18px; color: #fff; font-size: 13px; letter-spacing: .08em; text-transform: uppercase; }
.site-footer ul { margin: 0; padding: 0; display: grid; gap: 9px; list-style: none; font-size: 13px; }
.site-footer a:hover { color: #fff; }
.site-footer a[aria-current="page"] { color: #fff; text-decoration: underline; text-underline-offset: 4px; }
.footer-contact { color: #9eb3c1; }
.footer-hours { color: #9eb3c1; font-size: 13px; }
.footer-hours strong { color: #fff; font-size: 15px; }
.footer-call { color: #6cd6ee; font-weight: 800; }
.footer-bottom { min-height: 65px; display: flex; align-items: center; justify-content: space-between; border-top: 1px solid rgba(255,255,255,.1); color: #7894a5; font-size: 11px; }
.footer-bottom div { display: flex; gap: 25px; }
.mobile-call-bar { display: none; }
.legal-footer { padding-top: 0; }
.legal-footer-links { min-height: 62px; display: flex; align-items: center; gap: 28px; border-bottom: 1px solid rgba(255,255,255,.1); color: #9eb3c1; font-size: 12px; }

.legal-main { position: relative; min-height: 65vh; overflow: hidden; padding: 75px 0 110px; background: linear-gradient(145deg, #f5f9fb, #eef7fb); }
.legal-main::before { content: ""; position: absolute; z-index: 0; inset: -35% -20%; pointer-events: none; opacity: .58; background: repeating-linear-gradient(120deg, transparent 0 140px, rgba(3,164,207,.025) 141px 142px, rgba(3,164,207,.075) 143px, rgba(3,164,207,.025) 144px 145px, transparent 146px 275px); background-size: 620px 620px; animation: move-lines 20s linear infinite; }
.legal-main > .container { position: relative; z-index: 1; }
.legal-header { max-width: 850px; margin-bottom: 35px; }
.legal-header h1 { margin-bottom: 10px; font-size: clamp(38px, 5vw, 58px); }
.legal-card { max-width: 900px; padding: 48px; background: rgba(255,255,255,.97); border: 1px solid rgba(205,222,232,.9); border-radius: var(--radius); box-shadow: 0 24px 65px rgba(12,55,87,.09); backdrop-filter: blur(8px); }
.legal-card h2 { margin: 32px 0 10px; color: var(--blue-deep); font-size: 21px; }
.legal-card h2:first-child { margin-top: 0; }
.legal-card p, .legal-card li { color: var(--muted); }
.legal-card a { color: var(--blue); text-decoration: underline; text-decoration-color: rgba(7,86,156,.3); text-underline-offset: 3px; }
.legal-card address { color: var(--muted); font-style: normal; }
.legal-section { scroll-margin-top: 105px; padding-top: 4px; }
.legal-section + .legal-section { margin-top: 27px; padding-top: 27px; border-top: 1px solid #e4edf2; }
.legal-section h2 { margin-top: 0; }
.legal-notice { margin-bottom: 30px; padding: 17px 19px; color: #714c00 !important; background: #fff7df; border: 1px solid #ead28a; border-radius: 11px; font-size: 13px; }
.placeholder-inline { padding: 2px 5px; color: #795300; background: #fff2c8; border-radius: 4px; font-size: .82em; font-weight: 800; letter-spacing: .03em; }
.legal-toc { margin: 0 0 36px; padding: 20px; display: flex; flex-wrap: wrap; align-items: center; gap: 10px 12px; background: var(--surface); border: 1px solid var(--line); border-radius: 13px; }
.legal-toc strong { margin-right: 5px; color: var(--blue-deep); }
.legal-toc a { padding: 5px 9px; color: var(--blue); background: #fff; border: 1px solid #d9e7ee; border-radius: 6px; font-size: 12px; font-weight: 700; text-decoration: none; transition: transform .2s ease, border-color .2s ease, box-shadow .2s ease; }
.legal-toc a:hover, .legal-toc a:focus-visible { transform: translateY(-2px); border-color: var(--cyan); box-shadow: 0 7px 16px rgba(7,86,156,.1); }
.legal-contact { margin: 0; display: grid; gap: 1px; background: var(--line); border: 1px solid var(--line); border-radius: 12px; overflow: hidden; }
.legal-contact div { padding: 11px 14px; display: grid; grid-template-columns: minmax(210px, .8fr) 1.2fr; gap: 18px; background: #fff; }
.legal-contact dt { color: var(--blue-deep); font-weight: 750; }
.legal-contact dd { margin: 0; color: var(--muted); }

.reveal { opacity: 0; transform: translateY(22px); transition: opacity .65s ease var(--reveal-delay, 0ms), transform .65s ease var(--reveal-delay, 0ms); }
.reveal.visible { opacity: 1; transform: none; }
.reveal-delay { --reveal-delay: 120ms; }

.hero-copy .eyebrow, .hero-copy h1, .hero-copy .hero-tagline, .hero-copy .hero-lead, .hero-copy .hero-actions, .hero-copy .hero-trust { opacity: 0; transform: translateY(18px); animation: hero-enter .7s cubic-bezier(.2,.75,.25,1) forwards; }
.hero-copy h1 { animation-delay: .08s; }
.hero-copy .hero-tagline { animation-delay: .15s; }
.hero-copy .hero-lead { animation-delay: .22s; }
.hero-copy .hero-actions { animation-delay: .3s; }
.hero-copy .hero-trust { animation-delay: .38s; }

@keyframes call-pulse {
  0%, 78%, 100% { box-shadow: 0 8px 20px rgba(7, 86, 156, .2); }
  86% { box-shadow: 0 8px 20px rgba(7, 86, 156, .2), 0 0 0 7px rgba(3, 164, 207, .12); }
}

@keyframes hero-enter {
  to { opacity: 1; transform: translateY(0); }
}

@keyframes hero-float {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(-9px); }
}

@keyframes route-flow {
  to { background-position: 22px 0; }
}

@keyframes arrow-breathe {
  0%, 100% { opacity: .45; transform: translateX(0); }
  50% { opacity: 1; transform: translateX(4px); }
}

@keyframes move-lines {
  from { background-position: 0 0; }
  to { background-position: 520px -260px; }
}

@keyframes global-lines {
  from { background-position: 0 0; }
  to { background-position: 720px -360px; }
}

@keyframes star-pop {
  0% { transform: scale(.7); }
  65% { transform: scale(1.25) rotate(-5deg); }
  100% { transform: scale(1); }
}

@keyframes review-enter {
  from { opacity: 0; transform: translateY(16px) scale(.985); }
  to { opacity: 1; transform: none; }
}

@media (max-width: 1050px) {
  .main-nav { gap: 15px; }
  .main-nav, .nav-dropdown > button { font-size: 13px; }
  .hero-grid { gap: 35px; }
  .visual-panel { min-height: 420px; }
  .trust-strip { align-items: flex-start; }
  .trust-items { flex-wrap: wrap; gap: 14px 25px; }
  .split-grid { gap: 65px; }
  .contact-info { padding-right: 50px; }
  .contact-form { padding-left: 50px; }
  .promise-grid { grid-template-columns: repeat(2, 1fr); }
  .process-grid { grid-template-columns: 1fr 1fr; }
  .step-arrow { display: none; }
}

@media (max-width: 860px) {
  body { padding-bottom: 70px; }
  .topbar-links a:first-child { display: none; }
  .menu-toggle { display: block; }
  .menu-toggle[aria-expanded="true"] > span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
  .menu-toggle[aria-expanded="true"] > span:nth-child(2) { opacity: 0; }
  .menu-toggle[aria-expanded="true"] > span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }
  .main-nav { position: absolute; left: 0; right: 0; top: 86px; padding: 15px 20px 24px; display: none; flex-direction: column; align-items: stretch; gap: 0; background: #fff; border-bottom: 1px solid var(--line); box-shadow: 0 20px 30px rgba(12,55,87,.09); }
  .main-nav.open { display: flex; }
  .main-nav.legal-nav { position: static; padding: 0; display: flex; flex-direction: row; align-items: center; background: transparent; border: 0; box-shadow: none; }
  .main-nav.legal-nav > a:not(.nav-call) { display: none; }
  .main-nav.legal-nav .nav-call { margin: 0; }
  .main-nav > a:not(.nav-call) { padding: 13px 4px; border-bottom: 1px solid #edf2f5; }
  .main-nav > a:not(.nav-call)::after { display: none; }
  .site-header.is-compact .nav-wrap { min-height: 68px; }
  .nav-dropdown { border-bottom: 1px solid #edf2f5; }
  .nav-dropdown > button { width: 100%; padding: 13px 4px; justify-content: space-between; }
  .nav-dropdown-menu { position: static; min-width: 0; padding: 0 0 8px 13px; border: 0; border-radius: 0; box-shadow: none; }
  .nav-dropdown-menu a { padding: 8px 4px; color: var(--muted); }
  .nav-call { margin-top: 14px; justify-content: center; }
  .hero { padding-top: 65px; }
  .hero-grid, .split-grid, .faq-grid { grid-template-columns: 1fr; }
  .hero-grid { gap: 55px; }
  .hero-copy { text-align: center; }
  .hero-copy .eyebrow, .hero-actions { justify-content: center; }
  .hero-lead { margin-inline: auto; }
  .hero-trust { justify-content: center; }
  .hero-visual { width: min(100%, 580px); margin-inline: auto; }
  .trust-strip { margin-top: 55px; flex-direction: column; align-items: center; }
  .trust-items { justify-content: center; }
  .service-grid { grid-template-columns: 1fr 1fr; }
  .service-card:last-child { min-height: 300px; }
  .split-grid { max-width: 680px; }
  .about-visual { width: min(100%, 520px); margin-inline: auto; }
  .process-grid { grid-template-columns: 1fr 1fr; }
  .process-step { min-height: 190px; }
  .reassurance-grid { grid-template-columns: 1fr; }
  .reviews-layout { grid-template-columns: 1fr; }
  .review-form { position: static; }
  .team-grid { grid-template-columns: 1fr 1fr; }
  .team-card:last-child { grid-column: 1 / -1; }
  .faq-grid { gap: 15px; }
  .contact { background: var(--blue-deep); }
  .contact-shell { width: 100%; grid-template-columns: 1fr; }
  .contact-info, .contact-form { padding: 70px max(20px, calc((100vw - 720px) / 2)); }
  .contact-form { background: var(--surface); }
  .location-grid { grid-template-columns: 1fr; gap: 35px; }
  .footer-grid { grid-template-columns: 1.5fr 1fr 1fr; }
  .footer-grid > div:last-child { grid-column: 2; }
  .mobile-call-bar { position: fixed; z-index: 110; left: 12px; right: 12px; bottom: 10px; min-height: 57px; padding: 8px 18px; display: flex; align-items: center; justify-content: center; gap: 12px; color: #fff; background: var(--blue); border-radius: 12px; box-shadow: 0 10px 35px rgba(4,43,78,.35); }
  .mobile-call-bar svg { width: 21px; }
  .mobile-call-bar span { display: flex; flex-direction: column; line-height: 1.25; }
  .mobile-call-bar small { font-size: 9px; opacity: .8; }
  .mobile-call-bar strong { font-size: 16px; }
}

@media (max-width: 580px) {
  .container { width: min(calc(100% - 30px), var(--container)); }
  .topbar-inner { justify-content: center; min-height: 34px; }
  .topbar-links { display: none; }
  .nav-wrap { min-height: 75px; }
  .brand { width: 124px; height: 54px; }
  .brand img { width: 120px; }
  .main-nav { top: 75px; }
  .hero { padding-top: 48px; }
  h1 { font-size: 41px; }
  .hero-lead { font-size: 16px; }
  .hero-tagline { font-size: 19px; }
  .hero-actions { flex-direction: column; }
  .button { width: 100%; }
  .hero-trust { gap: 18px; }
  .hero-trust div + div::before { left: -9px; }
  .hero-trust strong { font-size: 13px; }
  .hero-trust span { font-size: 10px; }
  .visual-panel { min-height: 385px; border-radius: 26px 26px 26px 70px; }
  .route-card { left: 20px; right: 20px; top: 30px; padding: 20px; }
  .visual-message { left: 16px; right: 35px; top: 215px; }
  .visual-call { left: 25px; right: 25px; bottom: 30px; }
  .visual-call a { font-size: 18px; }
  .trust-items { display: grid; grid-template-columns: 1fr 1fr; }
  .section { padding: 78px 0; }
  .section-heading { margin-bottom: 35px; }
  .section-heading h2, .about-copy h2, .contact-info h2 { font-size: 35px; }
  .service-grid { grid-template-columns: 1fr; }
  .service-card, .service-card:last-child { grid-column: auto; min-height: 330px; }
  .promise-grid { grid-template-columns: 1fr; }
  .promise-card { min-height: 205px; }
  .about-visual { padding-left: 0; }
  .about-shape { min-height: 410px; padding: 38px 28px; border-radius: 80px 20px 20px; }
  .about-logo { left: 28px; top: 38px; width: 175px; }
  .experience-badge { right: -4px; width: 115px; height: 115px; }
  .benefit-list { grid-template-columns: 1fr; }
  .process-grid { grid-template-columns: 1fr; }
  .team-grid { grid-template-columns: 1fr; }
  .team-card:last-child { grid-column: auto; }
  .stats-card { grid-template-columns: 1fr; padding: 20px; }
  .stats-card > div { min-height: 105px; border-bottom: 1px solid var(--line); }
  .stats-card > div:first-child { border-radius: 12px 12px 0 0; }
  .stats-card > div:nth-child(3) { border-radius: 0 0 12px 12px; border-bottom: 0; }
  .form-grid { grid-template-columns: 1fr; }
  .review-fields { grid-template-columns: 1fr; }
  .review-form, .reviews-display { padding: 25px; }
  .reviews-display-heading { align-items: flex-start; flex-direction: column; }
  .google-rating-summary { align-items: flex-start; flex-wrap: wrap; }
  .google-rating-summary > span:last-child { flex-basis: 100%; }
  .review-card-header { flex-direction: column; }
  .star-rating label { font-size: 36px; }
  .full-width { grid-column: auto; }
  .contact-info, .contact-form { padding: 65px 20px; }
  .contact-main strong { font-size: 22px; }
  .map-placeholder { min-height: 285px; }
  .map-label { left: 18px; right: 18px; top: auto; bottom: 45px; }
  .footer-grid { grid-template-columns: 1fr 1fr; gap: 38px 25px; }
  .footer-brand { grid-column: 1 / -1; }
  .footer-grid > div:last-child { grid-column: auto; }
  .footer-bottom { padding: 20px 0; flex-direction: column; gap: 12px; text-align: center; }
  .legal-footer-links { justify-content: center; flex-wrap: wrap; gap: 13px 22px; padding: 18px 0; }
  .legal-main { padding-top: 55px; }
  .legal-card { padding: 25px; }
  .legal-toc { align-items: flex-start; }
  .legal-contact div { grid-template-columns: 1fr; gap: 2px; }
}

@media (hover: none) {
  .promise-card:hover:not(.press-feedback),
  .team-card:hover:not(.press-feedback),
  .service-card:hover:not(.press-feedback),
  .process-step:hover:not(.press-feedback),
  .contact-list li:hover:not(.press-feedback) {
    transform: none;
  }

  .promise-card:hover:not(.press-feedback),
  .team-card:hover:not(.press-feedback) {
    background: var(--surface);
    border-color: var(--line);
    box-shadow: none;
  }

  .promise-card:hover:not(.press-feedback) {
    background: linear-gradient(145deg, #fff, #f7fbfd);
  }
  .promise-card:hover:not(.press-feedback)::before { width: 38px; box-shadow: none; }
  .promise-card:hover:not(.press-feedback) h3,
  .team-card:hover:not(.press-feedback) h3 { color: var(--blue-deep); }
  .team-card:hover:not(.press-feedback) .team-icon { transform: none; filter: none; box-shadow: 0 12px 25px rgba(7,86,156,.18); }
  .team-card:hover:not(.press-feedback) .team-icon svg { transform: none; }

  .service-card:hover:not(.press-feedback) {
    color: var(--ink);
    background: #fff;
    border-color: var(--line);
    box-shadow: none;
  }

  .service-card:hover:not(.press-feedback) h3 { color: var(--ink); }
  .service-card:hover:not(.press-feedback) p { color: var(--muted); }
  .service-card:hover:not(.press-feedback) a { color: var(--blue); transform: none; }
  .service-card:hover:not(.press-feedback) .card-number { color: rgba(7,86,156,.08); }
  .service-card:hover:not(.press-feedback) .service-icon { color: var(--blue); background: var(--blue-light); box-shadow: none; transform: none; }
  .service-card:hover:not(.press-feedback) .service-icon svg { transform: none; }

  .process-step:hover:not(.press-feedback) {
    background: rgba(255,255,255,.045);
    border-color: rgba(255,255,255,.12);
    box-shadow: none;
  }
  .process-step:hover:not(.press-feedback) h3 { color: #fff; }
  .process-step:hover:not(.press-feedback) .step-number { background: #fff; box-shadow: none; transform: scale(1); }

  .contact-list li:hover:not(.press-feedback) {
    background: rgba(255,255,255,.025);
    border-color: transparent;
    box-shadow: none;
  }
  .contact-list li:hover:not(.press-feedback) svg { transform: none; filter: none; }
}

@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  *, *::before, *::after { animation-duration: .01ms !important; transition-duration: .01ms !important; }
  .reveal { opacity: 1; transform: none; }
  body::before, .nav-call, .hero-visual, .route-dash, .step-arrow, .hero::after, .section::before, .location-section::before, .legal-main::before, .site-footer::before, .review-card, .star-rating input:checked + label, .hero-copy .eyebrow, .hero-copy h1, .hero-copy .hero-tagline, .hero-copy .hero-lead, .hero-copy .hero-actions, .hero-copy .hero-trust { animation: none; }
  .hero-copy .eyebrow, .hero-copy h1, .hero-copy .hero-tagline, .hero-copy .hero-lead, .hero-copy .hero-actions, .hero-copy .hero-trust { opacity: 1; transform: none; }
  .step-number { transform: none; }
}
