*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
:root{
  --navy:#0a1628;--navy2:#0f1d32;--navyLight:#16263f;
  --accent:#2BA7DA;--accentDeep:#1C73B3;--accentBtn:#187BA3;
  --white:#ffffff;--off:#f0f4f8;--off2:#e2e8f0;
  --txt:#0a1628;--muted:#556170;
  --s1:8px;--s2:16px;--s3:24px;--s4:32px;
  --s5:40px;--s6:48px;--s8:64px;--s12:96px;
  --serif:'DM Serif Display',Georgia,serif;
  --sans:'DM Sans',system-ui,sans-serif;
  --orange:var(--accent);
}
html{scroll-behavior:smooth}
body{font-family:var(--sans);background:var(--white);color:var(--txt);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility;overflow-x:hidden}
a{text-decoration:none;color:inherit}
.wrap{max-width:1320px;margin:0 auto;padding:0 56px}
img{display:block;max-width:100%;height:auto}

/* BUTTONS */
.btn{display:inline-flex;align-items:center;gap:8px;font-family:var(--sans);font-weight:800;font-size:.75rem;letter-spacing:.1em;text-transform:uppercase;padding:16px 32px;border:2px solid transparent;cursor:pointer;transition:all .2s;white-space:nowrap;border-radius:4px}
.btn:hover{transform:translateY(-1px)}
.btn-accent{background:var(--accentBtn);color:var(--white);border-color:var(--accentBtn);box-shadow:0 6px 24px rgba(43,167,218,.25)}
.btn-accent:hover{box-shadow:0 8px 32px rgba(43,167,218,.35);background:var(--accent)}
.btn-orange{background:var(--accentBtn);color:var(--white);border-color:var(--accentBtn);box-shadow:0 4px 16px rgba(43,167,218,.2)}
.btn-navy{background:var(--navy);color:var(--white);border-color:var(--navy)}
.btn-white{background:var(--white);color:var(--navy);border-color:var(--white)}
.btn-ghost{background:transparent;color:var(--white);border-color:rgba(255,255,255,.2)}
.btn-ghost:hover{border-color:var(--white)}
.btn-outline-dark{background:transparent;color:var(--navy);border-color:var(--navy)}
.btn-nav{padding:11px 22px;font-size:.68rem;border-radius:4px;box-shadow:0 4px 16px rgba(43,167,218,.25);background:var(--accentBtn);border-color:var(--accentBtn)}

/* UTILITY TOP BAR */
.topbar{background:var(--navy);border-bottom:1px solid rgba(255,255,255,.04);padding:8px 0}
.tb-inner{display:flex;justify-content:space-between;align-items:center}
.tb-left{display:flex;gap:24px;align-items:center}
.tb-item{font-size:.68rem;color:rgba(255,255,255,.65);display:flex;align-items:center;gap:6px}
.tb-item i{color:var(--accent);font-size:.65rem}
.tb-right{display:flex;gap:12px;align-items:center}
.tb-badge{background:rgba(43,167,218,.08);border:1px solid rgba(43,167,218,.15);padding:3px 12px;border-radius:3px;font-size:.62rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--accent);display:flex;align-items:center;gap:6px}
.tb-badge i{font-size:.6rem}

/* NAVBAR */
.navbar{position:sticky;top:0;z-index:200;background:var(--navy2);border-bottom:1px solid rgba(255,255,255,.05);transition:background .25s,padding .25s}
.navbar.scrolled{background:var(--navy);box-shadow:0 4px 24px rgba(0,0,0,.3)}
.nb-inner{display:flex;align-items:center;justify-content:space-between;height:72px}
.logo{display:flex;align-items:center;gap:14px}
.logo-sq{width:48px;height:48px;display:flex;align-items:center;justify-content:center;flex-shrink:0;overflow:hidden;border-radius:10px;background:#fff;padding:5px;box-shadow:0 2px 12px rgba(43,167,218,.15)}
.logo-sq img{width:100%;height:100%;object-fit:contain}
.logo-name{font-weight:800;font-size:.9rem;letter-spacing:.12em;color:var(--white);line-height:1.15;text-transform:uppercase}
.logo-name-accent{font-weight:700;font-size:.68rem;letter-spacing:.25em;color:var(--accent);text-transform:uppercase}
.logo-sub{font-size:.5rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:rgba(43,167,218,.85);margin-top:2px}
.nav-links{display:flex;align-items:stretch;gap:0;height:72px}
.nav-links a{font-size:.72rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.68);padding:0 20px;transition:color .15s;display:flex;align-items:center;border-bottom:2px solid transparent}
.nav-links a:hover{color:rgba(255,255,255,.85)}
.nav-links a.active{color:var(--white);border-bottom-color:var(--accent)}
.nb-right{display:flex;align-items:center;gap:20px}
.nb-phone-wrap{text-align:right}
.nb-phone-label{display:block;font-size:.58rem;font-weight:600;color:rgba(255,255,255,.55);letter-spacing:.15em;text-transform:uppercase;margin-bottom:2px}
.nb-phone{font-weight:800;font-size:.9rem;color:var(--white);letter-spacing:.03em}
.nb-divider{width:1px;height:32px;background:rgba(255,255,255,.08)}

