*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;scroll-padding-top:110px}
body{font-family:'Inter',sans-serif;background:#fff;color:#1a1a1a;overflow-x:hidden;line-height:1.6}
img{display:block;max-width:100%}
a{text-decoration:none;color:inherit}
:root{
  --red:#0f2f63;--red-d:#0a1f47;--red-lt:#e7eef9;
  --navy:#081720;--navy2:#162a4a;
  --white:#ffffff;--off:#f3f5fb;--gray:#d8dbe5;
  --t1:#0f1d33;--t2:#4d627f;--t3:#7f8fa3;
  --fh:'Playfair Display',serif;--fb:'Inter',sans-serif;--fnum:'Inter',sans-serif;
  --tr:all .22s ease;--maxw:1280px;
}

/* OFFSET FOR STICKY HEADER */
[id]{scroll-margin-top:110px}

/* MAIN NAV */
.mainnav{background:#fff;border-bottom:1px solid var(--gray);position:sticky;top:0;z-index:1000;transform:translateY(0);transition:transform .28s ease,box-shadow .22s ease,border-color .22s ease}
.mainnav.shadow{box-shadow:0 2px 24px rgba(0,0,0,.1)}
.mainnav.nav-hidden{transform:translateY(-100%)}
.nav-wrap{max-width:var(--maxw);margin:0 auto;padding:0 40px;height:68px;display:flex;align-items:center}
.nav-logo{display:flex;align-items:center;gap:12px;margin-right:36px;flex-shrink:0}
.nav-logo-img{width:54px;height:54px;object-fit:contain;flex-shrink:0}
.nav-logo-text{font-family:var(--fh);font-size:18px;font-weight:700;color:#000}
.nav-logo-text span{color:#000}
.nav-links{display:flex;align-items:center;justify-content:center;gap:0;flex:1}
.nav-links a{font-size:14px;font-weight:500;color:var(--t2);padding:0 15px;height:68px;display:flex;align-items:center;border-bottom:3px solid transparent;transition:var(--tr);white-space:nowrap}
.nav-links a:hover{color:var(--red);border-bottom-color:var(--red)}
.nav-ctas{display:flex;align-items:center;gap:10px;margin-left:auto;flex-shrink:0}
.btn-ghost{padding:9px 20px;border:1.5px solid var(--navy);border-radius:4px;font-size:13px;font-weight:600;color:var(--navy);background:transparent;cursor:pointer;transition:var(--tr);font-family:var(--fb);display:inline-flex;align-items:center;gap:6px}
.btn-ghost:hover{border-color:var(--red);color:var(--red)}
.btn-red{padding:9px 22px;background:var(--red);border:1.5px solid var(--red);border-radius:4px;font-size:13px;font-weight:600;color:#fff;cursor:pointer;transition:var(--tr);font-family:var(--fb);display:inline-flex;align-items:center;gap:6px}
.btn-red:hover{background:var(--red-d);border-color:var(--red-d)}
.nav-ham{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:6px;margin-left:auto}
.nav-ham span{width:22px;height:2px;background:var(--navy);border-radius:2px;display:block;transition:var(--tr)}

/* HERO */
.hero{display:grid;grid-template-columns:1fr 1fr;height:580px}
.hero-panel{position:relative;overflow:hidden;display:flex;flex-direction:column;justify-content:flex-end;padding:56px 52px}
.hero-bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.82) 0%,rgba(0,0,0,.35) 55%,rgba(0,0,0,.1) 100%)}
.hero-overlay.navy{background:linear-gradient(135deg,rgba(13,27,42,.94) 0%,rgba(13,27,42,.72) 100%)}
.hero-cnt{position:relative;z-index:2}
.hero-lbl{font-size:11px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.7);margin-bottom:14px;display:flex;align-items:center;gap:10px}
.hero-lbl::before{content:'';width:22px;height:2px;background:var(--red);border-radius:1px}
.hero-h1{font-family:var(--fh);font-size:clamp(36px,4vw,56px);font-weight:700;color:#fff;line-height:1.08;letter-spacing:-.025em;margin-bottom:16px}
.hero-h1 em{color:var(--red);font-style:normal}
.hero-p{font-size:15px;color:rgba(255,255,255,.72);line-height:1.65;margin-bottom:28px;max-width:400px}
.hero-srch{display:flex;border-radius:4px;overflow:hidden;background:#fff;max-width:440px;box-shadow:0 4px 24px rgba(0,0,0,.28)}
.hero-srch input{flex:1;padding:14px 18px;border:none;outline:none;font-size:14px;font-family:var(--fb);color:var(--t1)}
.hero-srch input::placeholder{color:var(--t3)}
.hero-srch button{padding:14px 22px;background:var(--red);border:none;color:#fff;font-size:14px;font-weight:600;font-family:var(--fb);cursor:pointer;white-space:nowrap;transition:var(--tr)}
.hero-srch button:hover{background:var(--red-d)}
.btn-wht{display:inline-flex;align-items:center;gap:8px;padding:14px 30px;background:#fff;border:none;border-radius:4px;font-size:15px;font-weight:600;color:var(--navy);font-family:var(--fb);cursor:pointer;transition:var(--tr);width:fit-content}
.btn-wht:hover{background:#efefef;transform:translateY(-1px)}
.hero-mstats{display:flex;gap:28px;margin-top:28px;flex-wrap:wrap}
.hms-n{font-family:var(--fnum);font-style:normal;font-variant-numeric:lining-nums tabular-nums;font-size:26px;font-weight:700;color:#fff}
.hms-l{font-size:11px;color:rgba(255,255,255,.5);margin-top:2px}

/* APPROACH */
.approach{padding:80px 40px;background:#fff}
.approach-in{max-width:var(--maxw);margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:72px;align-items:center}
.apt h2{font-family:var(--fh);font-size:clamp(28px,3vw,42px);font-weight:700;line-height:1.18;letter-spacing:-.025em;color:var(--navy);margin-bottom:20px}
.apt h2 em{font-style:italic;color:var(--red)}
.apt p{font-size:16px;color:var(--t2);line-height:1.8;margin-bottom:28px}
.apt a{display:inline-flex;align-items:center;gap:8px;font-size:14px;font-weight:600;color:var(--red);transition:var(--tr)}
.apt a:hover{gap:12px}
.apv{position:relative;border-radius:14px;overflow:hidden}
.apv img{width:100%;height:420px;object-fit:cover}
.apv-badge{position:absolute;bottom:24px;left:24px;background:var(--red);color:#fff;padding:12px 22px;border-radius:6px;font-family:var(--fh);font-size:13px;font-weight:700;box-shadow:0 4px 20px rgba(15,47,99,.4)}

/* STATS */
.stats{background:var(--off);border-top:1px solid var(--gray);border-bottom:1px solid var(--gray)}
.stats-in{max-width:var(--maxw);margin:0 auto;display:grid;grid-template-columns:repeat(4,1fr)}
.sbox{padding:40px 32px;text-align:center;border-right:1px solid var(--gray)}
.sbox:last-child{border-right:none}
.sbox-n{font-family:var(--fnum);font-style:normal;font-variant-numeric:lining-nums tabular-nums;font-size:clamp(38px,3.5vw,54px);font-weight:700;color:var(--navy);display:block;letter-spacing:0;line-height:1}
.sbox-n sup{font-size:.45em;vertical-align:super}
.sbox-t{font-size:13px;font-weight:700;color:var(--t1);margin-top:8px}
.sbox-d{font-size:12px;color:var(--t3);margin-top:4px;line-height:1.5}

/* ESSENTIALS */
.ess{padding:72px 40px;background:#fff}
.ess-in{max-width:var(--maxw);margin:0 auto}
.sh{margin-bottom:48px}
.sec-name{display:inline-flex;align-items:center;gap:8px;padding:4px 12px;border:1px solid rgba(15,47,99,.2);border-radius:999px;font-size:11px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--red);background:var(--red-lt);margin-bottom:12px}
.sec-name::before{content:'';width:16px;height:2px;background:var(--red);border-radius:2px}
.sh h2{font-family:var(--fh);font-size:clamp(26px,2.8vw,38px);font-weight:700;color:var(--navy);letter-spacing:-.02em;margin-bottom:12px}
.sh h2 em{font-style:italic;color:var(--red)}
.sh p{font-size:16px;color:var(--t2);max-width:560px;line-height:1.75}
.ess-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.ecard{background:var(--off);border-radius:12px;overflow:hidden;transition:var(--tr);border:1.5px solid transparent}
.ecard:hover{border-color:rgba(15,47,99,.2);box-shadow:0 8px 36px rgba(0,0,0,.09);transform:translateY(-3px)}
.ecard-img{height:200px;overflow:hidden;position:relative}
.ecard-img img{width:100%;height:100%;object-fit:cover;transition:transform .4s ease}
.ecard:hover .ecard-img img{transform:scale(1.05)}
.ecard-body{padding:28px}
.ecard-icon{width:42px;height:42px;background:transparent;border:1px solid rgba(15,47,99,.22);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:15px;margin-bottom:16px;color:var(--navy)}
.ecard-title{font-family:var(--fh);font-size:19px;font-weight:700;color:var(--navy);margin-bottom:8px}
.ecard-desc{font-size:13px;color:var(--t2);line-height:1.75;margin-bottom:14px}
.ecard-link{display:inline-flex;align-items:center;gap:6px;font-size:13px;font-weight:600;color:var(--red);transition:var(--tr)}
.ecard-link:hover{gap:10px}

/* SOLUTIONS */
.sols{padding:72px 40px;background:var(--off)}
.sols-in{max-width:var(--maxw);margin:0 auto}
.sols-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:48px}
.scard{background:#fff;padding:0;transition:var(--tr);cursor:pointer;position:relative;display:flex;flex-direction:column;border:1px solid rgba(15,47,99,.1);border-radius:12px;overflow:hidden;box-shadow:0 3px 16px rgba(8,23,32,.05)}
.scard:hover{background:#fff;z-index:1;transform:translateY(-3px);border-color:rgba(15,47,99,.25);box-shadow:0 10px 30px rgba(8,23,32,.12)}
.scard-img{height:180px;overflow:hidden;position:relative}
.scard-img img{width:100%;height:100%;object-fit:cover;transition:transform .4s ease}
.scard:hover .scard-img img{transform:scale(1.05)}
.scard-body{padding:26px;flex:1;display:flex;flex-direction:column}
.scard-icon{font-size:20px;margin-bottom:14px;color:var(--navy);font-family:var(--fh);letter-spacing:.03em}
.scard-title{font-family:var(--fh);font-size:18px;font-weight:700;color:var(--navy);margin-bottom:8px;letter-spacing:-.01em}
.scard-desc{font-size:13px;color:var(--t2);line-height:1.75;margin-bottom:14px;flex:1}
.scard-link{display:inline-flex;align-items:center;gap:6px;font-size:13px;font-weight:600;color:var(--red);transition:var(--tr);margin-top:auto}
.scard:hover .scard-link{gap:10px}

/* INDUSTRIES */
.inds{padding:72px 40px;background:#fff}
.inds-in{max-width:var(--maxw);margin:0 auto}
.inds-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-top:48px}
.icard{position:relative;border-radius:10px;overflow:hidden;cursor:pointer;transition:var(--tr)}
.icard:hover{transform:translateY(-4px);box-shadow:0 14px 44px rgba(0,0,0,.16)}
.icard img{width:100%;height:210px;object-fit:cover;display:block;transition:transform .4s ease}
.icard:hover img{transform:scale(1.06)}
.icard-ov{position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.72) 0%,transparent 55%)}
.icard:hover .icard-ov{background:linear-gradient(to top,rgba(15,47,99,.78) 0%,transparent 65%)}
.icard-cnt{position:absolute;bottom:0;left:0;right:0;padding:18px}
.icard-name{font-family:var(--fh);font-size:15px;font-weight:700;color:#fff}
.icard-more{font-size:12px;color:rgba(255,255,255,.8);margin-top:4px;display:flex;align-items:center;gap:5px;transition:var(--tr)}
.icard:hover .icard-more{gap:8px}

/* ECOSYSTEM */
.eco{padding:80px 40px;background:#fff;border-top:1px solid var(--gray)}
.eco-in{max-width:var(--maxw);margin:0 auto}
.eco-top{display:grid;grid-template-columns:1fr 1fr;gap:72px;align-items:center;margin-bottom:56px}
.eco-img{border-radius:14px;overflow:hidden;position:relative}
.eco-img img{width:100%;height:380px;object-fit:cover}
.eco-img-tag{position:absolute;bottom:20px;left:20px;background:var(--red);color:#fff;padding:10px 18px;border-radius:6px;font-family:var(--fh);font-size:13px;font-weight:700}
.eco-txt h2{font-family:var(--fh);font-size:clamp(26px,2.8vw,40px);font-weight:700;color:var(--navy);line-height:1.2;letter-spacing:-.025em;margin-bottom:18px}
.eco-txt h2 em{color:var(--red);font-style:italic}
.eco-txt p{font-size:15px;color:var(--t2);line-height:1.8;margin-bottom:24px}
.eco-txt a{display:inline-flex;align-items:center;gap:8px;font-size:14px;font-weight:600;color:var(--red);transition:var(--tr)}
.eco-txt a:hover{gap:12px}
.eco-brands{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.ebrand{background:#fff;border:1.5px solid var(--gray);border-radius:14px;padding:0;overflow:hidden;transition:var(--tr);box-shadow:0 3px 12px rgba(0,0,0,.06)}
.ebrand:hover{background:#fff;border-color:var(--red);transform:translateY(-4px);box-shadow:0 12px 32px rgba(15,47,99,.15)}
.ebrand-img{height:150px;overflow:hidden}
.ebrand-img img{width:100%;height:100%;object-fit:cover;filter:brightness(1) saturate(1);transition:transform .4s ease}
.ebrand:hover .ebrand-img img{transform:scale(1.02)}
.ebrand-body{padding:32px;background:#fff}
.ebrand-name{font-family:var(--fh);font-size:22px;font-weight:800;color:var(--navy);margin-bottom:14px;letter-spacing:-.01em;line-height:1.3}
.ebrand-name span{color:var(--red)}
.ebrand-desc{font-size:13px;color:var(--t2);line-height:1.85;margin-bottom:18px;font-weight:400}
.ebrand-link{font-size:13px;font-weight:700;color:var(--red);display:inline-flex;align-items:center;gap:6px;transition:all .3s ease;text-transform:uppercase;letter-spacing:.03em}
.ebrand-link:hover{gap:10px;color:var(--red-d)}

/* ADVANTAGES */
.adv{padding:72px 40px;background:var(--red)}
.adv-in{max-width:var(--maxw);margin:0 auto}
.adv-hdr{margin-bottom:48px}
.adv-hdr h2{font-family:var(--fh);font-size:clamp(26px,2.6vw,36px);font-weight:700;color:#fff;letter-spacing:-.02em;margin-bottom:10px}
.adv-hdr p{font-size:15px;color:rgba(255,255,255,.75);max-width:500px}
.adv-grid{display:grid;grid-template-columns:repeat(4,1fr);border-left:1px solid rgba(255,255,255,.2)}
.adv-item{padding:28px 24px;border-right:1px solid rgba(255,255,255,.2);text-align:center}
.adv-ico{font-size:20px;margin-bottom:14px;color:rgba(255,255,255,.92);font-family:var(--fh);letter-spacing:.04em}
.adv-num{font-family:var(--fnum);font-style:normal;font-variant-numeric:lining-nums tabular-nums;font-size:clamp(28px,2.5vw,40px);font-weight:700;color:#fff;letter-spacing:-.025em}
.adv-lbl{font-size:13px;color:rgba(255,255,255,.75);margin-top:5px;font-weight:500}

/* TEAM SECTION */
.team{padding:72px 40px;background:#fff}
.team-in{max-width:var(--maxw);margin:0 auto}
.team-wrap{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center;margin-top:48px}
.team-img-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.team-img-grid img{width:100%;border-radius:10px;object-fit:cover}
.team-img-grid img:first-child{height:280px;grid-row:span 2}
.team-img-grid img:nth-child(2){height:130px}
.team-img-grid img:nth-child(3){height:130px}
.team-txt h2{font-family:var(--fh);font-size:clamp(26px,2.6vw,38px);font-weight:700;color:var(--navy);letter-spacing:-.025em;margin-bottom:16px}
.team-txt h2 em{font-style:italic;color:var(--red)}
.team-txt p{font-size:15px;color:var(--t2);line-height:1.8;margin-bottom:24px}
.team-badges{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:28px}
.tbadge{padding:6px 14px;background:var(--off);border:1.5px solid var(--gray);border-radius:20px;font-size:12px;font-weight:600;color:var(--t2)}
.team-facts{display:flex;flex-direction:column;gap:14px}
.tfact{display:flex;gap:14px;align-items:flex-start;padding:16px;background:var(--off);border-radius:10px;border:1.5px solid var(--gray)}
.tfact-icon{width:38px;height:38px;background:#fff;border:1px solid rgba(15,47,99,.2);border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:14px;color:var(--navy);flex-shrink:0}
.tfact-title{font-weight:600;font-size:14px;color:var(--navy);margin-bottom:2px}
.tfact-desc{font-size:13px;color:var(--t3);line-height:1.5}

/* JOBS */
.jobs{padding:72px 40px;background:var(--off)}
.jobs-in{max-width:var(--maxw);margin:0 auto}
.jobs-toprow{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:28px;gap:24px;flex-wrap:wrap}
.jsrow{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:22px}
.jsb{display:flex;background:#fff;border:1.5px solid var(--gray);border-radius:4px;overflow:hidden;flex:1;max-width:380px}
.jsb input{flex:1;padding:12px 16px;border:none;outline:none;font-size:14px;font-family:var(--fb);color:var(--t1)}
.jsb input::placeholder{color:var(--t3)}
.jsb button{padding:12px 18px;background:var(--red);border:none;color:#fff;font-size:13px;font-weight:600;font-family:var(--fb);cursor:pointer;transition:var(--tr)}
.jsb button:hover{background:var(--red-d)}
.jfilt{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:26px}
.jfb{padding:7px 16px;border-radius:20px;border:1.5px solid var(--gray);background:#fff;font-size:12px;font-weight:600;color:var(--t2);cursor:pointer;transition:var(--tr);font-family:var(--fb)}
.jfb.on,.jfb:hover{border-color:var(--red);color:var(--red);background:var(--red-lt)}
.jgrid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
.jcard{background:#fff;border:1.5px solid var(--gray);border-radius:10px;padding:24px;transition:var(--tr);display:flex;flex-direction:column;gap:12px}
.jcard:hover{border-color:rgba(15,47,99,.25);box-shadow:0 8px 28px rgba(0,0,0,.08);transform:translateY(-2px)}
.jcard-top{display:flex;justify-content:space-between;align-items:flex-start;gap:12px}
.jcard-title{font-family:var(--fh);font-size:17px;font-weight:700;color:var(--navy);letter-spacing:-.01em}
.jcard-co{font-size:12px;color:var(--t3);margin-top:3px}
.jbadge{padding:4px 10px;border-radius:12px;font-size:11px;font-weight:700;flex-shrink:0}
.jbadge.ft{background:#e8f5e9;color:#2e7d32}
.jbadge.rm{background:#e3f2fd;color:#1565c0}
.jbadge.ct{background:#fff8e1;color:#e65100}
.jmeta{display:flex;gap:14px;flex-wrap:wrap}
.jmi{font-size:11px;color:var(--t3);display:flex;align-items:center;gap:4px;letter-spacing:.04em;text-transform:uppercase}
.jtags{display:flex;gap:6px;flex-wrap:wrap}
.jtag{padding:3px 9px;background:var(--off);border-radius:10px;font-size:11px;color:var(--t2);font-weight:500}
.jfoot{display:flex;justify-content:space-between;align-items:center;padding-top:12px;border-top:1px solid var(--gray);margin-top:auto}
.jsal{font-family:var(--fnum);font-style:normal;font-variant-numeric:lining-nums tabular-nums;font-size:15px;font-weight:700;color:var(--navy)}
.japp{padding:8px 18px;background:var(--red);border:none;border-radius:4px;font-size:13px;font-weight:600;color:#fff;cursor:pointer;font-family:var(--fb);transition:var(--tr)}
.japp:hover{background:var(--red-d);transform:translateY(-1px);box-shadow:0 4px 14px rgba(15,47,99,.3)}

/* CASES */
.cases{padding:72px 40px;background:#fff}
.cases-in{max-width:var(--maxw);margin:0 auto}
.cgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:48px}
.ccase{border-radius:12px;overflow:hidden;border:1.5px solid var(--gray);transition:var(--tr);display:flex;flex-direction:column;background:#fff}
.ccase:hover{border-color:rgba(15,47,99,.2);box-shadow:0 12px 44px rgba(0,0,0,.1);transform:translateY(-4px)}
.ccase img{width:100%;height:200px;object-fit:cover;transition:transform .4s ease}
.ccase:hover img{transform:scale(1.04)}
.ccase-body{padding:24px;display:flex;flex-direction:column;gap:10px;flex:1}
.cvert{display:inline-flex;padding:3px 10px;border-radius:10px;font-size:10px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;width:fit-content}
.cvert.it{background:var(--red-lt);color:var(--red)}
.cvert.hr{background:#e3f2fd;color:#1565c0}
.ctitle{font-family:var(--fh);font-size:18px;font-weight:700;color:var(--navy);line-height:1.3;letter-spacing:-.01em}
.cdesc{font-size:13px;color:var(--t2);line-height:1.7}
.cnums{display:flex;gap:20px;padding-top:12px;border-top:1px solid var(--gray);margin-top:auto}
.cnv{font-family:var(--fnum);font-style:normal;font-variant-numeric:lining-nums tabular-nums;font-size:24px;font-weight:700;color:var(--red)}
.cnl{font-size:11px;color:var(--t3)}
.clink{font-size:13px;font-weight:600;color:var(--red);display:flex;align-items:center;gap:5px;transition:var(--tr)}
.clink:hover{gap:9px}

/* TESTIMONIALS */
.testi{padding:72px 40px;background:var(--off)}
.testi-in{max-width:var(--maxw);margin:0 auto}
.twrap{overflow:hidden;margin-top:48px}
.ttrack{display:flex;gap:20px;transition:transform .5s cubic-bezier(.4,0,.2,1)}
.tcard{min-width:390px;background:#fff;border:1.5px solid var(--gray);border-radius:12px;overflow:hidden;flex-shrink:0;transition:var(--tr)}
.tcard:hover{box-shadow:0 8px 32px rgba(0,0,0,.09)}
.tcard-img{height:140px;overflow:hidden;position:relative}
.tcard-img img{width:100%;height:100%;object-fit:cover;object-position:center top}
.tcard-img-ov{position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.4),transparent)}
.tcard-body{padding:28px}
.tstars{display:flex;gap:3px;margin-bottom:14px;color:var(--red);font-size:16px}
.tquote{font-family:var(--fh);font-size:15px;line-height:1.75;color:var(--navy);margin-bottom:22px;font-style:italic}
.tauth{display:flex;align-items:center;gap:13px}
.tav{width:44px;height:44px;border-radius:50%;overflow:hidden;flex-shrink:0;border:2px solid var(--red-lt)}
.tav img{width:100%;height:100%;object-fit:cover}
.tname{font-weight:600;font-size:14px;color:var(--navy)}
.trole{font-size:12px;color:var(--t3);margin-top:2px}
.tctrl{display:flex;justify-content:center;align-items:center;gap:14px;margin-top:32px}
.tbtn{width:40px;height:40px;border-radius:50%;border:1.5px solid var(--gray);background:#fff;color:var(--t2);cursor:pointer;font-size:16px;transition:var(--tr);display:flex;align-items:center;justify-content:center}
.tbtn:hover{border-color:var(--red);color:var(--red)}
.tdots{display:flex;gap:8px;align-items:center}
.tdot{width:8px;height:8px;border-radius:50%;background:var(--gray);cursor:pointer;transition:var(--tr)}
.tdot.on{background:var(--red);width:20px;border-radius:4px}

/* CONTACT */
.contact{padding:80px 40px;background:#fff}
.contact-in{max-width:var(--maxw);margin:0 auto;display:grid;grid-template-columns:1fr 1.3fr;gap:80px;align-items:start}
.cleft h2{font-family:var(--fh);font-size:clamp(26px,2.8vw,38px);font-weight:700;color:var(--navy);letter-spacing:-.02em;margin-bottom:14px}
.cleft h2 em{color:var(--red);font-style:italic}
.cleft p{font-size:15px;color:var(--t2);line-height:1.75;margin-bottom:32px}
.cinfo{display:flex;flex-direction:column;gap:20px}
.ci{display:flex;gap:14px;align-items:flex-start}
.ci-ico{width:42px;height:42px;background:#fff;border:1px solid rgba(15,47,99,.2);border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:14px;color:var(--navy);flex-shrink:0}
.ci-tit{font-weight:700;font-size:14px;color:var(--navy);margin-bottom:3px}
.ci-val{font-size:13px;color:var(--t2);line-height:1.65}
.ccta{margin-top:28px;padding:24px;background:var(--red-lt);border:1.5px solid rgba(15,47,99,.15);border-radius:10px}
.ccta h3{font-family:var(--fh);font-size:17px;font-weight:700;color:var(--navy);margin-bottom:6px}
.ccta p{font-size:13px;color:var(--t2);margin-bottom:18px;line-height:1.6}
.cform{background:#fff;border:1.5px solid var(--gray);border-radius:14px;padding:44px;box-shadow:0 8px 44px rgba(0,0,0,.08)}
.cform h3{font-family:var(--fh);font-size:22px;font-weight:700;color:var(--navy);margin-bottom:4px}
.cform-sub{font-size:14px;color:var(--t3);margin-bottom:26px}
.frow{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.fg{display:flex;flex-direction:column;gap:5px;margin-bottom:16px}
.flbl{font-size:11px;font-weight:700;color:var(--t2);text-transform:uppercase;letter-spacing:.07em}
.fi,.fsel,.fta{padding:11px 14px;background:var(--off);border:1.5px solid var(--gray);border-radius:6px;font-size:14px;font-family:var(--fb);color:var(--t1);outline:none;transition:var(--tr);width:100%}
.fi:focus,.fsel:focus,.fta:focus{border-color:var(--red);background:#fff;box-shadow:0 0 0 3px rgba(15,47,99,.08)}
.fi::placeholder,.fta::placeholder{color:var(--t3)}
.fta{resize:vertical;min-height:105px}
.fsel{cursor:pointer}
.ferr{font-size:11px;color:var(--red);display:none}
.fg.err .fi,.fg.err .fsel{border-color:var(--red)}
.fg.err .ferr{display:block}
.fsub{width:100%;padding:14px;background:var(--red);border:none;border-radius:6px;color:#fff;font-size:15px;font-weight:600;cursor:pointer;font-family:var(--fb);transition:var(--tr)}
.fsub:hover{background:var(--red-d);transform:translateY(-1px);box-shadow:0 8px 24px rgba(15,47,99,.3)}
.fnote{font-size:12px;color:var(--t3);text-align:center;margin-top:12px}

/* FOOTER */
.footer-main{background:var(--navy);color:#fff}
.footer-cta-wrap{padding:46px 40px 0}
.footer-cta-box{background:linear-gradient(135deg,#132742 0%,#0d1e35 100%);border:1px solid rgba(255,255,255,.12);border-radius:14px;padding:30px 30px 24px;display:grid;grid-template-columns:1.5fr 1fr;gap:24px 30px;box-shadow:0 18px 40px rgba(0,0,0,.24)}
.footer-cta-copy h2{font-family:var(--fh);font-size:clamp(24px,2.3vw,34px);line-height:1.22;letter-spacing:-.02em;margin-bottom:10px;color:#fff}
.footer-cta-copy p{font-size:14px;line-height:1.75;color:rgba(255,255,255,.72);max-width:760px}
.footer-cta-actions{display:flex;align-items:center;justify-content:flex-end;gap:12px;flex-wrap:wrap}
.footer-cta-btn{display:inline-flex;align-items:center;justify-content:center;padding:11px 18px;border-radius:6px;font-size:13px;font-weight:600;transition:var(--tr)}
.footer-cta-btn.primary{background:#fff;color:#0b1d34;border:1.5px solid #fff}
.footer-cta-btn.primary:hover{background:#eef2f8}
.footer-cta-btn.secondary{background:transparent;color:#fff;border:1.5px solid rgba(255,255,255,.55)}
.footer-cta-btn.secondary:hover{border-color:#fff;background:rgba(255,255,255,.08)}
.footer-cta-points{grid-column:1 / -1;display:flex;gap:16px;flex-wrap:wrap;padding-top:2px}
.footer-cta-points span{font-size:12px;font-weight:600;color:rgba(255,255,255,.75);padding:7px 11px;border-radius:999px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.14)}
.footer-top{padding:60px 40px 50px;border-bottom:1px solid rgba(255,255,255,.07)}
.footer-container{max-width:var(--maxw);margin:0 auto}
.footer-top .footer-container{display:grid;grid-template-columns:1.25fr 2fr;gap:52px;align-items:start}

.footer-brand{margin-bottom:0}
.footer-logo-img{width:82px;height:82px;object-fit:contain;margin-bottom:12px}
.footer-brand h3{font-family:var(--fh);font-size:22px;font-weight:700;margin-bottom:12px;color:#fff}
.footer-brand-text p{font-size:14px;line-height:1.8;color:rgba(255,255,255,.55);margin-bottom:24px;max-width:390px}

.footer-contact-info{display:flex;flex-direction:column;gap:10px;margin-bottom:18px;font-size:14px}
.footer-contact-info a{color:rgba(255,255,255,.7);text-decoration:none;transition:var(--tr)}
.footer-contact-info a:hover{color:var(--red)}

.footer-address{font-size:13px;color:rgba(255,255,255,.55);line-height:1.8}

.footer-links-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:34px}
.footer-column h4{font-family:var(--fh);font-size:14px;font-weight:700;margin-bottom:18px;color:#fff;text-transform:uppercase;letter-spacing:.5px}
.footer-column ul{list-style:none}
.footer-column ul li{margin-bottom:10px}
.footer-column ul a{font-size:13px;color:rgba(255,255,255,.55);text-decoration:none;transition:var(--tr);display:inline-block}
.footer-column ul a:hover{color:var(--red);transform:translateX(4px)}

.footer-bottom{padding:24px 40px;background:rgba(0,0,0,.25)}
.footer-bottom .footer-container{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:24px}

.footer-bottom-content{width:100%;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:32px}
.footer-copyright{font-size:13px;color:rgba(255,255,255,.48)}
.footer-copyright p{margin:0}

.footer-socials{display:flex;gap:10px;flex-wrap:wrap}
.footer-socials a{width:38px;height:38px;padding:0;border-radius:8px;border:1px solid rgba(255,255,255,.15);display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.62);font-size:14px;font-weight:600;text-decoration:none;transition:var(--tr)}
.footer-socials a svg{width:16px;height:16px;display:block}
.footer-socials a:hover{border-color:rgba(255,255,255,.38);color:#fff;background:rgba(255,255,255,.08)}

.footer-hours{font-size:13px;color:rgba(255,255,255,.48)}
.footer-hours p{margin:0}

/* MOBILE */
.mnav{position:fixed;top:68px;left:0;right:0;z-index:999;background:#fff;border-bottom:1px solid var(--gray);display:none;flex-direction:column;padding:14px 20px;box-shadow:0 8px 24px rgba(0,0,0,.1)}
.mnav.open{display:flex}
.mnav a{padding:11px 0;border-bottom:1px solid var(--gray);font-size:15px;font-weight:500;color:var(--t2);transition:var(--tr)}
.mnav a:hover{color:var(--red)}

/* TOAST */
.toast{position:fixed;bottom:24px;right:24px;z-index:9999;background:var(--navy);border-radius:10px;padding:14px 22px;display:flex;align-items:center;gap:10px;box-shadow:0 8px 36px rgba(0,0,0,.2);transform:translateY(80px);opacity:0;transition:all .4s ease;pointer-events:none;max-width:360px}
.toast.show{transform:translateY(0);opacity:1;pointer-events:all}
.toast span:last-child{font-size:13px;font-weight:500;color:#fff}

/* REVEAL */
.rv{opacity:0;transform:translateY(26px);transition:opacity .6s ease,transform .6s ease}
.rv.in{opacity:1;transform:translateY(0)}

/* RESPONSIVE */
@media(max-width:1200px){.inds-grid{grid-template-columns:repeat(3,1fr)}.footer-cta-box{grid-template-columns:1fr;gap:16px}.footer-cta-actions{justify-content:flex-start}.footer-top .footer-container{grid-template-columns:1fr;gap:40px}}
@media(max-width:960px){.hero{grid-template-columns:1fr}.hero-panel{min-height:320px;padding:44px 32px}.approach-in{grid-template-columns:1fr}.stats-in{grid-template-columns:1fr 1fr}.sbox:nth-child(2){border-right:none}.sbox:nth-child(3){border-top:1px solid var(--gray)}.sbox:nth-child(4){border-top:1px solid var(--gray);border-right:none}.ess-grid{grid-template-columns:1fr 1fr}.sols-grid{grid-template-columns:1fr 1fr}.cgrid{grid-template-columns:1fr 1fr}.inds-grid{grid-template-columns:1fr 1fr}.eco-top{grid-template-columns:1fr}.team-wrap{grid-template-columns:1fr}.contact-in{grid-template-columns:1fr}.nav-links{display:none}.nav-ctas .btn-ghost{display:none}.nav-ham{display:flex}.eco-brands{grid-template-columns:1fr 1fr}.footer-links-grid{grid-template-columns:repeat(2,1fr);gap:28px}}
@media(max-width:600px){.ess-grid,.sols-grid,.cgrid,.eco-brands{grid-template-columns:1fr}.tcard{min-width:290px}.footer-cta-wrap{padding:34px 20px 0}.footer-cta-box{padding:22px 18px 18px;border-radius:12px}.footer-cta-btn{width:100%}.footer-top{padding:34px 20px 32px}.footer-links-grid{grid-template-columns:1fr;gap:22px}.footer-column h4{font-size:13px}.footer-bottom-content{flex-direction:column;gap:16px;text-align:center}.footer-copyright,.footer-hours{order:1;width:100%}.footer-socials{order:2;justify-content:center;width:100%}.topnav{display:none}.mainnav{top:0}.mnav{top:68px}.stats-in{grid-template-columns:1fr}.approach,.ess,.sols,.inds,.eco,.team,.cases,.testi,.contact{padding-left:20px;padding-right:20px}.hero-panel{padding:36px 20px}}

@media(max-width:960px){
  .footer-bottom{padding:22px 20px}
  .footer-bottom-content{flex-direction:column;align-items:center;justify-content:center;gap:14px;text-align:center}
  .footer-copyright,.footer-hours,.footer-socials{width:100%;display:flex;justify-content:center}
  .footer-copyright p,.footer-hours p{text-align:center}
  .footer-socials{flex-wrap:wrap;gap:10px}
  .footer-socials a{width:40px;height:40px;padding:0}
}

@media(max-width:600px){
  .footer-socials a{width:36px;height:36px}
}