:root{
  --brand:#233B53;
  --brand2:#16273A;
  --accent:#2E6FA3;

  --bg:#F5F7FB;
  --surface:#FFFFFF;

  --text:#0B1220;
  --muted:#5B6678;

  --border: rgba(15, 23, 42, 0.10);
  --border2: rgba(15, 23, 42, 0.06);

  --shadow: 0 22px 60px rgba(15,23,42,.12);
  --shadow2: 0 10px 28px rgba(15,23,42,.10);
}

*{box-sizing:border-box}
html,body{
  margin:0;padding:0;
  font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
  color:var(--text);
  background:var(--bg)
}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.container{width:min(1160px,92%);margin:0 auto}
.reveal{opacity:0;transform:translateY(14px);transition:opacity .55s ease, transform .55s ease}
.reveal.show{opacity:1;transform:translateY(0)}
.wFull{width:100%}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  padding:10px 16px;border-radius:14px;border:1px solid rgba(15,23,42,.12);
  background:#fff;color:var(--brand);font-weight:900;
  box-shadow:0 8px 20px rgba(15,23,42,.08);
  transition:transform .15s ease, box-shadow .15s ease, background .15s ease, border-color .15s ease;
}
.btn:hover{transform:translateY(-1px);box-shadow:0 14px 30px rgba(15,23,42,.12)}
.btn:active{transform:translateY(0);box-shadow:0 8px 20px rgba(15,23,42,.08)}
.btn.primary{
  border:none;background:linear-gradient(180deg, #233B53 0%, #16273A 100%);
  color:#fff;
}
/* ghost button for LIGHT background */
.btn.ghost{
  background:transparent;
  border:1px solid rgba(35,59,83,.22);
  color:var(--brand);
  box-shadow:none
}
.btn.ghost:hover{background:rgba(35,59,83,.06)}

/* ---------- Topbar ---------- */
.topbar{
  background:linear-gradient(180deg, var(--brand2) 0%, #0f1d2e 100%);
  color:#fff;
}
.topbarInner{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 0}
.topbarLeft{display:flex;flex-wrap:wrap;gap:10px;align-items:center}
.topPill{
  display:inline-flex;gap:8px;align-items:center;
  padding:6px 10px;border-radius:999px;
  border:1px solid rgba(255,255,255,.18);
  background:rgba(255,255,255,.08);
  font-weight:800;font-size:12px
}
.topPill a{color:#fff;text-decoration:underline}

/* ---------- Navbar ---------- */
.navbar{
  position:sticky;top:0;z-index:50;
  background:rgba(255,255,255,.92);
  backdrop-filter: blur(10px);
  border-bottom:1px solid rgba(15,23,42,.06);
  transition: background .22s ease, border-color .22s ease, box-shadow .22s ease;
}
.navbar.scrolled{
  background:rgba(255,255,255,.96);
  border-bottom:1px solid rgba(15,23,42,.08);
  box-shadow:0 12px 30px rgba(15,23,42,.06);
}
.navInner{
  display:flex;align-items:center;justify-content:space-between;gap:18px;
  padding:10px 0;
}
.brand{display:flex;align-items:center}
.brand img{height:58px;width:auto}

.navlinks{
  display:flex;align-items:center;gap:10px;
  font-weight:1000;letter-spacing:.08em;text-transform:uppercase;
  font-size:13px;color:rgba(11,18,32,.80);
}
.navlinks > a{
  padding:10px 12px;border-radius:12px;
  transition: background .15s ease, color .15s ease;
}
.navlinks > a:hover{background:rgba(35,59,83,.08)}
.navlinks > a.active{background:rgba(35,59,83,.10);color:var(--brand)}

.cta{display:flex;align-items:center;gap:10px}
.cta .btn{box-shadow:none}
.hamburger{
  display:none;border:1px solid rgba(15,23,42,.12);
  padding:10px 12px;border-radius:12px;background:#fff;font-weight:1000
}

/* ---------- Dropdown (with badges + active) ---------- */
.dropdown{position:relative}
.dropBtn{
  cursor:pointer;
  display:inline-flex;align-items:center;gap:8px;
  padding:10px 12px;border-radius:12px;
  border:none;background:transparent;
  font:inherit;color:inherit;
  transition:background .15s ease;
}
.dropBtn:hover{background:rgba(35,59,83,.08)}
.dropBtn .chev{opacity:.7;font-size:12px}

.dropMenu{
  position:absolute;left:0;top:calc(100% + 10px);
  min-width:290px;
  background:#fff;border:1px solid rgba(15,23,42,.10);
  border-radius:16px;
  box-shadow:0 22px 60px rgba(15,23,42,.14);
  padding:10px;
  display:none;
}
.dropdown.open .dropMenu{display:block;animation:ddIn .14s ease}
@keyframes ddIn{from{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}

.dropMenu a{
  display:flex;align-items:center;gap:10px;
  padding:12px 12px;
  border-radius:12px;
  font-weight:950;
  letter-spacing:0;
  text-transform:none;
  color:rgba(11,18,32,.88);
  transition:background .12s ease, transform .12s ease, border-color .12s ease;
  border:1px solid transparent;
}
.ddBadge{
  width:34px;height:34px;border-radius:14px;
  display:flex;align-items:center;justify-content:center;
  background:rgba(46,111,163,.12);
  color:var(--accent);
  font-weight:1100;
  font-size:12px;
  flex:0 0 auto;
}
.ddText{display:flex;flex-direction:column;gap:2px;min-width:0}
.ddTitle{font-weight:1100;line-height:1.1}
.ddSub{
  font-size:12px;
  color:rgba(11,18,32,.60);
  font-weight:800;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.dropMenu a:hover{
  background:rgba(35,59,83,.08);
  transform:translateX(2px);
}
.dropMenu a.is-active{
  background:rgba(46,111,163,.10);
  border-color:rgba(46,111,163,.22);
}
.dropMenu a.is-active .ddBadge{background:rgba(46,111,163,.18)}
.dropMenu a.is-active .ddTitle{color:var(--brand)}
.dropMenu a.is-active .ddSub{color:rgba(11,18,32,.68)}

@media (hover:hover){
  .dropdown:hover .dropMenu{display:block}
}

/* ---------- Mobile menu ---------- */
.mobilemenu{display:none;padding:10px 0 16px 0}
.mobilemenu.show{display:block}
.mLink{
  display:block;padding:12px 12px;border-radius:14px;
  border:1px solid rgba(15,23,42,.10);
  background:#fff;margin:10px 0;
  font-weight:950
}
.mMeta{display:flex;flex-direction:column;gap:8px;margin-top:10px}
.mMeta a{text-decoration:underline;color:rgba(11,18,32,.8)}
.mDropBtn{
  width:100%;
  display:flex;align-items:center;justify-content:space-between;
  padding:12px 12px;border-radius:14px;
  border:1px solid rgba(15,23,42,.10);
  background:#fff;margin:10px 0;
  font-weight:950
}
.mDrop{display:none;margin-top:8px}
.mDrop.show{display:block}
.mDrop a{
  display:block;
  padding:10px 12px;border-radius:12px;
  background:rgba(255,255,255,.85);
  border:1px solid rgba(15,23,42,.08);
  margin:8px 0;
  font-weight:900
}

/* ---------- HERO (FIXED: image will stay on right on desktop) ---------- */
.hero2{position:relative;padding:44px 0 26px 0}
.heroBg{
  position:absolute;inset:0;
  background:linear-gradient(180deg, rgba(35,59,83,.10) 0%, rgba(35,59,83,0) 70%);
  pointer-events:none;
}
.heroGrid{
  display:grid;
  grid-template-columns: 1.08fr .92fr;   /* left text, right image */
  gap:26px;
  align-items:center;
  position:relative
}
.kicker2{
  display:inline-flex;align-items:center;gap:10px;
  padding:8px 12px;border-radius:999px;
  border:1px solid rgba(15,23,42,.10);
  background:rgba(255,255,255,.75);
  font-weight:950;color:rgba(11,18,32,.75)
}
.heroLeft h1{font-size:44px;line-height:1.08;margin:14px 0 12px 0;letter-spacing:-.02em}
.lead2{color:rgba(11,18,32,.72);font-weight:700;line-height:1.7;margin:0 0 14px 0}
.heroBtns{display:flex;gap:12px;flex-wrap:wrap;margin:14px 0 10px 0}

.heroMini{margin-top:14px;display:grid;gap:10px}
.miniCard{
  display:flex;gap:12px;align-items:flex-start;
  background:rgba(255,255,255,.85);
  border:1px solid rgba(15,23,42,.10);
  border-radius:18px;padding:12px 14px
}
.miniIcon{
  width:28px;height:28px;border-radius:10px;
  display:flex;align-items:center;justify-content:center;
  background:rgba(46,111,163,.12);color:var(--accent);font-weight:1100
}
.miniTitle{font-weight:1100}
.miniText{color:rgba(11,18,32,.68);font-weight:700;margin-top:2px;font-size:13px}

.heroArt{
  background:#fff;border:1px solid rgba(15,23,42,.10);
  border-radius:22px;
  box-shadow:0 22px 60px rgba(15,23,42,.12);
  padding:18px;
}
.heroArt img{width:100%;height:auto}

.statsRow{
  margin-top:14px;
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:10px
}
.stat2{
  background:#fff;border:1px solid rgba(15,23,42,.10);
  border-radius:16px;padding:12px 12px;
  box-shadow:0 10px 24px rgba(15,23,42,.08);
}
.num2{font-size:22px;font-weight:1100;color:var(--brand)}
.lbl2{font-weight:900;color:rgba(11,18,32,.70);font-size:12px;margin-top:4px}

/* ---------- Page Hero ---------- */
.pageHero{padding:26px 0}
.pageHeroInner{
  background:#fff;border:1px solid rgba(15,23,42,.10);
  border-radius:22px;padding:18px 18px;
  box-shadow:0 18px 44px rgba(15,23,42,.10)
}
.breadcrumb{color:rgba(11,18,32,.62);font-weight:800;margin-bottom:10px}
.pageHero h1{margin:0;font-size:34px;letter-spacing:-.02em}

/* ---------- Sections & Cards ---------- */
.section2{padding:34px 0}
.section2.alt{background:rgba(35,59,83,.04)}
.sectionTitle2{margin-bottom:16px}
.eyebrow{
  display:inline-flex;align-items:center;
  font-weight:1000;font-size:12px;letter-spacing:.12em;text-transform:uppercase;
  color:rgba(35,59,83,.85);
  background:rgba(35,59,83,.08);
  border:1px solid rgba(35,59,83,.12);
  padding:6px 10px;border-radius:999px
}
.sectionTitle2 h2{margin:10px 0 6px 0;font-size:28px;letter-spacing:-.02em}
.sectionTitle2 p{margin:0;color:rgba(11,18,32,.70);font-weight:700;line-height:1.7}

.processGrid{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:14px;margin-top:14px
}
.pCard{
  background:#fff;border:1px solid rgba(15,23,42,.10);
  border-radius:20px;padding:16px 16px;
  box-shadow:0 14px 34px rgba(15,23,42,.10);
}
.pHead{display:flex;align-items:center;gap:12px;margin-bottom:8px}
.pIcon{
  width:40px;height:40px;border-radius:14px;
  display:flex;align-items:center;justify-content:center;
  background:rgba(46,111,163,.12);color:var(--accent);
  font-weight:1100
}
.pTitle{font-weight:1100}
.pText{color:rgba(11,18,32,.70);font-weight:700;line-height:1.7}

/* CTA Strip */
.ctaStrip{
  margin-top:16px;
  background:linear-gradient(180deg, var(--brand) 0%, var(--brand2) 100%);
  border-radius:22px;padding:18px 18px;
  color:#fff;display:flex;align-items:center;justify-content:space-between;gap:14px
}
.ctaTitle{font-size:18px;font-weight:1100}
.ctaText{opacity:.9;font-weight:700;margin-top:4px}
.ctaBtns{display:flex;gap:10px;flex-wrap:wrap}
.ctaStrip .btn{border:1px solid rgba(255,255,255,.18);background:rgba(255,255,255,.08);color:#fff;box-shadow:none}
.ctaStrip .btn.primary{border:none;background:#fff;color:var(--brand)}

/* ---------- Clients (Marquee) ---------- */
.logoMarquee{
  position:relative;
  background:#fff;
  border:1px solid rgba(15,23,42,.10);
  border-radius:22px;
  box-shadow:0 16px 40px rgba(15,23,42,.10);
  overflow:hidden;
  padding:14px 0;
  margin-top:14px;
}
.logoFade{
  position:absolute;inset:0;
  background:linear-gradient(90deg, #fff 0%, rgba(255,255,255,0) 12%, rgba(255,255,255,0) 88%, #fff 100%);
  pointer-events:none;
  z-index:2;
}
.logoTrack{
  display:flex;
  gap:14px;
  width:max-content;
  padding:0 14px;
  animation:marq 18s linear infinite;
}
.logoMarquee:hover .logoTrack{animation-play-state:paused}
@keyframes marq{
  from{transform:translateX(0)}
  to{transform:translateX(-50%)}
}
.logoCard{
  background:#fff;
  border:1px solid rgba(15,23,42,.06);
  border-radius:18px;
  padding:16px 18px;
  min-width:180px;
  height:90px;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 10px 25px rgba(15,23,42,.06);
}
.logoCard img{
  max-width:150px;
  max-height:55px;
  filter:grayscale(100%);
  opacity:.9;
  transition:filter .18s ease, opacity .18s ease, transform .18s ease;
}
.logoCard:hover img{filter:grayscale(0%);opacity:1;transform:scale(1.03)}

/* ---------- Clients (Grid backup) ---------- */
.logoGrid{
  display:grid;
  grid-template-columns:repeat(4, minmax(0, 1fr));
  gap:14px;
  margin-top:22px;
}
.logoGrid .logoCard{min-width:auto;height:110px}
.logoGrid .logoCard img{max-width:160px;max-height:64px}

/* ---------- Portfolio / Case ---------- */
.portGrid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:14px}
.caseCard{
  background:#fff;border:1px solid rgba(15,23,42,.10);border-radius:22px;padding:16px;
  box-shadow:0 16px 40px rgba(15,23,42,.10)
}
.caseTop{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:10px}
.caseBadge{display:inline-flex;padding:6px 10px;border-radius:999px;background:rgba(35,59,83,.08);border:1px solid rgba(35,59,83,.12);font-weight:1000}
.caseTitle{font-weight:1100;font-size:18px}
.caseDesc{color:rgba(11,18,32,.70);font-weight:700;line-height:1.7}
.kpiRow{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin:12px 0}
.kpi{background:rgba(35,59,83,.05);border:1px solid rgba(15,23,42,.08);border-radius:16px;padding:10px}
.kpiNum{font-weight:1200;color:var(--brand)}
.kpiLbl{font-weight:900;color:rgba(11,18,32,.65);font-size:12px;margin-top:2px}
.caseBtns{display:flex;gap:10px;flex-wrap:wrap;margin-top:10px}

/* ---------- Pricing ---------- */
.priceGrid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:14px}
.priceCard{
  background:#fff;border:1px solid rgba(15,23,42,.10);border-radius:22px;
  padding:16px;box-shadow:0 16px 40px rgba(15,23,42,.10)
}
.priceCard.featured{border:1px solid rgba(46,111,163,.30);box-shadow:0 22px 60px rgba(46,111,163,.12)}
.badge{
  display:inline-flex;padding:6px 10px;border-radius:999px;
  background:rgba(46,111,163,.10);border:1px solid rgba(46,111,163,.18);
  font-weight:1000;font-size:12px;color:var(--accent)
}
.pName{font-weight:1100;font-size:18px;margin-top:10px}
.pSub{color:rgba(11,18,32,.68);font-weight:700;margin:6px 0 10px 0}
.pPrice{font-size:32px;font-weight:1200;color:var(--brand)}
.pMeta{color:rgba(11,18,32,.55);font-weight:800}
.pList{margin:14px 0 0 0;padding:0;list-style:none;display:grid;gap:10px}
.pList li{display:flex;gap:10px;align-items:flex-start;color:rgba(11,18,32,.72);font-weight:750;line-height:1.5}
.tick{display:inline-flex;width:22px;height:22px;border-radius:9px;align-items:center;justify-content:center;background:rgba(35,59,83,.10);color:var(--brand);font-weight:1100}
.priceCTA{display:grid;gap:10px;margin-top:14px}

/* ---------- Testimonials ---------- */
.tWrap{
  position:relative;background:#fff;border:1px solid rgba(15,23,42,.10);
  border-radius:22px;box-shadow:0 16px 40px rgba(15,23,42,.10);
  overflow:hidden;
}
.tTrack{display:flex;gap:12px;transition:transform .45s ease;padding:14px}
.tCard{
  min-width:calc(100% - 28px);
  background:rgba(35,59,83,.04);
  border:1px solid rgba(15,23,42,.08);
  border-radius:18px;padding:16px;
}
.tText{font-weight:800;color:rgba(11,18,32,.78);line-height:1.7}
.tWho{display:flex;align-items:center;gap:10px;margin-top:12px}
.tAvatar{
  width:40px;height:40px;border-radius:16px;
  display:flex;align-items:center;justify-content:center;
  background:rgba(46,111,163,.12);color:var(--accent);font-weight:1200
}
.tName{font-weight:1100}
.tRole{color:rgba(11,18,32,.62);font-weight:800;font-size:13px}
.tControls{position:absolute;right:12px;top:12px;display:flex;gap:8px}
.tBtn{
  width:38px;height:38px;border-radius:14px;
  border:1px solid rgba(15,23,42,.12);
  background:#fff;font-weight:1200;cursor:pointer
}

/* ---------- FAQ ---------- */
.faqGrid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin-top:14px}
.faqItem{
  background:#fff;border:1px solid rgba(15,23,42,.10);border-radius:18px;
  overflow:hidden;box-shadow:0 12px 30px rgba(15,23,42,.08)
}
.faqQ{
  width:100%;display:flex;align-items:center;justify-content:space-between;gap:10px;
  padding:14px 14px;border:none;background:transparent;cursor:pointer;
  font-weight:1100
}
.faqIcon{font-weight:1200;font-size:18px;opacity:.8}
.faqA{display:none;padding:0 14px 14px 14px}
.faqA p{margin:0;color:rgba(11,18,32,.70);font-weight:750;line-height:1.7}
.faqItem.open .faqA{display:block}

/* ---------- Contact / Map ---------- */
.formGrid{display:grid;grid-template-columns:1.2fr .8fr;gap:14px;margin-top:14px}
.card{background:#fff;border:1px solid rgba(15,23,42,.10);border-radius:22px;padding:16px;box-shadow:0 16px 40px rgba(15,23,42,.10)}
.field{margin-top:12px}
.label{font-weight:1000;color:rgba(11,18,32,.75);font-size:13px}
.input,.textarea{
  width:100%;margin-top:8px;border-radius:16px;padding:12px 12px;
  border:1px solid rgba(15,23,42,.12);outline:none;background:#fff;
  font-weight:800
}
.textarea{min-height:120px;resize:vertical}
.mapWrap{margin-top:14px;border-radius:22px;overflow:hidden;border:1px solid rgba(15,23,42,.10);box-shadow:0 16px 40px rgba(15,23,42,.10)}
.mapFrame{width:100%;height:320px;border:0}

/* ---------- Footer ---------- */
.footer2{background:#0f1d2e;color:#fff;padding:28px 0}
.fGrid{display:grid;grid-template-columns:1.2fr .6fr .8fr;gap:16px}
.fBrand img{height:44px}
.fTitle{font-weight:1100;margin-bottom:10px}
.fText{color:rgba(255,255,255,.85);font-weight:750;line-height:1.7}
.fLinks{display:flex;flex-direction:column;gap:10px}
.fLinks a{color:rgba(255,255,255,.90);font-weight:850;text-decoration:underline}
.fBottom{margin-top:16px;padding-top:14px;border-top:1px solid rgba(255,255,255,.10);color:rgba(255,255,255,.80);font-weight:800}

/* ---------- Floating buttons ---------- */
.floatBtns{position:fixed;right:18px;bottom:18px;display:flex;flex-direction:column;gap:12px;z-index:60}
.floatBtn{
  width:52px;height:52px;border-radius:18px;
  display:flex;align-items:center;justify-content:center;
  border:1px solid rgba(15,23,42,.12);
  background:#fff;box-shadow:0 16px 40px rgba(15,23,42,.14);
}
.floatBtn svg{width:24px;height:24px;fill:currentColor}
.waBtn{background:#25D366;border:none;color:#fff}
.topBtn2{color:var(--brand)}

/* ---------- Responsive ---------- */
@media (max-width: 980px){
  .navlinks{display:none}
  .hamburger{display:inline-flex}
  .mobilemenu{display:none}

  .heroGrid{grid-template-columns:1fr;gap:16px}
  .statsRow{grid-template-columns:repeat(2,1fr)}

  .processGrid{grid-template-columns:1fr}
  .priceGrid{grid-template-columns:1fr}
  .portGrid{grid-template-columns:1fr}
  .faqGrid{grid-template-columns:1fr}
  .formGrid{grid-template-columns:1fr}
  .fGrid{grid-template-columns:1fr}
  .logoGrid{grid-template-columns:repeat(2, minmax(0, 1fr))}
}
@media (max-width: 520px){
  .logoGrid{grid-template-columns:1fr}
}