/* PAGE HERO (inner pages) */
.page-hero{padding:160px 0 80px;background:var(--navy);position:relative;overflow:hidden}
.page-hero::before{content:'';position:absolute;inset:0;background:var(--page-bg, url('images/proj7_substation.jpg')) center/cover no-repeat;opacity:.2}
.page-hero-inner{position:relative;z-index:1}
.page-hero .kicker{color:var(--accent)}
.page-hero h1{font-family:var(--serif);font-weight:400;font-size:clamp(2.2rem,4.5vw,3.6rem);line-height:1.1;letter-spacing:-.01em;color:var(--white);margin-bottom:var(--s3)}
.page-hero p{font-size:1rem;color:rgba(255,255,255,.72);max-width:560px;line-height:1.8}

/* SECTIONS */
.sec{padding:96px 0}
.sec-sm{padding:64px 0}
.kicker{display:flex;align-items:center;gap:12px;font-weight:800;font-size:.68rem;letter-spacing:.2em;text-transform:uppercase;color:var(--accent);margin-bottom:16px}
.kicker::before{content:'';width:28px;height:2px;background:var(--accent)}
h2.th2{font-family:var(--serif);font-weight:400;line-height:1.12;letter-spacing:-.01em;font-size:clamp(1.8rem,3.5vw,2.6rem);color:var(--txt)}
h2.th2.on-dark{color:var(--white)}
h2.th2 em{font-style:normal;color:var(--accent)}
.tbody{font-size:1rem;line-height:1.8;color:var(--muted);font-weight:400}
.tbody.on-dark{color:rgba(255,255,255,.72)}

/* ═══ PREMIUM HERO ═══ */
.hero{position:relative;background:var(--navy);overflow:hidden}
/* Slideshow */
.hero-slideshow{position:absolute;inset:0;z-index:0}
.hero-slide{position:absolute;inset:0;background-size:cover;background-position:center;opacity:0;transition:opacity 1.8s ease-in-out;transform:scale(1.04);will-change:opacity,transform;animation:heroSlideZoom 8s ease-in-out infinite alternate}
.hero-slide.active{opacity:1}
@keyframes heroSlideZoom{from{transform:scale(1.0)}to{transform:scale(1.06)}}
/* Overlay */
.hero-overlay{position:absolute;inset:0;z-index:1;background:linear-gradient(90deg,rgba(10,22,40,0.92) 0%,rgba(10,22,40,0.85) 45%,rgba(10,22,40,0.6) 70%,rgba(10,22,40,0.45) 100%),linear-gradient(180deg,rgba(10,22,40,0.3) 0%,transparent 30%,transparent 70%,rgba(10,22,40,0.5) 100%)}
/* Dots */
.hero-dots{position:absolute;bottom:28px;left:50%;transform:translateX(-50%);z-index:10;display:flex;gap:10px}
.hero-dot{width:32px;height:3px;border-radius:2px;background:rgba(255,255,255,.2);cursor:pointer;transition:all .4s ease;position:relative;overflow:hidden}
.hero-dot.active{background:rgba(255,255,255,.15)}
.hero-dot.active::after{content:'';position:absolute;left:0;top:0;bottom:0;right:0;background:var(--accent);border-radius:2px;transform-origin:left;animation:dotProgress 6s linear forwards}
@keyframes dotProgress{from{transform:scaleX(0)}to{transform:scaleX(1)}}
.hero-grid-bg{position:absolute;inset:0;z-index:2;opacity:.025;background-image:linear-gradient(rgba(255,255,255,.5) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.5) 1px,transparent 1px);background-size:60px 60px;pointer-events:none}
.hero-split{display:grid;grid-template-columns:55fr 45fr;min-height:600px;align-items:center;gap:48px;position:relative;z-index:5}
.hero-left{padding:80px 0 72px}
.hero-kicker{display:flex;align-items:center;gap:14px;font-size:.7rem;font-weight:800;letter-spacing:.2em;text-transform:uppercase;color:var(--accent);margin-bottom:28px;animation:fadeUp .7s ease both .1s}
.hero-kicker-line{width:40px;height:2px;background:var(--accent);flex-shrink:0}
.hero-h1{font-family:var(--serif);font-size:clamp(2.4rem,4.2vw,3.3rem);font-weight:400;line-height:1.14;color:var(--white);margin-bottom:24px;letter-spacing:-.01em;animation:fadeUp .7s ease both .2s}
.hero-h1 em{font-style:normal;color:var(--accent)}
.hero-desc{font-size:1rem;line-height:1.85;color:rgba(255,255,255,.72);max-width:500px;margin-bottom:36px;animation:fadeUp .7s ease both .3s}
.hero-ctas{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:48px;animation:fadeUp .7s ease both .4s}
.hero-trust-row{display:flex;gap:28px;align-items:center;animation:fadeUp .7s ease both .5s}
.hero-trust-item{display:flex;align-items:center;gap:8px;font-size:.7rem;font-weight:700;color:rgba(255,255,255,.65);letter-spacing:.03em}
.hero-trust-ico{width:28px;height:28px;border-radius:50%;background:rgba(43,167,218,.08);border:1px solid rgba(43,167,218,.12);display:flex;align-items:center;justify-content:center;font-size:.7rem;color:var(--accent)}
.hero-right{display:flex;align-items:center;justify-content:center;padding:40px 0}
.hero-stats-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;width:100%;max-width:420px;animation:fadeUp .8s ease both .35s}
.hero-stat-card{background:rgba(255,255,255,.04);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.07);border-radius:8px;padding:24px 20px;border-left:3px solid var(--accent);transition:all .3s ease}
.hero-stat-card:nth-child(even){border-left-color:var(--accentDeep)}
.hero-stat-card:hover{border-color:rgba(255,255,255,.14);background:rgba(255,255,255,.07);transform:translateY(-2px);box-shadow:0 8px 32px rgba(0,0,0,.2)}
.hsc-num{font-family:var(--serif);font-size:2.2rem;font-weight:400;color:var(--accent);line-height:1;margin-bottom:6px}
.hsc-unit{font-size:1.1rem;font-weight:700;color:var(--accent)}
.hsc-label{font-size:.75rem;font-weight:800;color:rgba(255,255,255,.85);letter-spacing:.03em;margin-bottom:4px}
.hsc-sub{font-size:.65rem;color:rgba(255,255,255,.55);line-height:1.4}
.hero-accent-line{position:absolute;bottom:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,var(--accent),transparent);z-index:10;opacity:.4}
.hero-accent-line::after{content:'';position:absolute;top:-1px;bottom:-1px;left:0;width:80px;background:var(--accent);border-radius:2px;filter:blur(2px);will-change:transform;animation:pulseSlide 4s ease-in-out infinite}
@keyframes pulseSlide{0%{transform:translateX(-80px);opacity:0}10%{opacity:1}90%{opacity:1}100%{transform:translateX(calc(100vw + 80px));opacity:0}}

