:root{
  --blue:#0a22d5;
  --blue2:#1e5fa5;
  --navy:#0a2d57;
  --lime:#b6e73a;
  --sky:#8ecdff;
  --white:#ffffff;
  --gray:#dce2e8;
  --text:#0b1220;
  --muted:#556277;
  --shadow: 0 10px 30px rgba(10,45,87,.10);
  --max: 1120px;
  --radius: 10px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial, "Helvetica Neue", Helvetica, sans-serif;
  color:var(--text);
  background:var(--white);
  line-height:1.6;
}
img{max-width:100%; height:auto; display:block}
a{color:inherit; text-decoration:none}
a:hover{color:var(--blue2)}
.container{max-width:var(--max); margin:0 auto; padding:0 20px}

/* Header */
.header{
  position:sticky; top:0; z-index:50;
  background:rgba(255,255,255,.88);
  backdrop-filter:saturate(180%) blur(10px);
  border-bottom:1px solid rgba(220,226,232,.8);
}
.navbar{display:flex; align-items:center; justify-content:space-between; gap:16px; padding:14px 0}
.brand{display:flex; align-items:center; gap:12px; min-width:220px}
.brand img{width:42px; height:42px; object-fit:contain}
.brand .title{font-weight:800; letter-spacing:.2px}
.brand .title span{color:var(--lime)}
.navlinks{display:flex; gap:18px; align-items:center; flex-wrap:wrap; justify-content:flex-end}
.navlinks a{font-size:14px; color:var(--muted); padding:8px 10px; border-radius:999px}
.navlinks a[aria-current="page"]{background:rgba(142,205,255,.25); color:var(--navy)}
.cta{display:inline-flex; align-items:center; gap:10px; padding:10px 14px; border-radius:999px; background:var(--lime); color:#07101f; font-weight:700}
.cta:hover{filter:brightness(.98)}
.menuBtn{display:none; border:1px solid rgba(220,226,232,.9); background:transparent; padding:10px 12px; border-radius:10px}
@media (max-width: 860px){
  .navlinks{display:none}
  .menuBtn{display:inline-flex}
  .mobileNav{display:none; padding:12px 0 18px}
  .mobileNav a{display:block; padding:10px 0; color:var(--muted)}
  .mobileNav .cta{display:inline-flex; margin-top:10px}
  .mobileNav.open{display:block}
}

/* Hero */
.hero{position:relative; overflow:hidden}
.hero::before{
  content:""; position:absolute; inset:0;
  background:linear-gradient(120deg, rgba(10,45,87,.75), rgba(10,34,213,.20) 55%, rgba(182,231,58,.08));
  z-index:1;
}
.heroImg{position:absolute; inset:0; background:url('../images/hero.jpg') center/cover no-repeat; filter:saturate(1.05) contrast(1.05)}
.heroInner{position:relative; z-index:2; padding:72px 0 54px}
.kicker{display:inline-flex; align-items:center; gap:10px; padding:6px 10px; border:1px solid rgba(220,226,232,.55); border-radius:999px; background:rgba(255,255,255,.12); color:#f2f6ff; font-size:13px}
.kicker .dot{width:8px; height:8px; border-radius:999px; background:var(--lime)}
.h1{font-size:clamp(34px, 4.2vw, 56px); line-height:1.05; letter-spacing:-.6px; margin:14px 0 14px; color:white; font-weight:900}
.lead{max-width:62ch; color:rgba(255,255,255,.88); font-size:18px}
.heroActions{display:flex; gap:12px; flex-wrap:wrap; margin-top:22px}
.btn{display:inline-flex; align-items:center; justify-content:center; gap:10px; padding:12px 16px; border-radius:999px; border:1px solid rgba(255,255,255,.25); color:white; background:transparent; font-weight:700}
.btn.primary{background:var(--lime); border-color:transparent; color:#07101f}
.btn:hover{transform:translateY(-1px)}
.heroMeta{display:flex; gap:18px; flex-wrap:wrap; margin-top:24px; color:rgba(255,255,255,.78); font-size:14px}

/* Sections */
.section{padding:62px 0}
.section.alt{background:linear-gradient(180deg, rgba(220,226,232,.35), rgba(255,255,255,1))}
.sectionTitle{display:flex; align-items:flex-end; justify-content:space-between; gap:18px; flex-wrap:wrap}
.sectionTitle h2{margin:0; font-size:28px; letter-spacing:-.3px}
.sectionTitle p{margin:0; color:var(--muted); max-width:64ch}

/* Layout blocks (avoid repetitive cards) */
.split{display:grid; grid-template-columns: 1.1fr .9fr; gap:28px; margin-top:24px; align-items:start}
@media(max-width: 900px){ .split{grid-template-columns:1fr} }
.panel{border:1px solid rgba(220,226,232,.9); background:white; border-radius:var(--radius); padding:18px; box-shadow:var(--shadow)}
.panel.soft{background:rgba(142,205,255,.12)}
.panel.navy{background:rgba(10,45,87,.06)}
.panel h3{margin:0 0 10px}
.list{margin:0; padding-left:18px; color:var(--muted)}
.list li{margin:8px 0}

/* Services preview: alternating rows */
.servicesGrid{margin-top:22px; display:grid; gap:16px}
.serviceRow{display:grid; grid-template-columns: 160px 1fr; gap:16px; align-items:center; padding:14px; border:1px solid rgba(220,226,232,.9); border-radius:var(--radius); background:white}
.serviceRow img{width:160px; height:110px; object-fit:cover; border-radius:0}
@media(max-width:720px){ .serviceRow{grid-template-columns:1fr} .serviceRow img{width:100%; height:180px} }
.serviceRow h3{margin:0 0 6px}
.serviceRow p{margin:0; color:var(--muted)}

/* Steps */
.steps{margin-top:18px; display:grid; gap:10px}
.step{display:grid; grid-template-columns: 42px 1fr; gap:12px; padding:12px 14px; border-left:4px solid rgba(182,231,58,.9); background:rgba(220,226,232,.25)}
.step .num{font-weight:900; color:var(--navy)}
.step h4{margin:0 0 6px}
.step p{margin:0; color:var(--muted)}

/* Blog */
.blogGrid{margin-top:22px; display:grid; grid-template-columns: repeat(3, 1fr); gap:16px}
@media(max-width: 900px){ .blogGrid{grid-template-columns:1fr} }
.postCard{border:1px solid rgba(220,226,232,.9); background:white; box-shadow:var(--shadow)}
.postCard img{height:170px; width:100%; object-fit:cover; border-radius:0}
.postCard .pad{padding:14px}
.tag{display:inline-flex; font-size:12px; color:var(--navy); background:rgba(142,205,255,.22); padding:4px 10px; border-radius:999px; border:1px solid rgba(220,226,232,.9)}
.postCard h3{margin:10px 0 8px; letter-spacing:-.2px}
.postCard p{margin:0; color:var(--muted)}
.postMeta{margin-top:10px; font-size:13px; color:var(--muted)}

/* Article page */
.articleHero{padding:44px 0 18px}
.articleHero h1{margin:0 0 10px; font-size:40px; letter-spacing:-.4px}
.articleHero .sub{color:var(--muted); max-width:70ch}
.articleBody{padding:22px 0 70px}
.articleBody .content{max-width: 780px}
.articleBody h2{margin-top:26px}
.articleBody p, .articleBody li{color:#2b3648}
.articleBody img{border-radius:0; border:1px solid rgba(220,226,232,.9)}

/* Forms */
.form{display:grid; gap:12px}
.field{display:grid; gap:6px}
label{font-weight:700; font-size:14px}
input, select, textarea{width:100%; padding:12px 12px; border-radius:10px; border:1px solid rgba(220,226,232,.95); font:inherit}
textarea{min-height:120px; resize:vertical}
.note{font-size:13px; color:var(--muted)}

/* Footer */
.footer{background:rgba(10,45,87,.06); border-top:1px solid rgba(220,226,232,.9); padding:34px 0}
.footerGrid{display:grid; grid-template-columns: 1.1fr .9fr; gap:18px; align-items:start}
@media(max-width: 900px){ .footerGrid{grid-template-columns:1fr} }
.small{font-size:13px; color:var(--muted)}
.social{display:flex; gap:10px; align-items:center; margin-top:10px}
.iconBtn{width:38px; height:38px; display:inline-flex; align-items:center; justify-content:center; border-radius:10px; border:1px solid rgba(220,226,232,.9); background:white}
.iconBtn svg{width:18px; height:18px; fill:var(--navy)}

/* Utility */
.badge{display:inline-flex; align-items:center; gap:8px; padding:6px 10px; border-radius:999px; border:1px solid rgba(220,226,232,.9); background:rgba(255,255,255,.72); color:var(--navy); font-size:13px}
.hr{height:1px; background:rgba(220,226,232,.9); margin:18px 0}