/* ============================================================
   VISTAAR ENTERPRISE SOLUTIONS — MASTER STYLESHEET v2.0
   Modern, responsive, premium design
   ============================================================ */

/* ============================================================
   VISTAAR TYPOGRAPHY SYSTEM — GLOBAL NORMALISATION
   All font sizes, weights, and colours standardised here.
   ============================================================ */
/* Headline hierarchy — Roboto Condensed for all display headings */
h1, h2, h3 {
  font-family: 'Roboto Condensed', sans-serif;
  color: var(--navy);
  line-height: 1.2;
}
/* Inner-page section headline sizes */
.sec h2 { font-size: clamp(24px, 3vw, 38px); font-weight: 700 }
.sec h3 { font-size: clamp(16px, 1.8vw, 19px); font-weight: 700 }
/* Body / paragraph global */
p { font-family: 'Inter', sans-serif; font-size: 15px; line-height: 1.78; color: var(--mid) }
/* Dark section paragraphs inherit white */
.sd p, .sd2 p { color: rgba(255,255,255,.62) }
/* ---- CUSTOM PROPERTIES ---- */
:root {
  --green:    #4caf50;
  --green2:   #7dc442;
  --green3:   #3d9a42;
  --green-gl: rgba(76,175,80,.15);
  --navy:     #111827;
  --navy2:    #1a2a4a;
  --navy3:    #0d1520;
  --white:    #fff;
  --off:      #f5f7fa;
  --border:   #e2e8f0;
  --mid:      #6b7280;
  --shadow:   0 4px 24px rgba(0,0,0,.10);
  --shadow-lg:0 12px 48px rgba(0,0,0,.18);
  --shadow-xl:0 24px 64px rgba(0,0,0,.22);
  --radius:   12px;
  --radius-lg:20px;
  --trans:    .25s ease;
  --wa-green: #25d366;
}