/* TRUST STRIP */
.trust-strip{background:var(--white);border-bottom:1px solid var(--off2);padding:18px 0}
.ts-inner{display:flex;justify-content:space-between;align-items:center}
.ts-left{display:flex;align-items:center;gap:28px}
.ts-label{font-size:.68rem;font-weight:700;color:#5c6a76;letter-spacing:.15em;text-transform:uppercase}
.ts-client{font-size:.8rem;font-weight:800;color:#4a5568;letter-spacing:.08em;text-transform:uppercase}
.ts-link{font-size:.7rem;font-weight:700;color:var(--accentDeep);letter-spacing:.05em;display:flex;align-items:center;gap:6px;transition:color .15s}
.ts-link:hover{color:var(--accent)}

/* ABOUT */
.about-g{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}
.about-photo-div{width:100%;aspect-ratio:4/3;background-size:cover;background-position:center;border-left:5px solid var(--accent);border-radius:4px}
.about-img{position:relative}
.about-badge{position:absolute;bottom:-16px;right:-16px;background:var(--accent);padding:var(--s3);text-align:center}
.ab-n{font-family:var(--serif);font-weight:400;font-size:2.2rem;color:var(--white);line-height:1}
.ab-l{font-size:.62rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.7);margin-top:4px}
.feat-list{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:var(--s5)}
.feat-item{display:flex;align-items:center;gap:10px;font-size:.82rem;font-weight:600;color:var(--txt)}
.feat-item i{color:var(--accent);font-size:.85rem}

/* SERVICES */
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--s2)}
.svc-card{background:var(--white);padding:var(--s4);border-top:3px solid var(--accent);transition:transform .2s,box-shadow .2s;border-radius:4px}
.svc-card:hover{transform:translateY(-4px);box-shadow:0 8px 32px rgba(0,0,0,.06)}
.svc-n{font-size:.68rem;font-weight:800;letter-spacing:.08em;color:rgba(43,167,218,.25);margin-bottom:var(--s2)}
.svc-ico{font-size:1.5rem;color:var(--accent);margin-bottom:var(--s2)}
.svc-card h3{font-family:var(--sans);font-weight:800;font-size:.95rem;color:var(--txt);margin-bottom:var(--s1);letter-spacing:-.01em}
.svc-card p{font-size:.82rem;line-height:1.7;color:var(--muted)}
.svc-more{display:inline-flex;align-items:center;gap:6px;font-size:.68rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--accent);margin-top:var(--s3);transition:gap .15s}
.svc-more:hover{gap:10px}

/* INDUSTRIES */
.ind-grid{display:grid;grid-template-columns:repeat(4,1fr);border:1px solid var(--off2);border-right:none;border-bottom:none}
.ind-card{position:relative;overflow:hidden;aspect-ratio:1/1;cursor:pointer;border-right:1px solid var(--off2);border-bottom:1px solid var(--off2)}
.ind-photo{position:absolute;inset:0;background-size:cover;background-position:center;transition:transform .55s ease;filter:brightness(.82)}
.ind-card:hover .ind-photo{transform:scale(1.08);filter:brightness(.92)}
.ind-grad{position:absolute;inset:0;background:linear-gradient(to top,rgba(10,22,40,.78) 0%,rgba(10,22,40,.05) 100%);transition:background .3s}
.ind-card:hover .ind-grad{background:linear-gradient(to top,rgba(43,167,218,.88) 0%,rgba(10,22,40,.35) 100%)}
.ind-content{position:absolute;bottom:0;left:0;right:0;padding:var(--s3)}
.ind-name{font-weight:800;font-size:.95rem;letter-spacing:-.01em;color:var(--white);display:flex;align-items:center;gap:6px}
.ind-name i{font-size:.8rem;opacity:0;transform:translateX(-6px);transition:.25s}
.ind-card:hover .ind-name i{opacity:1;transform:translateX(0)}

