:root {
  --blue: #0878d8;
  --blue-dark: #003a72;
  --navy: #061b34;
  --navy-2: #0a2748;
  --ink: #102033;
  --muted: #607086;
  --soft: #f2f7fd;
  --white: #ffffff;
  --line: rgba(8, 120, 216, 0.22);
  --shadow: 0 22px 55px rgba(6, 27, 52, 0.13);
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: "Inter", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  color: var(--ink);
  background: var(--white);
}

a { color: inherit; text-decoration: none; }
.container { width: min(1180px, calc(100% - 40px)); margin: 0 auto; }

.site-header {
  background: linear-gradient(135deg, #04172d 0%, #082744 58%, #06192e 100%);
  border-bottom: 1px solid rgba(255,255,255,0.14);
  position: sticky;
  top: 0;
  z-index: 20;
}

.nav-wrap {
  min-height: 92px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 28px;
}

.brand img { width: 190px; display: block; }
.nav-links { display: flex; align-items: center; gap: 48px; }
.nav-links a {
  color: rgba(255,255,255,0.92);
  font-weight: 700;
  font-size: 1rem;
  position: relative;
  padding: 33px 0;
}
.nav-links a::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: 24px;
  height: 4px;
  border-radius: 999px;
  background: var(--blue);
  transform: scaleX(0);
  transform-origin: center;
  transition: transform .2s ease;
}
.nav-links a:hover::after,
.nav-links a.active::after { transform: scaleX(1); }