/* ---- RESET & BASE ---- */
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box }
html { scroll-behavior:smooth; font-size:16px }
body { font-family:'Inter',sans-serif; color:var(--navy); overflow-x:hidden; background:#fff; line-height:1.6 }
a { text-decoration:none; color:inherit }
img { max-width:100%; display:block }
button { cursor:pointer; border:none; background:none }
ul { list-style:none }

/* ---- SCROLL PROGRESS ---- */
.scroll-progress {
  position:fixed; top:0; left:0; height:3px; width:0%;
  background:linear-gradient(90deg,var(--green),var(--green2));
  z-index:9999; transition:width .1s linear;
}

/* ============================================================
   HEADER / NAVBAR
   ============================================================ */
header {
  position:fixed; top:0; left:0; right:0; z-index:1000;
  background:#fff; box-shadow:0 2px 16px rgba(0,0,0,.07);
  transition:box-shadow .35s ease, background .35s ease, backdrop-filter .35s ease;
}
body { padding-top:68px; }
header.scrolled {
  background:#fff;
  box-shadow:0 2px 20px rgba(0,0,0,.10);
}
.hd {
  max-width:1320px; margin:0 auto; padding:0 24px;
  display:flex; align-items:center; justify-content:space-between; height:68px; gap:24px;
}
.logo-wrap { flex-shrink:0 }
.logo-img { height:52px; object-fit:contain; width:auto }

/* Contact info block — right end of nav (desktop only) */
.hd-contact {
  display:flex; flex-direction:column; gap:6px; flex-shrink:0; margin-left:14px;
}
.hd-contact a {
  display:inline-flex; align-items:center; gap:6px;
  font-size:10px; font-weight:600; white-space:nowrap;
  padding:4px 11px; border-radius:50px;
  border:1.5px solid rgba(76,175,80,.5);
  color:var(--navy);
  background:rgba(76,175,80,.06);
  transition:background var(--trans), color var(--trans);
  line-height:1.4;
}
.hd-contact a i { font-size:9px; flex-shrink:0; color:var(--green) }
.hd-contact a:hover { background:var(--green); color:#fff }
.hd-contact a:hover i { color:#fff }

/* Desktop Nav */
nav#desktopNav {
  display:flex; align-items:center; gap:2px; flex:1; justify-content:flex-end;
}
.ni { position:relative }
.ni > a, .ni > span {
  display:flex; align-items:center; gap:5px;
  padding:8px 12px; font-size:13.5px; font-weight:500;
  color:var(--navy); cursor:pointer; border-radius:6px;
  transition:color var(--trans), background var(--trans); white-space:nowrap;
}
.ni > a:hover, .ni > span:hover { color:var(--green); background:rgba(76,175,80,.06) }
.ni-arr { font-size:9px; color:#aaa; transition:transform .22s ease; display:inline-block }

/* ---- Shared dropdown/mega base (JS-driven, not CSS :hover) ---- */
/*
  Structure: .ni > span (trigger) + .drop OR .mega
  Open state: .ni.nav-open  (added/removed by JS)
  The outer .drop/.mega has transparent padding-top = bridge that
  fills the visual gap so no "escape route" exists between trigger and panel.
*/

/* Dropdown */
.drop {
  position:absolute;
  top:100%;
  left:0;
  padding-top:14px;    /* wider transparent bridge for diagonal mouse travel */
  min-width:240px;
  z-index:999;
  opacity:0;
  visibility:hidden;
  pointer-events:none;
  transform:translateY(-4px);
  transition:opacity .18s ease, transform .18s ease, visibility .18s ease;
}
.drop-inner {
  background:#fff;
  border-radius:var(--radius);
  box-shadow:var(--shadow-xl);
  border-top:3px solid var(--green);
  padding:8px 0;
  overflow:hidden;
}
.drop-wide { min-width:480px }
.drop-cols { display:grid; grid-template-columns:1fr 1fr }
.drop-cols > div { padding:4px 0 }

/* Open state */
.ni.nav-open > .drop {
  opacity:1;
  visibility:visible;
  pointer-events:auto;
  transform:translateY(0);
}

.drop a {
  display:flex; align-items:center; gap:9px;
  padding:9px 20px; font-size:13.5px; color:#4b5563;
  transition:background .15s, color .15s, padding-left .15s;
}
.drop a i { width:14px; color:var(--green); font-size:12px; flex-shrink:0 }
.drop a:hover { background:#f0faf0; color:var(--green); padding-left:26px }

/* Mega Menu */
.mega {
  position:absolute;
  top:100%;
  left:50%;
  padding-top:14px;    /* wider transparent bridge for diagonal mouse travel */
  z-index:999;
  opacity:0;
  visibility:hidden;
  pointer-events:none;
  transform:translateX(-50%) translateY(-4px);
  transition:opacity .18s ease, transform .18s ease, visibility .18s ease;
  min-width:720px;
}
.mega-wide { min-width:940px }
.mega-inner {
  background:#fff;
  border-radius:var(--radius);
  box-shadow:var(--shadow-xl);
  border-top:3px solid var(--green);
  padding:28px 32px;
}

/* Open state */
.ni.nav-open > .mega {
  opacity:1;
  visibility:visible;
  pointer-events:auto;
  transform:translateX(-50%) translateY(0);
}
.mg { display:grid; grid-template-columns:repeat(3,1fr); gap:24px }
.mg-4 { grid-template-columns:repeat(4,1fr) }
.mc h4 {
  font-size:10px; font-weight:700; text-transform:uppercase;
  letter-spacing:1.8px; color:var(--green); margin-bottom:12px;
  padding-bottom:8px; border-bottom:1px solid #e8f5e9;
  display:flex; align-items:center; gap:7px;
}
.mc h4 i { font-size:11px }
.mc a {
  display:flex; align-items:center; gap:7px;
  padding:7px 0; font-size:13px; color:#4b5563;
  transition:color var(--trans), padding var(--trans);
}
.mc a::before { content:'›'; color:var(--green2); font-size:15px; flex-shrink:0 }
.mc a:hover { color:var(--green); padding-left:5px }

/* Header CTA */
.hcta {
  background:linear-gradient(135deg,var(--green),var(--green2));
  color:#fff !important; padding:10px 22px !important; border-radius:6px;
  font-weight:700 !important; font-size:13px !important; margin-left:6px;
  transition:transform var(--trans), box-shadow var(--trans) !important;
  white-space:nowrap; flex-shrink:0;
}
.hcta:hover { transform:translateY(-2px); box-shadow:0 6px 20px rgba(76,175,80,.4) !important }

/* ============================================================
   HAMBURGER & MOBILE DRAWER
   ============================================================ */
.hamburger {
  display:none; flex-direction:column; gap:5px;
  width:36px; height:36px; justify-content:center; align-items:center;
  border-radius:6px; transition:background var(--trans);
}
.hamburger:hover { background:var(--off) }
.hamburger span {
  display:block; width:22px; height:2px;
  background:var(--navy); border-radius:2px;
  transition:transform .3s, opacity .3s;
}
.hamburger.open span:nth-child(1) { transform:translateY(7px) rotate(45deg) }
.hamburger.open span:nth-child(2) { opacity:0 }
.hamburger.open span:nth-child(3) { transform:translateY(-7px) rotate(-45deg) }

.mob-overlay {
  display:none; position:fixed; inset:0; background:rgba(0,0,0,.5);
  z-index:1100; backdrop-filter:blur(2px);
}
.mob-overlay.show { display:block }

.mob-drawer {
  position:fixed; top:0; right:-340px; width:320px; max-width:90vw;
  height:100vh; background:#fff; z-index:1200;
  box-shadow:var(--shadow-xl); overflow-y:auto;
  transition:right .35s cubic-bezier(.4,0,.2,1);
  display:flex; flex-direction:column;
}
.mob-drawer.open { right:0 }
.mob-top {
  display:flex; align-items:center; justify-content:space-between;
  padding:18px 20px; border-bottom:1px solid var(--border);
  position:sticky; top:0; background:#fff; z-index:1;
}
.mob-logo { height:40px; object-fit:contain }
.mob-close {
  width:32px; height:32px; border-radius:50%;
  background:var(--off); font-size:20px; color:#555;
  display:flex; align-items:center; justify-content:center;
  transition:background var(--trans);
}
.mob-close:hover { background:#ddd }
.mob-nav { flex:1; padding:12px 0; overflow-y:auto }
.mob-item {}
.mob-hd {
  display:flex; justify-content:space-between; align-items:center;
  padding:13px 20px; font-size:15px; font-weight:600; color:var(--navy);
  cursor:pointer; transition:background var(--trans);
}
.mob-hd:hover { background:var(--off) }
.mob-hd i { font-size:11px; color:#aaa; transition:transform .25s }
.mob-hd.open i { transform:rotate(90deg) }
.mob-sub {
  display:none; background:#fafbfc; border-top:1px solid var(--border);
}
.mob-sub.show { display:block }
.mob-sub a {
  display:block; padding:10px 28px; font-size:13.5px;
  color:var(--mid); border-bottom:1px solid rgba(0,0,0,.04);
  transition:all var(--trans);
}
.mob-sub a:hover { color:var(--green); padding-left:36px; background:#f0faf0 }
.mob-link {
  display:block; padding:13px 20px;
  font-size:15px; font-weight:600; color:var(--navy);
  border-top:1px solid var(--border);
  transition:color var(--trans);
}
.mob-link:hover { color:var(--green) }
.mob-cta {
  display:block; margin:14px 20px 0; padding:13px;
  background:linear-gradient(135deg,var(--green),var(--green2));
  color:#fff; border-radius:8px; font-weight:700; font-size:14px;
  text-align:center; transition:transform var(--trans);
}
.mob-cta:hover { transform:translateY(-1px); color:#fff }
/* Contact rows below Get Free Consultation */
.mob-cta-contacts {
  display:flex; flex-direction:column; gap:6px;
  border-top:1px solid var(--border);
  padding:10px 20px 14px; margin:0;
}
.mob-cta-contacts a {
  display:flex; align-items:center; gap:9px;
  padding:7px 12px; font-size:12px; color:var(--mid);
  font-weight:500; line-height:1.5; transition:color var(--trans);
  background:#f8faf8; border-radius:6px;
  border:1px solid var(--border);
  word-break:break-all; overflow-wrap:anywhere;
}
.mob-cta-contacts a i { color:var(--green); width:14px; text-align:center; font-size:11px; flex-shrink:0 }
.mob-cta-contacts a:hover { color:var(--green); background:#f0faf0; border-color:#d1fae5 }

/* ============================================================
   SIDE STRIPE
   ============================================================ */
.stripe {
  position:fixed; right:0; top:55%; transform:translateY(-50%);
  z-index:900; display:flex; flex-direction:column;
}
.sb {
  writing-mode:vertical-rl; text-orientation:mixed;
  padding:16px 9px; font-size:10px; font-weight:700;
  letter-spacing:1.8px; text-transform:uppercase;
  color:#fff; text-decoration:none; transition:padding var(--trans);
}
.sb:hover { opacity:.88; padding:20px 9px; color:#fff }
.sb:nth-child(1) { background:var(--green); border-radius:8px 0 0 0 }
.sb:nth-child(2) { background:var(--navy2) }
.sb-wa { background:var(--wa-green) !important; border-radius:0 0 0 8px }

/* ============================================================
   FLOATING WHATSAPP
   ============================================================ */
.float-wa {
  position:fixed; bottom:28px; right:24px; z-index:950;
  background:none; color:var(--wa-green); font-size:42px;
  display:flex; align-items:center; justify-content:center;
  transition:transform var(--trans), color var(--trans);
}
.float-wa:hover { transform:scale(1.1); color:#1da851; background:none; box-shadow:none }
.wa-tooltip {
  position:absolute; right:68px; background:var(--navy);
  color:#fff; padding:6px 12px; border-radius:6px; font-size:12px;
  font-weight:600; white-space:nowrap; opacity:0; pointer-events:none;
  transition:opacity var(--trans);
}
.wa-tooltip::after {
  content:''; position:absolute; left:100%; top:50%; transform:translateY(-50%);
  border:5px solid transparent; border-left-color:var(--navy);
}
.float-wa:hover .wa-tooltip { opacity:1 }

/* BACK TO TOP */
.back-top {
  position:fixed; bottom:96px; right:26px; z-index:940;
  width:40px; height:40px; border-radius:50%;
  background:var(--navy); color:#fff; font-size:14px;
  display:flex; align-items:center; justify-content:center;
  box-shadow:var(--shadow); opacity:0; pointer-events:none;
  transition:opacity .3s, transform .3s;
}
.back-top.visible { opacity:1; pointer-events:all }
.back-top:hover { transform:translateY(-3px); background:var(--green) }

/* ============================================================
   LAYOUT UTILITIES
   ============================================================ */
.w { max-width:1320px; margin:0 auto; padding:0 24px }
.sec { padding:96px 0 }
.sl { background:#fff }
.so { background:#f5f7fa }
.sd { background:var(--navy); color:#fff }
.sd2 { background:var(--navy3); color:#fff }

/* Section Headers */
.sh { text-align:center; margin-bottom:64px }
.st {
  display:inline-block; font-size:11px; font-weight:700;
  letter-spacing:3px; text-transform:uppercase; color:var(--green);
  margin-bottom:14px; padding:5px 14px; background:rgba(76,175,80,.08);
  border-radius:100px; border:1px solid rgba(76,175,80,.2);
}
.stw { color:var(--green2); background:rgba(125,196,66,.1); border-color:rgba(125,196,66,.25) }
.stt {
  font-family:'Roboto Condensed',sans-serif;
  font-size:clamp(26px,3.5vw,44px); font-weight:700;
  color:var(--navy); line-height:1.2; margin-bottom:14px;
}
.sttw { color:#fff }
.stt span { color:var(--green) }
.sub { font-size:16px; color:var(--mid); max-width:640px; margin:0 auto; line-height:1.75 }
.subw { color:rgba(255,255,255,.65) }

/* Scroll Reveal */
.rv { opacity:0; transform:translateY(30px); transition:opacity .7s ease,transform .7s ease }
.rv.vis { opacity:1; transform:translateY(0) }
.d1{transition-delay:.1s} .d2{transition-delay:.2s} .d3{transition-delay:.3s} .d4{transition-delay:.4s}

/* Buttons */
.btn-g {
  background:linear-gradient(135deg,var(--green),var(--green2));
  color:#fff; padding:14px 32px; border-radius:8px;
  font-weight:700; font-size:15px; display:inline-flex; align-items:center; gap:10px;
  transition:transform var(--trans), box-shadow var(--trans);
  box-shadow:0 4px 20px rgba(76,175,80,.35);
}
.btn-g:hover { transform:translateY(-2px); box-shadow:0 8px 28px rgba(76,175,80,.5); color:#fff }
.btn-gh {
  border:2px solid rgba(255,255,255,.55); color:#fff; padding:13px 30px; border-radius:8px;
  font-weight:600; font-size:15px; display:inline-flex; align-items:center; gap:8px;
  transition:all var(--trans); backdrop-filter:blur(4px);
}
.btn-gh:hover { background:rgba(255,255,255,.1); border-color:#fff; color:#fff }
.btn-og {
  background:var(--green); color:#fff; padding:13px 30px; border-radius:8px;
  font-weight:700; font-size:14.5px; display:inline-flex; align-items:center; gap:8px;
  transition:all var(--trans); border:none;
}
.btn-og:hover { background:var(--green3); transform:translateY(-2px); color:#fff }
.btn-ow {
  display:inline-flex; align-items:center; gap:8px; padding:13px 32px;
  border:2px solid rgba(255,255,255,.4); color:#fff; border-radius:8px;
  font-weight:700; font-size:14.5px; transition:all var(--trans);
}
.btn-ow:hover { border-color:#fff; background:rgba(255,255,255,.08) }
.btn-gf {
  display:flex; width:100%; align-items:center; justify-content:center; gap:8px;
  background:var(--green); color:#fff; padding:13px; border-radius:8px;
  font-weight:700; font-size:14px; transition:all var(--trans);
}
.btn-gf:hover { background:var(--green3); color:#fff }

/* ============================================================
   HERO (SS1) — 5-slide carousel
   ============================================================ */
.hero {
  position:relative; overflow:hidden; height:660px; background:var(--navy3);
}
.htrack { display:flex; height:100%; transition:transform .85s cubic-bezier(.4,0,.2,1) }
.hs { min-width:100%; height:100%; position:relative; display:flex; align-items:center }
.hbg {
  position:absolute; inset:0; background-size:cover; background-position:center;
  transition:transform 6s ease;
}
.hs.active .hbg { transform:scale(1.04) }
.hbg::after {
  content:''; position:absolute; inset:0;
  background:linear-gradient(105deg,rgba(8,16,32,.95) 0%,rgba(8,16,32,.78) 55%,rgba(60,140,60,.14) 100%);
}
.hbg1 { background-image:url('/assets/images/banner/1.webp') }
.hbg2 { background-image:url('/assets/images/banner/2.webp') }
.hbg3 { background-image:url('/assets/images/banner/5.webp') }
.hbg4 { background-image:url('/assets/images/banner/3.webp') }
.hbg5 { background-image:url('/assets/images/banner/4.webp') }
.hcon {
  position:relative; z-index:2;
  max-width:1320px; margin:0 auto; padding:0 24px; width:100%;
}
.hbadge {
  display:inline-flex; align-items:center; gap:8px;
  background:rgba(76,175,80,.16); border:1px solid rgba(76,175,80,.45);
  border-radius:100px; padding:6px 16px; font-size:11px;
  color:var(--green2); font-weight:700; letter-spacing:1px;
  text-transform:uppercase; margin-bottom:22px;
  opacity:0; transform:translateY(20px);
  animation:su .7s .3s forwards;
}
.hbadge::before {
  content:''; width:6px; height:6px; border-radius:50%;
  background:var(--green2); display:block; animation:bl 1.5s infinite;
}
@keyframes bl { 0%,100%{opacity:1} 50%{opacity:.3} }
@keyframes su { to{opacity:1;transform:translateY(0)} }
.htit {
  font-family:'Roboto Condensed',sans-serif;
  font-size:clamp(34px,5.5vw,66px); font-weight:800;
  color:#fff; line-height:1.08; margin-bottom:20px; max-width:720px;
  opacity:0; transform:translateY(26px); animation:su .7s .5s forwards;
}
.htit span { color:var(--green2) }
.hdesc {
  font-size:17px; color:rgba(255,255,255,.78); max-width:560px;
  line-height:1.75; margin-bottom:36px;
  opacity:0; transform:translateY(26px); animation:su .7s .7s forwards;
}
.hbtns {
  display:flex; gap:14px; flex-wrap:wrap;
  opacity:0; transform:translateY(26px); animation:su .7s .9s forwards;
}
/* Nav controls */
.hdots {
  position:absolute; bottom:96px; left:50%; transform:translateX(-50%);
  display:flex; gap:8px; z-index:10;
}
.dot {
  width:8px; height:8px; border-radius:4px;
  background:rgba(255,255,255,.32); border:none; transition:all .3s;
}
.dot.on { width:28px; background:var(--green2) }
.harr {
  position:absolute; bottom:86px; right:120px;
  display:flex; gap:8px; z-index:10;
}
.ha {
  width:42px; height:42px; border-radius:50%;
  background:rgba(255,255,255,.1); border:1px solid rgba(255,255,255,.25);
  color:#fff; font-size:18px; display:flex; align-items:center; justify-content:center;
  transition:all var(--trans);
}
.ha:hover { background:var(--green); border-color:var(--green) }
.htabs {
  position:absolute; bottom:0; left:0; right:0; display:flex; z-index:5;
}
.htab {
  flex:1; padding:13px 14px; background:rgba(8,16,32,.72);
  color:rgba(255,255,255,.5); font-size:11.5px; font-weight:500;
  cursor:pointer; border-top:2px solid transparent; text-align:center;
  transition:all .3s; backdrop-filter:blur(6px);
  white-space:nowrap; overflow:hidden; text-overflow:ellipsis;
}
.htab.on { background:rgba(76,175,80,.2); color:var(--green2); border-top-color:var(--green2) }
.htab:hover:not(.on) { background:rgba(255,255,255,.07); color:#fff }

/* ============================================================
   STATS / SAVINGS (SS2)
   ============================================================ */
.sc-cols {
  display:grid; grid-template-columns:repeat(3,1fr);
  border-top:1px solid var(--border); margin-top:48px; gap:0;
}
.sc {
  padding:40px 44px 40px 0; border-right:1px solid var(--border);
  transition:all var(--trans);
}
.sc:last-child { border-right:none; padding-right:0; padding-left:44px }
.sc:nth-child(2) { padding:40px 44px }
.sc-top {
  display:flex; align-items:center; justify-content:space-between; margin-bottom:12px;
}
.sc-num {
  font-family:'Roboto Condensed',sans-serif;
  font-size:72px; font-weight:800; color:var(--green); line-height:1;
}
.sc-ico {
  width:64px; height:64px; background:#f0f8f0; border-radius:12px;
  display:flex; align-items:center; justify-content:center; overflow:hidden;
}
.sc-ico img { width:80%; height:80%; object-fit:contain }
.sc-lbl {
  font-size:10px; font-weight:700; letter-spacing:2.5px;
  text-transform:uppercase; color:#9ca3af; margin-bottom:18px;
}
.sc h3 { font-size:20px; font-weight:700; color:var(--navy); margin-bottom:12px; line-height:1.3 }
.sc p { font-size:14px; color:var(--mid); line-height:1.75 }

/* ============================================================
   SERVICES IMAGE CARDS (SS3)
   ============================================================ */
.sic { display:grid; grid-template-columns:repeat(3,1fr); gap:22px }
.sicard {
  border-radius:var(--radius); overflow:hidden; position:relative;
  height:300px; cursor:pointer; transition:transform .35s, box-shadow .35s;
}
.sicard:hover { transform:translateY(-6px); box-shadow:var(--shadow-xl) }
.sibg {
  position:absolute; inset:0; background-size:cover;
  background-position:center; transition:transform .5s;
  display:flex; align-items:center; justify-content:center;
}
.sibg img { width:65%; height:65%; object-fit:contain; opacity:.18; mix-blend-mode:luminosity; filter:saturate(0) brightness(1.4); transition:opacity .4s }
.sicard:hover .sibg img { opacity:.28 }
.sicard:hover .sibg { transform:scale(1.06) }
.siov {
  position:absolute; inset:0;
  background:linear-gradient(to top,rgba(5,12,30,.92) 0%,rgba(5,12,30,.28) 60%,transparent 100%);
}
.sicon {
  position:absolute; bottom:0; left:0; right:0; padding:26px;
  transform:translateY(0); transition:transform .3s;
}
.sicon h3 {
  font-size:17px; font-weight:700; color:#fff;
  margin-bottom:8px; display:flex; align-items:center; gap:8px;
}
.sicon p {
  font-size:13px; color:rgba(255,255,255,.75); line-height:1.65;
  max-height:80px; overflow:hidden; transition:max-height .4s, opacity .4s;
  opacity:1;
}
.sicard:hover .sicon p { max-height:80px; opacity:1 }
.sic-link {
  display:inline-flex; align-items:center; gap:6px; margin-top:10px;
  font-size:12.5px; font-weight:700; color:var(--green2);
  opacity:1; transition:opacity .3s .1s;
}
.sicard:hover .sic-link { opacity:1 }
.bg1{background:linear-gradient(135deg,#1a2a4a,#243560)}
.bg2{background:linear-gradient(135deg,#1e1e38,#2a1e48)}
.bg3{background:linear-gradient(135deg,#1a1a38,#202850)}
.bg4{background:linear-gradient(135deg,#1a2838,#1e3050)}
.bg5{background:linear-gradient(135deg,#282018,#342818)}
.bg6{background:linear-gradient(135deg,#101828,#182030)}

/* ============================================================
   AI SOLUTIONS (SS4)
   ============================================================ */
.ai-in { display:grid; grid-template-columns:1fr 1fr; gap:72px; align-items:center }
.ai-tabs { display:flex; gap:10px; flex-wrap:wrap; margin-bottom:28px }
.aitab {
  padding:10px 20px; border-radius:100px; border:1.5px solid var(--border);
  font-size:13px; font-weight:500; color:var(--mid); cursor:pointer;
  display:flex; align-items:center; gap:8px; transition:all var(--trans); background:#fff;
}
.aitab.on { background:var(--navy); color:#fff; border-color:var(--navy) }
.aitab:not(.on):hover { border-color:var(--green); color:var(--green) }
.ai-desc { font-size:15px; color:#4b5563; line-height:1.78; margin-bottom:22px }
.ai-chk { list-style:none; margin-bottom:32px }
.ai-chk li {
  display:flex; align-items:center; gap:10px;
  font-size:14.5px; color:#374151; padding:6px 0; font-weight:500;
}
.ai-chk li::before {
  content:''; width:22px; height:22px; min-width:22px; border-radius:50%;
  background:url("data:image/svg+xml,%3Csvg width='22' height='22' viewBox='0 0 22 22' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Ccircle cx='11' cy='11' r='11' fill='%234caf50'/%3E%3Cpath d='M6 11.5l3.5 3.5 6-7' stroke='white' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E") center/contain no-repeat;
}
.ai-vis {
  border-radius:16px; overflow:hidden; height:400px;
  background:linear-gradient(135deg,#0a1628,#1a2a4a,#0d2a1a);
  display:flex; align-items:center; justify-content:center; padding:28px;
}
.av-g { display:grid; grid-template-columns:repeat(3,1fr); gap:12px; width:100% }
.av {
  background:rgba(255,255,255,.07); border:1px solid rgba(76,175,80,.25);
  border-radius:10px; padding:18px 10px; text-align:center;
  transition:all .3s; cursor:pointer;
}
.av:hover { background:rgba(76,175,80,.18); transform:translateY(-3px); border-color:var(--green2) }
.av .i { font-size:26px; margin-bottom:8px }
.av .l { font-size:11px; color:rgba(255,255,255,.65); font-weight:500 }

/* ============================================================
   ABOUT DARK (SS5)
   ============================================================ */
.abt-in { display:grid; grid-template-columns:1fr 1fr; gap:64px; align-items:start }
.abt-st { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; margin-top:36px }
.ast { display:flex; align-items:center; gap:12px }
.ast-ico { font-size:24px; color:var(--green2) }
.ast-n {
  font-family:'Roboto Condensed',sans-serif;
  font-size:32px; font-weight:800; color:#fff; line-height:1;
}
.ast-l { font-size:12px; color:rgba(255,255,255,.5); margin-top:3px }
.exp-btn {
  display:inline-flex; align-items:center; gap:8px; margin-top:30px;
  padding:13px 30px; border:2px solid rgba(255,255,255,.28);
  color:#fff; border-radius:8px; font-weight:600; font-size:15px; transition:all var(--trans);
}
.exp-btn:hover { border-color:#fff; background:rgba(255,255,255,.08) }
.mag-lbl { font-size:10px; font-weight:700; letter-spacing:2.5px; text-transform:uppercase; color:var(--green2); margin-bottom:12px }
.mag-h { font-size:24px; font-weight:700; color:#fff; margin-bottom:18px }
.mag-rd { display:flex; align-items:center; gap:8px; font-size:14px; color:var(--green2); font-weight:600; margin-bottom:24px; cursor:pointer }
.mag-cards { display:grid; grid-template-columns:1fr 1fr; gap:16px }
.mc2 {
  border-radius:12px; overflow:hidden; height:auto;
  display:block; text-decoration:none;
  transition:transform .3s, box-shadow .3s;
  cursor:pointer;
}
.mc2:hover { transform:translateY(-5px); box-shadow:0 12px 32px rgba(0,0,0,.4) }
.mc2-bg {
  height:100%; display:flex; flex-direction:column;
  justify-content:flex-end; padding:18px;
  transition:filter .3s;
}
.mc2:hover .mc2-bg { filter:brightness(1.12) }
.mc2-tag {
  font-size:9px; font-weight:700; letter-spacing:1.5px; text-transform:uppercase;
  color:var(--green2); margin-bottom:6px;
}
.mc2-t { font-size:13px; font-weight:700; color:#fff; line-height:1.4; margin-bottom:6px }
.mc2-p { font-size:11px; color:rgba(255,255,255,.55); line-height:1.6; margin:0 }

/* ============================================================
   TECH STACK (SS6)
   ============================================================ */
.tech-rws { margin-top:40px; display:flex; flex-direction:column; gap:8px }
.tech-cat {
  margin-top:28px; margin-bottom:14px; font-size:17px; font-weight:600;
  text-align:center; color:#fff; letter-spacing:.4px;
}
.tech-rw { display:flex; flex-wrap:wrap; justify-content:center; gap:12px; margin-bottom:8px }
.chip {
  display:inline-flex; align-items:center; gap:8px;
  padding:10px 16px; background:rgba(255,255,255,.06);
  border:1.5px solid rgba(255,255,255,.15); border-radius:8px;
  font-size:13.5px; font-weight:500; color:rgba(255,255,255,.82);
  white-space:nowrap; transition:all .25s ease; cursor:pointer;
}
.chip i { font-size:15px; color:var(--green2) }
.chip:hover {
  background:rgba(76,175,80,.18); color:#fff;
  border-color:var(--green2); transform:translateY(-3px);
}
.chip:hover i { color:#fff }

/* ============================================================
   INDUSTRIES SLIDER (SS7)
   ============================================================ */
.ind-w { overflow:hidden; margin-top:48px; position:relative }
.ind-t { display:flex; gap:0; transition:transform .6s ease }
.icard {
  min-width:25%; height:176px; position:relative; overflow:hidden;
  cursor:pointer; transition:all .45s; flex-shrink:0;
}
.icard:hover { min-width:32% }
.ibg {
  position:absolute; inset:0; background-size:cover;
  background-position:center; transition:transform .5s;
}
.icard:hover .ibg { transform:scale(1.05) }
.ib1{background:linear-gradient(135deg,#1a2838,#2a3848)}
.ib2{background:linear-gradient(135deg,#2a2018,#382818)}
.ib3{background:linear-gradient(135deg,#101828,#1a2838)}
.ib4{background:linear-gradient(135deg,#182028,#243040)}
.ib5{background:linear-gradient(135deg,#181820,#24242e)}
.ib6{background:linear-gradient(135deg,#1a2820,#243428)}
.iov {
  position:absolute; inset:0;
  background:linear-gradient(to top,rgba(0,0,0,.88) 0%,rgba(0,0,0,.24) 60%,transparent 100%);
}
.ico { position:absolute; bottom:0; left:0; right:0; padding:28px 22px }
.iline { width:36px; height:3px; background:var(--green); margin-bottom:14px }
.ico h3 { font-size:18px; font-weight:700; color:#fff; margin-bottom:8px }
.ico p { font-size:12.5px; color:rgba(255,255,255,.68); line-height:1.6; margin-bottom:12px }
.ilnk {
  color:var(--green2); font-size:13px; font-weight:600;
  display:flex; align-items:center; gap:6px; transition:gap var(--trans);
}
.icard:hover .ilnk { gap:10px }
.iarr-w { display:flex; gap:10px; justify-content:center; margin-top:24px }
.iarr {
  width:44px; height:44px; border-radius:50%;
  border:2px solid var(--border); background:#fff;
  display:flex; align-items:center; justify-content:center;
  font-size:16px; transition:all var(--trans);
}
.iarr:hover { background:var(--navy); border-color:var(--navy); color:#fff }

/* ============================================================
   SOLUTIONS (SS8)
   ============================================================ */
.sol-g { display:grid; grid-template-columns:repeat(3,1fr); gap:24px }
.solc {
  border:1.5px solid var(--border); border-radius:var(--radius);
  padding:36px 28px; transition:all .3s; background:#fff;
}
.solc:hover { box-shadow:var(--shadow-xl); border-color:#d1fae5; transform:translateY(-5px) }
.solc-ico { font-size:30px; margin-bottom:16px }
.solc h3 { font-size:21px; font-weight:700; color:var(--navy); margin-bottom:10px }
.solc > p { font-size:14px; color:var(--mid); line-height:1.72; margin-bottom:20px }
.sol-l { list-style:none; margin-bottom:28px }
.sol-l li {
  display:flex; align-items:flex-start; gap:9px;
  padding:5px 0; font-size:13.5px; color:#374151; line-height:1.5;
}
.sol-l li::before { content:'›'; color:var(--green); font-weight:700; font-size:16px; flex-shrink:0 }

/* ============================================================
   CASE STUDIES (SS9)
   ============================================================ */
.cs-g { display:grid; grid-template-columns:repeat(3,1fr); gap:20px }
.cscard {
  border-radius:var(--radius); overflow:hidden; position:relative;
  height:230px; cursor:pointer; transition:transform .3s, box-shadow .3s;
}
.cscard:hover { transform:translateY(-5px); box-shadow:var(--shadow-xl) }
.csbg { position:absolute; inset:0; background-size:cover; background-position:center; transition:transform .5s }
.cscard:hover .csbg { transform:scale(1.05) }
.cb1{background:linear-gradient(135deg,#1a2840,#243456)}
.cb2{background:linear-gradient(135deg,#2a1a2a,#3a243a)}
.cb3{background:linear-gradient(135deg,#1a2828,#243438)}
.cb4{background:linear-gradient(135deg,#1a3018,#243820)}
.cb5{background:linear-gradient(135deg,#2a2018,#382818)}
.cb6{background:linear-gradient(135deg,#181838,#242448)}
.csov {
  position:absolute; inset:0;
  background:linear-gradient(to top,rgba(0,0,0,.92) 0%,rgba(0,0,0,.18) 100%);
}
.csc { position:absolute; bottom:0; left:0; right:0; padding:22px }
.cst {
  font-size:10px; font-weight:400; letter-spacing:1.5px;
  text-transform:uppercase; color:var(--green2); margin-bottom:6px;
}
.csc h3 { font-size:13px; font-weight:400; color:rgba(255,255,255,.80); line-height:1.65; margin-bottom:10px }
.csp { font-size:13px; font-weight:400; color:rgba(255,255,255,.80); line-height:1.65; margin-bottom:10px }
.csm { display:flex; align-items:center; gap:12px; font-size:12px; color:rgba(255,255,255,.52) }

/* ============================================================
   CONTACT CONVERSION HUB (SS10)
   ============================================================ */
.ct-hub { display:grid; grid-template-columns:1fr 1.2fr 1fr; gap:32px; align-items:start }

/* Contact Info Column */
.ct-info-col {}
.ct-info-col .st.stw { margin-bottom:12px }
.ct-info-col h2 {
  font-size:clamp(24px,3vw,36px); font-weight:700; color:#fff;
  line-height:1.3; margin-bottom:24px;
}
.ct-trust { display:flex; flex-wrap:wrap; gap:14px; margin-bottom:28px }
.cti { display:flex; align-items:center; gap:8px; font-size:13.5px; color:rgba(255,255,255,.72) }
.cti .ci { font-size:18px; color:var(--green2) }
.ct-methods { display:flex; flex-direction:column; gap:14px; margin-bottom:28px }
.ct-method {
  display:flex; align-items:center; gap:14px;
  padding:14px 16px; background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.1); border-radius:10px;
  transition:all var(--trans);
}
.ct-method:hover { background:rgba(76,175,80,.12); border-color:rgba(76,175,80,.35); text-decoration:none }
.ct-method-ico {
  width:42px; height:42px; border-radius:10px;
  display:flex; align-items:center; justify-content:center;
  font-size:18px; flex-shrink:0;
}
.ct-method-ico.green { background:rgba(76,175,80,.2); color:var(--green2) }
.ct-method-ico.wa { background:rgba(37,211,102,.2); color:#25d366 }
.ct-method-ico.phone { background:rgba(59,130,246,.2); color:#60a5fa }
.ct-method-ico.email { background:rgba(245,158,11,.2); color:#fbbf24 }
.ct-method-body {}
.ct-method-lbl { font-size:11px; color:rgba(255,255,255,.45); text-transform:uppercase; letter-spacing:1px; font-weight:600 }
.ct-method-val { font-size:14px; font-weight:600; color:#fff }

/* Contact Form Column */
.ct-form-col {}
.ct-form-col > p { font-size:13px; color:rgba(255,255,255,.45); margin-bottom:18px }
.cform { display:grid; grid-template-columns:1fr 1fr; gap:12px }
.cf {
  width:100%; padding:13px 17px;
  background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.14);
  border-radius:8px; color:#fff; font-size:14px;
  font-family:'Inter',sans-serif; outline:none; transition:border-color var(--trans);
}
.cf:focus { border-color:var(--green2); background:rgba(255,255,255,.09) }
.cf::placeholder { color:rgba(255,255,255,.32) }
.cff { grid-column:1/-1 }
.cf-select {
  width:100%; padding:13px 17px;
  background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.14);
  border-radius:8px; color:rgba(255,255,255,.75); font-size:14px;
  font-family:'Inter',sans-serif; outline:none; transition:border-color var(--trans);
  cursor:pointer; appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='%23999' d='M0 0l6 8 6-8z'/%3E%3C/svg%3E");
  background-repeat:no-repeat; background-position:right 16px center;
  padding-right:36px;
}
.cf-select:focus { border-color:var(--green2) }
.cf-select option { background:var(--navy); color:#fff }
textarea.cf { resize:vertical; min-height:110px }
.btn-bk {
  grid-column:1/-1; background:linear-gradient(135deg,var(--green),var(--green2));
  color:#fff; padding:15px; border-radius:8px; font-weight:700; font-size:15px;
  border:none; display:flex; align-items:center; justify-content:center;
  gap:10px; transition:all var(--trans); width:75%; margin-left:auto; margin-right:auto;
}
.btn-bk:hover { transform:translateY(-2px); box-shadow:0 8px 28px rgba(76,175,80,.45) }
.form-note {
  grid-column:1/-1; font-size:11.5px; color:rgba(255,255,255,.35);
  text-align:center; margin-top:4px;
}

/* Demo / Quick Actions Column */
.ct-demo-col {}
.ct-demo-col .demo-box {
  background:rgba(255,255,255,.05); border:1px solid rgba(255,255,255,.12);
  border-radius:var(--radius); padding:24px; margin-bottom:16px;
}
.demo-box h4 { font-size:17px; font-weight:700; color:#fff; margin-bottom:8px }
.demo-box p { font-size:13px; color:rgba(255,255,255,.55); line-height:1.65; margin-bottom:18px }
.demo-btn {
  display:flex; align-items:center; justify-content:center; gap:8px; width:75%;
  padding:13px; border-radius:8px; font-weight:700; font-size:14px;
  transition:all var(--trans); text-align:center; margin-left:auto; margin-right:auto;
}
.demo-btn.primary {
  background:linear-gradient(135deg,var(--green),var(--green2));
  color:#fff;
}
.demo-btn.primary:hover { transform:translateY(-2px); box-shadow:0 6px 20px rgba(76,175,80,.4); color:#fff }
.demo-btn.wa-btn { background:var(--wa-green); color:#fff }
.demo-btn.wa-btn:hover { background:#1da851; transform:translateY(-2px); color:#fff }
.demo-btn.outline-btn {
  border:1.5px solid rgba(255,255,255,.25); color:#fff; margin-top:10px;
}
.demo-btn.outline-btn:hover { background:rgba(255,255,255,.08); border-color:#fff; color:#fff }
.ct-social { margin-top:16px }
.ct-social p { font-size:11px; text-transform:uppercase; letter-spacing:1.5px; color:rgba(255,255,255,.4); font-weight:700; margin-bottom:12px }
.ct-soc-links { display:flex; gap:20px; flex-wrap:wrap }
.ct-soc-links a {
  display:flex; align-items:center; justify-content:center;
  font-size:26px; color:rgba(255,255,255,.6);
  transition:color var(--trans);
}
.ct-soc-links a:hover { background:none; border-color:transparent; color:#fff }
.ct-soc-links a:hover { background:var(--green); border-color:var(--green); color:#fff }
/* Form feedback */
.form-success {
  grid-column:1/-1; padding:14px 18px; border-radius:8px;
  background:rgba(76,175,80,.15); border:1px solid rgba(76,175,80,.4);
  color:var(--green2); font-weight:600; font-size:14px;
  display:none; align-items:center; gap:8px;
}
.form-success.show { display:flex }
.form-error {
  grid-column:1/-1; padding:12px 18px; border-radius:8px;
  background:rgba(239,68,68,.1); border:1px solid rgba(239,68,68,.3);
  color:#f87171; font-size:13.5px; display:none;
}
.form-error.show { display:block }
.cf.error { border-color:#f87171 }

/* ============================================================
   NEWS & INSIGHTS (SS11)
   ============================================================ */
.news-g { display:grid; grid-template-columns:repeat(3,1fr); gap:26px }
.nc {
  border-radius:var(--radius); overflow:hidden;
  border:1px solid var(--border); transition:all .3s; background:#fff;
}
.nc:hover { box-shadow:var(--shadow-xl); transform:translateY(-5px); border-color:#d1fae5 }
.ni-img { height:158px; overflow:hidden; position:relative }
.ni-bg {
  height:100%; background-size:cover; background-position:center;
  transition:transform .45s; display:flex; align-items:center;
  justify-content:center; font-size:52px;
}
.nc:hover .ni-bg { transform:scale(1.06) }
.ni1{background:linear-gradient(135deg,#1a2838,#243450)}
.ni2{background:linear-gradient(135deg,#0d1828,#182038)}
.ni3{background:linear-gradient(135deg,#1a1038,#28184a)}
.ni-source {
  position:absolute; top:12px; left:12px;
  background:rgba(0,0,0,.6); color:#fff; font-size:11px;
  padding:4px 10px; border-radius:100px; backdrop-filter:blur(4px);
}
.nb { padding:24px }
.nm { display:flex; align-items:center; justify-content:space-between; margin-bottom:12px }
.nd { font-size:12px; color:var(--mid); display:flex; align-items:center; gap:5px }
.ncat {
  background:var(--navy); color:#fff; font-size:10.5px;
  font-weight:700; padding:4px 10px; border-radius:100px;
}
.nb h3 { font-size:16px; font-weight:700; color:var(--navy); margin-bottom:10px; line-height:1.4 }
.nb p { font-size:13.5px; color:var(--mid); line-height:1.72; margin-bottom:20px }
.btn-rd {
  display:inline-flex; align-items:center; gap:8px;
  background:var(--green); color:#fff; padding:10px 20px;
  border-radius:6px; font-weight:700; font-size:13px; transition:all var(--trans);
}
.btn-rd:hover { background:var(--green3); color:#fff }
/* News loading state */
.news-loading {
  grid-column:1/-1; display:flex; align-items:center;
  justify-content:center; gap:12px; padding:48px;
  color:var(--mid); font-size:15px;
}
.news-loading .spinner {
  width:24px; height:24px; border-radius:50%;
  border:3px solid var(--border); border-top-color:var(--green);
  animation:spin .8s linear infinite;
}
@keyframes spin { to { transform:rotate(360deg) } }

/* ============================================================
   FAQ (SS12)
   ============================================================ */
.faq-l { max-width:840px; margin:0 auto }
.fi {
  border:1px solid var(--border); border-radius:var(--radius);
  margin-bottom:12px; overflow:hidden; transition:border-color var(--trans);
}
.fi.op { border-color:#d1fae5; box-shadow:0 4px 16px rgba(76,175,80,.1) }
.fq {
  display:flex; align-items:center; justify-content:space-between;
  padding:20px 24px; cursor:pointer; font-size:15.5px;
  font-weight:600; color:var(--navy); transition:color var(--trans); gap:16px;
}
.fq:hover { color:var(--green) }
.fi-ico {
  width:30px; height:30px; border-radius:50%; border:1.5px solid var(--border);
  display:flex; align-items:center; justify-content:center;
  font-size:14px; flex-shrink:0; transition:all var(--trans); color:var(--mid);
}
.fi.op .fi-ico { background:var(--navy); border-color:var(--navy); color:#fff; transform:rotate(180deg) }
.fa { display:none; padding:0 24px 20px; font-size:14.5px; color:var(--mid); line-height:1.78 }
.fi.op .fa { display:block }

/* ============================================================
   CTA BANNER
   ============================================================ */
.cta-b {
  padding:88px 0; background:linear-gradient(135deg,var(--navy3) 0%,var(--navy) 60%,#0a2818 100%);
  text-align:center; position:relative; overflow:hidden;
}
.cta-b::before {
  content:''; position:absolute; inset:0;
  background:radial-gradient(ellipse 70% 80% at 50% 120%,rgba(76,175,80,.2),transparent);
}
.cta-b h2 {
  font-family:'Roboto Condensed',sans-serif;
  font-size:clamp(30px,4vw,52px); font-weight:800;
  color:#fff; margin-bottom:16px; position:relative;
}
.cta-b h2 span { color:var(--green2) }
.cta-b p {
  font-size:17px; color:rgba(255,255,255,.7);
  max-width:560px; margin:0 auto 36px; position:relative;
}
.cta-bns { display:flex; gap:14px; justify-content:center; flex-wrap:wrap; position:relative }
.cta-tr { display:flex; gap:28px; justify-content:center; margin-top:36px; flex-wrap:wrap; position:relative }
.ctr { display:flex; align-items:center; gap:8px; font-size:13.5px; color:rgba(255,255,255,.52) }
.ctr::before { content:'✓'; color:var(--green2); font-weight:700 }

/* ============================================================
   FOOTER
   ============================================================ */
footer { background:#070d1a; color:rgba(255,255,255,.55); padding:72px 0 0 }
.fg {
  display:grid; grid-template-columns:2fr 1fr 1fr 1fr 1fr;
  gap:48px; margin-bottom:52px;
}
.footer-logo { text-align:center }
.footer-logo img { height:72px; object-fit:contain; margin-bottom:18px; width:auto }
.fabt { font-size:13.5px; line-height:1.82; margin-bottom:24px; text-align:left }
.fsoc-w { display:flex; gap:10px; flex-wrap:nowrap; justify-content:flex-start; width:100% }
.fs {
  flex:1 1 0; min-width:0; aspect-ratio:1/1;
  border-radius:12px; background:rgba(255,255,255,.09);
  display:flex; align-items:center; justify-content:center;
  color:rgba(255,255,255,.75); font-size:clamp(28px,2vw,36px);
  transition:all var(--trans); border:1px solid rgba(255,255,255,.08);
}
.fs:hover { background:var(--green); color:#fff; transform:translateY(-4px); border-color:var(--green); box-shadow:0 6px 20px rgba(76,175,80,.35) }
.fcol h4 {
  font-size:11.5px; font-weight:700; text-transform:uppercase;
  letter-spacing:2px; color:#fff; margin-bottom:18px;
  padding-bottom:10px; border-bottom:1px solid rgba(255,255,255,.08);
}
.fcol a {
  display:block; font-size:13px; color:rgba(255,255,255,.48);
  padding:5px 0; transition:all var(--trans);
}
.fcol a:hover { color:var(--green2); padding-left:5px }
.contact-item {
  display:flex; align-items:flex-start; gap:10px; margin:8px 0;
}
.contact-item i { width:16px; color:#9fb3c8; flex-shrink:0; margin-top:2px }
.contact-item span { font-size:13px; line-height:1.6 }
.contact-item a { display:inline; padding:0; transition:color var(--trans) }
.contact-item a:hover { color:var(--green2) !important; padding:0 }
.fbot {
  border-top:1px solid rgba(255,255,255,.07); padding:22px 0;
  display:flex; justify-content:space-between; align-items:center;
  font-size:12.5px; flex-wrap:wrap; gap:12px;
}
.fbot a { color:rgba(255,255,255,.38) }
.fbot a:hover { color:var(--green2) }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media(max-width:1200px) {
  .ct-hub { grid-template-columns:1fr 1fr }
  .ct-demo-col { grid-column:1/-1; display:grid; grid-template-columns:1fr 1fr; gap:16px }
  .ct-demo-col .demo-box:last-of-type { grid-column:1/-1 }
  .mega { min-width:600px }
  .mega-wide { min-width:720px }
  .mg-4 { grid-template-columns:repeat(2,1fr) }
}
@media(max-width:1100px) {
  .sc-cols,.sic,.ai-in,.abt-in,.sol-g,.cs-g,.news-g {
    grid-template-columns:1fr 1fr;
  }
  .icard { min-width:50% }
  .fg { grid-template-columns:repeat(3,1fr) }
}
@media(max-width:900px) {
  .ct-hub { grid-template-columns:1fr }
  .ct-demo-col { display:block }
  .ct-demo-col .demo-box { margin-bottom:14px }
}
@media(max-width:768px) {
  /* hide stripe, contact row and desktop nav on mobile */
  .stripe, .hd-contact { display:none }
  nav#desktopNav { display:none }
  .hamburger { display:flex }
  .hd { height:64px }
  body { padding-top:64px; }

  .hero { height:520px }
  .htabs { display:none }
  .harr { right:16px }
  .hdots { bottom:20px }

  .sec { padding:64px 0 }
  .sh { margin-bottom:44px }

  .sc-cols,.sic,.ai-in,.abt-in,.sol-g,.cs-g,.news-g,.ct-hub {
    grid-template-columns:1fr;
  }
  .sc { padding:28px 0; border-right:none; border-bottom:1px solid var(--border) }
  .sc:last-child { border-bottom:none }
  .sc:nth-child(2) { padding:28px 0 }

  .icard { min-width:80% }
  .abt-st { grid-template-columns:1fr 1fr }
  .cform { grid-template-columns:1fr }

  .fg { grid-template-columns:1fr 1fr }
  .fbot { flex-direction:column; text-align:center }

  .float-wa { bottom:20px; right:16px; font-size:34px; width:auto; height:auto }
  .back-top { right:20px; bottom:82px }

  .tech-rw { gap:8px }
  .chip { padding:8px 12px; font-size:12.5px }
}
@media(max-width:480px) {
  .hd { height:60px }
  .logo-img { height:44px }
  body { padding-top:60px; }
  .htit { font-size:clamp(28px,9vw,42px) }
  .hdesc { font-size:15px }
  .hbtns { gap:10px }
  .btn-g,.btn-gh { padding:12px 22px; font-size:14px }
  .fg { grid-template-columns:1fr }
  .abt-st { grid-template-columns:1fr }
  .sc-num { font-size:56px }
  .news-g,.cs-g,.sol-g { grid-template-columns:1fr }
  .mag-cards { grid-template-columns:1fr }
  .ct-soc-links { gap:8px }
}

/* ============================================================
   INNER PAGE COMPONENTS
   (used by Company subpages: About, Team, Vision, Careers, etc.)
   ============================================================ */

/* ---- PAGE HERO (static banner — replaces carousel on inner pages) ---- */
.ph {
  background:var(--navy3); position:relative; overflow:hidden;
  padding:96px 0 80px;
}
.ph::before {
  content:''; position:absolute; inset:0;
  background:radial-gradient(ellipse 80% 60% at 60% 50%, rgba(76,175,80,.12), transparent);
  pointer-events:none;
}
.ph::after {
  content:''; position:absolute; bottom:0; left:0; right:0; height:1px;
  background:linear-gradient(90deg,transparent,rgba(76,175,80,.4),transparent);
}
.ph-bread {
  display:flex; align-items:center; gap:8px; margin-bottom:20px;
  font-size:12.5px; color:rgba(255,255,255,.4);
}
.ph-bread a { color:rgba(255,255,255,.4); transition:color var(--trans) }
.ph-bread a:hover { color:var(--green2) }
.ph-bread span { color:rgba(255,255,255,.25) }
.ph-bread .ph-cur { color:rgba(255,255,255,.7) }
.ph-badge {
  display:inline-flex; align-items:center; gap:8px;
  background:rgba(76,175,80,.16); border:1px solid rgba(76,175,80,.4);
  border-radius:100px; padding:6px 16px; font-size:11px;
  color:var(--green2); font-weight:700; letter-spacing:1px;
  text-transform:uppercase; margin-bottom:20px;
}
.ph-badge::before {
  content:''; width:6px; height:6px; border-radius:50%;
  background:var(--green2); animation:bl 1.5s infinite;
}
.ph h1 {
  font-family:'Roboto Condensed',sans-serif;
  font-size:clamp(36px,5.5vw,64px); font-weight:800;
  color:#fff; line-height:1.08; margin-bottom:20px; max-width:760px;
}
.ph h1 span { color:var(--green2) }
.ph p {
  font-size:17px; color:rgba(255,255,255,.72);
  max-width:580px; line-height:1.78; margin-bottom:32px;
}
.ph-btns { display:flex; gap:14px; flex-wrap:wrap }
.ph-dec {
  position:absolute; right:0; top:0; bottom:0; width:45%;
  display:flex; align-items:center; justify-content:center;
  pointer-events:none; overflow:hidden; opacity:.05; padding-right:70px;
}
.ph-dec-num {
  font-family:'Roboto Condensed',sans-serif;
  font-size:clamp(40px,5vw,80px); font-weight:800;
  color:#fff; line-height:1; white-space:normal; user-select:none; text-align:right;
}

/* ---- TWO-COL INTRO LAYOUT ---- */
.page-intro { display:grid; grid-template-columns:1fr 1fr; gap:64px; align-items:start }
.page-intro-l {}
.page-intro-r {}

/* ---- STAT CARDS (reusable on any page) ---- */
.stat-row { display:flex; flex-wrap:wrap; gap:32px; margin-top:32px }
.stat-item {}
.stat-num {
  font-family:'Roboto Condensed',sans-serif;
  font-size:44px; font-weight:800; color:var(--green); line-height:1;
}
.stat-label { font-size:13px; color:var(--mid); margin-top:4px }

/* ---- STAT GRID (2×2 used in service page intros) ---- */
.stat-grid { display:grid; grid-template-columns:1fr 1fr; gap:16px }
.stat-box {
  background:var(--off); border:1.5px solid var(--border); border-radius:var(--radius);
  padding:22px 20px; text-align:center;
}
.stat-box .stat-num { font-size:32px }
.stat-lbl { font-size:12px; color:var(--mid); margin-top:4px; line-height:1.4 }

/* ---- FEATURE CARD (light bg sections) ---- */
.feat-card {
  background:#fff; border:1.5px solid var(--border); border-radius:var(--radius);
  padding:28px 24px; transition:all .3s;
}
.feat-card:hover { box-shadow:var(--shadow-xl); border-color:#d1fae5; transform:translateY(-4px) }
.feat-card .fc-ico {
  width:50px; height:50px; border-radius:10px;
  background:linear-gradient(135deg,rgba(76,175,80,.12),rgba(125,196,66,.08));
  display:flex; align-items:center; justify-content:center;
  font-size:22px; color:var(--green); margin-bottom:16px;
}
.feat-card h3 { font-size:17px; font-weight:700; color:var(--navy); margin-bottom:10px }
.feat-card p { font-size:14px; color:var(--mid); line-height:1.75 }

/* ---- INFO CARD NUMBER (used in dark process sections) ---- */
.info-card-num {
  font-family:'Roboto Condensed',sans-serif; font-size:13px; font-weight:800;
  letter-spacing:.12em; color:var(--green2); text-transform:uppercase;
  margin-bottom:12px; opacity:.7;
}

/* ---- CARD GRID GENERIC ---- */
.card-grid-3 { display:grid; grid-template-columns:repeat(3,1fr); gap:24px }
.card-grid-4 { display:grid; grid-template-columns:repeat(4,1fr); gap:24px }
.card-grid-2 { display:grid; grid-template-columns:repeat(2,1fr); gap:24px }

/* ---- INFO / FEATURE CARD ---- */
.info-card {
  background:#fff; border:1.5px solid var(--border); border-radius:var(--radius);
  padding:32px 28px; transition:all .3s;
}
.info-card:hover { box-shadow:var(--shadow-xl); border-color:#d1fae5; transform:translateY(-4px) }
.info-card-ico {
  width:54px; height:54px; border-radius:12px;
  background:linear-gradient(135deg,rgba(76,175,80,.15),rgba(125,196,66,.1));
  display:flex; align-items:center; justify-content:center;
  font-size:24px; margin-bottom:18px;
}
.info-card h3 { font-size:18px; font-weight:700; color:var(--navy); margin-bottom:10px }
.info-card p { font-size:14px; color:var(--mid); line-height:1.75 }

/* Dark variant */
.info-card-dk {
  background:rgba(255,255,255,.05); border:1px solid rgba(255,255,255,.1);
  border-radius:var(--radius); padding:32px 28px; transition:all .3s;
}
.info-card-dk:hover { background:rgba(76,175,80,.1); border-color:rgba(76,175,80,.35); transform:translateY(-4px) }
.info-card-dk .info-card-ico { background:rgba(76,175,80,.15) }
.info-card-dk h3 { color:#fff }
.info-card-dk p { color:rgba(255,255,255,.6) }

/* ---- TEAM CARDS ---- */
.team-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:24px }
.team-card {
  border-radius:var(--radius); overflow:hidden;
  border:1.5px solid var(--border); background:#fff; transition:all .3s;
}
.team-card:hover { box-shadow:var(--shadow-xl); border-color:#d1fae5; transform:translateY(-5px) }
.team-avatar {
  width:100%; aspect-ratio:1; background:linear-gradient(135deg,#1a2a4a,#243560);
  display:flex; align-items:center; justify-content:center; position:relative; overflow:hidden;
}
.team-avatar-inner {
  font-size:64px; opacity:.6;
}
.team-avatar-badge {
  position:absolute; bottom:12px; left:50%; transform:translateX(-50%);
  background:rgba(76,175,80,.9); color:#fff; font-size:10px; font-weight:700;
  padding:4px 12px; border-radius:100px; letter-spacing:.5px; white-space:nowrap;
}
.team-body { padding:22px 20px }
.team-name { font-size:17px; font-weight:700; color:var(--navy); margin-bottom:4px }
.team-role { font-size:13px; color:var(--green); font-weight:600; margin-bottom:10px }
.team-bio { font-size:13px; color:var(--mid); line-height:1.68; margin-bottom:16px }
.team-links { display:flex; gap:8px }
.team-links a {
  width:32px; height:32px; border-radius:6px;
  background:var(--off); display:flex; align-items:center; justify-content:center;
  font-size:13px; color:var(--mid); transition:all var(--trans);
}
.team-links a:hover { background:var(--green); color:#fff }

/* ---- TIMELINE ---- */
.timeline { position:relative; margin-top:48px }
.timeline::before {
  content:''; position:absolute; left:50%; top:0; bottom:0;
  width:2px; background:linear-gradient(to bottom,var(--green),var(--green2));
  transform:translateX(-50%);
}
.tl-item {
  display:grid; grid-template-columns:1fr auto 1fr; gap:32px;
  align-items:start; margin-bottom:48px;
}
.tl-item:nth-child(even) .tl-content { grid-column:3; text-align:left }
.tl-item:nth-child(even) .tl-empty { grid-column:1 }
.tl-dot {
  width:48px; height:48px; border-radius:50%;
  background:linear-gradient(135deg,var(--green),var(--green2));
  display:flex; align-items:center; justify-content:center;
  font-size:18px; color:#fff; flex-shrink:0; z-index:1;
  box-shadow:0 0 0 6px rgba(76,175,80,.15);
}
.tl-content {
  background:#fff; border:1.5px solid var(--border); border-radius:var(--radius);
  padding:24px; transition:all .3s;
}
.tl-content:hover { box-shadow:var(--shadow); border-color:#d1fae5 }
.tl-year { font-size:11px; font-weight:700; color:var(--green); letter-spacing:2px; text-transform:uppercase; margin-bottom:8px }
.tl-content h3 { font-size:17px; font-weight:700; color:var(--navy); margin-bottom:8px }
.tl-content p { font-size:13.5px; color:var(--mid); line-height:1.7 }
.tl-empty {}

/* ---- VALUES CARDS ---- */
.val-card {
  border-radius:var(--radius); padding:32px 28px; position:relative; overflow:hidden;
  background:linear-gradient(135deg,#0a1628,#1a2a4a); border:1px solid rgba(76,175,80,.2);
  transition:all .3s;
}
.val-card:hover { border-color:rgba(76,175,80,.5); transform:translateY(-4px); box-shadow:0 12px 40px rgba(0,0,0,.35) }
.val-card::before {
  content:''; position:absolute; top:0; left:0; right:0; height:3px;
  background:linear-gradient(90deg,var(--green),var(--green2));
}
.val-num {
  font-family:'Roboto Condensed',sans-serif; font-size:56px; font-weight:800;
  color:rgba(76,175,80,.12); position:absolute; top:16px; right:20px; line-height:1;
}
.val-ico { font-size:30px; margin-bottom:16px }
.val-card h3 { font-size:19px; font-weight:700; color:#fff; margin-bottom:10px }
.val-card p { font-size:14px; color:rgba(255,255,255,.6); line-height:1.75 }

/* ---- JOB CARDS (Careers) ---- */
.job-card {
  border:1.5px solid var(--border); border-radius:var(--radius);
  padding:28px 32px; background:#fff; transition:all .3s;
  display:flex; align-items:center; justify-content:space-between; gap:24px;
  flex-wrap:wrap;
}
.job-card:hover { box-shadow:var(--shadow-xl); border-color:#d1fae5; transform:translateY(-3px) }
.job-info {}
.job-role { font-size:18px; font-weight:700; color:var(--navy); margin-bottom:6px }
.job-meta { display:flex; flex-wrap:wrap; gap:12px; margin-bottom:10px }
.job-tag {
  display:inline-flex; align-items:center; gap:6px;
  font-size:12px; color:var(--mid); background:var(--off);
  padding:4px 12px; border-radius:100px;
}
.job-tag i { font-size:11px; color:var(--green) }
.job-desc { font-size:13.5px; color:var(--mid); line-height:1.65; max-width:640px }
.job-apply { flex-shrink:0 }
.btn-apply {
  display:inline-flex; align-items:center; gap:8px;
  background:linear-gradient(135deg,var(--green),var(--green2));
  color:#fff; padding:11px 24px; border-radius:8px;
  font-weight:700; font-size:13.5px; transition:all var(--trans);
  white-space:nowrap;
}
.btn-apply:hover { transform:translateY(-2px); box-shadow:0 6px 20px rgba(76,175,80,.4); color:#fff }

/* ---- PERKS / BENEFITS ---- */
.perk-card {
  background:rgba(255,255,255,.05); border:1px solid rgba(255,255,255,.1);
  border-radius:var(--radius); padding:28px 24px; text-align:center; transition:all .3s;
}
.perk-card:hover { background:rgba(76,175,80,.12); border-color:rgba(76,175,80,.3); transform:translateY(-4px) }
.perk-ico { font-size:32px; margin-bottom:14px }
.perk-card h4 { font-size:16px; font-weight:700; color:#fff; margin-bottom:8px }
.perk-card p { font-size:13px; color:rgba(255,255,255,.58); line-height:1.65 }

/* ---- PRESS / NEWS ITEMS ---- */
.press-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:24px }
.press-card {
  border:1.5px solid var(--border); border-radius:var(--radius);
  background:#fff; overflow:hidden; transition:all .3s;
}
.press-card:hover { box-shadow:var(--shadow-xl); transform:translateY(-4px); border-color:#d1fae5 }
.press-img {
  height:180px; display:flex; align-items:center; justify-content:center;
  font-size:48px; position:relative;
}
.press-tag {
  position:absolute; top:12px; left:12px;
  background:var(--green); color:#fff; font-size:10.5px;
  font-weight:700; padding:4px 12px; border-radius:100px;
}
.press-body { padding:22px }
.press-date { font-size:12px; color:var(--mid); margin-bottom:8px }
/* press-card h3 — direct children (press.php) + .press-body wrapper */
.press-card h3,
.press-body h3 {
  font-family:'Roboto Condensed',sans-serif;
  font-size:20px; font-weight:700; color:var(--navy);
  margin-bottom:10px; line-height:1.3;
}
.press-body p { font-size:13.5px; color:var(--mid); line-height:1.7; margin-bottom:18px }
.btn-press {
  display:inline-flex; align-items:center; gap:6px;
  font-size:13px; font-weight:700; color:var(--green); transition:gap var(--trans);
}
.btn-press:hover { gap:10px }

/* ---- CERT / AWARD CARDS ---- */
.cert-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:20px }
.cert-card {
  border:1.5px solid var(--border); border-radius:var(--radius);
  padding:28px 20px; text-align:center; background:#fff;
  transition:all .3s;
}
.cert-card:hover { box-shadow:var(--shadow-lg); border-color:#d1fae5; transform:translateY(-4px) }
.cert-ico { font-size:40px; margin-bottom:14px }
.cert-card h4 { font-size:15px; font-weight:700; color:var(--navy); margin-bottom:6px }
.cert-card p { font-size:12.5px; color:var(--mid); line-height:1.6 }

/* ---- PARTNER CARDS ---- */
.partner-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:24px }
.partner-card {
  border:1.5px solid var(--border); border-radius:var(--radius);
  padding:32px 28px; background:#fff; transition:all .3s;
  display:flex; flex-direction:column; gap:16px;
}
.partner-card:hover { box-shadow:var(--shadow-xl); border-color:#d1fae5; transform:translateY(-4px) }
.partner-logo {
  width:56px; height:56px; border-radius:12px;
  background:linear-gradient(135deg,rgba(76,175,80,.12),rgba(125,196,66,.08));
  display:flex; align-items:center; justify-content:center; font-size:26px;
}
.partner-card h4 { font-size:17px; font-weight:700; color:var(--navy) }
.partner-card p { font-size:13.5px; color:var(--mid); line-height:1.72; flex:1 }
.partner-type {
  display:inline-flex; align-items:center; gap:6px;
  font-size:11px; font-weight:700; color:var(--green);
  text-transform:uppercase; letter-spacing:1px;
}

/* ---- CONTACT PAGE ---- */
.contact-page-grid { display:grid; grid-template-columns:1fr 1.4fr; gap:48px; align-items:start }
.cp-info {}
.cp-info h2 { font-size:clamp(22px,3vw,32px); font-weight:700; color:#fff; line-height:1.35; margin-bottom:20px }
.cp-method-list { display:flex; flex-direction:column; gap:12px; margin-top:24px }
.map-box {
  border-radius:var(--radius); overflow:hidden;
  border:1px solid rgba(255,255,255,.1); margin-top:24px;
  height:200px; background:rgba(255,255,255,.05);
  display:flex; align-items:center; justify-content:center;
  color:rgba(255,255,255,.3); font-size:14px; gap:10px;
}

/* ---- TWO-COL VISION LAYOUT ---- */
.vis-col { display:grid; grid-template-columns:1fr 1fr; gap:32px; align-items:stretch }
.vis-box {
  border-radius:var(--radius); padding:40px 36px; position:relative; overflow:hidden;
}
.vis-box-vision { background:linear-gradient(135deg,#0a1628,#1a2a4a); border:1px solid rgba(76,175,80,.25) }
.vis-box-mission { background:linear-gradient(135deg,#111827,#1f2937); border:1px solid rgba(125,196,66,.2) }
.vis-box::before {
  content:''; position:absolute; top:0; left:0; right:0; height:3px;
  background:linear-gradient(90deg,var(--green),var(--green2));
}
.vis-box-big {
  font-family:'Roboto Condensed',sans-serif;
  font-size:clamp(140px,18vw,220px); font-weight:800;
  position:absolute; top:-10px; right:-10px; line-height:1;
  opacity:.06; color:#fff; user-select:none; pointer-events:none;
}
.vis-box h2 { font-size:13px; font-weight:700; letter-spacing:2px; text-transform:uppercase; color:var(--green2); margin-bottom:16px }
.vis-box h3 { font-family:'Roboto Condensed',sans-serif; font-size:clamp(26px,3vw,36px); font-weight:700; color:#fff; line-height:1.2; margin-bottom:18px }
.vis-box p { font-size:15px; color:rgba(255,255,255,.65); line-height:1.8 }

/* ---- PROCESS STEPS ---- */
.process-steps { display:grid; grid-template-columns:repeat(4,1fr); gap:0; position:relative }
.process-steps::before {
  content:''; position:absolute; top:32px; left:12.5%; right:12.5%; height:2px;
  background:linear-gradient(90deg,var(--green),var(--green2)); z-index:0;
}
.ps-item { text-align:center; padding:0 16px; position:relative; z-index:1 }
.ps-num {
  width:64px; height:64px; border-radius:50%;
  background:linear-gradient(135deg,var(--green),var(--green2));
  color:#fff; font-family:'Roboto Condensed',sans-serif;
  font-size:22px; font-weight:800; display:flex;
  align-items:center; justify-content:center; margin:0 auto 18px; flex-shrink:0;
}
.ps-item h4 { font-size:15px; font-weight:700; color:var(--navy); margin-bottom:8px }
.ps-item p { font-size:13px; color:var(--mid); line-height:1.65 }

/* ---- RESPONSIVE INNER PAGES ---- */
@media(max-width:1100px) {
  .team-grid { grid-template-columns:repeat(2,1fr) }
  .card-grid-4 { grid-template-columns:repeat(2,1fr) }
  .cert-grid { grid-template-columns:repeat(2,1fr) }
  .process-steps { grid-template-columns:repeat(2,1fr) }
  .process-steps::before { display:none }
}
@media(max-width:900px) {
  .page-intro,.vis-col,.contact-page-grid { grid-template-columns:1fr }
  /* Single-column timeline: dot left, card right for ALL items */
  .timeline::before { left:24px; transform:none }
  .tl-item { grid-template-columns:48px 1fr; gap:16px }
  /* Even items: DOM order is empty→dot→content — dot lands in col1 naturally, content forced to col2 */
  .tl-item:nth-child(even) .tl-dot   { grid-column:1; grid-row:1 }
  .tl-item:nth-child(even) .tl-content { grid-column:2; grid-row:1; text-align:left }
  .tl-item:nth-child(even) .tl-empty { display:none }
  /* Odd items: DOM order is content→dot→empty — must explicitly reorder so dot is col1, content col2 */
  .tl-item:nth-child(odd) .tl-content { grid-column:2; grid-row:1; text-align:left }
  .tl-item:nth-child(odd) .tl-dot    { grid-column:1; grid-row:1 }
  .tl-item:nth-child(odd) .tl-empty  { display:none }
  .partner-grid,.press-grid { grid-template-columns:repeat(2,1fr) }
}
@media(max-width:768px) {
  .ph { padding:72px 0 56px }
  .ph h1 { font-size:clamp(30px,8vw,48px) }
  .card-grid-3,.card-grid-2 { grid-template-columns:1fr }
  .team-grid { grid-template-columns:1fr 1fr }
  .partner-grid,.press-grid { grid-template-columns:1fr }
  .cert-grid { grid-template-columns:repeat(2,1fr) }
  .job-card { flex-direction:column; align-items:flex-start }
  .stat-row { gap:24px }
}

/* =================== VISION PAGE =================== */
.vis-cols { display:grid; grid-template-columns:1fr 1fr; gap:32px; align-items:stretch }
.vis-vision, .vis-mission {
  border-radius:var(--radius); padding:44px 40px;
  position:relative; overflow:hidden;
}
.vis-vision::before, .vis-mission::before {
  content:''; position:absolute; top:0; left:0; right:0; height:3px;
  background:linear-gradient(90deg,var(--green),var(--green2));
}
.vis-vision { background:linear-gradient(135deg,#0a1628,#1a2a4a); border:1px solid rgba(76,175,80,.25) }
.vis-mission { background:linear-gradient(135deg,#111827,#1f2937); border:1px solid rgba(125,196,66,.2) }
.vis-icon, .val-ico { font-size:30px; margin-bottom:16px }
.vis-lbl { font-size:11px; font-weight:700; letter-spacing:2.5px; text-transform:uppercase; color:var(--green2); margin-bottom:14px }
.vis-vision h2, .vis-mission h2 {
  font-family:'Roboto Condensed',sans-serif;
  font-size:clamp(22px,2.5vw,30px); font-weight:800; color:#fff; line-height:1.25; margin-bottom:18px;
}
.vis-vision h2 span, .vis-mission h2 span { color:var(--green2) }
.vis-vision > p, .vis-mission > p { font-size:15px; color:rgba(255,255,255,.65); line-height:1.8; margin-bottom:14px }
.vis-list { list-style:none; padding:0; margin-top:24px; display:flex; flex-direction:column; gap:10px }
.vis-list li { display:flex; align-items:center; gap:10px; font-size:14px; color:rgba(255,255,255,.72) }
.vis-list li i { color:var(--green2); flex-shrink:0 }

/* ---- process steps linear (5-step variant) ---- */
.process-steps.linear { grid-template-columns:1fr; gap:0 }
.process-steps.linear::before { display:none }
.ps-item { display:grid; grid-template-columns:64px 1fr; gap:24px; align-items:start; text-align:left; padding:0 0 32px }
.ps-item:last-child { padding-bottom:0 }
.ps-item h3 { font-size:17px; font-weight:700; color:#fff; margin-bottom:8px }
.ps-item p { font-size:14px; color:rgba(255,255,255,.6); line-height:1.75 }
.ps-item h4 { font-size:17px; font-weight:700; color:var(--navy); margin-bottom:8px }

/* =================== TEAM PAGE =================== */
.team-info { padding:0 }
.team-info h3 { font-size:18px; font-weight:700; color:var(--navy); margin-bottom:4px }
.team-socials { display:flex; gap:10px; margin-top:14px }
.team-socials a { width:32px; height:32px; border-radius:50%; background:rgba(76,175,80,.1); border:1px solid rgba(76,175,80,.25); display:flex; align-items:center; justify-content:center; color:var(--green); font-size:13px; transition:background var(--trans),color var(--trans) }
.team-socials a:hover { background:var(--green); color:#fff }

/* =================== CAREERS PAGE =================== */
.perk-card h3 { font-size:16px; font-weight:700; color:#fff; margin-bottom:8px }
.job-list { display:flex; flex-direction:column; gap:20px }
.job-header { display:flex; justify-content:space-between; align-items:flex-start; gap:16px; margin-bottom:12px }
.job-loc { font-size:13px; color:var(--mid) }
.job-type { font-size:11px; font-weight:700; padding:3px 10px; border-radius:30px; text-transform:uppercase; letter-spacing:.05em }
.job-type.full { background:#d1fae5; color:#065f46 }
.job-type.part { background:#fef3c7; color:#92400e }
.job-type.remote { background:#dbeafe; color:#1e40af }
.job-exp { font-size:12px; color:var(--mid); background:var(--off); padding:3px 10px; border-radius:20px }
.job-tags { display:flex; flex-wrap:wrap; gap:8px; margin-top:14px }
.job-tags span { font-size:12px; background:rgba(76,175,80,.08); border:1px solid rgba(76,175,80,.2); color:var(--green); padding:3px 10px; border-radius:20px }

/* =================== PRESS PAGE =================== */
.press-cat { font-size:11px; font-weight:700; color:var(--green); letter-spacing:1.5px; text-transform:uppercase; margin-bottom:10px }
.press-read { font-size:13px; color:var(--green); font-weight:600; display:inline-flex; align-items:center; gap:6px; text-decoration:none; margin-top:14px; transition:gap var(--trans) }
.press-read:hover { gap:10px }
.media-mentions { display:grid; grid-template-columns:repeat(2,1fr); gap:24px }
.media-item { background:#fff; border-radius:var(--radius); padding:28px; border:1px solid var(--border); transition:box-shadow var(--trans),transform var(--trans) }
.media-item:hover { box-shadow:var(--shadow); transform:translateY(-3px) }
.media-logo { font-size:15px; font-weight:700; color:var(--navy); margin-bottom:12px }
.media-item p { font-size:13.5px; color:var(--mid); line-height:1.7; font-style:italic }

/* =================== CONTACT PAGE =================== */
.contact-page-grid { display:grid; grid-template-columns:1fr 1.5fr 1fr; gap:36px; align-items:start }
.cp-info { padding:36px; background:linear-gradient(135deg,#0a1628,#1a2a4a); border-radius:var(--radius); border:1px solid rgba(76,175,80,.2) }
.cp-info .st { margin-bottom:8px }
.cp-info h2 { font-size:clamp(20px,2.5vw,28px); font-weight:800; color:#fff; line-height:1.3; margin-bottom:16px; font-family:'Roboto Condensed',sans-serif }
.cp-detail { display:flex; gap:14px; align-items:flex-start; margin-bottom:20px }
.cp-detail-ico { font-size:20px; flex-shrink:0; margin-top:2px }
.cp-detail-lbl { font-size:11px; font-weight:700; color:rgba(255,255,255,.4); text-transform:uppercase; letter-spacing:.1em; margin-bottom:4px }
.cp-detail-val { font-size:13.5px; color:rgba(255,255,255,.75); line-height:1.6 }
.cp-detail-val a { color:var(--green2); text-decoration:none }
.cp-detail-val a:hover { text-decoration:underline }
.cp-social { display:flex; gap:10px; margin-top:24px }
.cp-social a { width:36px; height:36px; border-radius:50%; background:rgba(76,175,80,.12); border:1px solid rgba(76,175,80,.25); display:flex; align-items:center; justify-content:center; color:var(--green2); font-size:14px; transition:background var(--trans) }
.cp-social a:hover { background:var(--green); color:#fff }
.cp-form { background:#fff; border-radius:var(--radius); padding:36px; box-shadow:var(--shadow-xl) }
.form-head { margin-bottom:28px }
.form-head h3 { font-size:22px; font-weight:800; color:var(--navy); margin-bottom:6px }
.form-head p { font-size:13.5px; color:var(--mid) }
.cform-row { display:grid; grid-template-columns:1fr 1fr; gap:16px }
.cp-demo { background:linear-gradient(135deg,#0a1628,#1a2a4a); border-radius:var(--radius); padding:32px; border:1px solid rgba(76,175,80,.2) }
.demo-head { text-align:center; margin-bottom:24px }
.demo-ico { font-size:36px; margin-bottom:10px }
.demo-head h3 { font-size:20px; font-weight:800; color:#fff; margin-bottom:8px }
.demo-head p { font-size:13px; color:rgba(255,255,255,.55); line-height:1.7 }
.demo-features { display:flex; flex-direction:column; gap:8px; margin-bottom:24px }
.demo-feat { font-size:13px; color:rgba(255,255,255,.7); display:flex; align-items:center; gap:10px }
.demo-feat i { color:var(--green2); flex-shrink:0 }
.demo-cta { display:block; text-align:center; width:100%; padding:14px }
.demo-divider { text-align:center; color:rgba(255,255,255,.3); font-size:12px; margin:16px 0 }
.demo-direct { display:grid; grid-template-columns:1fr 1fr; gap:12px; margin-bottom:20px }
.demo-link-wa,.demo-link-call { display:flex; align-items:center; justify-content:center; gap:8px; padding:11px; border-radius:8px; font-size:13px; font-weight:600; text-decoration:none; transition:opacity var(--trans) }
.demo-link-wa:hover,.demo-link-call:hover { opacity:.85 }
.demo-link-wa { background:#25d366; color:#fff }
.demo-link-call { background:rgba(255,255,255,.08); color:#fff; border:1px solid rgba(255,255,255,.15) }
.demo-trust { display:flex; flex-direction:column; gap:6px }
.demo-trust div { font-size:12px; color:rgba(255,255,255,.4); display:flex; align-items:center; gap:8px }
.map-wrap { border-radius:var(--radius); overflow:hidden; box-shadow:var(--shadow) }

/* ---- responsive additions ---- */
@media(max-width:1100px) {
  .contact-page-grid { grid-template-columns:1fr 1.4fr }
}
@media(max-width:900px) {
  .vis-cols,.media-mentions { grid-template-columns:1fr }
  .contact-page-grid { grid-template-columns:1fr }
  .cform-row { grid-template-columns:1fr }
}
@media(max-width:768px) {
  .process-steps { grid-template-columns:1fr }
  .process-steps::before { display:none }
  .ps-item { grid-template-columns:48px 1fr }
  .cert-grid { grid-template-columns:repeat(2,1fr) }
  .media-mentions { grid-template-columns:1fr }
}

/* ============================================================
   TYPOGRAPHY STANDARDISATION PATCH
   Ensures every card h3 and body text is consistent regardless
   of which section variant (light/dark) it appears in.
   ============================================================ */

/* Card headings — all variants */
.info-card h3,
.info-card-dk h3,
.feat-card h3,
.solc h3,
.val-card h3,
.perk-card h3,
.perk-card h4 {
  font-family: 'Roboto Condensed', sans-serif;
  font-size: 19px;
  font-weight: 700;
  line-height: 1.28;
  margin-bottom: 10px;
}

/* Card body text — consistent 14.5px/1.75 everywhere */
.info-card p,
.info-card-dk p,
.feat-card p,
.solc > p,
.val-card p,
.perk-card p {
  font-size: 14.5px;
  line-height: 1.75;
}

/* Section sub-headline (.sub) global size lock */
.sub { font-size: 16px; }

/* Section title label (.st) — always 11px uppercase */
.st {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 3px;
  text-transform: uppercase;
}

/* CTA banner headline — Roboto Condensed enforced */
.cta-b h2 {
  font-family: 'Roboto Condensed', sans-serif;
  font-weight: 800;
}

/* Page hero sub-text consistent */
.ph p {
  font-size: 17px;
  line-height: 1.78;
  color: rgba(255,255,255,.72);
}

/* Stat numbers — Roboto Condensed enforced */
.stat-num,
.sc-num,
.ast-n {
  font-family: 'Roboto Condensed', sans-serif;
}

/* Press page — card meta elements */
.press-card .press-cat {
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 1.5px;
  color: var(--green);
  margin-bottom: 10px;
  display: block;
}
.press-card .press-date {
  font-size: 12.5px;
  color: var(--mid);
  margin-bottom: 10px;
  display: flex;
  align-items: center;
  gap: 6px;
}
.press-card p {
  font-size: 14px;
  color: var(--mid);
  line-height: 1.75;
  margin-bottom: 18px;
}

/* News & Insights card headline size */
.nb h3 {
  font-family: 'Roboto Condensed', sans-serif;
  font-size: 17px;
  font-weight: 700;
  line-height: 1.35;
}

/* Navbar items — Inter 13.5px standardised */
.ni > a, .ni > span {
  font-family: 'Inter', sans-serif;
  font-size: 13.5px;
}

/* Footer column heading standardisation */
.fcol h4 {
  font-family: 'Roboto Condensed', sans-serif;
  font-size: 13px;
  letter-spacing: 2px;
}

/* SEO Geo coverage block — hidden from display, present in DOM for crawlers */
.seo-geo {
  position:absolute;
  width:1px; height:1px;
  padding:0; margin:-1px;
  overflow:hidden;
  clip:rect(0,0,0,0);
  white-space:nowrap;
  border:0;
}

/* Footer social icon wrapper spacing */
/* Mobile responsive — social icons stay in one line */
@media(max-width:480px) {
  .fsoc-w { gap:8px }
  .fs { font-size:16px }
}

/* ============================================================
   MOBILE RESPONSIVENESS — COMPREHENSIVE PATCH
   ============================================================ */

/* --- Prevent horizontal scroll on all screens --- */
html, body { max-width:100%; overflow-x:hidden }
* { box-sizing:border-box }

/* --- Wrapper padding tighter on very small screens --- */
@media(max-width:360px) {
  .w { padding:0 14px }
}

/* --- Hero section mobile --- */
@media(max-width:768px) {
  .hero { height:auto; min-height:480px }
  .htit { font-size:clamp(26px,8vw,40px); line-height:1.18 }
  .hdesc { font-size:14.5px; line-height:1.7 }
  .hbtns { flex-direction:column; align-items:flex-start; gap:10px }
  .hbtns .btn-g, .hbtns .btn-gh { width:100%; text-align:center; justify-content:center }
  .hs { padding:60px 0 40px }
}

/* --- Stats row on homepage --- */
@media(max-width:768px) {
  .sc-cols { grid-template-columns:repeat(2,1fr) }
  .sc { padding:20px 12px }
  .sc-num { font-size:clamp(36px,10vw,54px) }
  .sc-lbl { font-size:12px }
}
@media(max-width:400px) {
  .sc-cols { grid-template-columns:1fr 1fr }
}

/* --- Page intro (service/solution inner pages) --- */
@media(max-width:768px) {
  .page-intro { grid-template-columns:1fr; gap:32px }
  .stat-row { flex-wrap:wrap; gap:16px }
  .stat-item { flex:1 1 calc(50% - 8px); min-width:0 }
  .stat-num { font-size:clamp(32px,9vw,48px) }
}

/* --- Inner page cards --- */
@media(max-width:768px) {
  .card-grid-3 { grid-template-columns:1fr }
  .card-grid-2 { grid-template-columns:1fr }
  .info-card, .info-card-dk { padding:28px 22px }
}
@media(max-width:600px) {
  .press-grid { grid-template-columns:1fr }
  .cert-grid { grid-template-columns:repeat(2,1fr) }
}

/* --- CTA banner section --- */
@media(max-width:768px) {
  .cta-b { padding:56px 0 }
  .cta-b h2 { font-size:clamp(24px,7vw,36px) }
  .cta-bns { flex-direction:column; align-items:center; gap:12px }
  .cta-bns .btn-g, .cta-bns .btn-gh,
  .cta-bns a { width:100%; max-width:320px; text-align:center; justify-content:center }
}

/* --- Industry carousel section --- */
@media(max-width:768px) {
  .ind-w { overflow-x:auto; -webkit-overflow-scrolling:touch }
  .icard { min-width:75vw; height:195px }
}

/* --- Service icon cards grid --- */
@media(max-width:768px) {
  .sic { grid-template-columns:repeat(2,1fr) }
  .sicard { padding:20px 16px }
}
@media(max-width:400px) {
  .sic { grid-template-columns:1fr }
}

/* --- Section headings on small screens --- */
@media(max-width:480px) {
  .stt { font-size:clamp(22px,7vw,30px) }
  .sub { font-size:14px }
  .sec { padding:52px 0 }
  .sh { margin-bottom:36px }
}

/* --- News cards --- */
@media(max-width:768px) {
  .news-g { grid-template-columns:1fr }
  .nc { max-width:100% }
}

/* --- Footer columns --- */
@media(max-width:768px) {
  .fg { grid-template-columns:1fr 1fr }
  .fcol:first-child { grid-column:1 / -1 }
}
@media(max-width:480px) {
  .fg { grid-template-columns:1fr }
  .fcol:first-child { grid-column:auto }
  .fbot { flex-direction:column; gap:8px; text-align:center }
}

/* --- Contact form --- */
@media(max-width:768px) {
  .ct-hub { grid-template-columns:1fr }
  .ct-info { padding:28px 20px }
  .cform { padding:28px 20px }
}

/* --- Page hero (inner pages) --- */
@media(max-width:480px) {
  .ph { padding:56px 0 44px }
  .ph h1 { font-size:clamp(26px,8.5vw,40px) }
  .ph p { font-size:14px }
  .ph-btns { flex-direction:column; gap:10px }
  .ph-btns a { width:100%; text-align:center; justify-content:center }
}

/* --- Vision page --- */
@media(max-width:768px) {
  .vis-cols { grid-template-columns:1fr }
}

/* --- Tech chip row --- */
@media(max-width:480px) {
  .tech-rw { flex-wrap:wrap; gap:6px }
  .chip { font-size:12px; padding:6px 10px }
}

/* --- Carousel dots & arrows --- */
@media(max-width:480px) {
  .harr { display:none }
  .hdots { bottom:12px }
}

/* --- WhatsApp float button --- */
@media(max-width:480px) {
  .float-wa { font-size:32px; width:auto; height:auto; bottom:16px; right:12px }
  .back-top { right:16px; bottom:74px }
}

/* ============================================================
   ABOUT PAGE — TIMELINE & TEAM MOBILE FIXES
   ============================================================ */

/* Timeline: sizing refinements (grid placement handled in the 900px block above) */
@media(max-width:900px) {
  .tl-item { margin-bottom:28px }
  .tl-dot { width:40px; height:40px; font-size:15px; align-self:start }
  .tl-content { padding:18px 16px }
  .tl-content h3 { font-size:15px }
  .tl-content p { font-size:13px }
}
@media(max-width:480px) {
  .timeline::before { left:18px }
  .tl-item { grid-template-columns:36px 1fr; gap:10px; margin-bottom:20px }
  .tl-dot { width:36px; height:36px; font-size:13px }
  .tl-content { padding:14px 13px }
  .tl-year { font-size:10px; letter-spacing:1px }
  .tl-content h3 { font-size:14.5px; margin-bottom:6px }
  .tl-content p { font-size:12.5px; line-height:1.65 }
}

/* Team grid: 2-col at tablet, 1-col at phone */
@media(max-width:900px) {
  .team-grid { grid-template-columns:repeat(2,1fr); gap:20px }
}
@media(max-width:540px) {
  .team-grid { grid-template-columns:1fr }
  .team-avatar { aspect-ratio:16/9 }
  .team-avatar-inner { font-size:80px }
  .team-body { padding:18px 16px }
  .team-name { font-size:16px }
  .team-bio { font-size:12.5px }
}

/* About page stats row */
@media(max-width:600px) {
  .abt-st { grid-template-columns:1fr 1fr }
}
@media(max-width:360px) {
  .abt-st { grid-template-columns:1fr }
}

/* ============================================================
   INNER SERVICE / SOLUTION PAGES — MOBILE AUDIT FIXES
   ============================================================ */

/* Page intro stat grid — 2 items per row on phone */
@media(max-width:540px) {
  .stat-row { gap:12px }
  .stat-item { flex:1 1 calc(50% - 6px); text-align:center }
  .stat-num { font-size:clamp(28px,8vw,40px) }
  .stat-label { font-size:11.5px }
}

/* Process steps on service pages */
@media(max-width:540px) {
  .process-steps { grid-template-columns:1fr; gap:16px }
  .ps-item { gap:14px; padding-bottom:20px }
  .ps-num, .ps-ico { width:52px; height:52px; font-size:18px }
}

/* Info cards — comfortable padding on phones */
@media(max-width:400px) {
  .info-card, .info-card-dk { padding:22px 18px }
  .info-card-ico { width:48px; height:48px; font-size:22px }
  .info-card h3, .info-card-dk h3 { font-size:16px }
}

/* CTA secondary buttons row — stack on narrow */
@media(max-width:400px) {
  .cta-tr { flex-direction:column; align-items:center }
  .cta-tr a { width:100%; max-width:280px; text-align:center; justify-content:center }
}

/* Solc (solutions card) on inner pages */
@media(max-width:768px) {
  .sol-g { grid-template-columns:1fr }
}

/* ============================================================
   GENERAL OVERFLOW & TEXT WRAP FIXES
   ============================================================ */
@media(max-width:480px) {
  /* Prevent long email/URLs from overflowing */
  a, p, h1, h2, h3, h4, li { word-break:break-word; overflow-wrap:break-word }
  /* Tighter section wrapper on very narrow */
  .w { padding:0 16px }
  /* Press & media page hero badge */
  .ph-badge { font-size:10px; padding:5px 14px }
  /* Section label */
  .st { font-size:10px; letter-spacing:2px }
}

/* ============================================================
   MOBILE / TABLET COMPREHENSIVE UPDATE — June 2026
   Ensures all latest content displays correctly on all devices
   ============================================================ */

/* --- Hide desktop-only elements on mobile --- */
@media(max-width:768px) {
  .stripe { display:none !important }
  .hd-contact { display:none !important }
  .ph-dec { display:none }
}

/* --- iPad / Tablet (768px–1024px) --- */
@media(min-width:769px) and (max-width:1024px) {
  .hd { height:64px }
  body { padding-top:64px }
  .hd-contact { display:flex; gap:5px }
  .hd-contact a { font-size:9px; padding:3px 9px }
  .fg { grid-template-columns:repeat(3,1fr) }
  .fcol:first-child { grid-column:1 / -1 }
  .sc-cols { grid-template-columns:repeat(2,1fr) }
  .sic { grid-template-columns:repeat(2,1fr) }
  .ai-in,.abt-in,.sol-g,.cs-g { grid-template-columns:1fr 1fr }
  .news-g { grid-template-columns:1fr 1fr }
  .ph-dec { width:40%; opacity:.08 }
  .ph-dec-num { font-size:clamp(100px,12vw,180px) }
  .mega { min-width:500px }
}

/* --- Mobile header fixed bar --- */
@media(max-width:768px) {
  header { left:0; right:0; width:100% }
  .hd { padding:0 16px }
  .logo-img { height:40px }
}

/* --- Footer on mobile --- */
@media(max-width:768px) {
  .fabt { font-size:13px; line-height:1.7 }
  .ct-soc-links { gap:18px; margin-top:12px }
  .ct-soc-links a { font-size:22px }
  .fbot { font-size:11px; gap:10px }
  .fbot div:last-child { display:flex; flex-wrap:wrap; justify-content:center; gap:8px }
}

/* --- Mobile drawer updated styles --- */
@media(max-width:768px) {
  .mob-drawer { width:300px; max-width:85vw }
  .mob-sub a { font-size:13.5px; padding:10px 24px }
  .mob-cta { font-size:14px; padding:14px 20px; margin:12px 16px }
  .mob-cta-contacts { padding:0 16px 16px }
  .mob-cta-contacts a { font-size:12.5px; padding:9px 14px }
}

/* --- Inner page hero on mobile --- */
@media(max-width:768px) {
  .ph { padding:60px 0 44px }
  .ph h1 { font-size:clamp(24px,8vw,38px); line-height:1.2 }
  .ph-btns { flex-direction:column; gap:10px }
  .ph-btns a { width:100%; text-align:center; justify-content:center }
  .ph-dec { display:none }
}

/* --- Blog & Insights page mobile --- */
@media(max-width:768px) {
  .blog-feature { flex-direction:column !important }
  .blog-feature-img { width:100% !important; height:220px }
  .blog-feature-body { padding:20px 0 0 }
  .blog-stat-row { flex-wrap:wrap; gap:12px }
  .bsr-item { flex:1 1 40% }
  .live-feed-bar { flex-wrap:wrap; gap:8px }
}

/* --- EAM/IFMS solution page mobile --- */
@media(max-width:768px) {
  .eam-grid, .ifms-grid { grid-template-columns:1fr !important }
  .impl-steps { grid-template-columns:1fr !important }
}

/* --- Contact page mobile --- */
@media(max-width:768px) {
  .ct-info { padding:24px 16px }
  .ct-info-item { gap:12px }
}

/* --- Breadcrumb on mobile --- */
@media(max-width:480px) {
  .bc { font-size:11px; padding:8px 0 }
}

/* --- Side CTA strip — hide fully on all mobile/tablet --- */
@media(max-width:1024px) {
  .stripe { display:none !important }
}