/* FEATURE SECTIONS */
.feature{display:grid;grid-template-columns:1fr 1fr;min-height:560px}
.feature.flip{direction:rtl}.feature.flip>*{direction:ltr}
.feat-v{position:relative;overflow:hidden;min-height:460px}
.feat-v-bg{position:absolute;inset:0;background-size:cover;background-position:center;transition:transform .6s ease}
.feature:hover .feat-v-bg{transform:scale(1.03)}
.feat-c{background:var(--navy);display:flex;align-items:center;padding:var(--s12) var(--s8)}
.feat-c.light{background:var(--off)}
.feat-c.light h2{color:var(--navy)}
.feat-inner{max-width:520px}

/* STATS BAND */
.stats-band{background:var(--navy);padding:var(--s12) 0;border-top:4px solid var(--accent)}
.stats-g{display:grid;grid-template-columns:repeat(4,1fr)}
.st-c{text-align:center;padding:0 var(--s5);border-right:1px solid rgba(255,255,255,.07)}
.st-c:last-child{border-right:none}
.st-n{font-family:var(--serif);font-weight:400;font-size:3rem;line-height:1;color:var(--accent);margin-bottom:var(--s1)}
.st-l{font-size:.67rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.55)}

/* WHY */
.why-g{display:grid;grid-template-columns:1fr 1fr;gap:var(--s12);align-items:start}
.why-cards{display:grid;grid-template-columns:1fr 1fr;gap:var(--s2);margin-top:var(--s6)}
.why-card{background:var(--white);padding:var(--s4);border-left:3px solid var(--accent);transition:border-color .2s;border-radius:4px}
.why-card:hover{border-left-color:var(--navy)}
.why-card>i{font-size:1.3rem;color:var(--accent);display:block;margin-bottom:var(--s2)}
.why-card h3{font-weight:800;font-size:.88rem;color:var(--txt);margin-bottom:var(--s1)}
.why-card p{font-size:.78rem;line-height:1.65;color:var(--muted)}
.proc-lbl{font-size:.67rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--accent);display:block;margin-bottom:var(--s4)}
.proc-list{display:flex;flex-direction:column}
.proc-item{display:flex;gap:var(--s2);align-items:flex-start;padding:var(--s3) 0;border-bottom:1px solid var(--off2)}
.proc-item:last-child{border-bottom:none}
.proc-num{width:40px;height:40px;flex-shrink:0;background:var(--navy);display:flex;align-items:center;justify-content:center;font-weight:800;font-size:.95rem;color:var(--accent);border-radius:4px;transition:background .2s}
.proc-item:hover .proc-num{background:var(--accent);color:var(--white)}
.proc-item h3{font-weight:700;font-size:.88rem;color:var(--txt);margin-bottom:4px}
.proc-item p{font-size:.78rem;line-height:1.65;color:var(--muted)}

/* PROJECTS GRID */
.proj-top{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:var(--s6);flex-wrap:wrap;gap:var(--s2)}
.proj-all{display:inline-flex;align-items:center;gap:6px;font-size:.72rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--accent);border-bottom:2px solid var(--accent);padding-bottom:3px;transition:opacity .15s}
.proj-all:hover{opacity:.7}
.proj-grid{display:grid;grid-template-columns:1.55fr 1fr 1fr;grid-template-rows:300px 240px;gap:var(--s2)}
.proj-grid.full{grid-template-columns:repeat(3,1fr);grid-template-rows:auto}
.proj-item{position:relative;overflow:hidden;cursor:pointer;border-radius:4px}
.proj-item.big{grid-row:span 2}
.proj-bg{position:absolute;inset:0;background-size:cover;background-position:center;transition:transform .55s ease;filter:brightness(.85)}
.proj-item:hover .proj-bg{transform:scale(1.05);filter:brightness(.95)}
.proj-veil{position:absolute;inset:0;background:linear-gradient(to top,rgba(10,22,40,.85) 0%,rgba(10,22,40,.06) 55%,transparent 100%)}
.proj-info{position:absolute;bottom:0;left:0;right:0;padding:var(--s4)}
.proj-tag{font-size:.59rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--accent);border:1px solid rgba(43,167,218,.3);background:rgba(43,167,218,.08);padding:4px 10px;display:inline-block;margin-bottom:8px;border-radius:3px}
.proj-name{font-weight:800;font-size:1rem;letter-spacing:-.02em;color:var(--white);line-height:1.25}
.proj-sub{font-size:.7rem;color:rgba(255,255,255,.4);margin-top:4px}

