
:root {
  --navy:#102a43; --blue:#1268a6; --teal:#10a5a5; --green:#3e8f64; --amber:#e6a43a;
  --ink:#14212b; --muted:#5f6f7b; --paper:#fff; --soft:#f4f8fb; --line:#d8e4ea;
  --shadow:0 18px 48px rgba(16,42,67,.14);
}
* { box-sizing:border-box; }
html { scroll-behavior:smooth; }
body { margin:0; font-family:Arial, Helvetica, sans-serif; color:var(--ink); background:#fff; line-height:1.55; }
a { color:inherit; text-decoration:none; }
img { max-width:100%; display:block; }
.container { width:min(1160px, calc(100% - 40px)); margin:0 auto; }
.nav-wrap { position:fixed; top:18px; left:0; right:0; z-index:50; pointer-events:none; }
.nav-pill { width:min(1160px, calc(100% - 32px)); min-height:72px; margin:0 auto; display:flex; align-items:center; gap:20px; padding:10px 12px 10px 18px; border:1px solid rgba(216,228,234,.9); border-radius:8px; background:rgba(255,255,255,.86); box-shadow:0 16px 44px rgba(16,42,67,.16); backdrop-filter:blur(18px); pointer-events:auto; }
.nav-logo { display:flex; align-items:center; flex:0 0 auto; }
.nav-logo img { width:196px; height:auto; max-height:48px; object-fit:contain; }
.nav-links { display:flex; align-items:center; gap:8px; margin-left:auto; }
.nav-link { padding:11px 13px; border-radius:8px; color:#253847; font-size:15px; font-weight:700; white-space:nowrap; }
.nav-link:hover, .nav-link.active { background:#edf7fb; color:var(--blue); }
.nav-cta, .btn { display:inline-flex; align-items:center; justify-content:center; gap:8px; min-height:46px; padding:13px 18px; border-radius:8px; font-weight:800; border:1px solid transparent; line-height:1.1; }
.nav-cta { background:var(--blue); color:#fff; white-space:nowrap; }
.btn-primary { background:var(--blue); color:#fff; box-shadow:0 14px 28px rgba(18,104,166,.22); }
.btn-secondary { background:#fff; color:var(--navy); border-color:var(--line); }
.btn-amber { background:var(--amber); color:#14212b; }
.mobile-menu-toggle { display:none; width:48px; height:48px; border:0; border-radius:8px; background:#edf7fb; align-items:center; justify-content:center; flex-direction:column; gap:5px; }
.mobile-menu-toggle span { width:23px; height:2px; background:var(--navy); display:block; }
.mobile-menu { display:none; position:fixed; z-index:45; top:96px; left:16px; right:16px; background:#fff; border:1px solid var(--line); border-radius:8px; box-shadow:var(--shadow); padding:14px; }
.mobile-menu a { display:block; padding:13px 12px; border-bottom:1px solid #edf2f5; font-weight:700; }
.mobile-menu.open { display:block; }
.hero { position:relative; min-height:760px; display:grid; align-items:end; overflow:hidden; padding:150px 0 72px; background:#edf6fa; }
.hero picture, .hero .hero-media { position:absolute; inset:0; z-index:0; }
.hero img { width:100%; height:100%; object-fit:cover; }
.hero::after { content:""; position:absolute; inset:0; background:linear-gradient(90deg, rgba(255,255,255,.94) 0%, rgba(255,255,255,.80) 44%, rgba(255,255,255,.28) 100%); z-index:1; }
.hero-inner { position:relative; z-index:2; max-width:760px; }
.eyebrow { display:inline-flex; align-items:center; gap:8px; margin:0 0 18px; color:var(--blue); font-weight:900; text-transform:uppercase; font-size:13px; letter-spacing:0; }
.eyebrow::before { content:""; width:34px; height:3px; background:var(--teal); border-radius:4px; }
h1, h2, h3, p { overflow-wrap:break-word; }
h1 { margin:0; font-size:clamp(42px, 8vw, 86px); line-height:.98; letter-spacing:0; color:var(--navy); max-width:900px; }
.hero-copy { margin:24px 0 0; font-size:21px; color:#334957; max-width:660px; }
.hero-actions { display:flex; gap:12px; flex-wrap:wrap; margin-top:32px; }
.trust-strip { display:grid; grid-template-columns:repeat(3,1fr); gap:1px; margin-top:42px; border:1px solid var(--line); border-radius:8px; overflow:hidden; background:var(--line); max-width:780px; }
.trust-item { background:rgba(255,255,255,.88); padding:18px; }
.trust-item strong { display:block; font-size:24px; color:var(--navy); }
.trust-item span { display:block; color:var(--muted); font-size:14px; }
.section { padding:88px 0; }
.section-soft { background:var(--soft); }
.section-head { display:flex; align-items:end; justify-content:space-between; gap:30px; margin-bottom:34px; }
.section-head h2, .narrow h2 { margin:0; font-size:clamp(30px, 5vw, 54px); line-height:1.04; letter-spacing:0; color:var(--navy); }
.section-head p { max-width:520px; color:var(--muted); margin:0; font-size:18px; }
.grid { display:grid; gap:20px; }
.service-grid { grid-template-columns:repeat(4,1fr); }
.card { background:#fff; border:1px solid var(--line); border-radius:8px; overflow:hidden; box-shadow:0 10px 24px rgba(16,42,67,.08); }
.card-body { padding:22px; }
.card h3 { margin:0 0 10px; font-size:23px; line-height:1.15; color:var(--navy); }
.card p { margin:0; color:var(--muted); }
.card-link { display:inline-flex; margin-top:18px; font-weight:900; color:var(--blue); }
.split { display:grid; grid-template-columns:1.05fr .95fr; gap:42px; align-items:center; }
.panel { background:#fff; border:1px solid var(--line); border-radius:8px; padding:30px; box-shadow:var(--shadow); }
.check-list { list-style:none; padding:0; margin:22px 0 0; display:grid; gap:12px; }
.check-list li { display:flex; gap:10px; align-items:flex-start; }
.check-list li::before { content:""; width:18px; height:18px; margin-top:4px; border-radius:50%; background:linear-gradient(135deg,var(--teal),var(--green)); flex:0 0 18px; }
.area-cloud { display:flex; flex-wrap:wrap; gap:10px; }
.area-cloud span { padding:10px 13px; border:1px solid var(--line); border-radius:8px; background:#fff; font-weight:800; color:#314959; }
.process { counter-reset:step; grid-template-columns:repeat(3,1fr); }
.process .card { padding:26px; }
.process .card::before { counter-increment:step; content:counter(step); display:grid; place-items:center; width:42px; height:42px; border-radius:8px; background:var(--blue); color:#fff; font-weight:900; margin-bottom:18px; }
#reviews { background:#fff; overflow:hidden; }
.gr-summary { display:grid; grid-template-columns:1fr auto; gap:22px; align-items:center; border:1px solid var(--line); border-radius:8px; padding:24px; margin-bottom:26px; background:linear-gradient(135deg,#fff,#f3f9fc); }
.gr-sum-left { display:flex; align-items:center; gap:20px; flex-wrap:wrap; }
.gr-logo { width:54px; height:54px; border-radius:8px; background:#fff; border:1px solid var(--line); display:grid; place-items:center; font-weight:900; color:#4285f4; box-shadow:0 8px 20px rgba(16,42,67,.08); }
.gr-meta-top { color:var(--muted); font-weight:800; font-size:14px; text-transform:uppercase; }
.gr-score { font-size:44px; line-height:1; font-weight:900; color:var(--navy); }
.gr-stars { color:#f4b400; font-size:22px; letter-spacing:0; }
.gr-sub { color:var(--muted); }
.gr-cta { color:#fff; background:var(--blue); padding:13px 18px; border-radius:8px; font-weight:900; white-space:nowrap; }
.gr-marquee { overflow:visible; margin:14px 0; }
.gr-track { display:grid; grid-template-columns:repeat(3,minmax(0,1fr)); gap:16px; width:100%; }
.gr-marquee:nth-of-type(2) .gr-track { transform:none; }
.gr-card { width:auto; min-height:170px; border:1px solid var(--line); border-radius:8px; padding:20px; background:#fff; box-shadow:0 10px 26px rgba(16,42,67,.08); }
.gr-card strong { display:block; color:var(--navy); margin-bottom:7px; }
.gr-card p { color:#4c6070; margin:0 0 12px; }
@keyframes marquee { from { transform:translateX(0); } to { transform:translateX(-50%); } }
.faq-list { display:grid; gap:14px; }
details { background:#fff; border:1px solid var(--line); border-radius:8px; padding:18px 20px; }
summary { cursor:pointer; font-weight:900; color:var(--navy); }
details p { color:var(--muted); margin:12px 0 0; }
.contact-band { background:var(--navy); color:#fff; padding:58px 0; }
.contact-band .container { display:flex; align-items:center; justify-content:space-between; gap:24px; }
.contact-band h2 { margin:0; font-size:36px; letter-spacing:0; }
.site-footer { background:#0c2234; color:#dce9ef; padding:64px 0 28px; }
.footer-grid { display:grid; grid-template-columns:1.3fr repeat(3,1fr); gap:32px; }
.footer-logo { width:210px; padding:8px; background:#fff; border-radius:8px; margin-bottom:18px; }
.site-footer h3 { color:#fff; margin:0 0 14px; font-size:16px; }
.site-footer a { display:block; color:#dce9ef; padding:5px 0; }
.site-footer p { color:#b6c8d3; margin:0 0 12px; }
.footer-bottom { border-top:1px solid rgba(255,255,255,.14); margin-top:34px; padding-top:20px; display:flex; justify-content:space-between; gap:20px; color:#9fb3c0; font-size:14px; }
.sticky-cta { display:none; position:fixed; left:14px; right:14px; bottom:14px; z-index:60; grid-template-columns:1fr 1fr; gap:10px; padding:10px; background:rgba(255,255,255,.94); border:1px solid var(--line); border-radius:8px; box-shadow:var(--shadow); }
.sticky-cta a { display:flex; align-items:center; justify-content:center; min-height:48px; border-radius:8px; font-weight:900; }
.sticky-cta .call { background:var(--blue); color:#fff; }
.sticky-cta .contact { background:#eef7fb; color:var(--navy); }
.sticky-cta.is-visible { display:grid; }
.service-hero { padding:150px 0 70px; background:linear-gradient(135deg,#f5fafc,#e9f5f9); }
.service-hero h1 { font-size:clamp(38px,7vw,72px); max-width:850px; }
.narrow { max-width:840px; }
.legal { max-width:850px; }
.legal h2 { color:var(--navy); }
@media (max-width: 920px) {
  .nav-links,.nav-cta { display:none; } .mobile-menu-toggle { display:flex; margin-left:auto; } .nav-logo img { width:176px; }
  .hero { min-height:700px; padding-top:130px; }
  .section-head, .split, .contact-band .container { display:block; }
  .service-grid, .process, .footer-grid { grid-template-columns:1fr 1fr; }
  .section-head p { margin-top:14px; }
  .panel { margin-top:24px; }
}
@media (max-width: 620px) {
  .container { width:min(100% - 28px, 1160px); }
  .nav-pill { width:calc(100% - 24px); min-height:64px; padding:8px 10px; } .nav-logo img { width:150px; }
  .hero { min-height:720px; padding:118px 0 100px; } .hero::after { background:rgba(255,255,255,.88); }
  h1 { font-size:42px; } .hero-copy { font-size:18px; }
  .hero-actions .btn { width:100%; } .trust-strip { grid-template-columns:1fr; }
  .section { padding:62px 0; } .service-grid,.process,.footer-grid { grid-template-columns:1fr; }
  .gr-summary { grid-template-columns:1fr; } .gr-cta { text-align:center; } .gr-track { grid-template-columns:1fr; } .gr-card { width:auto; }
  .contact-band h2 { font-size:28px; } .footer-bottom { display:block; }
  body { padding-bottom:84px; }
}
@media (prefers-reduced-motion: reduce) { * { animation-duration:.001ms !important; scroll-behavior:auto !important; } }
