:root {
  --blue:#145a9a; --navy:#0d2e4a; --yellow:#f6c23e; --lime:#73b043; --ink:#141820; --muted:#5e6875; --soft:#f4f7f2; --line:#dce4dd;
}
* { 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; letter-spacing:0; }
a { color:inherit; }
img { max-width:100%; display:block; height:auto; }
.site-header { position:fixed; top:18px; left:50%; transform:translateX(-50%); z-index:30; width:min(1120px, calc(100% - 32px)); display:flex; align-items:center; justify-content:space-between; gap:24px; padding:10px 12px 10px 18px; background:rgba(255,255,255,.9); border:1px solid rgba(255,255,255,.72); box-shadow:0 12px 36px rgba(8,22,34,.12); backdrop-filter:blur(18px); border-radius:999px; }
.brand img { width:206px; height:auto; }
.nav-links { display:flex; align-items:center; gap:8px; font-size:14px; font-weight:700; }
.nav-links a { text-decoration:none; padding:10px 13px; border-radius:999px; color:var(--navy); white-space:nowrap; }
.nav-links a:hover, .nav-links a[aria-current="page"] { background:var(--soft); }
.nav-links .nav-cta { background:var(--blue); color:#fff; padding-inline:18px; }
.mobile-menu-toggle { display:none; width:44px; height:44px; border:0; background:var(--navy); border-radius:999px; align-items:center; justify-content:center; flex-direction:column; gap:4px; }
.mobile-menu-toggle span { width:18px; height:2px; background:#fff; display:block; }
.mobile-menu { display:none; position:absolute; top:72px; right:0; width:min(320px, calc(100vw - 32px)); background:#fff; border:1px solid var(--line); box-shadow:0 20px 50px rgba(9,26,42,.18); padding:12px; border-radius:8px; }
.mobile-menu a { display:block; padding:13px 12px; text-decoration:none; font-weight:700; color:var(--navy); }
.hero { min-height:92vh; position:relative; display:grid; align-items:end; overflow:hidden; padding:140px max(24px, calc((100vw - 1120px)/2)) 84px; }
.hero picture, .hero-img { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; }
.hero-overlay { position:absolute; inset:0; background:linear-gradient(90deg, rgba(8,28,45,.82), rgba(8,28,45,.48) 45%, rgba(8,28,45,.08)); }
.hero-content { position:relative; z-index:1; max-width:760px; color:#fff; }
.eyebrow { margin:0 0 12px; font-size:13px; font-weight:900; text-transform:uppercase; letter-spacing:.12em; color:var(--lime); }
h1, h2, h3 { line-height:1.04; margin:0 0 18px; letter-spacing:0; color:inherit; }
h1 { font-size:clamp(42px, 7vw, 88px); max-width:920px; }
h2 { font-size:clamp(28px, 4.4vw, 54px); }
h3 { font-size:24px; }
p { margin:0 0 18px; }
.hero p:not(.eyebrow) { font-size:20px; max-width:680px; color:rgba(255,255,255,.88); }
.hero-actions { display:flex; flex-wrap:wrap; gap:12px; margin-top:28px; }
.btn { display:inline-flex; align-items:center; justify-content:center; min-height:48px; padding:13px 20px; border-radius:8px; font-weight:900; text-decoration:none; border:2px solid transparent; cursor:pointer; font-size:15px; }
.btn.primary { background:var(--yellow); color:var(--navy); }
.btn.ghost { color:#fff; border-color:rgba(255,255,255,.6); }
.btn.ghost.dark { color:var(--navy); border-color:var(--line); }
.btn.small { min-height:40px; padding:9px 14px; font-size:14px; background:var(--blue); color:#fff; }
.band, .services, .feature-band, .faq-strip, .contact-band, .page-main section { padding:84px max(24px, calc((100vw - 1120px)/2)); }
.intro { display:grid; grid-template-columns:1.5fr .8fr; gap:48px; background:#fff; border-bottom:1px solid var(--line); }
.intro-copy p:last-child { font-size:18px; color:var(--muted); }
.quick-panel { display:grid; grid-template-columns:auto 1fr; gap:10px 18px; align-self:start; padding:28px; background:var(--soft); border:1px solid var(--line); border-radius:8px; }
.quick-panel span { color:var(--muted); font-size:13px; font-weight:800; text-transform:uppercase; }
.quick-panel strong { color:var(--navy); }
.services { background:var(--soft); }
.section-head { max-width:740px; margin-bottom:34px; }
.service-grid { display:grid; grid-template-columns:repeat(5, 1fr); gap:16px; }
.service-card { background:#fff; border:1px solid var(--line); border-radius:8px; overflow:hidden; display:flex; flex-direction:column; }
.service-card div { padding:20px; }
.service-card-img { height:150px; width:100%; object-fit:cover; }
.text-link { font-weight:900; color:var(--blue); text-decoration:none; }
.feature-band { display:grid; grid-template-columns:1fr 1fr; gap:50px; align-items:center; background:#fff; }
.feature-img { width:100%; height:auto; aspect-ratio:4/3; object-fit:cover; border-radius:8px; }
.check-list { list-style:none; padding:0; margin:22px 0 0; display:grid; gap:10px; }
.check-list li { position:relative; padding-left:30px; }
.check-list li::before { content:""; position:absolute; left:0; top:.45em; width:16px; height:16px; border-radius:50%; background:var(--lime); box-shadow:inset 0 0 0 4px #fff; border:1px solid var(--lime); }
.faq-strip { display:grid; grid-template-columns:.75fr 1.25fr; gap:48px; background:var(--navy); color:#fff; }
.faq-list { display:grid; gap:10px; }
details { background:#fff; color:var(--ink); border:1px solid var(--line); border-radius:8px; padding:16px 18px; }
summary { cursor:pointer; font-weight:900; color:var(--navy); }
details p { margin:12px 0 0; color:var(--muted); }
.contact-band { display:grid; grid-template-columns:.9fr 1.1fr; gap:48px; background:linear-gradient(135deg, var(--blue), var(--navy)); color:#fff; }
.contact-band a { color:#fff; font-weight:900; }
.contact-form { display:grid; gap:14px; background:#fff; color:var(--ink); padding:24px; border-radius:8px; border:1px solid var(--line); }
.contact-form label { display:grid; gap:6px; font-weight:900; font-size:13px; color:var(--navy); }
input, textarea { width:100%; border:1px solid #cfd9d5; border-radius:6px; min-height:44px; padding:10px 12px; font:inherit; }
textarea { resize:vertical; }
.page-main { padding-top:120px; }
.page-hero { background:var(--soft); }
.page-hero p, .detail-grid p, .legal-copy p { max-width:760px; color:var(--muted); font-size:18px; }
.service-rows { display:grid; gap:24px; }
.service-row { display:grid; grid-template-columns:360px 1fr; gap:28px; align-items:center; border-bottom:1px solid var(--line); padding-bottom:24px; }
.row-img { width:100%; aspect-ratio:4/3; object-fit:cover; border-radius:8px; }
.service-row ul { columns:2; padding-left:20px; color:var(--muted); }
.service-hero, .about-hero, .contact-layout { display:grid; grid-template-columns:1fr 1fr; gap:48px; align-items:center; background:#fff; }
.service-hero-img, .about-img { width:100%; aspect-ratio:4/3; object-fit:cover; border-radius:8px; }
.detail-grid { display:grid; grid-template-columns:1fr 1fr; gap:28px; background:var(--soft); }
.detail-grid > div { background:#fff; border:1px solid var(--line); border-radius:8px; padding:28px; }
.qa-section { background:#fff; }
.compact { padding-top:60px; padding-bottom:60px; }
.map-band { background:var(--soft); }
.contact-info { display:grid; gap:8px; margin-top:26px; padding:20px; background:var(--soft); color:var(--navy); border-radius:8px; border:1px solid var(--line); }
.legal-copy { background:#fff; }
.site-footer { background:#101820; color:#dce6ec; padding:64px max(24px, calc((100vw - 1120px)/2)) 86px; }
.footer-grid { display:grid; grid-template-columns:1.4fr 1fr 1fr; gap:42px; }
.footer-logo { width:220px; background:#fff; border-radius:8px; padding:8px; margin-bottom:18px; }
.site-footer h2 { font-size:18px; color:#fff; margin-bottom:12px; }
.site-footer ul { list-style:none; padding:0; margin:0; display:grid; gap:8px; }
.site-footer a { color:#fff; text-decoration:none; font-weight:800; }
.nap { color:#fff; }
.footer-bottom { border-top:1px solid rgba(255,255,255,.14); margin-top:42px; padding-top:20px; display:flex; justify-content:space-between; gap:18px; flex-wrap:wrap; font-size:14px; }
.mobile-sticky-cta { display:none; }
@media (min-width:1024px) {
  .mobile-menu-toggle { display:none !important; }
  .mobile-menu { display:none !important; }
}
@media (max-width:1120px) {
  .service-grid { grid-template-columns:repeat(2, 1fr); }
}
@media (max-width:760px) {
  .site-header { top:10px; width:calc(100% - 20px); border-radius:8px; }
  .brand img { width:186px; }
  .nav-links { display:none; }
  .mobile-menu-toggle { display:flex; }
  .mobile-menu.open { display:block; }
  .hero { min-height:88vh; padding:116px 22px 64px; }
  .hero-overlay { background:linear-gradient(180deg, rgba(8,28,45,.38), rgba(8,28,45,.82)); }
  h1 { font-size:42px; }
  h2 { font-size:31px; }
  .band, .services, .feature-band, .faq-strip, .contact-band, .page-main section { padding:56px 22px; }
  .intro, .feature-band, .faq-strip, .contact-band, .service-hero, .about-hero, .contact-layout, .detail-grid, .footer-grid { grid-template-columns:1fr; }
  .service-grid { grid-template-columns:1fr; }
  .service-row { grid-template-columns:1fr; }
  .service-row ul { columns:1; }
  .page-main { padding-top:96px; }
  .site-footer { padding-bottom:104px; }
  .mobile-sticky-cta { position:fixed; z-index:35; left:0; right:0; bottom:0; display:grid; grid-template-columns:1fr 1fr; box-shadow:0 -10px 30px rgba(0,0,0,.18); }
  .mobile-sticky-cta a { min-height:56px; display:flex; align-items:center; justify-content:center; text-decoration:none; font-weight:900; color:#fff; }
  .mobile-sticky-cta a:first-child { background:var(--blue); }
  .mobile-sticky-cta a:last-child { background:#0a0a0a; }
}