/* OUR WORK PAGE GRIDS */
.ow-row{display:grid;gap:var(--s2);margin-bottom:var(--s2)}
.ow-row-2a{grid-template-columns:1.4fr 1fr}
.ow-row-2b{grid-template-columns:1fr 1.4fr}
.ow-row-3{grid-template-columns:repeat(3,1fr)}

/* PRODUCTS */
.prod-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--s3)}
.prod-card{background:var(--white);overflow:hidden;transition:transform .2s;border-radius:4px;box-shadow:0 2px 8px rgba(0,0,0,.04)}
.prod-card:hover{transform:translateY(-3px)}
.prod-img{width:100%;aspect-ratio:16/10;object-fit:cover;background:var(--navy);display:block;filter:brightness(.92)}
.prod-body{padding:var(--s3)}
.prod-tag{display:inline-block;font-size:.58rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--accent);border:1px solid rgba(43,167,218,.25);padding:3px 9px;margin-bottom:var(--s2);border-radius:3px}
.prod-name{font-weight:800;font-size:1rem;letter-spacing:-.02em;color:var(--txt);margin-bottom:var(--s1)}
.prod-desc{font-size:.82rem;line-height:1.65;color:var(--muted)}

/* TESTIMONIAL */
.testimonial{background:var(--navy);padding:var(--s12) 0}
.testi-inner{max-width:700px;margin:0 auto;text-align:center}
.testi-stars{color:var(--accent);font-size:1rem;display:flex;justify-content:center;gap:4px;margin-bottom:var(--s4)}
.testi-inner blockquote{font-family:var(--serif);font-size:1.3rem;font-weight:400;line-height:1.6;color:rgba(255,255,255,.8);margin-bottom:var(--s5)}
.testi-attr{display:flex;align-items:center;justify-content:center;gap:var(--s2)}
.testi-av{width:48px;height:48px;background:var(--accent);color:var(--white);display:flex;align-items:center;justify-content:center;font-weight:800;font-size:.9rem;border-radius:50%}
.testi-name{font-weight:800;font-size:.88rem;color:var(--white)}
.testi-role{font-size:.72rem;color:rgba(255,255,255,.4);margin-top:2px}

/* CTA BAND */
.cta-band{background:var(--accent);padding:var(--s6) 0}
.cta-row{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:var(--s4)}
.cta-text h3{font-family:var(--serif);font-size:1.5rem;font-weight:400;color:var(--white);margin-bottom:6px}
.cta-text p{font-size:.88rem;color:rgba(255,255,255,.75)}
.cta-acts{display:flex;gap:var(--s2)}

/* CONTACT PAGE */
.contact-g{display:grid;grid-template-columns:1fr 1fr;gap:var(--s8)}
.form-group{margin-bottom:var(--s3)}
.form-group label{display:block;font-size:.72rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--txt);margin-bottom:8px}
.form-group input,.form-group textarea,.form-group select{width:100%;padding:14px 16px;border:1px solid var(--off2);font-family:var(--sans);font-size:.88rem;background:var(--white);transition:border-color .15s;border-radius:4px}
.form-group input:focus,.form-group textarea:focus,.form-group select:focus{outline:none;border-color:var(--accent)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--s3)}
.contact-info h3{font-family:var(--serif);font-weight:400;font-size:1.6rem;color:var(--txt);margin-bottom:var(--s3)}
.ci-item{display:flex;gap:16px;align-items:flex-start;padding:var(--s3) 0;border-bottom:1px solid var(--off2)}
.ci-item:last-child{border-bottom:none}
.ci-ico{width:44px;height:44px;background:rgba(43,167,218,.08);display:flex;align-items:center;justify-content:center;font-size:1.1rem;color:var(--accent);flex-shrink:0;border-radius:4px}
.ci-label{font-size:.62rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--accent);margin-bottom:4px}
.ci-val{font-size:.92rem;font-weight:600;color:var(--txt)}

/* FOOTER */
.footer{background:var(--navy);padding:var(--s12) 0 var(--s6)}
.footer-top{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:var(--s6);margin-bottom:var(--s8)}
.ft-brand{max-width:320px}
.ft-brand .logo{margin-bottom:var(--s3)}
.ft-brand p{font-size:.82rem;line-height:1.7;color:rgba(255,255,255,.65);margin-bottom:var(--s3)}
.ft-cert{display:inline-flex;align-items:center;gap:8px;background:rgba(43,167,218,.06);border:1px solid rgba(43,167,218,.12);color:rgba(43,167,218,.9);font-size:.62rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;padding:6px 14px;border-radius:3px}
.ft-col-hd{font-size:.68rem;font-weight:800;letter-spacing:.15em;text-transform:uppercase;color:var(--white);margin-bottom:var(--s3)}
.ft-col ul{list-style:none}
.ft-col ul li{padding:5px 0}
.ft-col ul li a{font-size:.82rem;color:rgba(255,255,255,.58);transition:color .15s;display:flex;align-items:center;gap:6px}
.ft-col ul li a::before{content:'—';font-size:.55rem;opacity:.35}
.ft-col ul li a:hover{color:rgba(43,167,218,.75)}
.footer-bot{border-top:1px solid rgba(255,255,255,.05);padding-top:var(--s4);display:flex;justify-content:space-between;font-size:.72rem;color:rgba(255,255,255,.58)}