.hero {
  min-height: 620px;
  position: relative;
  overflow: hidden;
  background:
    linear-gradient(90deg, rgba(255,255,255,.98) 0%, rgba(255,255,255,.94) 43%, rgba(242,247,253,.76) 100%),
    radial-gradient(circle at 82% 35%, rgba(8,120,216,.2), transparent 35%);
}
.hero::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(135deg, rgba(8,120,216,.07) 0 15%, transparent 15% 100%),
    linear-gradient(135deg, transparent 0 68%, rgba(8,120,216,.96) 68% 75%, transparent 75% 100%);
  pointer-events: none;
}
.hero-grid { position: relative; z-index: 2; display: grid; grid-template-columns: 1fr 0.82fr; min-height: 620px; align-items: center; }
.hero-content { max-width: 620px; padding: 56px 0 50px; }
.hero-logo { width: min(355px, 72vw); display: block; margin: 0 0 10px; }
.eyebrow { color: var(--blue); font-size: .78rem; text-transform: uppercase; letter-spacing: .22em; font-weight: 800; margin: 0 0 12px; }
h1 { font-size: clamp(3.4rem, 7vw, 5.75rem); line-height: .96; margin: 0; letter-spacing: -0.06em; color: #061b34; }
h1 span { color: var(--blue); }
.accent-line { width: 56px; height: 5px; background: var(--blue); border-radius: 99px; margin: 28px 0 22px; }
.lead { margin: 0 0 14px; font-size: clamp(1.1rem, 2vw, 1.45rem); line-height: 1.5; color: #233247; font-weight: 500; }
.support { margin: 0 0 28px; color: #3f4c60; font-size: 1.04rem; line-height: 1.75; }
.hero-actions { display: flex; flex-wrap: wrap; gap: 18px; align-items: center; }
.btn {
  min-height: 56px;
  padding: 0 25px;
  border-radius: 10px;
  display: inline-flex;
  gap: 12px;
  align-items: center;
  justify-content: center;
  font-weight: 800;
  transition: transform .2s ease, box-shadow .2s ease, background .2s ease;
}
.btn svg { width: 22px; height: 22px; fill: currentColor; }
.btn:hover { transform: translateY(-2px); }
.btn-primary { background: linear-gradient(135deg, var(--blue), #005bbb); color: #fff; box-shadow: 0 15px 30px rgba(8,120,216,.26); }
.btn-secondary { color: var(--blue); background: rgba(255,255,255,.75); border: 1.5px solid var(--blue); }
.contact-strip { display: flex; flex-wrap: wrap; gap: 12px; align-items: center; margin-top: 26px; color: #24334a; font-weight: 700; }
.contact-strip span { width: 6px; height: 6px; border-radius: 50%; background: var(--blue); }

.hero-bg { position: absolute; inset: 0; pointer-events: none; }
.house-shape {
  position: absolute;
  right: 4%;
  top: 14%;
  width: 520px;
  height: 330px;
  border-radius: 22px;
  opacity: .19;
  filter: blur(.2px);
  background:
    linear-gradient(135deg, transparent 0 26%, #8da2ba 26% 31%, transparent 31%),
    linear-gradient(45deg, transparent 0 45%, #6f8296 45% 50%, transparent 50%),
    linear-gradient(#b7c4d3, #eef3f8);
  clip-path: polygon(0 45%, 22% 26%, 22% 12%, 39% 12%, 39% 17%, 58% 0, 100% 42%, 100% 100%, 0 100%);
}
.house-two { right: 20%; top: 24%; transform: scale(.72); opacity: .12; }
.tool-card {
  position: absolute;
  right: 7%;
  bottom: 58px;
  width: 380px;
  height: 260px;
}
.helmet {
  position: absolute;
  left: 0;
  bottom: 24px;
  width: 150px;
  height: 88px;
  background: linear-gradient(135deg, #0b8ff1, #005bb7);
  border-radius: 90px 90px 20px 20px;
  box-shadow: inset 0 0 0 7px rgba(255,255,255,.16), 0 20px 34px rgba(5,42,77,.24);
}
.helmet::after { content:""; position:absolute; left: -16px; right: -16px; bottom: 0; height: 18px; border-radius: 99px; background: #065aa9; }
.bag {
  position: absolute;
  right: 0;
  bottom: 28px;
  width: 185px;
  height: 145px;
  border-radius: 22px 22px 12px 12px;
  background: linear-gradient(135deg, #081d35, #102d4f);
  box-shadow: 0 25px 45px rgba(5,22,42,.28);
}
.bag::before { content:""; position:absolute; left: 46px; top: -36px; width: 90px; height: 54px; border: 12px solid #102d4f; border-bottom: 0; border-radius: 45px 45px 0 0; }
.bag span { position:absolute; bottom: 108px; width: 14px; height: 86px; border-radius: 8px; background: #0b83df; box-shadow: inset 0 0 0 2px rgba(255,255,255,.2); }
.bag span:nth-child(1){ left:38px; transform:rotate(-10deg); }
.bag span:nth-child(2){ left:72px; height:105px; transform:rotate(7deg); }
.bag span:nth-child(3){ left:107px; transform:rotate(-4deg); }
.bag span:nth-child(4){ left:140px; height:96px; transform:rotate(13deg); }
.hammer { position:absolute; right:54px; bottom: 15px; width: 190px; height: 18px; background:#064e99; border-radius:99px; transform: rotate(-5deg); }
.hammer::before { content:""; position:absolute; left:-32px; top:-16px; width:56px; height:34px; border-radius:8px; background:#b8c3ce; }
.wrench { position:absolute; right:190px; bottom: 6px; width: 115px; height: 14px; background:#0b83df; border-radius:99px; transform: rotate(10deg); }
.wrench::before { content:""; position:absolute; left:-24px; top:-10px; width:34px; height:34px; border:9px solid #a9b5c2; border-right-color:transparent; border-radius:50%; }

.services { background: linear-gradient(180deg, #f8fbff 0%, #eef5fc 100%); padding: 36px 0 48px; }
.service-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 28px; }
.service-card {
  background: #fff;
  border: 1px solid rgba(8,120,216,.08);
  border-radius: 14px;
  padding: 30px 28px;
  min-height: 185px;
  display: grid;
  grid-template-columns: 105px 1fr;
  gap: 20px;
  align-items: center;
  box-shadow: var(--shadow);
}
.icon-circle { width: 94px; height: 94px; display:grid; place-items:center; border-radius:50%; background: #edf4fc; }
.icon-circle svg { width: 48px; height: 48px; fill: var(--blue); }
.service-card h2 { margin: 0 0 8px; color: #09213d; font-size: 1.2rem; }
.service-card p { margin: 0; color: #4a596d; line-height: 1.55; font-size: .96rem; }
.mini-line { width: 54px; height: 4px; border-radius:99px; background: var(--blue); margin-top: 22px; }

.about { padding: 72px 0; background: #fff; }
.about-box { text-align: center; max-width: 850px; }
.about-box h2 { font-size: clamp(1.8rem, 3vw, 2.6rem); line-height: 1.18; margin: 0 0 18px; color: var(--navy); letter-spacing: -0.03em; }
.about-box p:last-child { margin: 0 auto; max-width: 680px; color: var(--muted); line-height: 1.75; font-size: 1.05rem; }

.site-footer { background: linear-gradient(135deg, #06172d 0%, #0b2039 100%); color: #cbd6e3; padding: 36px 0 40px; text-align: center; }
.footer-inner h2 { margin: 0 0 7px; color: var(--blue); letter-spacing: .18em; font-size: 1.8rem; }
.footer-inner p { margin: 0 0 16px; }
.footer-links { display: flex; justify-content: center; gap: 22px; flex-wrap: wrap; font-weight: 700; color: #fff; }
.footer-links a:hover { color: #5db4ff; }

@media (max-width: 980px) {
  .nav-wrap { min-height: auto; padding: 16px 0; flex-direction: column; }
  .nav-links { gap: 26px; flex-wrap: wrap; justify-content: center; }
  .nav-links a { padding: 8px 0 14px; }
  .nav-links a::after { bottom: 4px; }
  .hero-grid { grid-template-columns: 1fr; min-height: auto; }
  .hero-content { text-align: center; margin: 0 auto; padding: 54px 0; }
  .hero-logo { margin-left: auto; margin-right: auto; }
  .accent-line { margin-left: auto; margin-right: auto; }
  .hero-actions, .contact-strip { justify-content: center; }
  .tool-card, .house-shape { opacity: .14; transform: scale(.8); right: -60px; }
  .service-grid { grid-template-columns: 1fr; max-width: 660px; }
}

@media (max-width: 620px) {
  .container { width: min(100% - 28px, 1180px); }
  .brand img { width: 160px; }
  .nav-links { gap: 18px; font-size: .9rem; }
  h1 { font-size: 3.25rem; }
  .hero-content { padding: 42px 0; }
  .btn { width: 100%; }
  .service-card { grid-template-columns: 1fr; text-align: center; justify-items: center; }
  .mini-line { margin-left: auto; margin-right: auto; }
  .tool-card { display:none; }
}
