:root{
  --navy:#0B1F3A; --navy-2:#102E55; --blue:#1E7BE8; --blue-2:#3B95FF;
  --blue-soft:#EAF2FD; --ink:#0E1B2C; --muted:#566578; --bg:#FFFFFF;
  --bg-2:#F4F8FD; --line:#E4EAF2; --gold:#E0A93B;
  --shadow:0 22px 60px -28px rgba(11,31,58,.42);
  --shadow-sm:0 10px 28px -16px rgba(11,31,58,.30);
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:'Mulish',sans-serif;background:var(--bg);color:var(--ink);line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden}
h1,h2,h3,h4{font-family:'Bricolage Grotesque',sans-serif;font-weight:600;line-height:1.07;letter-spacing:-.015em}
a{color:inherit;text-decoration:none}
.wrap{max-width:1200px;margin:0 auto;padding:0 28px}
img{display:block;max-width:100%}
.blue{color:var(--blue)}

/* utility bar */
.utility{background:var(--navy);color:#C5D6EC;font-size:13.5px}
.utility .wrap{display:flex;justify-content:space-between;align-items:center;gap:18px;padding:9px 28px;flex-wrap:wrap}
.utility .u-left{display:flex;gap:22px;flex-wrap:wrap}
.utility a,.utility span{display:inline-flex;align-items:center;gap:7px}
.utility a:hover{color:#fff}
.utility svg{width:14px;height:14px;flex:none;color:var(--blue-2)}
.u-tag{color:#8FB4DD;font-weight:600;letter-spacing:.04em}

/* header */
header{position:sticky;top:0;z-index:60;background:var(--navy);border-bottom:1px solid rgba(255,255,255,.08)}
header .wrap{display:flex;align-items:center;justify-content:space-between;padding:14px 28px}
.logo img{height:46px;width:auto}
nav.main{display:flex;align-items:center;gap:30px}
nav.main ul{display:flex;gap:26px;list-style:none;font-weight:600;font-size:15px}
nav.main a{color:#CFE0F4;transition:color .2s}
nav.main a:hover{color:#fff}
.btn{display:inline-flex;align-items:center;gap:9px;font-family:'Mulish',sans-serif;font-weight:700;font-size:15px;padding:13px 24px;border-radius:8px;transition:transform .2s,box-shadow .2s,background .2s,color .2s;cursor:pointer;border:none}
.btn-primary{background:var(--blue);color:#fff;box-shadow:var(--shadow-sm)}
.btn-primary:hover{transform:translateY(-2px);box-shadow:var(--shadow);background:var(--blue-2)}
.btn-ghost{background:transparent;color:#fff;border:1.5px solid rgba(255,255,255,.45)}
.btn-ghost:hover{background:#fff;color:var(--navy)}
.btn-dark{background:var(--navy);color:#fff}
.btn-dark:hover{transform:translateY(-2px);box-shadow:var(--shadow);background:var(--navy-2)}
.nav-toggle{display:none}

/* hero */
.hero{background:linear-gradient(160deg,var(--navy) 0%,var(--navy-2) 70%,#143866 100%);color:#fff;position:relative;overflow:hidden;padding:78px 0 90px}
.hero::after{content:'';position:absolute;top:-30%;right:-10%;width:55%;height:150%;background:radial-gradient(circle,rgba(30,123,232,.30),transparent 62%)}
.hero .wrap{position:relative;z-index:1;display:grid;grid-template-columns:1.04fr .96fr;gap:54px;align-items:center}
.eyebrow{display:inline-flex;align-items:center;gap:9px;font-size:12.5px;font-weight:800;letter-spacing:.16em;text-transform:uppercase;color:#9FC6F2;margin-bottom:20px}
.eyebrow .ln{width:26px;height:2px;background:var(--blue-2)}
.hero h1{font-size:clamp(38px,5vw,62px);margin-bottom:20px;color:#fff}
.hero h1 .accent{background:linear-gradient(90deg,#3B95FF,#8Fc4ff);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.hero p.lead{font-size:18px;color:#C2D4EA;max-width:500px;margin-bottom:30px}
.hero-cta{display:flex;gap:13px;flex-wrap:wrap;margin-bottom:30px}
.hero-trust{display:flex;gap:14px 26px;flex-wrap:wrap;font-size:14px;color:#BFD2E9;font-weight:600}
.hero-trust span{display:flex;align-items:center;gap:8px}
.hero-trust svg{width:17px;height:17px;color:var(--blue-2);flex:none}
.hero-visual{position:relative}
.hero-visual .frame{border-radius:18px;overflow:hidden;box-shadow:var(--shadow);border:5px solid rgba(255,255,255,.10)}
.hero-visual .frame img{width:100%;height:430px;object-fit:cover}
.hero-stat{position:absolute;bottom:-22px;left:-22px;background:#fff;color:var(--ink);border-radius:14px;padding:16px 20px;box-shadow:var(--shadow);display:flex;align-items:center;gap:13px}
.hero-stat .ic{width:44px;height:44px;border-radius:11px;background:var(--blue-soft);display:grid;place-items:center;color:var(--blue);flex:none}
.hero-stat .ic svg{width:23px;height:23px}
.hero-stat b{font-family:'Bricolage Grotesque';font-size:15px;display:block;line-height:1.15}
.hero-stat small{color:var(--muted);font-size:12.5px}

/* trust strip */
.strip{background:var(--bg-2);border-bottom:1px solid var(--line)}
.strip .wrap{display:flex;justify-content:space-between;gap:18px;flex-wrap:wrap;padding:22px 28px}
.strip .item{display:flex;align-items:center;gap:10px;font-weight:700;font-size:14.5px;color:var(--ink)}
.strip .item svg{width:20px;height:20px;color:var(--blue);flex:none}

/* sections */
section{padding:86px 0}
.sec-head{max-width:680px;margin:0 auto 52px;text-align:center}
.sec-eyebrow{font-size:12.5px;font-weight:800;letter-spacing:.16em;text-transform:uppercase;color:var(--blue);margin-bottom:13px}
.sec-head h2{font-size:clamp(29px,3.6vw,43px);margin-bottom:15px}
.sec-head p{color:var(--muted);font-size:17px}

/* industries */
.ind-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}
.ind{position:relative;border-radius:18px;overflow:hidden;box-shadow:var(--shadow-sm);min-height:280px;display:flex;align-items:flex-end;border:1px solid var(--line)}
.ind img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .6s ease}
.ind:hover img{transform:scale(1.06)}
.ind::after{content:'';position:absolute;inset:0;background:linear-gradient(to top,rgba(8,20,38,.92) 8%,rgba(8,20,38,.45) 45%,rgba(8,20,38,.08) 100%)}
.ind .body{position:relative;z-index:1;padding:28px;color:#fff}
.ind .tag{display:inline-block;font-size:11.5px;font-weight:800;letter-spacing:.12em;text-transform:uppercase;color:#9FC6F2;margin-bottom:8px}
.ind h3{font-size:23px;color:#fff;margin-bottom:7px}
.ind p{font-size:14.5px;color:#D5E2F1;max-width:420px}

/* process */
.process{background:var(--navy);color:#fff;position:relative;overflow:hidden}
.process::before{content:'';position:absolute;bottom:-40%;left:-8%;width:45%;height:150%;background:radial-gradient(circle,rgba(30,123,232,.22),transparent 62%)}
.process .sec-head h2{color:#fff}
.process .sec-head p{color:#B7CCE6}
.proc-grid{position:relative;z-index:1;display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.proc{padding:28px 22px;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.10);border-radius:16px}
.proc .n{font-family:'Bricolage Grotesque';font-size:14px;font-weight:700;color:var(--navy);background:var(--blue-2);width:32px;height:32px;border-radius:50%;display:grid;place-items:center;margin-bottom:16px}
.proc h3{font-size:18px;color:#fff;margin-bottom:7px}
.proc p{font-size:14px;color:#B7CCE6}

/* gallery */
.gal{display:grid;grid-template-columns:repeat(12,1fr);grid-auto-rows:200px;gap:14px}
.gal figure{position:relative;overflow:hidden;border-radius:14px;border:1px solid var(--line)}
.gal img{width:100%;height:100%;object-fit:cover;transition:transform .6s}
.gal figure:hover img{transform:scale(1.07)}
.gal figcaption{position:absolute;left:0;bottom:0;right:0;padding:16px 16px 13px;background:linear-gradient(to top,rgba(8,20,38,.85),transparent);color:#fff;font-size:13px;font-weight:700;opacity:0;transform:translateY(8px);transition:.3s}
.gal figure:hover figcaption{opacity:1;transform:none}
.g-a{grid-column:span 5;grid-row:span 2}
.g-b{grid-column:span 4}
.g-c{grid-column:span 3}
.g-d{grid-column:span 4}
.g-e{grid-column:span 4}
.g-f{grid-column:span 4}
.g-g{grid-column:span 7}
.gal-note{text-align:center;margin-top:26px;color:var(--muted);font-size:15px}

/* why */
.why-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px 40px}
.why-item{display:flex;gap:15px;align-items:flex-start;padding-bottom:6px}
.why-item .ic{width:46px;height:46px;border-radius:12px;background:var(--blue-soft);display:grid;place-items:center;color:var(--blue);flex:none}
.why-item .ic svg{width:23px;height:23px}
.why-item b{font-family:'Bricolage Grotesque';font-size:18px;display:block;margin-bottom:3px}
.why-item p{color:var(--muted);font-size:15px}

/* owner teaser */
.owner{background:var(--bg-2);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.owner .wrap{display:grid;grid-template-columns:.85fr 1.15fr;gap:50px;align-items:center}
.owner .photo{border-radius:18px;overflow:hidden;box-shadow:var(--shadow);border:1px solid var(--line)}
.owner .photo img{width:100%;height:480px;object-fit:cover;object-position:top center}
.owner h2{font-size:clamp(28px,3.4vw,40px);margin-bottom:8px}
.owner .role{color:var(--blue);font-weight:800;letter-spacing:.04em;text-transform:uppercase;font-size:13px;margin-bottom:18px}
.owner p{color:var(--muted);font-size:16.5px;margin-bottom:16px}
.owner .creds{display:flex;gap:10px;flex-wrap:wrap;margin:20px 0 26px}
.owner .creds span{background:#fff;border:1px solid var(--line);border-radius:8px;padding:8px 14px;font-size:13.5px;font-weight:700;color:var(--ink)}

/* CTA band */
.cta-band{background:linear-gradient(135deg,var(--blue),#1559b8);border-radius:24px;padding:58px 50px;text-align:center;color:#fff;position:relative;overflow:hidden;max-width:1144px;margin:0 auto}
.cta-band::before{content:'';position:absolute;top:-60%;left:-8%;width:45%;height:220%;background:radial-gradient(circle,rgba(255,255,255,.18),transparent 60%)}
.cta-band h2{font-size:clamp(27px,3.4vw,40px);color:#fff;margin-bottom:13px;position:relative}
.cta-band p{color:#DCEAFB;font-size:17px;margin-bottom:26px;position:relative;max-width:540px;margin-left:auto;margin-right:auto}
.cta-band .hero-cta{justify-content:center;position:relative;margin:0}

/* footer */
footer{background:var(--navy);color:#9FB4CE;padding:60px 0 26px}
.foot-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1.2fr;gap:38px;padding-bottom:40px;border-bottom:1px solid rgba(255,255,255,.09)}
.foot-grid h4{color:#fff;font-size:16px;margin-bottom:16px}
.foot-grid img{height:42px;margin-bottom:15px}
.foot-grid p{font-size:14px;line-height:1.7;max-width:270px}
.foot-grid ul{list-style:none}
.foot-grid li{margin-bottom:9px;font-size:14px}
.foot-grid a:hover{color:#fff}
.foot-c div{display:flex;gap:10px;margin-bottom:12px;font-size:14px;align-items:flex-start}
.foot-c svg{width:16px;height:16px;color:var(--blue-2);flex:none;margin-top:3px}
.foot-bottom{padding-top:22px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;font-size:13px;color:#6F84A0}

/* about page */
.about-hero{background:linear-gradient(160deg,var(--navy),var(--navy-2));color:#fff;padding:64px 0}
.about-hero .wrap{display:grid;grid-template-columns:.8fr 1.2fr;gap:50px;align-items:center}
.about-hero .photo{border-radius:18px;overflow:hidden;box-shadow:var(--shadow);border:5px solid rgba(255,255,255,.10)}
.about-hero .photo img{width:100%;height:460px;object-fit:cover;object-position:top center}
.about-hero h1{font-size:clamp(34px,4.4vw,52px);color:#fff;margin-bottom:10px}
.about-hero .role{color:#9FC6F2;font-weight:800;letter-spacing:.05em;text-transform:uppercase;font-size:14px;margin-bottom:18px}
.about-hero p{color:#C2D4EA;font-size:17px;margin-bottom:14px}
.bio-body{max-width:820px;margin:0 auto}
.bio-body h2{font-size:30px;margin:8px 0 18px}
.bio-body p{color:#3A4961;font-size:17px;margin-bottom:18px}
.cred-card{background:var(--bg-2);border:1px solid var(--line);border-radius:18px;padding:32px;margin:34px 0}
.cred-card h3{font-size:20px;margin-bottom:18px}
.cred-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.cred-grid .row{display:flex;gap:12px;align-items:flex-start}
.cred-grid svg{width:20px;height:20px;color:var(--blue);flex:none;margin-top:2px}
.cred-grid b{display:block;font-size:15px}
.cred-grid small{color:var(--muted);font-size:13.5px}

@media(max-width:920px){
  .hero .wrap,.owner .wrap,.about-hero .wrap{grid-template-columns:1fr;gap:42px}
  .proc-grid{grid-template-columns:1fr 1fr}
  .foot-grid{grid-template-columns:1fr 1fr}
  .gal{grid-auto-rows:170px}
}
@media(max-width:680px){
  nav.main ul,.u-left .u-addr{display:none}
  .ind-grid,.why-grid,.proc-grid,.foot-grid,.cred-grid{grid-template-columns:1fr}
  .strip .wrap{gap:14px}
  .gal{display:flex;flex-direction:column}
  .gal img{height:220px}
  .cta-band{padding:42px 24px}
  .hero{padding:52px 0 70px}
}

/* ===== v2 additions ===== */
/* services */
.svc-wrap{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.svc-card{padding:26px 24px;background:var(--bg-2);border:1px solid var(--line);border-radius:16px;transition:transform .3s,box-shadow .3s}
.svc-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-sm)}
.svc-card .ic{width:48px;height:48px;border-radius:12px;background:var(--blue-soft);display:grid;place-items:center;color:var(--blue);margin-bottom:15px}
.svc-card .ic svg{width:24px;height:24px}
.svc-card h3{font-size:18.5px;margin-bottom:6px}
.svc-card p{color:var(--muted);font-size:14.5px}
.freq{margin-top:34px;background:var(--navy);border-radius:18px;padding:28px 30px;display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:wrap}
.freq .lbl{color:#fff}
.freq .lbl b{font-family:'Bricolage Grotesque';font-size:20px;display:block}
.freq .lbl span{color:#B7CCE6;font-size:14.5px}
.freq .chips{display:flex;gap:10px;flex-wrap:wrap}
.freq .chips span{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.16);color:#E4EEF9;padding:9px 16px;border-radius:999px;font-size:14px;font-weight:700}
.svc-note{text-align:center;margin-top:24px;color:var(--muted);font-size:15px}

/* industries extras */
.ind-more{margin-top:30px;background:var(--bg-2);border:1px solid var(--line);border-radius:18px;padding:28px 30px}
.ind-more h4{font-size:16px;margin-bottom:14px;font-family:'Bricolage Grotesque'}
.ind-chips{display:flex;gap:10px;flex-wrap:wrap}
.ind-chips span{background:#fff;border:1px solid var(--line);border-radius:999px;padding:8px 15px;font-size:13.5px;font-weight:600;color:var(--ink)}
.ind-chips span.more{background:var(--blue-soft);border-color:transparent;color:var(--blue)}
.res-note{margin-top:18px;font-size:15px;color:var(--muted);border-left:3px solid var(--blue);padding-left:16px}
.res-note b{color:var(--ink)}

/* owner blurb inside why */
.owner-note{margin-top:46px;background:var(--bg-2);border:1px solid var(--line);border-radius:18px;padding:26px 30px;display:flex;gap:24px;align-items:center}
.owner-note img{width:96px;height:96px;border-radius:50%;object-fit:cover;object-position:top center;flex:none;border:3px solid #fff;box-shadow:var(--shadow-sm)}
.owner-note .t .lbl{font-size:12px;font-weight:800;letter-spacing:.14em;text-transform:uppercase;color:var(--blue);margin-bottom:6px}
.owner-note .t b{font-family:'Bricolage Grotesque';font-size:18px}
.owner-note .t p{color:var(--muted);font-size:14.5px;margin-top:4px;max-width:640px}

/* contact form */
.contact{background:var(--navy);color:#fff}
.contact .wrap{display:grid;grid-template-columns:.9fr 1.1fr;gap:50px;align-items:start}
.contact .intro h2{color:#fff;font-size:clamp(28px,3.4vw,40px);margin-bottom:14px}
.contact .intro p{color:#B7CCE6;font-size:16.5px;margin-bottom:24px}
.contact .intro .line{display:flex;gap:11px;align-items:center;margin-bottom:14px;font-size:15.5px;color:#E4EEF9;font-weight:600}
.contact .intro .line svg{width:19px;height:19px;color:var(--blue-2);flex:none}
.form{background:#fff;border-radius:18px;padding:30px;box-shadow:var(--shadow)}
.form .row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.field{margin-bottom:14px}
.field label{display:block;font-size:13px;font-weight:700;color:var(--ink);margin-bottom:6px}
.field input,.field select,.field textarea{width:100%;padding:12px 14px;border:1.5px solid var(--line);border-radius:9px;font-family:'Mulish';font-size:14.5px;color:var(--ink);background:#fff;transition:border-color .2s}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--blue)}
.field textarea{resize:vertical;min-height:90px}
.form button{width:100%;margin-top:6px;justify-content:center}
.form .ok{display:none;text-align:center;padding:30px 10px}
.form .ok svg{width:52px;height:52px;color:#1FА86B;color:#1f9d63;margin:0 auto 14px}
.form .ok b{font-family:'Bricolage Grotesque';font-size:22px;display:block;margin-bottom:6px;color:var(--ink)}
.form .ok p{color:var(--muted);font-size:15px}
.form-tiny{font-size:12px;color:var(--muted);text-align:center;margin-top:12px}
@media(max-width:920px){
  .svc-wrap{grid-template-columns:1fr 1fr}
  .contact .wrap{grid-template-columns:1fr;gap:34px}
}
@media(max-width:680px){
  .svc-wrap{grid-template-columns:1fr}
  .freq{flex-direction:column;align-items:flex-start}
  .form .row{grid-template-columns:1fr}
  .owner-note{flex-direction:column;text-align:center}
}

/* testimonials */
.tn-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.tn{background:#fff;border:1px solid var(--line);border-radius:18px;padding:28px;box-shadow:var(--shadow-sm);display:flex;flex-direction:column}
.tn .stars{color:var(--gold);font-size:16px;letter-spacing:2px;margin-bottom:14px}
.tn p{font-size:15.5px;color:var(--ink);line-height:1.6;margin-bottom:18px;flex:1}
.tn .by{display:flex;align-items:center;gap:10px;border-top:1px solid var(--line);padding-top:15px}
.tn .by .g{width:30px;height:30px;border-radius:50%;background:var(--blue-soft);display:grid;place-items:center;flex:none;font-family:'Bricolage Grotesque';font-weight:700;color:var(--blue);font-size:15px}
.tn .by b{font-size:14px;display:block}
.tn .by small{color:var(--muted);font-size:12.5px}
@media(max-width:920px){.tn-grid{grid-template-columns:1fr}}