/* CONTACT PAGE — Form & Info */
.contact-g{display:grid;grid-template-columns:1fr 1fr;gap:var(--s8);align-items:start}
.contact-links{display:flex;flex-direction:column;gap:0}
.contact-link{display:flex;gap:16px;align-items:flex-start;padding:var(--s3) 0;border-bottom:1px solid var(--off2)}
.contact-link:last-child{border-bottom:none}
.contact-link>i{width:44px;height:44px;background:rgba(43,167,218,.08);display:flex;align-items:center;justify-content:center;font-size:1.1rem;color:var(--accent);flex-shrink:0;border-radius:6px}
.cl-lbl{font-size:.62rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--accent);margin-bottom:4px}
.cl-val{font-size:.92rem;font-weight:600;color:var(--txt);line-height:1.5}
.cl-val a{color:var(--txt);transition:color .15s}
.cl-val a:hover{color:var(--accent)}
.qform{background:var(--white);padding:var(--s5);border-radius:8px;border:1px solid var(--off2);box-shadow:0 4px 24px rgba(0,0,0,.06)}
.qf-title{font-family:var(--sans);font-weight:800;font-size:1.3rem;color:var(--txt);margin-bottom:6px}
.qf-sub{font-size:.85rem;color:var(--muted);margin-bottom:var(--s4);line-height:1.6}
.fg{margin-bottom:var(--s3)}
.fl{display:block;font-size:.7rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--txt);margin-bottom:8px}
.fi{width:100%;padding:14px 16px;border:1px solid var(--off2);font-family:var(--sans);font-size:.88rem;background:var(--off);transition:border-color .15s;border-radius:6px;color:var(--txt)}
.fi:focus{outline:none;border-color:var(--accent);background:var(--white)}
textarea.fi{min-height:100px;resize:vertical}
select.fi{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath d='M6 8L1 3h10z' fill='%236b7585'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 16px center;padding-right:40px}
.qf-submit{width:100%;padding:16px;background:var(--accent);color:var(--white);font-family:var(--sans);font-weight:800;font-size:.82rem;letter-spacing:.1em;text-transform:uppercase;border:none;border-radius:6px;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;transition:all .2s;box-shadow:0 4px 16px rgba(43,167,218,.25)}
.qf-submit:hover{box-shadow:0 6px 24px rgba(43,167,218,.35);transform:translateY(-1px)}
.msg-ok{background:rgba(16,185,129,.08);border:1px solid rgba(16,185,129,.2);color:#059669;padding:16px;border-radius:6px;font-size:.88rem;font-weight:600;margin-bottom:var(--s4);display:flex;align-items:center;gap:8px}
.msg-err{background:rgba(239,68,68,.08);border:1px solid rgba(239,68,68,.2);color:#dc2626;padding:16px;border-radius:6px;font-size:.88rem;font-weight:600;margin-bottom:var(--s4);display:flex;align-items:center;gap:8px}

/* CLIENTS PAGE */
.clients-intro{max-width:800px;margin-bottom:var(--s8)}
.client-cats{display:flex;flex-direction:column;gap:var(--s8)}
.client-cat-title{font-family:var(--sans);font-weight:800;font-size:1rem;color:var(--txt);margin-bottom:var(--s3);display:flex;align-items:center;gap:8px;padding-bottom:var(--s2);border-bottom:2px solid var(--accent)}
.client-cat-title i{color:var(--accent);font-size:1.1rem}
.client-logos{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
.client-card{background:var(--off);padding:20px 24px;border-radius:6px;border:1px solid var(--off2);transition:all .2s;cursor:default;display:flex;align-items:center;justify-content:center;text-align:center;min-height:72px}
.client-card:hover{background:var(--white);border-color:var(--accent);box-shadow:0 4px 16px rgba(43,167,218,.08);transform:translateY(-2px)}
.client-name{font-weight:700;font-size:.88rem;color:var(--txt);letter-spacing:.01em}

/* ANIMATIONS */
@keyframes fadeUp{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}
.reveal{opacity:0;transform:translateY(24px);transition:opacity .65s ease,transform .65s ease}
.reveal.in{opacity:1;transform:translateY(0)}
.d1{transition-delay:.12s}.d2{transition-delay:.24s}.d3{transition-delay:.36s}.d4{transition-delay:.48s}

/* MAP & TESTIMONIAL GRIDS */
.map-grid{display:grid;grid-template-columns:1fr 2fr;gap:var(--s8);align-items:center}
.testi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--s3)}

/* MOBILE STATS STRIP */
.mob-stats{display:none;background:var(--accentBtn);border-bottom:1px solid rgba(255,255,255,.1)}
.mob-stats-grid{display:grid;grid-template-columns:repeat(4,1fr)}
.mob-stat{text-align:center;padding:16px 8px;border-right:1px solid rgba(255,255,255,.15)}
.mob-stat:last-child{border-right:none}
.mob-stat-n{font-family:var(--serif);font-size:1.5rem;color:var(--white);line-height:1}
.mob-stat-n span{font-size:.8rem;font-weight:700}
.mob-stat-l{font-size:.55rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.92);margin-top:4px}

