/* ═══════════════════════════════════════════
   NAVBAR.CSS — shared by navbar.php & transparent-navbar.php
═══════════════════════════════════════════ */

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

:root{
  --blue:#1b5ef7;
  --blue-d:#1247d6;
  --blue-xl:#f4f7ff;
  --blue-l:#ebf1ff;
  --text:#0d1b3e;
  --muted:#6b7a99;
  --border:#e4eaf6;
  --white:#ffffff;
  --sh-lg:0 24px 80px rgba(27,94,247,.2);
}

/* ── MARQUEE ── */
.marquee-wrapper{
  background:#016dee;
  overflow:hidden;
  white-space:nowrap;
  padding:9px 0;
  font-size:13.5px;
  color:#fff;
}
.marquee-track{
  display:inline-block;
  will-change:transform;
  animation:scroll-left 30s linear infinite;
}
.marquee-wrapper:hover .marquee-track{animation-play-state:paused}
.marquee-item{display:inline-block;padding:0 32px}
.marquee-item a{color:#fff;font-weight:600;text-decoration:underline;text-underline-offset:2px}
.marquee-dot{display:inline-block;width:6px;height:6px;background:#fff;border-radius:50%;vertical-align:middle;margin:0 4px}

@keyframes scroll-left{
  from{transform:translateX(0)}
  to{transform:translateX(-50%)}
}

/* ── NAVBAR ── */
/* NOTE: NO contain:layout — it breaks fixed-position children (mega menu) */
.navbar{
  height:64px;
  padding:0 clamp(20px,3vw,48px);
  display:flex;
  align-items:center;
  justify-content:space-between;
  position:sticky;
  top:0;
  z-index:1000;
  background:transparent;
  transition:background .25s,box-shadow .25s,border-color .25s;
}
.navbar.scrolled{
  background:#fff;
  border-bottom:1px solid var(--border);
  box-shadow:0 2px 14px rgba(27,94,247,.07);
}

/* always-white variant (inner pages) */
.navbar--always-white{
  background:#fff !important;
  border-bottom:1px solid var(--border);
  box-shadow:0 2px 14px rgba(27,94,247,.07);
}

/* ── LOGO ── */
.logo{
  display:flex;align-items:center;gap:9px;
  font-size:1.45rem;font-weight:800;
  color:var(--text);text-decoration:none;letter-spacing:-.02em;flex-shrink:0;
}
.logo img{width:auto;height:45px}

/* transparent navbar: white logo by default, color logo on scroll */
.logo-white{display:block}
.logo-color{display:none}
.navbar.scrolled .logo-white{display:none}
.navbar.scrolled .logo-color{display:block}

/* always-white navbar: only color logo */
.navbar--always-white .logo-white{display:none}
.navbar--always-white .logo-color{display:block}

/* menu-open: keep color logo visible, never hide it */
body.menu-open .navbar .logo-white{display:none}
body.menu-open .navbar .logo-color{display:block}

/* ── NAV LINKS ── */
.nav-links{display:flex;align-items:center;gap:2px;margin-bottom:0;list-style:none}
.nav-item{position:static}

.nav-btn{
  display:flex;align-items:center;gap:5px;
  padding:10px 16px;border-radius:8px;
  font-size:16px !important;font-weight:600 !important;
  /* default transparent navbar = white text */
  color:#fff !important;
  cursor:pointer;background:none;border:none;
  font-family:inherit;white-space:nowrap;
  transition:color .2s;
}
/* scrolled OR always-white = dark text */
.navbar.scrolled .nav-btn,
.navbar--always-white .nav-btn{color:#000 !important}

.nav-btn:hover,
.nav-item.open .nav-btn{color:var(--blue) !important}

.nav-btn .chev{transition:transform .25s}
.nav-item.open .chev{transform:rotate(180deg)}

/* ── NAV ACTIONS ── */
.nav-actions{display:flex;align-items:center;gap:10px;flex-shrink:0}

.btn-primary{
  padding:9px 22px;border-radius:8px;border:none;
  background:var(--blue);color:#fff;
  font-size:.82rem;font-weight:600;cursor:pointer;
  font-family:inherit;
  transition:background .2s,transform .15s;
  box-shadow:0 3px 12px rgba(27,94,247,.28);
}
.btn-primary:hover{background:var(--blue-d);transform:translateY(-1px)}

/* ── HAMBURGER ── */
.hamburger{
  display:none;flex-direction:column;gap:5px;
  background:none;border:none;cursor:pointer;padding:6px;
}
.hamburger span{
  display:block;width:22px;height:2px;border-radius:2px;
  transition:.3s;
  /* transparent navbar: white lines by default */
  background:#fff;
}
/* scrolled or always-white: dark lines */
.navbar.scrolled .hamburger span,
.navbar--always-white .hamburger span{background:#000}

.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)}

/* menu-open: dark lines always */
body.menu-open .navbar .hamburger span{background:#000}

/* ── MENU-OPEN STATE: navbar white + above mobile menu ── */
body.menu-open .navbar{
  background:#fff !important;
  z-index:10000;
  box-shadow:0 2px 10px rgba(0,0,0,.08);
}

/* ── WHATSAPP ── */
.btn-whatsapp-pulse2{
  height:50px;width:50px;
  background:#25d366;color:#fff;
  padding:13px !important;
  text-decoration:none;border-radius:50%;
  display:inline-flex;align-items:center;justify-content:center;
}
.btn-whatsapp-pulse2 img{width:25px;height:25px;display:block}

/* ═══════════════════════════════════
   MEGA MENU
═══════════════════════════════════ */
.mega-wrap,
.ind-wrap{
  position:fixed;
  left:50%;
  transform:translateX(-50%) translateY(-10px);
  width:min(1400px,98vw);
  z-index:999;
  opacity:0;
  pointer-events:none;
  transition:opacity .24s ease,transform .24s ease;
  margin-top:-5px;
  /* NO will-change here — causes stacking context issues with sticky navbar */
}
.mega-wrap.visible,
.ind-wrap.visible{
  opacity:1;
  pointer-events:all;
  transform:translateX(-50%) translateY(0);
}

.mega-inner,
.ind-inner{
  background:var(--white);
  border-radius:0 0 16px 16px;
  border:1px solid var(--border);
  box-shadow:var(--sh-lg);
  overflow:hidden;
}

/* ── TOPBAR ── */
.mm-topbar{
  display:flex;align-items:center;justify-content:space-between;
  padding:10px 28px;border-bottom:1px solid var(--border);
  background:var(--blue-xl);
}
.mm-topbar-title{font-size:.65rem;font-weight:700;color:var(--blue);text-transform:uppercase;letter-spacing:.13em}
.mm-topbar-right{display:flex;align-items:center;gap:16px}
.mm-topbar-stat{display:flex;align-items:center;gap:6px}
.mm-topbar-stat-num{font-size:.85rem;font-weight:800;color:var(--blue)}
.mm-topbar-stat-lbl{font-size:.7rem;color:var(--text);font-weight:500}
.mm-topbar-divider{width:1px;height:16px;background:var(--border)}

/* ── SCROLLABLE BODY ── */
.mm-scroll{
  max-height:calc(100vh - 260px);
  overflow-y:auto;overflow-x:hidden;
  padding:16px 28px 18px;
}
.mm-scroll::-webkit-scrollbar{width:4px}
.mm-scroll::-webkit-scrollbar-thumb{background:var(--blue-l);border-radius:4px}
.mm-scroll::-webkit-scrollbar-track{background:transparent}

/* ── GRID ── */
.mm-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:0;align-items:start}
.mm-col{padding:0 18px;border-right:1px solid var(--border)}
.mm-col:first-child{padding-left:0}
.mm-col:last-child{border-right:none;padding-right:0}

/* ── SECTION ── */
.mm-section{margin-bottom:16px}
.mm-section:last-child{margin-bottom:0}
.mm-cat-heading{
  font-size:.76rem;font-weight:700;color:var(--text);
  margin-bottom:7px;line-height:1.3;
  display:flex;align-items:flex-start;gap:7px;
}
.mm-cat-heading-dot{
  width:7px;height:7px;border-radius:50%;
  background:var(--blue);flex-shrink:0;margin-top:3px;
}

/* ── SERVICE LINK ── */
.mm-svc-link{
  display:flex;align-items:baseline;
  padding:2.5px 0;font-size:.8rem;font-weight:400;
  color:var(--text);text-decoration:none;cursor:pointer;
  transition:color .15s,padding-left .15s;line-height:1.4;
}
.mm-svc-link::before{
  content:"›";font-size:.78rem;color:var(--blue);
  opacity:0;transform:translateX(-5px);
  transition:opacity .15s,transform .15s;
  flex-shrink:0;font-weight:700;margin-right:0;
}
.mm-svc-link:hover{color:var(--blue);padding-left:6px}
.mm-svc-link:hover::before{opacity:1;transform:translateX(0)}

/* ── CTA BAR ── */
.mm-cta,.ind-cta{
  padding:13px 28px;
  display:inline-flex;align-items:center;gap:100px;
}
.mm-cta-left{display:flex;align-items:center;gap:14px;flex:1}
.mm-cta-text{font-size:.76rem;color:var(--text);line-height:1.5}
.mm-cta-text strong{color:var(--text);font-weight:700}
.mm-cta-btn{
  background:var(--blue);color:#fff;
  font-size:.76rem;font-weight:600;
  padding:11px 24px;border:none;border-radius:50px;
  cursor:pointer;white-space:nowrap;
  transition:background .2s,transform .18s,box-shadow .2s;
  box-shadow:0 4px 14px rgba(27,94,247,.32);flex-shrink:0;
}
.mm-cta-btn:hover{background:var(--blue-d);transform:scale(1.04);box-shadow:0 6px 22px rgba(27,94,247,.44)}

/* ═══════════════════════════════════
   INDUSTRIES
═══════════════════════════════════ */
.ind-body{padding:28px 40px 20px}
.ind-section{margin-bottom:0}
.ind-section-lbl{
  font-size:.62rem;font-weight:700;color:var(--blue);
  text-transform:uppercase;letter-spacing:.11em;
  margin-bottom:12px;padding-left:2px;
}
.ind-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:4px}
.ind-link{
  display:flex;align-items:center;gap:11px;
  padding:10px 14px;border-radius:10px;
  text-decoration:none;color:inherit;cursor:pointer;
  transition:background .15s;
}
.ind-link:hover{background:var(--blue-xl)}
.ind-link:hover .ind-lname{color:var(--blue)}
.ind-dot{
  width:34px;height:34px;border-radius:9px;flex-shrink:0;
  background:var(--blue-l);display:grid;place-items:center;
}
.ind-dot svg{width:15px;height:15px;color:var(--blue)}
.ind-lname{font-size:.82rem;font-weight:500;color:var(--text);line-height:1.3;transition:color .15s}
.ind-divider{height:1px;background:var(--border);margin:4px 0 20px}
.ind-cta p{font-size:.82rem;color:var(--text);line-height:1.5;flex:1;margin-bottom:0}
.ind-cta p strong{font-weight:700}
.ind-cta-btn{
  padding:11px 26px !important;border-radius:50px !important;
  font-size:.82rem !important;white-space:nowrap;
  box-shadow:0 4px 14px rgba(27,94,247,.32) !important;
}
.ind-cta-btn:hover{transform:scale(1.04) !important}

/* ═══════════════════════════════════
   MOBILE MENU
═══════════════════════════════════ */
.mob-menu{
  position:fixed;top:0;left:0;
  width:100%;height:100vh;
  background:#fff;z-index:9999;
  display:flex;flex-direction:column;
  transform:translateY(-100%);
  transition:transform .3s ease;
  overflow:hidden;
}
.mob-menu.open{
  transform:translateY(0);
  height:100%;
  top:64px;
  overflow-y:auto;
  background-color:#fff !important;
}
.mob-inner{overflow:auto;height:100%;padding:12px 5%}
.mob-acc{border-bottom:1px solid var(--border)}
.mob-trigger{
  display:flex;align-items:center;justify-content:space-between;
  padding:13px 0;font-size:.87rem;font-weight:600;
  color:var(--text);background:none;border:none;
  width:100%;font-family:inherit;cursor:pointer;text-align:left;gap:10px;
}
.mob-trigger .arr{transition:transform .3s;flex-shrink:0}
.mob-trigger.open .arr{transform:rotate(180deg)}
.mob-body{display:none;flex-direction:column;gap:1px;padding-bottom:10px}
.mob-body.open{display:flex}
.mob-glbl{
  font-size:.62rem;font-weight:700;color:var(--blue);
  text-transform:uppercase;letter-spacing:.08em;padding:7px 10px 3px;
}
.mob-svc{
  padding:8px 10px;border-radius:7px;
  font-size:.79rem;color:var(--muted);
  cursor:pointer;transition:background .15s,color .15s;
  text-decoration:none;display:block;
}
.mob-svc:hover{background:var(--blue-xl);color:var(--blue)}

/* mobile top links */
.mob-top-links{display:flex;flex-direction:column;gap:0}
.mob-top-links a{
  padding:8px 0;font-size:.95rem;font-weight:600;
  color:#0d1b3e;display:block;
  border-bottom:1px solid #f0f0f0;text-decoration:none;
}
.mob-top-links a:hover{background-color:#f5f7ff}
.btn-whatsapp-mobile{
  margin-bottom:4rem;background-color:#25D366;border-radius:10px;
  width:60px;height:40px;display:flex;align-items:center;
  justify-content:center;cursor:pointer;margin-top:10px;
}
.btn-whatsapp-mobile img{display:block;margin:0 auto;width:25px;height:25px}

/* ═══════════════════════════════════
   RESPONSIVE
═══════════════════════════════════ */
@media(max-width:992px){
  .hamburger{display:flex}
  .nav-links,.nav-actions{display:none}
}
@media(max-width:960px){
  .ind-wrap{display:none !important}
}
@media(max-width:768px){
  .marquee-wrapper{display:none}
}
@media(max-width:500px){
  .navbar.scrolled{
    background:#fff;border-bottom:1px solid var(--border);
    box-shadow:0 2px 14px rgba(27,94,247,.07);
  }
  body.menu-open .navbar.scrolled{background:#fff !important}
}

/* desktop size variants */
@media(min-width:1440px){
  .mm-scroll{padding:18px 32px 20px}
  .mm-col{padding:0 22px}
  .mm-topbar{padding:11px 32px}
  .mm-cta,.ind-cta{padding:14px 32px}
  .mm-section{margin-bottom:18px}
  .mm-cat-heading{font-size:.79rem;margin-bottom:8px}
  .mm-svc-link{font-size:.72rem;padding:3px 0}
  .mm-topbar-stat-num{font-size:.88rem}
}
@media(min-width:1280px) and (max-width:1439px){
  .mega-wrap{width:min(1280px,98vw)}
  .mm-scroll{padding:14px 24px 16px;max-height:calc(100vh - 180px)}
  .mm-col{padding:0 16px}
  .mm-topbar,.mm-cta{padding:10px 24px}
  .mm-section{margin-bottom:14px}
  .mm-cat-heading{font-size:.74rem}
  .mm-svc-link{font-size:.69rem}
}
@media(min-width:1024px) and (max-width:1279px){
  .mega-wrap{width:min(1020px,98vw)}
  .mm-scroll{padding:12px 20px 14px;max-height:calc(100vh - 145px)}
  .mm-col{padding:0 13px}
  .mm-topbar{padding:9px 20px;gap:12px}
  .mm-topbar-right{gap:12px}
  .mm-topbar-stat-num{font-size:.78rem}
  .mm-topbar-stat-lbl{font-size:.58rem}
  .mm-cta{padding:11px 20px}
  .mm-section{margin-bottom:12px}
  .mm-cat-heading{font-size:.71rem;gap:6px;margin-bottom:6px}
  .mm-cat-heading-dot{width:6px;height:6px}
  .mm-svc-link{font-size:.66rem;padding:2px 0}
  .mm-cta-text{font-size:.71rem}
  .mm-cta-btn{font-size:.71rem;padding:9px 18px}
}