:root{
  --navy:#13293d; --navy2:#1b3a57; --blue:#2b7de9; --blue-d:#1d63c4;
  --ink:#1a2230; --muted:#5a6678; --line:#e6eaf0; --bg:#ffffff; --soft:#f5f8fc;
  --max:1120px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
     color:var(--ink);background:var(--bg);line-height:1.6;-webkit-font-smoothing:antialiased}
a{color:var(--blue);text-decoration:none}
h1,h2,h3{line-height:1.2;color:var(--navy);margin:0 0 .4em}
h1{font-size:clamp(2.1rem,5vw,3.4rem);letter-spacing:-.02em}
h2{font-size:clamp(1.6rem,3.2vw,2.3rem);letter-spacing:-.01em}
h3{font-size:1.2rem}
p{margin:0 0 1em}
.wrap{max-width:var(--max);margin:0 auto;padding:0 22px}
.btn{display:inline-block;background:var(--blue);color:#fff;font-weight:600;padding:.8em 1.5em;
     border-radius:8px;border:0;cursor:pointer;transition:.15s}
.btn:hover{background:var(--blue-d)}
.btn.ghost{background:transparent;color:#fff;border:1.5px solid rgba(255,255,255,.55)}
.btn.ghost:hover{background:rgba(255,255,255,.12)}
.btn.dark{background:var(--navy)}
.btn.dark:hover{background:var(--navy2)}

/* header */
header{position:sticky;top:0;z-index:20;background:rgba(255,255,255,.95);backdrop-filter:blur(8px);
       border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;justify-content:space-between;height:68px}
.logo{display:flex;align-items:center;gap:10px;font-weight:800;color:var(--navy);font-size:1.15rem;letter-spacing:-.01em}
.logo .mark{width:30px;height:30px;border-radius:7px;background:linear-gradient(135deg,var(--blue),var(--navy));
     display:grid;place-items:center;color:#fff;font-weight:800;font-size:.95rem}
nav.links{display:flex;gap:26px;align-items:center}
nav.links a{color:var(--ink);font-weight:500;font-size:.97rem}
nav.links a:hover{color:var(--blue)}
.nav .btn{padding:.55em 1.1em}
@media(max-width:760px){nav.links a:not(.btn){display:none}}

/* hero */
.hero{background:radial-gradient(1200px 500px at 75% -10%,rgba(43,125,233,.25),transparent),
      linear-gradient(160deg,var(--navy) 0%,var(--navy2) 60%,#244a6e 100%);color:#fff;
      padding:92px 0 100px}
.hero .eyebrow{color:#9ec5ff;font-weight:700;letter-spacing:.14em;text-transform:uppercase;font-size:.8rem;margin-bottom:18px}
.hero h1{color:#fff;max-width:14ch}
.hero p.lead{font-size:1.22rem;color:#d7e3f2;max-width:52ch;margin-top:.4em}
.hero .cta{display:flex;gap:14px;flex-wrap:wrap;margin-top:30px}

/* page hero (shorter, for interior pages) */
.hero.page{padding:70px 0 76px}
.hero.page h1{max-width:20ch}

/* sections */
section{padding:74px 0}
.section-head{max-width:60ch;margin-bottom:42px}
.section-head .eyebrow{color:var(--blue);font-weight:700;letter-spacing:.12em;text-transform:uppercase;font-size:.78rem}
.lead-muted{color:var(--muted);font-size:1.08rem}
.soft{background:var(--soft)}

.welcome{text-align:center}
.welcome p{max-width:62ch;margin-inline:auto;font-size:1.18rem;color:var(--muted)}

/* services grid */
.grid{display:grid;gap:22px}
.grid.cols-4{grid-template-columns:repeat(4,1fr)}
.grid.cols-3{grid-template-columns:repeat(3,1fr)}
.grid.cols-2{grid-template-columns:repeat(2,1fr)}
@media(max-width:900px){.grid.cols-4,.grid.cols-3{grid-template-columns:repeat(2,1fr)}}
@media(max-width:600px){.grid.cols-4,.grid.cols-3,.grid.cols-2{grid-template-columns:1fr}}
.card{background:#fff;border:1px solid var(--line);border-radius:14px;padding:26px;transition:.18s}
.card:hover{box-shadow:0 14px 34px rgba(19,41,61,.10);transform:translateY(-3px);border-color:#d2deee}
.card .ico{width:46px;height:46px;border-radius:11px;background:#eaf2fe;display:grid;place-items:center;margin-bottom:16px}
.card .ico svg{width:24px;height:24px;stroke:var(--blue);fill:none;stroke-width:1.9}
.card h3{margin-bottom:.35em}
.card p{color:var(--muted);font-size:.97rem;margin:0}
.card a.more{display:inline-block;margin-top:14px;font-weight:600;font-size:.92rem}

/* link-card: make a whole card clickable */
a.card{display:block;color:inherit}
a.card:hover{color:inherit}

/* why list */
.why{display:grid;grid-template-columns:repeat(2,1fr);gap:18px 40px}
@media(max-width:700px){.why{grid-template-columns:1fr}}
.why .item{display:flex;gap:14px}
.why .chk{flex:0 0 auto;width:26px;height:26px;border-radius:50%;background:#e7f8ee;display:grid;place-items:center;margin-top:2px}
.why .chk svg{width:15px;height:15px;stroke:#1aa55b;fill:none;stroke-width:2.4}
.why h3{font-size:1.05rem;margin-bottom:.15em}
.why p{color:var(--muted);font-size:.95rem;margin:0}

/* about split */
.split{display:grid;grid-template-columns:1.1fr .9fr;gap:54px;align-items:center}
@media(max-width:820px){.split{grid-template-columns:1fr;gap:34px}}
.stat-row{display:flex;gap:34px;margin-top:18px;flex-wrap:wrap}
.stat .n{font-size:2rem;font-weight:800;color:var(--navy)}
.stat .l{color:var(--muted);font-size:.9rem}
.panel{background:linear-gradient(160deg,var(--navy),#244a6e);color:#fff;border-radius:18px;padding:34px}
.panel h3{color:#fff}
.panel ul{list-style:none;padding:0;margin:0}
.panel li{padding:11px 0;border-bottom:1px solid rgba(255,255,255,.12);color:#dbe6f4;display:flex;gap:10px}
.panel li:last-child{border:0}
.panel li b{color:#fff;font-weight:600}

/* detailed service blocks */
.svc{display:grid;grid-template-columns:1fr 1fr;gap:44px;align-items:center;padding:40px 0;border-bottom:1px solid var(--line)}
.svc:last-child{border-bottom:0}
.svc.rev .svc-text{order:2}
@media(max-width:820px){.svc{grid-template-columns:1fr;gap:26px}.svc.rev .svc-text{order:0}}
.svc .svc-ico{width:60px;height:60px;border-radius:14px;background:#eaf2fe;display:grid;place-items:center;margin-bottom:18px}
.svc .svc-ico svg{width:30px;height:30px;stroke:var(--blue);fill:none;stroke-width:1.8}
.svc .lead-muted{margin-bottom:0}
.incl{background:#fff;border:1px solid var(--line);border-radius:14px;padding:26px}
.incl h3{font-size:1rem;letter-spacing:.04em;text-transform:uppercase;color:var(--muted);margin-bottom:16px}
.incl ul{list-style:none;padding:0;margin:0}
.incl li{display:flex;gap:11px;padding:9px 0;color:var(--ink);font-size:.97rem;align-items:flex-start}
.incl li .chk{flex:0 0 auto;width:22px;height:22px;border-radius:50%;background:#e7f8ee;display:grid;place-items:center;margin-top:2px}
.incl li .chk svg{width:13px;height:13px;stroke:#1aa55b;fill:none;stroke-width:2.6}

/* numbered steps */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:22px;counter-reset:step}
@media(max-width:900px){.steps{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.steps{grid-template-columns:1fr}}
.step{background:#fff;border:1px solid var(--line);border-radius:14px;padding:26px}
.step .num{width:40px;height:40px;border-radius:10px;background:linear-gradient(135deg,var(--blue),var(--navy));
     color:#fff;font-weight:800;display:grid;place-items:center;margin-bottom:14px}
.step h3{font-size:1.08rem;margin-bottom:.3em}
.step p{color:var(--muted);font-size:.95rem;margin:0}

/* team */
.member{text-align:center}
.avatar{width:96px;height:96px;border-radius:50%;margin:0 auto 14px;
     background:linear-gradient(135deg,var(--blue),var(--navy));color:#fff;display:grid;place-items:center;
     font-size:1.9rem;font-weight:700}
.member h3{margin-bottom:.1em}
.member .role{color:var(--blue);font-weight:600;font-size:.92rem}
.member p{color:var(--muted);font-size:.95rem;margin-top:.6em}

/* testimonials */
.quote{background:#fff;border:1px solid var(--line);border-radius:14px;padding:26px}
.quote p{font-size:1.02rem;color:var(--ink);font-style:italic}
.quote .who{color:var(--muted);font-style:normal;font-size:.9rem;margin:0}

/* CTA band */
.band{background:linear-gradient(120deg,var(--blue),var(--navy));color:#fff;text-align:center;border-radius:20px;padding:54px 26px}
.band h2{color:#fff}
.band p{color:#e3edfb;max-width:48ch;margin-inline:auto}

/* contact */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:44px}
@media(max-width:760px){.contact-grid{grid-template-columns:1fr}}
.cinfo a{display:flex;gap:13px;align-items:center;padding:13px 0;border-bottom:1px solid var(--line);color:var(--ink);font-weight:500}
.cinfo a:last-child{border:0}
.cinfo .ci{width:40px;height:40px;border-radius:10px;background:#eaf2fe;display:grid;place-items:center;flex:0 0 auto}
.cinfo .ci svg{width:19px;height:19px;stroke:var(--blue);fill:none;stroke-width:1.9}
.cinfo small{display:block;color:var(--muted);font-weight:400;font-size:.8rem}
form .row{display:flex;gap:14px}
form .row>*{flex:1}
input,textarea{width:100%;padding:.8em;border:1px solid var(--line);border-radius:9px;font:inherit;margin-bottom:13px;background:var(--soft)}
textarea{min-height:120px;resize:vertical}

/* blog */
.post-card{background:#fff;border:1px solid var(--line);border-radius:14px;padding:26px;transition:.18s;display:flex;flex-direction:column}
.post-card:hover{box-shadow:0 14px 34px rgba(19,41,61,.10);transform:translateY(-3px);border-color:#d2deee}
.post-card .tag{display:inline-block;font-size:.72rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--blue);margin-bottom:12px}
.post-card h3{margin-bottom:.4em}
.post-card p{color:var(--muted);font-size:.96rem;margin:0 0 16px}
.post-card .more{margin-top:auto;font-weight:600;font-size:.92rem}

/* footer */
footer{background:var(--navy);color:#cdd9e8;padding:54px 0 26px}
footer .cols{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:34px}
@media(max-width:700px){footer .cols{grid-template-columns:1fr}}
footer h4{color:#fff;font-size:.85rem;letter-spacing:.08em;text-transform:uppercase;margin:0 0 14px}
footer a{color:#cdd9e8;display:block;padding:5px 0;font-size:.95rem}
footer a:hover{color:#fff}
.foot-logo{color:#fff;font-weight:800;font-size:1.2rem;margin-bottom:10px}
.foot-tag{color:#8fa6c0;font-size:.95rem}
.copyright{border-top:1px solid rgba(255,255,255,.12);margin-top:34px;padding-top:20px;
     color:#8fa6c0;font-size:.85rem;display:flex;justify-content:space-between;flex-wrap:wrap;gap:8px}