/* HAMBURGER BUTTON */
.hamburger{display:none;background:none;border:none;cursor:pointer;padding:8px;z-index:300;flex-direction:column;gap:5px}
.hamburger span{display:block;width:24px;height:2px;background:var(--white);border-radius:2px;transition:all .3s}
.hamburger.open span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}
.hamburger.open span:nth-child(2){opacity:0}
.hamburger.open span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}
.mob-cta,.mob-phone{display:none!important}
body.menu-open{overflow:hidden}

/* ═══ RESPONSIVE ═══ */

/* TABLET — 1024px */
@media(max-width:1024px){
  .wrap{padding:0 var(--s3)}
  .topbar{display:none}
  
  /* Mobile stats visible */
  .mob-stats{display:block}

  /* Hamburger visible */
  .hamburger{display:flex}
  .nb-right{display:none}
  
  /* Mobile slide-out menu */
  .nav-links{
    position:fixed;top:0;right:-100%;width:300px;height:100vh;
    background:var(--navy);flex-direction:column;align-items:stretch;
    padding:88px var(--s4) var(--s4);gap:0;z-index:250;
    transition:right .35s cubic-bezier(.4,0,.2,1);
    box-shadow:-8px 0 32px rgba(0,0,0,.4);overflow-y:auto;
    height:auto!important
  }
  .nav-links.open{right:0}
  .nav-links a{
    padding:16px 20px!important;border-bottom:1px solid rgba(255,255,255,.06)!important;
    font-size:.85rem!important;color:rgba(255,255,255,.7)!important;
    display:flex!important;align-items:center!important;
    border-left:3px solid transparent!important
  }
  .nav-links a.active{color:var(--white)!important;border-left-color:var(--accent)!important;background:rgba(43,167,218,.06)!important}
  .nav-links a:hover{color:var(--white)!important;background:rgba(255,255,255,.03)!important}
  .mob-cta{display:flex!important;margin-top:16px!important;background:var(--accentBtn)!important;color:var(--white)!important;justify-content:center!important;border-radius:6px!important;font-weight:800!important;letter-spacing:.08em!important;text-transform:uppercase!important;font-size:.78rem!important;border:none!important;border-left:none!important;padding:16px 20px!important}
  .mob-phone{display:flex!important;margin-top:8px!important;background:rgba(255,255,255,.04)!important;color:var(--accent)!important;justify-content:center!important;border-radius:6px!important;font-weight:700!important;font-size:.88rem!important;border:none!important;border-left:none!important;gap:8px!important;padding:14px 20px!important}

  /* Hero */
  .hero-split{grid-template-columns:1fr;min-height:auto}
  .hero-right{display:none}
  .hero-left{padding:48px 0 56px}
  .hero-h1{font-size:clamp(2rem,5.5vw,2.8rem)}
  .hero-desc{font-size:.92rem}
  .hero-ctas{flex-direction:column;gap:12px}
  .hero-ctas .btn{justify-content:center;width:100%;text-align:center}
  .hero-trust-row{flex-wrap:wrap;gap:14px}
  .hero-dots{bottom:16px}
  .hero-overlay{background:linear-gradient(180deg,rgba(10,22,40,0.88) 0%,rgba(10,22,40,0.82) 50%,rgba(10,22,40,0.7) 100%)}

  /* Our Work grids */
  .ow-row-3{grid-template-columns:1fr 1fr}
  .ow-row .proj-item{height:280px!important}

  /* Trust strip */
  .trust-strip .ts-inner{flex-direction:column;gap:12px;text-align:center}
  .trust-strip .ts-left{flex-wrap:wrap;justify-content:center;gap:12px}
  .trust-strip .ts-client:nth-child(n+5){display:none}

  /* Sections */
  .sec{padding:64px 0}
  .about-g{grid-template-columns:1fr;gap:var(--s5)}
  .about-badge{bottom:-12px;right:0}
  .feat-list{grid-template-columns:1fr}
  .why-g{grid-template-columns:1fr;gap:var(--s6)}
  .svc-grid{grid-template-columns:1fr 1fr;gap:12px}
  .feature{grid-template-columns:1fr}
  .feat-v{min-height:260px}
  .feat-c{padding:var(--s6) var(--s4)}
  .ind-grid{grid-template-columns:1fr 1fr}
  .proj-grid{grid-template-columns:1fr 1fr;grid-template-rows:auto}
  .proj-item{min-height:200px}
  .proj-item.big{grid-row:auto;min-height:280px}
  .prod-grid{grid-template-columns:1fr 1fr;gap:12px}
  .stats-g{grid-template-columns:1fr 1fr}
  .st-c{padding:var(--s3) var(--s2)}
  .st-n{font-size:2.2rem}

  /* Contact */
  .contact-g{grid-template-columns:1fr}
  .form-row{grid-template-columns:1fr}
  .qform{padding:var(--s4)}
  .map-grid{grid-template-columns:1fr}
  .testi-grid{grid-template-columns:1fr;gap:12px}

  /* Clients */
  .client-logos{grid-template-columns:1fr 1fr;gap:10px}

  /* Footer */
  .footer-top{grid-template-columns:1fr 1fr;gap:var(--s5)}
  .footer-bot{flex-direction:column;gap:8px;text-align:center}

  /* CTA band */
  .cta-row{flex-direction:column;text-align:center;gap:var(--s3)}
  .cta-acts{justify-content:center}

  /* Page hero */
  .page-hero{padding:120px 0 56px}
  .page-hero h1{font-size:clamp(1.8rem,5vw,2.6rem)}
}

/* TABLET — 768px */
@media(max-width:768px){
  .ow-row-2a,.ow-row-2b{grid-template-columns:1fr}
  .ow-row .proj-item{height:240px!important}
  .feature{grid-template-columns:1fr}
  .feat-v{min-height:240px}
  .footer-top{grid-template-columns:1fr 1fr;gap:var(--s4)}
  .about-photo-div{height:300px}
  .mob-stats-grid{grid-template-columns:repeat(4,1fr);gap:6px}
  .mob-stat{padding:12px 8px}
  .hero-dot{width:28px;height:4px;padding:8px 0;background-clip:content-box}
}

/* MOBILE — 640px */
@media(max-width:640px){
  .wrap{padding:0 var(--s2)}

  /* Hero */
  .hero-h1{font-size:clamp(1.6rem,6.5vw,2.2rem)}
  .hero-kicker{font-size:.6rem;letter-spacing:2px}
  .hero-desc{font-size:.88rem;line-height:1.75}
  .hero-trust-row{flex-direction:column;align-items:flex-start;gap:10px}
  .hero-trust-item{font-size:.65rem}
  .hero-left{padding:36px 0 48px}
  .hero-dots{bottom:12px;gap:8px}
  .hero-dot{width:24px}

  /* Our Work grids — single column */
  .ow-row-2a,.ow-row-2b,.ow-row-3{grid-template-columns:1fr}
  .ow-row .proj-item{height:220px!important}

  /* Services */
  .svc-grid{grid-template-columns:1fr;gap:12px}
  .svc-card{padding:var(--s3)}

  /* Feature */
  .feat-v{min-height:220px}
  .feat-c{padding:var(--s5) var(--s3)}

  /* Stats */
  .stats-g{grid-template-columns:1fr 1fr;gap:0}
  .st-c{padding:var(--s3) var(--s1);border-right:1px solid rgba(255,255,255,.05)}
  .st-n{font-size:1.8rem}
  .st-l{font-size:.55rem;letter-spacing:.1em}

  /* Projects */
  .proj-grid{grid-template-columns:1fr;grid-template-rows:auto;gap:10px}
  .proj-item,.proj-item.big{min-height:200px}
  .proj-info{padding:16px}
  .proj-name{font-size:.88rem}

  /* Why */
  .why-cards{grid-template-columns:1fr!important;gap:10px!important}
  .why-card{padding:var(--s3)}
  .proc-item{padding:var(--s2) 0}

  /* Clients */
  .client-logos{grid-template-columns:1fr;gap:8px}
  .client-card{min-height:56px;padding:14px 16px}
  .clients-intro h2.th2{font-size:clamp(1.5rem,5vw,2rem)}

  /* Contact */
  .qform{padding:var(--s3)}
  .qf-title{font-size:1.1rem}
  .contact-link>i{width:36px;height:36px;font-size:.9rem}

  /* Footer */
  .footer{padding:var(--s8) 0 var(--s4)}
  .footer-top{grid-template-columns:1fr;gap:var(--s5)}
  .ft-brand{max-width:100%}

  /* Products */
  .prod-grid{grid-template-columns:1fr;gap:12px}

  /* Industries */
  .ind-grid{grid-template-columns:1fr}

  /* Sections */
  .sec{padding:48px 0}
  h2.th2{font-size:clamp(1.4rem,4.5vw,2rem)}
  .page-hero{padding:100px 0 40px}
  .page-hero h1{font-size:clamp(1.5rem,6vw,2rem)}

  /* CTA */
  .cta-band{padding:var(--s5) 0}
  .cta-text h3{font-size:1.2rem}
  .cta-acts{flex-direction:column;width:100%}
  .cta-acts .btn{width:100%;justify-content:center}

  /* Testimonial */
  .testi-inner blockquote{font-size:1.05rem}

  /* Trust strip */
  .trust-strip{padding:14px 0}
  .ts-label{font-size:.6rem}
  .ts-client{font-size:.7rem}
  .ts-link{font-size:.6rem}
  /* Touch-friendly dots */
  .hero-dot{width:24px;height:3px;padding:10px 0;background-clip:content-box}
  .hero-dots{bottom:8px}
  /* Mobile stats */
  .mob-stats-grid{grid-template-columns:repeat(2,1fr);gap:8px}
}

/* VERY SMALL PHONES — 380px */
@media(max-width:380px){
  .wrap{padding:0 12px}
  .hero-left{padding:28px 0 40px}
  .hero-h1{font-size:1.5rem}
  .hero-desc{font-size:.82rem}
  .btn{padding:14px 20px;font-size:.68rem}
  .client-cat-title{font-size:.88rem}
  .client-name{font-size:.8rem}
  .proj-name{font-size:.82rem}
  .svc-card h3{font-size:.88rem}
}
