@media (min-width:1500px){.container{max-width:1440px!important;}}
@media (min-width:1900px){.container{max-width:1700px!important;}}
@media (min-width:2560px){.container{max-width:1900px!important;}}
:root {
 --white:         #ffffff;
 --gray: #595963;
 --dgray: #191919;
 --lgray: #e5e5e5;
 --blue: #25598B;
 --yellow: #E8A020;
 --silver: #F0F0F0;
 --dblue: #06183c; 
 --fontmain: 'Poppins', sans-serif;
 --fontbody: 'Roboto', sans-serif;
 --ttext: #888888;
 --border: rgba(255,255,255,0.08);
 --transition: all 0.35s cubic-bezier(0.4,0,0.2,1);
 --shadow: 0 8px 40px rgba(0,0,0,0.12);
 --radius: 4px;
 --radius-lg: 8px;
}

.tblue { color: var(--blue); }
.bgsilver { background: var(--silver); }
/* ----------------------------------------------------------
   2. RESET & BASE
   ---------------------------------------------------------- */
*,
*::before,
*::after { box-sizing: border-box; margin: 0; padding: 0; }
html{scroll-behavior:smooth}
body{font-family:var(--fontbody);font-size:16px;color:var(--gray);background:var(--white);overflow-x:hidden;line-height:1.7}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none;transition:var(--transition)}
ul{margin:0;padding:0;list-style:none}
.section-padding{padding:100px 0 0 0}
.insection-padding{padding:50px 0 0 0}

/* ----------------------------------------------------------
   3. TYPOGRAPHY
   ---------------------------------------------------------- */
.section-label{display:inline-flex;align-items:center;gap:8px;font-family:var(--fontmain);font-size:14px;font-weight:600;letter-spacing:3px;text-transform:uppercase;color:var(--blue);margin-bottom:16px; display:block}
.ttext01{font-size:16px;font-weight:500;color:var(--dgray);line-height:1.7}
.ttext{color:var(--ttext);margin-bottom:0}
.square{width:9px;height:9px;background-color:var(--blue)}
.line{position:relative;height:1px;background-color:#aaa}
.line::after,.line::before{content:"";position:absolute;top:50%;width:9px;height:9px;background-color:var(--blue);transform:translateY(-50%)}
.line::before{left:0}
.line::after{right:0}
.theading{font-family:var(--fontmain);font-size:clamp(30px, 4vw, 46px);font-weight:700;color:var(--dgray);line-height:1.1;margin-bottom:20px}
.tsubheading{font-family:var(--fontmain);font-weight:600;color:var(--dgray);padding-bottom:10px;border-bottom:2px solid var(--lgray);}
.tsubheading01{font-family:var(--fontmain);font-weight:600;color:var(--dgray);padding-bottom:10px;}

/* ----------------------------------------------------------
   4. BUTTONS
   ---------------------------------------------------------- */
.btn-hightechot{display:inline-block;padding:13px 32px;background:0 0;color:var(--white)!important;font-family:var(--fontmain);font-size:16px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;border:2px solid rgba(255,255,255,.5);border-radius:var(--radius);transition:var(--transition);cursor:pointer}
.btn-hightechot:hover{background:var(--white);color:var(--dgray)!important;border-color:var(--white)}
.btn-quote{display:inline-block;padding:11px 28px;background:var(--blue);color:var(--white)!important;font-family:var(--fontmain);font-size:16px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;border-radius:var(--radius);transition:var(--transition)}
.btn-quote:hover{background:var(--gray);color:var(--white)!important}
.btn-hightech{display:inline-flex;align-items:stretch;text-decoration:none;border-radius:3px;overflow:hidden;cursor:pointer}
.btn-hightech-text{display:flex;align-items:center;padding:10px 20px;background:var(--blue);color:var(--white);font-family:var(--fontmain);font-size:14px;font-weight:700;letter-spacing:2px;text-transform:uppercase;white-space:nowrap;transition:background .3s ease}
.btn-hightech-box{width:52px;background:var(--dgray);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background .3s ease}
.btn-hightech-box svg{transition:transform .3s ease}
.btn-hightech:hover .btn-hightech-text{background:var(--dgray)}
.btn-hightech:hover .btn-hightech-box{background:#333}
.btn-hightech:hover .btn-hightech-box svg{transform:translate(2px,-2px)}

.btn-hightech01{display:inline-flex;align-items:stretch;text-decoration:none;border-radius:3px;overflow:hidden;cursor:pointer}
.btn-hightech01-text{display:flex;align-items:center;padding:10px 20px;background:var(--white);color:var(--blue);font-family:var(--fontmain);font-size:14px;font-weight:700;letter-spacing:2px;text-transform:uppercase;white-space:nowrap;transition:background .3s ease}
.btn-hightech01-box{width:52px;background:var(--blue);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background .3s ease}
.btn-hightech01-box svg{transition:transform .3s ease}
.btn-hightech01:hover .btn-hightech01-text{background:var(--dgray);color:var(--white)}
.btn-hightech01:hover .btn-hightech01-box{background:#333}
.btn-hightech01:hover .btn-hightech01-box svg{transform:translate(2px,-2px)}


.btn-whatsapp{display:inline-flex;align-items:stretch;text-decoration:none;border-radius:3px;overflow:hidden;cursor:pointer}
.btn-whatsapp-text{display:flex;align-items:center;padding:10px 10px;background:var(--blue);color:var(--white);font-family:var(--fontmain);font-size:13px;font-weight:400;letter-spacing:2px;text-transform:uppercase;white-space:nowrap;transition:background .3s ease}
.btn-whatsapp-box{width:52px;background:#25D366;color:var(--white);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background .3s ease}
.btn-whatsapp-box svg{transition:transform .3s ease}
.btn-whatsapp:hover .btn-whatsapp-text{background:var(--dgray);color:var(--white)}
.btn-whatsapp:hover .btn-whatsapp-box{background:#25D366;color:var(--white)}
.btn-whatsapp:hover .btn-whatsapp-box svg{transform:translate(2px,-2px)}

.btn-whatsapp01{display:inline-flex;align-items:stretch;text-decoration:none;border-radius:3px;overflow:hidden;cursor:pointer}
.btn-whatsapp01-text{display:flex;align-items:center;padding:10px 10px;background:var(--dgray);color:var(--white);font-family:var(--fontmain);font-size:13px;font-weight:400;letter-spacing:2px;text-transform:uppercase;white-space:nowrap;transition:background .3s ease}
.btn-whatsapp01-box{width:52px;background:#25D366;color:var(--white);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background .3s ease}
.btn-whatsapp01-box svg{transition:transform .3s ease}
.btn-whatsapp01:hover .btn-whatsapp01-text{background:var(--dgray);color:var(--white)}
.btn-whatsapp01:hover .btn-whatsapp01-box{background:#25D366;color:var(--white)}
.btn-whatsapp01:hover .btn-whatsapp01-box svg{transform:translate(2px,-2px)}

/* ----------------------------------------------------------
   5. TOP BAR
   ---------------------------------------------------------- */
.topbar{background:var(--gray);padding:10px 20px;border-bottom:1px solid var(--border);position:relative;top:0;left:0;width:100%;z-index:9999}
.topbar-info li{display:flex;align-items:center;font-size:15px;color:var(--white)}
.topbar-info li a{color:var(--white)}
.topbar-info li a:hover{color:var(--white)}
.topbar-info li i{color:var(--white);font-size:15px}
.topbar-socials a{color:var(--white);font-size:15px;width:28px;height:28px;display:flex;align-items:center;justify-content:center;border:1px solid var(--border);border-radius:50%;transition:var(--transition)}
.topbar-socials a:hover{color:var(--blue);border-color:var(--blue)}
.site-header{position:sticky;top:0;z-index:999;transition:var(--transition)}
.bgheader{background:var(--white)}
.site-header.scrolled{background:var(--white);box-shadow:0 4px 30px rgba(0,0,0,.4)}
.logo{max-width:380px}
.navbar{padding:0}
.navbar-nav .nav-link{font-family:var(--fontmain);font-size:16px;font-weight:500;letter-spacing:.5px;text-transform:uppercase;color:var(--blue)!important;padding:26px 30px!important;transition:var(--transition);position:relative}
.navbar-nav .nav-link::after{content:'';position:absolute;bottom:20px;left:14px;right:14px;height:2px;background:var(--blue);transform:scaleX(0);transition:transform .3s ease;transform-origin:right}
.navbar-nav .nav-item.active .nav-link,.navbar-nav .nav-link:hover{color:var(--gray)!important}
.navbar-nav .nav-link:hover::after{transform:scaleX(1);transform-origin:left}
.navbar-nav .dropdown-toggle::after{display:none}
.navbar-nav .dropdown-toggle .bi-chevron-down{font-size:10px;margin-left:4px}
.navbar .container{position:relative}
.mega-nav-item{position:static!important}
.dropdown-menu{background:var(--blue);background-image:url('../img/menubg.jpg');background-size:cover;background-position:center}
.mega-dropdown{position:absolute!important;top:90%!important;left:0!important;right:0!important;width:100%!important;border:none;border-top:3px solid var(--blue);border-radius:0 0 var(--radius) var(--radius);padding:28px 20px;box-shadow:0 12px 40px rgba(0,0,0,.35);z-index:1050;opacity:0;transform:translateY(-6px);transition:opacity .22s ease,transform .22s ease;display:none}
.mega-dropdown.show{display:block;opacity:1;transform:translateY(0)}
@keyframes dropIn{
from{opacity:0;transform:translateY(-8px)}
to{opacity:1;transform:translateY(0)}
}
.mega-inner{display:grid;grid-template-columns:repeat(4,1fr);gap:0}
.mega-col{padding:0 20px;border-right:1px solid rgba(255,255,255,.3)}
.mega-col:first-child{padding-left:0}
.mega-col:last-child{border-right:none}
.mega-dropdown .dropdown-item{font-family:var(--fontmain);font-size:15px;font-weight:400;color:rgba(255,255,255,.9)!important;padding:7px 0;background:0 0;white-space:normal;line-height:1.4;transition:var(--transition);border-radius:0}
.mega-dropdown .dropdown-item:hover{color:#fff!important;background:0 0;padding-left:8px}
.mega-cta-link{display:inline-flex;align-items:center;gap:6px;margin-top:14px;padding:9px 14px;background:rgba(37,89,139,.25);border:1px solid rgba(37,89,139,.4);border-radius:var(--radius);font-family:var(--fontmain);font-size:11px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--blue)!important;transition:var(--transition);width:100%;justify-content:center}
.mega-cta-link:hover{background:var(--blue);color:#fff!important;border-color:var(--blue)}
@media (max-width:991px){
.mega-dropdown{position:static!important;width:100%!important;transform:none!important;border-top:2px solid var(--blue);box-shadow:none;padding:12px 0;background:rgba(255,255,255,.04);opacity:1!important}
.mega-inner{grid-template-columns:1fr}
.mega-col{border-right:none;border-bottom:1px solid rgba(255,255,255,.06);padding:10px 8px}
.mega-col:last-child{border-bottom:none}
}
.navbar-toggler{border:none;padding:8px;background:0 0;display:flex;flex-direction:column;gap:5px}
.navbar-toggler:focus{box-shadow:none}
.toggler-icon{display:block;width:26px;height:2px;background:var(--blue);transition:var(--transition)}
.offcanvas-header{background:var(--white)}
.mobile-nav{background:var(--blue)}
.mobile-nav .navbar-brand .logo-text{color:var(--white)}
.mobile-nav .navbar-nav .nav-link{color:rgba(255,255,255,.8)!important;padding:12px 0!important;border-bottom:1px solid var(--border);font-size:15px}
.mobile-nav .navbar-nav .nav-link::after{display:none}

/* ----------------------------------------------------------
   7. HERO SLIDER
   ---------------------------------------------------------- */
.hero-slider{position:relative;overflow:hidden;margin-top:-160px}
.hero-swiper{width:100%;height:90vh;min-height:600px}
.hero-slide{background-size:cover;background-position:center;background-repeat:no-repeat;height:100%;position:relative}
.hero-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(
    105deg,
    rgba(10,10,10,0.6) 0,
    rgba(10,10,10,0.35) 55%,
    rgba(10,10,10,0.1) 100%
  );
  z-index: 1;
}
.hero-slide .container{position:relative;z-index:2;height:100%}
.hero-content{max-width:950px;opacity:0;transform:translateY(30px);transition:opacity .8s ease,transform .8s ease}
.swiper-slide-active .hero-content,.swiper-slide-duplicate-active .hero-content{opacity:1;transform:translateY(0)}
.hero-content-visible{opacity:1!important;transform:translateY(0)!important}
.hero-tagline{display:flex;align-items:center;gap:10px;font-family:var(--fontmain);font-size:14px;font-weight:700;letter-spacing:4px;text-transform:uppercase;color:var(--yellow);margin-bottom:20px;transition-delay:0.1s}
.hero-icon-img{width:22px;filter:invert(72%) sepia(90%) saturate(500%) hue-rotate(3deg)}
.hero-title{font-family:var(--fontmain);font-size:clamp(28px, 5.5vw, 72px);font-weight:800;color:var(--white);line-height:1.2;margin-bottom:24px;transition-delay:0.2s}
.hero-desc{font-size:15px;color:rgba(255,255,255,.75);margin-bottom:36px;max-width:520px;line-height:1.8;transition-delay:0.3s}
.hero-actions{transition-delay:0.4s}
.hero-next,.hero-prev{width:52px!important;height:52px!important;background:rgba(255,255,255,.1)!important;border:1px solid rgba(255,255,255,.2)!important;border-radius:50%;transition:var(--transition);color:var(--white)!important;display:flex!important;align-items:center!important;justify-content:center!important}
.hero-next:hover,.hero-prev:hover{background:var(--blue)!important;border-color:var(--blue)!important}
.hero-next::after,.hero-prev::after{display:none}
.hero-next i,.hero-prev i{font-size:18px}
.hero-prev{left:24px!important}
.hero-next{right:24px!important}
.hero-pagination{bottom:80px!important}
.hero-pagination .swiper-pagination-bullet{width:10px!important;height:10px!important;background:rgba(255,255,255,.4)!important;opacity:1!important;transition:var(--transition)}
.hero-pagination .swiper-pagination-bullet-active{background:var(--blue)!important;width:30px!important;border-radius:5px!important}
.hero-cta-bar{position:absolute;bottom:0;left:0;right:0;z-index:10;background:var(--blue);padding:14px 0}
.hero-cta-text{font-family:var(--fontmain);font-size:13px;font-weight:600;color:var(--dgray);letter-spacing:1px}
.hero-cta-link{font-family:var(--fontmain);font-size:13px;font-weight:700;color:var(--dgray);text-transform:uppercase;letter-spacing:1px}
.hero-cta-link:hover{color:var(--dgray);opacity:.8}
.hero-cta-box{position:absolute;bottom:50px;right:0;z-index:20;background:var(--blue);display:flex;overflow:hidden;max-width:340px;box-shadow:0 8px 32px rgba(0,0,0,.4)}
.hero-cta-box-inner{padding:22px 20px;flex:1;display:flex;flex-direction:column;justify-content:space-between}
.hero-cta-box-inner p{font-family:var(--fontmain);font-size:15px;font-weight:400;color:var(--white);line-height:1.5;margin:0 0 14px}
.hero-cta-box-inner p strong{font-weight:700;font-size:17px;display:block}
.hero-cta-box-btn{width:44px;height:44px;background:var(--white);color:var(--blue);border-radius:var(--radius);display:flex;align-items:center;justify-content:center;font-size:20px;transition:var(--transition);align-self:flex-start}
.hero-cta-box-btn:hover{background:var(--gray);color:var(--white)}
.hero-cta-box-img{width:130px;flex-shrink:0;overflow:hidden}
.hero-cta-box-img img{width:100%;height:100%;object-fit:cover;display:block}

/* ----------------------------------------------------------
   8. ABOUT SECTION
   ---------------------------------------------------------- */
.about-section::before{height:100%}
.about-section{position:relative;background:#fff}
.about-section::before{content:'';position:absolute;top:0;left:0;width:30%;height:580px;background:var(--silver);z-index:0}
.about-img-wrap{position:relative}
.about-img-main img{width:100%;object-fit:cover;border-radius:var(--radius-lg)}
.about-img-badge{position:absolute;bottom:40px;right:-20px;display:flex;align-items:center;gap:16px;background:var(--blue);padding:20px 24px;border-radius:var(--radius-lg);max-width:280px;box-shadow:var(--shadow)}
.about-badge-img{width:50px;flex-shrink:0}
.about-exp-box{display:flex;flex-direction:column}
.exp-number{font-family:var(--fontmain);font-size:42px;font-weight:800;color:var(--white);line-height:1}
.exp-label{font-family:var(--fontmain);font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--white)}
.exp-sub{font-size:11px;color:rgba(255,255,255,.6);text-transform:uppercase;letter-spacing:.5px}
.about-feature{display:flex;gap:14px;align-items:flex-start}
.about-feature-icon{width:44px;height:44px;min-width:44px;background:var(--white);border:1px solid var(--blue);border-radius:var(--radius);display:flex;align-items:center;justify-content:center;color:var(--blue);font-size:19px;transition:var(--transition)}
.about-feature:hover .about-feature-icon{background:var(--blue);color:var(--white)}
.about-feature h5{font-family:var(--fontmain);font-size:15px;font-weight:700;color:var(--dgray);margin-bottom:4px;text-transform:uppercase;letter-spacing:.5px}
.about-feature p{font-size:14px;color:var(--ttext);margin:0}


*{box-sizing:border-box;margin:0;padding:0}
.stats-section{position:relative;overflow:hidden;min-height:220px}
.parallax-bg{position:absolute;inset:-60px 0;background-image:url('../img/statsbg.jpg');background-size:cover;background-position:center;will-change:transform;transition:transform 0.1s linear}
.parallax-overlay{position:absolute;inset:0;background:linear-gradient(135deg,rgba(10,24,48,0.88) 0%,rgba(37,89,139,0.82) 100%)}
.stats-inner{position:relative;z-index:2;display:grid;grid-template-columns:repeat(4,1fr);gap:0;padding:0}
.stat-col{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:48px 20px;border-right:1px solid rgba(255,255,255,0.12);text-align:center;transition:background .3s}
.stat-col:last-child{border-right:none}
.stat-col:hover{background:rgba(255,255,255,0.06)}
.icon-wrap{width:64px;height:64px;border:1.5px solid rgba(255,255,255,0.25);border-radius:50%;display:flex;align-items:center;justify-content:center;margin-bottom:18px;transition:border-color .3s,transform .3s}
.stat-col:hover .icon-wrap{border-color:rgba(255,255,255,0.7);transform:scale(1.08)}
.icon-wrap svg{width:28px;height:28px;stroke:#ffffff;fill:none;stroke-width:1.6;stroke-linecap:round;stroke-linejoin:round}
.num-row{display:flex;align-items:flex-start;gap:2px;line-height:1;margin-bottom:10px}
.snum{font-size:52px;font-weight:700;color:#ffffff;line-height:1;font-family:var(--fontmain);letter-spacing:-1px}
.splus{font-size:26px;font-weight:700;color:#7eb8f7;margin-top:6px;line-height:1}
.slabel{font-size:11px;font-weight:600;letter-spacing:2.5px;text-transform:uppercase;color:rgba(255,255,255,0.6)}
@media(max-width:768px){.stats-inner{grid-template-columns:repeat(2,1fr)}.stat-col:nth-child(2){border-right:none}.stat-col:nth-child(3){border-top:1px solid rgba(255,255,255,0.12);border-right:1px solid rgba(255,255,255,0.12)}.stat-col:nth-child(4){border-top:1px solid rgba(255,255,255,0.12)}}
/* ----------------------------------------------------------
   9. SERVICES SECTION
   ---------------------------------------------------------- */


/* ══════════════════════════════════════
   SERVICES SLIDER SECTION
══════════════════════════════════════ */
.svc-label{display:inline-flex;align-items:center;gap:8px;font-size:11px;font-weight:700;letter-spacing:3px;text-transform:uppercase;color:var(--blue);margin-bottom:14px}
.svc-label-dot{display:inline-block;width:10px;height:10px;background:var(--blue);border-radius:2px;flex-shrink:0}
.svc-arr-btn{width:52px;height:52px;background:var(--dgray);border:none;color:#fff;font-size:18px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .25s ease;flex-shrink:0;border-radius:0}
.svc-arr-btn:hover{background:var(--blue)}
.svc-slider-row{display:flex;align-items:flex-start;gap:0}
.svc-arrows-left{display:flex;flex-direction:column;gap:4px;flex-shrink:0;padding-left:max(20px,calc((100vw - 1200px)/ 2))}
.svc-arrows{display:none!important}
.svc-track-wrap{overflow:hidden;flex:1;padding-left:20px}
.svc-track{display:flex;gap:20px;transition:transform .5s cubic-bezier(.4, 0, .2, 1);will-change:transform}
.svc-card{min-width:400px;max-width:400px;border:1px solid var(--lgray);border-radius:4px;overflow:hidden;cursor:pointer;position:relative;flex-shrink:0;background:#fff;margin-bottom:20px;transition:border-color .35s ease,box-shadow .35s ease}
.svc-card::after{content:'';position:absolute;bottom:0;left:0;right:0;height:3px;background:0 0;transition:background .35s ease}
.svc-card:hover{box-shadow:5px 5px 0 #C9D7E5}
.svc-card-media{position:relative;height:300px;overflow:hidden;background:#1a1a1a}
.svc-card-num{position:absolute;top:12px;left:16px;font-size:14px;font-weight:700;color:rgba(255,255,255,.75);letter-spacing:1px;z-index:4;transition:color .35s ease}
.svc-card:hover .svc-card-num{color:#fff}
.svc-card-photo{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:1;transform:scale(1);z-index:1;transition:transform .5s ease,opacity .4s ease}
.svc-card:hover .svc-card-photo{transform:scale(1.06);opacity:.85}
.svc-card-media::before{content:'';position:absolute;inset:0;background:linear-gradient(to bottom,rgba(0,0,0,.15) 0,rgba(0,0,0,.05) 40%,rgba(0,0,0,.45) 100%);z-index:2;transition:opacity .35s ease}
.svc-card:hover .svc-card-media::before{background:linear-gradient(to bottom,rgba(37,89,139,.3) 0,rgba(37,89,139,.1) 40%,rgba(37,89,139,.6) 100%)}
.svc-icon-box{position:absolute;bottom:16px;right:16px;width:auto;height:auto;background:0 0;z-index:3;display:flex;align-items:center;justify-content:center;transition:transform .35s ease}
.svc-card:hover .svc-icon-box{transform:scale(1.1)}
.svc-icon-inner{width:52px;height:52px;background:var(--blue);border-radius:4px;display:flex;align-items:center;justify-content:center;transition:background .35s ease;box-shadow:0 4px 16px rgba(0,0,0,.3)}
.svc-icon-inner i{font-size:22px;color:#fff}
.svc-card:hover .svc-icon-inner{background:#fff}
.svc-card:hover .svc-icon-inner i{color:var(--blue)}
.svc-card-body{padding:24px 22px 22px}
.svc-card-body h3{font-size:18px;font-weight:800;color:var(--dgray);margin-bottom:10px;line-height:1.3;transition:color .35s ease}
.svc-card:hover .svc-card-body h3{color:var(--blue)}
.svc-card-body p{font-size:16px;color:var(--gray);line-height:1.7;margin-bottom:18px}
.svc-card-link{display:inline-flex!important;align-items:center!important;gap:6px!important;font-size:14px!important;font-weight:700!important;letter-spacing:2px!important;text-transform:uppercase!important;color:var(--gray)!important;transition:color .35s ease!important}
.svc-card-link i{font-size:13px;transition:transform .35s ease}
.svc-card:hover .svc-card-link{color:var(--blue)}
.svc-card:hover .svc-card-link i{transform:translateX(4px)}
.svc-dots{display:flex;justify-content:center;gap:6px;padding:32px 0 8px}
.svc-dot{width:8px;height:8px;border-radius:50%;background:#ddd;cursor:pointer;border:none;padding:0;transition:all .3s ease}
.svc-dot.active{background:var(--blue);width:24px;border-radius:4px}

/* Prevent horizontal scroll on the section itself */
.svc-section { overflow-x: hidden; }

@media (max-width:991px){
    .svc-slider-row { flex-direction:column; gap:12px; }
    .svc-arrows-left { flex-direction:row; padding-left:16px; }
    .svc-track-wrap { padding-left:16px; width:100%; flex:none; }
    .svc-card { min-width:280px; max-width:280px; }
}
@media (max-width:767px){
    .svc-card { min-width:calc(100vw - 80px); max-width:calc(100vw - 80px); }
}
@media (max-width:575px){
    .svc-card { min-width:calc(100vw - 48px); max-width:calc(100vw - 48px); }
    .svc-arrows-left { padding-left:12px; }
    .svc-track-wrap { padding-left:12px; }
    .svc-arr-btn { width:44px; height:44px; font-size:16px; }
}
/* ----------------------------------------------------------
   10. WHAT WE DO SECTION
   ---------------------------------------------------------- */
.whatwedo-padding{padding-right:150px;}
.whatwedo-img-wrap{height:100%;min-height:700px;position:relative;overflow:hidden}
.whatwedo-img{width:100%;height:100%;object-fit:cover;transition:opacity .5s ease}
.whatwedo-content{background:var(--silver);height:100%}
.whatwedo-tabs{gap:0;border-bottom:2px solid rgba(0,0,0,.1);margin-bottom:0;flex-wrap:wrap}
.whatwedo-tabs .nav-link{font-family:var(--fontmain);font-size:15px;font-weight:500;text-transform:uppercase;letter-spacing:1px;color:var(--blue)!important;padding:12px 16px;border-bottom:2px solid transparent;margin-bottom:-2px;border-radius:0;transition:var(--transition)}
.whatwedo-tabs .nav-link.active,.whatwedo-tabs .nav-link:hover{color:var(--blue)!important;border-bottom-color:var(--blue);background:0 0}
.wt-pane{display:none;padding-top:28px;animation:fadeIn .4s ease}
.wt-pane.active{display:block}
@keyframes fadeIn{
from{opacity:0;transform:translateY(8px)}
to{opacity:1;transform:translateY(0)}
}
.wt-pane h3{font-family:var(--fontmain);font-size:24px;font-weight:700;color:var(--dgray);margin-bottom:14px}
.wt-pane p{color:var(--gray);font-size:16px;line-height:1.8;margin-bottom:20px}
.wt-checklist li{font-size:16px;color:var(--gray);padding:8px 0;border-bottom:1px solid rgba(0,0,0,.05);display:flex;align-items:flex-start}
.wt-checklist li i{color:var(--blue);flex-shrink:0;margin-top:2px}
.pillar-card{padding:24px 20px;border:1px solid rgba(0,0,0,.08);border-top:3px solid var(--blue);background:var(--white);border-radius:var(--radius);transition:var(--transition);position:relative;overflow:hidden}
.pillar-card.h-100{overflow:visible}
.pillar-card:hover{box-shadow:var(--shadow);transform:translateY(-4px)}
.pillar-card h5{font-family:var(--fontmain);font-size:17px;font-weight:700;color:var(--dgray);margin-bottom:8px}
.pillar-card p{font-size:14px;color:var(--gray);margin-bottom:12px}
.pillar-bg-icon{position:absolute;bottom:-10px;right:-10px;font-size:90px;color:var(--blue);opacity:.1;line-height:1;pointer-events:none;transition:opacity .3s ease,transform .3s ease;z-index:0}
.pillar-card:hover .pillar-bg-icon{opacity:.12;transform:scale(1.1) rotate(-5deg)}
.pillar-card .pillar-link,.pillar-card h5,.pillar-card p{position:relative;z-index:1}
/* ----------------------------------------------------------
   12. PROJECTS SECTION
   ---------------------------------------------------------- */
.project-card{border-radius:var(--radius-lg);overflow:hidden;transition:var(--transition)}
.project-card:hover{box-shadow:var(--shadow);transform:translateY(-6px)}
.project-img-wrap{position:relative;overflow:hidden;aspect-ratio:3/4}
.project-img{width:100%;height:100%;object-fit:cover;transition:transform .6s ease}
.project-card:hover .project-img{transform:scale(1.06)}
.project-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(14,14,14,.95) 0,rgba(14,14,14,.4) 50%,transparent 100%);opacity:0;transition:var(--transition);display:flex;align-items:flex-end}
.project-card:hover .project-overlay{opacity:1}
.project-overlay-content{padding:28px;transform:translateY(20px);transition:transform .35s ease;width:100%}
.project-card:hover .project-overlay-content{transform:translateY(0)}
.project-cats{display:inline-block;font-family:var(--fontmain);font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:2px;color:var(--yellow);margin-bottom:8px}
.project-overlay-content h4{font-family:var(--fontbody);font-size:20px;font-weight:700;color:var(--white);margin-bottom:12px}
.project-meta{display:flex;flex-direction:column;gap:4px}
.project-meta span{font-size:12px;color:rgba(255,255,255,.7)}
.project-meta span i{color:var(--blue)}
.project-link{position:absolute;top:20px;right:20px;width:42px;height:42px;background:var(--white);color:var(--blue);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:18px;transform:scale(0);transition:transform .35s cubic-bezier(.34,1.56,.64,1)}
.project-card:hover .project-link{transform:scale(1)}
.project-info{padding:20px 0 0;background:var(--white)}
.project-cats-sm{font-family:var(--fontmain);font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:1.5px;color:var(--blue);display:block;margin-bottom:8px}
.project-info h5{font-family:var(--fontmain);font-size:18px;font-weight:700;color:var(--dgray);margin-bottom:8px}
.project-info h5 a:hover{color:var(--blue)}
.project-info p{font-size:13px;color:var(--ttext)}
/* ----------------------------------------------------------
   18. BLOG SECTION
   ---------------------------------------------------------- */
.blog-section{background:var(--silver);margin-top:100px;padding-bottom:100px}
.blog-section .section-label{display:block;margin-bottom:12px}
.blog-section .theading{margin-top:0}
.blog-section .row{align-items:stretch}
.blog-section [class*=col-]{display:flex}
.blog-card{background:var(--white);border-radius:var(--radius-lg);overflow:hidden;transition:var(--transition);display:flex;flex-direction:column;width:100%}
.blog-card:hover{box-shadow:var(--shadow);transform:translateY(-6px)}
.blog-img-wrap{position:relative;overflow:hidden;flex-shrink:0}
.blog-img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}
.blog-card:hover .blog-img{transform:scale(1.06)}
.blog-date-badge{position:absolute;top:16px;left:16px;background:var(--blue);color:var(--white);font-family:var(--fontmain);font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:1px;padding:6px 12px;border-radius:var(--radius)}
.blog-info{padding:24px;display:flex;flex-direction:column;flex:1}
.blog-meta{display:flex;align-items:center;gap:14px;margin-bottom:12px;font-size:12px;color:var(--gray);flex-shrink:0}
.blog-cat a{color:var(--blue);font-weight:600}
.blog-cat a:hover{color:var(--dgray)}
.blog-author a{color:var(--gray)}
.blog-author a:hover{color:var(--blue)}
.blog-title{font-family:var(--fontmain);font-size:17px;font-weight:700;color:var(--dgray);line-height:1.4;margin-bottom:12px;flex-shrink:0;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;min-height:calc(17px * 1.4 * 2)}
.blog-title a{color:var(--dgray)}
.blog-title a:hover{color:var(--blue)}
.blog-excerpt{font-size:16px;color:var(--ttext);line-height:1.7;margin-bottom:0;flex-shrink:0;display:-webkit-box;-webkit-line-clamp:4;-webkit-box-orient:vertical;overflow:hidden;min-height:calc(13.5px * 1.7 * 2)}
.blog-footer{margin-top:auto;padding-top:20px;border-top:1px solid rgba(0,0,0,.06)}
.blog-link{display:inline-flex;align-items:center;gap:4px;font-family:var(--fontmain);font-size:14px;font-weight:700;text-transform:uppercase;letter-spacing:1.5px;color:var(--blue);transition:var(--transition)}
.blog-link i{transition:transform .3s ease}
.blog-link:hover{color:var(--dgray)}
.blog-link:hover i{transform:translateX(4px)}
/* ----------------------------------------------------------
   19. CTA SECTION — Diagonal Split
   ---------------------------------------------------------- */
.cta-section{position:relative;height:370px;overflow:hidden;background:url("../img/ctaimg.jpg") no-repeat right center;background-size:50% auto}
.cta-blue{position:absolute;top:0;left:0;width:62%;height:100%;z-index:1;background-color:var(--blue);background-image:repeating-linear-gradient(0deg,transparent,transparent 39px,rgba(255,255,255,.08) 39px,rgba(255,255,255,.08) 40px),repeating-linear-gradient(90deg,transparent,transparent 39px,rgba(255,255,255,.08) 39px,rgba(255,255,255,.08) 40px)}
.cta-blade{position:absolute;top:0;right:-55px;width:110px;height:100%;background-color:var(--blue);background-image:repeating-linear-gradient(0deg,transparent,transparent 39px,rgba(255,255,255,.08) 39px,rgba(255,255,255,.08) 40px),repeating-linear-gradient(90deg,transparent,transparent 39px,rgba(255,255,255,.08) 39px,rgba(255,255,255,.08) 40px);transform:skewX(-6deg);transform-origin:top center}
.cta-inner{position:absolute;inset:0;z-index:3;display:flex;align-items:center}
.cta-content{width:55%}
.cta-content h2{font-family:var(--fontmain);font-size:clamp(22px, 3vw, 32px);font-weight:700;color:#fff;line-height:1.2;margin-bottom:14px}
.cta-content p{font-size:16px;color:rgba(255,255,255,.78);line-height:1.7;margin-bottom:28px;max-width:620px}
@media (max-width:991px){
.cta-section{height:auto;background-image:none;background-color:var(--blue)}
.cta-blue{width:100%}
.cta-blade{display:none}
.cta-inner{position:relative;inset:auto}
.cta-content{width:100%;padding:60px 0}
}
@media (max-width:575px){
.cta-content{padding:48px 0}
.cta-content h2{font-size:22px}
}
/* ----------------------------------------------------------
   20. FOOTER
   ---------------------------------------------------------- */
.site-footer{background:var(--silver);background-image:url('../img/bottombg.jpg');background-size:cover;background-position:center;will-change:transform;transition:transform .1s linear}
.footer-main{padding:80px 0 50px}
.footer-desc{font-size:15px;color:var(--dgray);line-height:1.8;max-width:300px}
.footer-contact-item{display:flex;align-items:flex-start;gap:10px;margin-bottom:12px;font-size:13px;color:rgba(255,255,255,.55)}
.footer-contact-item i{color:var(--blue);margin-top:2px;flex-shrink:0}
.footer-contact-item a{color:rgba(255,255,255,.55)}
.footer-contact-item a:hover{color:var(--blue)}
.footer-heading{font-family:var(--fontmain);font-size:16px;font-weight:700;text-transform:uppercase;letter-spacing:2px;color:var(--dgray);margin-bottom:24px;padding-bottom:12px;border-bottom:1px solid var(--border);position:relative}
.footer-heading::after{content:'';position:absolute;bottom:-1px;left:0;width:36px;height:2px;background:var(--blue)}
.footer-links li{margin-bottom:10px}
.footer-links a{font-family:var(--fontmain);font-size:16px;font-weight:500;color:var(--gray);display:flex;align-items:center;gap:8px;transition:var(--transition)}
.footer-links a::before{content:'';width:6px;height:1px;background:var(--gray);opacity:1;transition:var(--transition)}
.footer-links a:hover{color:var(--blue);padding-left:8px}
.footer-links a:hover::before{opacity:1}
.footer-socials{display:flex;justify-content:center;align-items:center;gap:12px}
.footer-socials a{width:36px;height:36px;background:rgba(255,255,255,.06);border:1px solid var(--border);color:var(--dgray);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:16px;transition:var(--transition)}
.footer-socials a:hover{background:var(--white);color:var(--blue);border-color:var(--white)}
/* Mobile social icons strip — between footer-main and footer-bottom, below 992px only */
.footer-mobile-socials{background:var(--dblue);border-top:1px solid rgba(255,255,255,.06);padding:16px 20px;justify-content:center;align-items:center;gap:12px}
.footer-mobile-socials a{width:36px;height:36px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);color:rgba(255,255,255,.55);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:15px;transition:var(--transition);text-decoration:none}
.footer-mobile-socials a:hover{background:var(--white);color:var(--blue);border-color:var(--white)}

.footer-bottom{background:var(--dblue);padding:18px 0;border-top:1px solid var(--border)}
.footer-bottom p{font-size:13px;color:rgba(255,255,255,.4)}
.footer-bottom a{font-size:13px;color:rgba(255,255,255,.4)}
.footer-bottom a:hover{color:var(--blue)}
.tcopyright{font-family:Roboto,sans-serif;font-size:12px!important;line-height:17px}
.tdesignby{font-family:Roboto,sans-serif;font-size:12px!important;line-height:17px}

/* ----------------------------------------------------------
   22. BACK TO TOP
   ---------------------------------------------------------- */
.back-to-top{position:fixed;bottom:32px;right:32px;width:46px;height:46px;background:var(--blue);color:var(--white);border-radius:var(--radius);display:flex;align-items:center;justify-content:center;font-size:18px;z-index:999;opacity:0;transform:translateY(20px);transition:var(--transition);box-shadow:0 4px 20px rgba(160,160,160,.3)}
.back-to-top.visible{opacity:1;transform:translateY(0)}
.back-to-top:hover{background:var(--dgray);color:var(--white)}

/* ----------------------------------------------------------
   23. SCROLL REVEAL ANIMATIONS
   ---------------------------------------------------------- */
.reveal{opacity:0;transform:translateY(30px);transition:opacity .7s ease,transform .7s ease}
.reveal.visible{opacity:1;transform:translateY(0)}
.reveal-left{opacity:0;transform:translateX(-30px);transition:opacity .7s ease,transform .7s ease}
.reveal-left.visible{opacity:1;transform:translateX(0)}
.reveal-right{opacity:0;transform:translateX(30px);transition:opacity .7s ease,transform .7s ease}
.reveal-right.visible{opacity:1;transform:translateX(0)}
.reveal-delay-1{transition-delay:0.1s}
.reveal-delay-2{transition-delay:0.2s}
.reveal-delay-3{transition-delay:0.3s}
.reveal-delay-4{transition-delay:0.4s}
/* ----------------------------------------------------------
   24. RESPONSIVE
   ---------------------------------------------------------- */
@media (max-width:1199px){
.logo{max-width:280px}
.hero-next,.hero-prev{display:none!important}
.snum{font-size:32px;font-weight:600}
.about-img-badge{right:0}
.contact-form-wrap{padding:60px 40px}
}
@media (max-width:991px){
	
.about-section::before{background:none;}
.section-padding{padding:40px 0 0 0}
.hero-swiper{height:75vh}
.hero-slider{margin-top:0px}
.hero-title{font-size:28px}
.hero-pagination{bottom:40px!important}
.about-img-main img{height:440px}
.about-img-badge{position:relative;bottom:auto;right:auto;display:inline-flex;margin-top:16px}
.services-side-img{display:none!important}
.wcu-since-badge{position:relative;bottom:auto;right:auto;margin-top:20px;max-width:100%}
.wcu-main-img{height:380px}
.contact-form-wrap{padding:60px 30px}
.whatwedo-content .container{padding:40px 20px}
.navbar-nav .nav-item.active .nav-link, .navbar-nav .nav-link:hover {color: var(--white) !important;}
.btn-hightech-text{padding:10px 15px;font-weight:500;letter-spacing:1px}
.btn-hightech01-text{padding:10px 15px;font-weight:500;letter-spacing:1px}
.page-banner-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(
    135deg,
    rgba(6, 24, 60, 0.3) 0%,
    rgba(37, 89, 139, 0.2) 100%
  ) !important;
}
}
@media (max-width:767px){
.hero-cta-box{display:none}
.stat-item{border-right:none;border-bottom:1px solid #d8e2ef;padding:22px 20px}
.stat-item:last-child{border-bottom:none}
.section-padding{padding:55px 0 0 0}
.hero-swiper{height:85vh}
.hero-next,.hero-prev{display:none!important}
.about-img-main img{height:320px}
.stat-item{border-right:none;border-bottom:1px solid var(--border)}
.stat-item:last-child{border-bottom:none}
.contact-actions{gap:8px}
.contact-action-btn{padding:9px 14px;font-size:11px}
.footer-main{padding:55px 0 35px}
.contact-form-wrap{padding:45px 20px}
.hero-cta-bar{display:none}
.process-step{flex-direction:column;gap:8px}
}
@media (max-width:575px){
.theading{font-size:28px}
.hero-title{font-size:32px}
.hero-content{padding:0 8px}
.stats-bar .stat-item{padding:24px 16px}
.stat-number{font-size:38px}
.service-card{padding:28px 20px}
}
@media only screen and (min-device-width:992px) and (max-device-width:1199px){
.logo{max-width:200px}
.navbar-nav .nav-link{font-size:14px;font-weight:400;letter-spacing:0}
.hero-title{font-size:32px}
.btn-hightech-text{padding:10px 15px;font-weight:500;letter-spacing:1px}
.btn-hightech01-text{padding:10px 15px;font-weight:500;letter-spacing:1px}
}
@media only screen and (min-device-width:1200px) and (max-device-width:1399px){
.logo{max-width:270px}
.navbar-nav .nav-link{font-size:15px}
.btn-hightech-text{padding:10px 15px;font-weight:500;letter-spacing:1px}
.btn-hightech01-text{padding:10px 15px;font-weight:500;letter-spacing:1px}
}
@media only screen and (min-device-width:1400px) and (max-device-width:1499px){
.logo{max-width:280px}
.navbar-nav .nav-link{font-size:15px}
.btn-hightech-text{padding:10px 15px;font-weight:500;letter-spacing:1px}
.btn-hightech01-text{padding:10px 15px;font-weight:500;letter-spacing:1px}
}
@media only screen and (min-device-width:1500px) and (max-device-width:1699px){
.logo{max-width:300px}
}
@media only screen and (min-device-width:1500px) and (max-device-width:1699px){
.logo{max-width:300px}
}
@media only screen and (min-device-width:1500px) and (max-device-width:1699px){
.logo{max-width:300px}
}
@media only screen and (min-device-width:1700px) and (max-device-width:1899px){
.logo{max-width:340px}
}

@media only screen and (min-width: 2560px) {.whatwedo-padding{padding-right:300px;}}
/* ==========================================================
   INNER PAGES — minimal additions (page banner, sidebar,
   contact specifics). All other styles reuse index classes.
   ========================================================== */

.page-banner{position:relative;height:440px;background-size:cover;background-position:center;background-repeat:no-repeat;align-items:center;margin-top:-160px;}
.promise-box{background:#ebf2f9;border:1px solid #c5d9ed;border-left:4px solid var(--blue);border-radius:var(--radius);padding:24px 28px}
.promise-box h5{font-family:var(--fontmain);font-size:15px;font-weight:700;color:var(--blue);margin-bottom:12px}
.promise-box p{font-family:var(--fontbody);font-size:15px;color:var(--dgray);line-height:1.8;margin:0;text-align:justify}
.page-banner-overlay{position:absolute;inset:0;background:linear-gradient(135deg,rgba(6,24,60,.88) 0%,rgba(37,89,139,.80) 100%)}
.page-banner .container{position:relative;z-index:2}
.page-banner h1{font-family:var(--fontmain);font-size:clamp(26px,4vw,42px);font-weight:800;color:#fff;margin-bottom:10px;line-height:1.1}
.breadcrumb{margin:0;padding:0;background:none;font-size:14px;font-family:var(--fontmain)}
.breadcrumb-item a{color:var(--gray);font-size:14px;font-family:var(--fontmain);text-decoration:none}
.breadcrumb-item a:hover{color:var(--dgray)}
.breadcrumb-item.active{color:var(--blue);font-size:14px;font-family:var(--fontmain)}
.breadcrumb-item+.breadcrumb-item::before{color:var(--blue)}
.innerimg{border-radius:var(--radius);object-fit:cover;}
@media(max-width:767px){.page-banner{height:180px}}
@media (max-width: 991px) {
    .page-banner {
        margin-top: 0;
        padding-top: 0;
        height: 220px;
    }
}
.processdiv {display:flex;gap:14px;padding:14px 0;border-bottom:1px solid var(--lgray);}
.processnum{font-family:var(--fontmain);font-size:22px;font-weight:800;color:var(--blue);line-height:1;min-width:36px;flex-shrink:0;}
.processhead{font-family:var(--fontmain);font-size:14px;color:var(--dgray);display:block;margin-bottom:3px;}
.abouticon{width:56px;height:56px;background:var(--blue);border-radius:var(--radius);display:flex;align-items:center;justify-content:center;margin-bottom:16px;}
/* Sidebar */
.sidebar-box{background:var(--silver);border-radius:var(--radius);padding:24px;border:1px solid var(--lgray);margin-bottom:24px}
.sidebar-box .footer-heading{color:var(--dgray);border-bottom:2px solid var(--blue);border-color:var(--blue)}
.sidebar-box .footer-heading::after{display:none}
.sidebar-nav li{border-bottom:1px solid var(--lgray)}
.sidebar-nav li:last-child{border-bottom:none}
.sidebar-nav li a{padding:9px 0;font-family:var(--fontmain);font-size:14px;color:var(--gray);display:flex;align-items:center;gap:8px;transition:var(--transition)}
.sidebar-nav li a:hover,.sidebar-nav li a.is-active{color:var(--blue);padding-left:6px}
.sidebar-form-input{background:var(--white)!important;border:1px solid var(--lgray)!important;border-radius:var(--radius)!important;font-family:var(--fontmain);font-size:14px;padding:11px 14px;color:var(--dgray)!important}
.sidebar-form-input:focus{border-color:var(--blue)!important;box-shadow:0 0 0 3px rgba(37,89,139,.12)!important;outline:none}
.sidebar-cta-box{background:var(--blue);border-radius:var(--radius);padding:28px 24px}
.sidebar-cta-box h5{font-family:var(--fontmain);font-size:16px;font-weight:700;color:#fff;margin-bottom:8px}
.sidebar-cta-box p{font-size:16px;color:rgba(255,255,255,.78);margin-bottom:20px;line-height:1.6}
.sidebar-cta-box .sidebar-form-input{background:rgba(255,255,255,.12)!important;border:1px solid rgba(255,255,255,.2)!important;color:#fff!important;margin-bottom:10px}
.sidebar-cta-box .sidebar-form-input::placeholder{color:rgba(255,255,255,.45)}
.sidebar-wa-box{background:var(--blue);border-radius:var(--radius);padding:18px 20px;display:flex;align-items:center;gap:14px;margin-top:16px}
.sidebar-wa-box>i{font-size:30px;color:#25d366;flex-shrink:0}
.sidebar-wa-box h5{font-family:var(--fontmain);font-size:16px;font-weight:700;color:#fff;margin-bottom:8px}
.sidebar-wa-box p{font-size:16px;color:rgba(255,255,255,.78);margin-bottom:20px;}
.sidebar-wa-box a{font-size:24px;font-weight:700;color:var(--white);text-decoration:none}
.sidebar-recent-post{display:flex;gap:12px;align-items:flex-start;padding:12px 0;border-bottom:1px solid var(--lgray)}
.sidebar-recent-post:last-child{border-bottom:none}
.sidebar-recent-post img{width:64px;height:60px;object-fit:cover;border-radius:var(--radius);flex-shrink:0}
.sidebar-recent-post a{font-family:var(--fontmain);font-size:13px;font-weight:600;color:var(--dgray);display:block;line-height:1.4;margin-bottom:4px}
.sidebar-recent-post a:hover{color:var(--blue)}
.sidebar-recent-post span{font-size:12px;color:var(--ttext)}

/* Service detail */
.svc-feature-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin-bottom:32px}
.svc-feature-item{display:flex;align-items:flex-start;gap:12px;padding:16px;border:1px solid var(--lgray);border-radius:var(--radius);transition:var(--transition)}
.svc-feature-item:hover{border-color:var(--blue);box-shadow:0 4px 16px rgba(37,89,139,.1)}
.svc-feature-item-icon{width:42px;height:42px;min-width:42px;background:var(--blue);border-radius:var(--radius);display:flex;align-items:center;justify-content:center}
.svc-feature-item-icon i{font-size:18px;color:#fff}
.svc-feature-item strong{font-family:var(--fontmain);font-size:14px;color:var(--dgray);display:block;margin-bottom:3px}
.svc-feature-item span{font-size:13px;color:var(--ttext)}
.svc-process-step{display:flex;gap:20px;padding:20px 0;border-bottom:1px solid var(--lgray)}
.svc-process-step:last-child{border-bottom:none}
.svc-process-num{font-family:var(--fontmain);font-size:36px;font-weight:800;color:var(--lgray);line-height:1;min-width:50px}
.svc-process-step strong{font-family:var(--fontmain);font-size:15px;color:var(--dgray);display:block;margin-bottom:5px}
.svc-process-step p{font-size:14px;color:var(--gray);margin:0;line-height:1.7}
@media(max-width:575px){.svc-feature-grid{grid-template-columns:1fr}}

/* Blog detail */
.blog-detail-meta{display:flex;flex-wrap:wrap;align-items:center;gap:16px;margin-bottom:16px;font-family:var(--fontmain);font-size:13px;color:var(--gray)}
.blog-cat-pill{background:var(--blue);color:#fff;padding:4px 12px;border-radius:2px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:1px}
.blog-detail-h1{font-family:var(--fontmain);font-size:clamp(22px,3.5vw,34px);font-weight:800;color:var(--dgray);line-height:1.2;margin-bottom:24px}
.blog-blockquote{background:rgba(37,89,139,.06);border-left:4px solid var(--blue);border-radius:0 var(--radius) var(--radius) 0;padding:22px 26px;margin:24px 0;display:flex;gap:14px;align-items:flex-start}
.blog-blockquote>i{font-size:34px;color:var(--blue);opacity:.4;flex-shrink:0;line-height:1}
.blog-blockquote p{font-size:15px;font-style:italic;color:var(--blue);font-weight:500;margin:0;line-height:1.7}
.blog-tags{display:flex;flex-wrap:wrap;align-items:center;gap:8px;margin-top:24px}
.blog-tag{padding:5px 12px;background:var(--silver);border:1px solid var(--lgray);border-radius:2px;font-size:12px;color:var(--gray);text-decoration:none;transition:var(--transition)}
.blog-tag:hover{background:var(--blue);color:#fff;border-color:var(--blue)}
.blog-share{display:flex;flex-wrap:wrap;align-items:center;gap:8px;margin-top:16px}
.blog-share-btn{width:36px;height:36px;background:var(--silver);border:1px solid var(--lgray);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:15px;color:var(--gray);text-decoration:none;transition:var(--transition)}
.blog-share-btn:hover{background:var(--blue);color:#fff;border-color:var(--blue)}
.blog-author-box{display:flex;gap:20px;align-items:flex-start;padding:26px;background:var(--silver);border-radius:var(--radius);border:1px solid var(--lgray);margin-top:32px}
.blog-author-avatar{width:68px;height:68px;min-width:68px;background:var(--blue);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:30px;color:#fff}
.blog-author-box h5{font-family:var(--fontmain);font-size:16px;font-weight:700;color:var(--dgray);margin-bottom:3px}
.blog-author-box .blog-cat-pill{margin-bottom:10px;display:inline-block}
.blog-author-box p{font-size:13.5px;color:var(--gray);margin:0;line-height:1.7}
@media(max-width:575px){.blog-author-box{flex-direction:column} .whatwedo-padding{padding-right:0px;}}

/* Contact page */
.contact-info-card{background:var(--white);border:1px solid var(--lgray);border-radius:var(--radius);padding:28px 24px;text-align:center;border-top:3px solid var(--blue);transition:var(--transition);height:100%}
.contact-info-card:hover{box-shadow:var(--shadow);transform:translateY(-4px)}
.contact-info-icon{width:60px;height:60px;background:rgba(37,89,139,.08);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 16px;font-size:22px;color:var(--blue);transition:var(--transition)}
.contact-info-card:hover .contact-info-icon{background:var(--blue);color:#fff}
.contact-info-card h5{font-family:var(--fontmain);font-size:17px;font-weight:700;color:var(--dgray);margin-bottom:10px}
.contact-info-card p{font-size:16px;color:var(--gray);line-height:1.7;margin-bottom:14px}
.contact-info-card p a{color:var(--gray);text-decoration:none}
.contact-info-card p a:hover{color:var(--blue)}
.contact-info-link{font-family:var(--fontmain);font-size:16px;font-weight:700;text-transform:uppercase;letter-spacing:1.5px;color:var(--blue);text-decoration:none;display:inline-flex;align-items:center;gap:4px}
.contact-hours-bar{background:var(--dblue);border-radius:var(--radius);padding:13px 22px;display:flex;flex-wrap:wrap;align-items:center;gap:8px;font-family:var(--fontmain);font-size:14px;color:rgba(255,255,255,.8)}
.btn-wa{display:inline-flex;align-items:center;gap:8px;padding:12px 22px;background:#25d366;color:#fff;font-family:var(--fontmain);font-size:14px;font-weight:700;border-radius:var(--radius);text-decoration:none;transition:var(--transition)}
.btn-wa:hover{background:#1da851;color:#fff}
@media(max-width:767px){.contact-hours-bar{flex-direction:column;align-items:flex-start;gap:4px}}

/* ==========================================================
   PROJECT LIGHTBOX
   ========================================================== */

/* Lens zoom button — top-right of each card, appears on hover */
.project-zoom-btn {
    position: absolute;
    top: 16px;
    right: 16px;
    width: 44px;
    height: 44px;
    background: rgba(255,255,255,0.95);
    border: none;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 18px;
    color: var(--blue);
    cursor: pointer;
    transform: scale(0);
    transition: transform .35s cubic-bezier(.34,1.56,.64,1), background .25s ease;
    z-index: 5;
    box-shadow: 0 4px 16px rgba(0,0,0,.25);
}
.project-card:hover .project-zoom-btn {
    transform: scale(1);
}
.project-zoom-btn:hover {
    background: var(--blue);
    color: #ffffff;
}

/* Lightbox backdrop */
.ht-lightbox {
    position: fixed;
    inset: 0;
    background: rgba(6,24,60,0.96);
    z-index: 9999;
    display: flex;
    align-items: center;
    justify-content: center;
    opacity: 0;
    pointer-events: none;
    transition: opacity .3s ease;
}
.ht-lightbox.is-open {
    opacity: 1;
    pointer-events: all;
}

/* Content wrapper */
.ht-lb-content {
    display: flex;
    flex-direction: column;
    align-items: center;
    max-width: 90vw;
    max-height: 90vh;
    transform: scale(0.94) translateY(12px);
    transition: transform .35s cubic-bezier(.34,1.26,.64,1);
}
.ht-lightbox.is-open .ht-lb-content {
    transform: scale(1) translateY(0);
}

/* Image */
.ht-lb-img-wrap {
    max-width: 80vw;
    max-height: 75vh;
    overflow: hidden;
    border-radius: var(--radius-lg);
    box-shadow: 0 24px 80px rgba(0,0,0,.6);
    line-height: 0;
}
.ht-lb-img-wrap img {
    max-width: 80vw;
    max-height: 75vh;
    object-fit: contain;
    display: block;
    border-radius: var(--radius-lg);
    transition: opacity .25s ease;
}
.ht-lb-img-wrap img.is-loading { opacity: 0; }

/* Caption */
.ht-lb-caption {
    text-align: center;
    padding: 16px 0 0;
}
.ht-lb-cats {
    display: inline-block;
    font-family: var(--fontmain);
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 2px;
    color: var(--yellow);
    margin-bottom: 6px;
}
.ht-lb-caption h5 {
    font-family: var(--fontmain);
    font-size: 18px;
    font-weight: 700;
    color: #ffffff;
    margin: 0;
}

/* Close button */
.ht-lb-close {
    position: fixed;
    top: 20px;
    right: 20px;
    width: 46px;
    height: 46px;
    background: rgba(255,255,255,0.12);
    border: 1px solid rgba(255,255,255,0.2);
    border-radius: 50%;
    color: #ffffff;
    font-size: 18px;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: background .25s ease;
    z-index: 10000;
}
.ht-lb-close:hover { background: var(--blue); border-color: var(--blue); }

/* Prev / Next arrows */
.ht-lb-prev,
.ht-lb-next {
    position: fixed;
    top: 50%;
    transform: translateY(-50%);
    width: 52px;
    height: 52px;
    background: rgba(255,255,255,0.1);
    border: 1px solid rgba(255,255,255,0.2);
    border-radius: 50%;
    color: #ffffff;
    font-size: 20px;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: background .25s ease;
    z-index: 10000;
}
.ht-lb-prev { left: 16px; }
.ht-lb-next { right: 16px; }
.ht-lb-prev:hover,
.ht-lb-next:hover { background: var(--blue); border-color: var(--blue); }

/* Counter badge */
.ht-lb-counter {
    position: fixed;
    bottom: 20px;
    left: 50%;
    transform: translateX(-50%);
    font-family: var(--fontmain);
    font-size: 12px;
    font-weight: 600;
    color: rgba(255,255,255,0.5);
    letter-spacing: 2px;
    z-index: 10000;
}

/* Mobile */
@media (max-width: 575px) {
    .ht-lb-prev { left: 8px; }
    .ht-lb-next { right: 8px; }
    .ht-lb-prev, .ht-lb-next { width: 42px; height: 42px; font-size: 16px; }
    .ht-lb-img-wrap, .ht-lb-img-wrap img { max-width: 94vw; }
}
/* Video thumbnail */
.video-thumb-wrap {
    position: relative;
    border-radius: var(--radius);
    overflow: hidden;
    cursor: pointer;
    aspect-ratio: 16/9;
}
.video-thumb-img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    transition: transform .5s ease;
}
.video-thumb-wrap:hover .video-thumb-img { transform: scale(1.06); }
.video-thumb-overlay {
    position: absolute;
    inset: 0;
    background: rgba(6,24,60,.30);
    transition: background .35s ease;
}
.video-thumb-wrap:hover .video-thumb-overlay { background: rgba(6,24,60,.6); }

/* Play button */
.video-play-btn {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%,-50%) scale(1);
    width: 64px;
    height: 64px;
    background: var(--blue);
    border: 3px solid rgba(255,255,255,.6);
    border-radius: 50%;
    color: #ffffff;
    font-size: 26px;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: transform .35s cubic-bezier(.34,1.56,.64,1), background .25s ease;
    padding-left: 4px; /* optical centre for play icon */
    z-index: 2;
}
.video-thumb-wrap:hover .video-play-btn {
    transform: translate(-50%,-50%) scale(1.12);
    background: #ffffff;
    color: var(--blue);
    border-color: #ffffff;
}
/* ==========================================================
   PAGE TITLE BAR (below page-banner, shared inner pages)
   ========================================================== */
.page-title-bar{background:var(--white);padding:16px 0}
.page-title-heading{font-family:var(--fontmain);font-size:clamp(18px,2.5vw,26px);font-weight:700;color:var(--dgray);margin:0;line-height:1.2}
.page-title-bar .breadcrumb{margin:0;padding:0;background:none}
.page-title-bar .breadcrumb-item a{color:var(--gray);font-family:var(--fontmain);font-size:13px;text-decoration:none}
.page-title-bar .breadcrumb-item a:hover{color:var(--blue)}
.page-title-bar .breadcrumb-item.active{color:var(--blue);font-family:var(--fontmain);font-size:13px}
.page-title-bar .breadcrumb-item+.breadcrumb-item::before{color:var(--lgray)}

/* ==========================================================
   FAQ PAGE
   ========================================================== */

/* Group heading */
.faq-group-heading{display:flex;align-items:center;gap:14px;margin-bottom:20px;padding-bottom:14px;border-bottom:2px solid var(--blue)}
.faq-group-icon{width:44px;height:44px;min-width:44px;background:var(--blue);border-radius:var(--radius);display:flex;align-items:center;justify-content:center;font-size:20px;color:#fff}
.faq-group-heading h4{font-family:var(--fontmain);font-size:18px;font-weight:700;color:var(--dgray);margin:0}

/* Accordion item */
.faq-item{border:none;border-bottom:1px solid var(--lgray);background:transparent}
.faq-item:first-child{border-top:1px solid var(--lgray)}

/* Accordion button */
.faq-btn{font-family:var(--fontmain);font-size:15px;font-weight:600;color:var(--dgray);background:var(--white);padding:18px 20px;border:none;box-shadow:none;display:flex;align-items:flex-start;gap:14px;line-height:1.4}
.faq-btn:not(.collapsed){color:var(--blue);background:rgba(37,89,139,.04)}
.faq-btn:focus{box-shadow:none;outline:none}
.faq-btn::after{display:none} /* remove default Bootstrap chevron */

/* Custom +/- indicator */
.faq-btn::before{
    content:'\f4fe'; /* bi-plus-circle */
    font-family:'bootstrap-icons';
    font-size:18px;
    color:var(--blue);
    flex-shrink:0;
    margin-top:1px;
    transition:transform .3s ease;
}
.faq-btn:not(.collapsed)::before{
    content:'\f2ea'; /* bi-dash-circle */
    color:var(--blue);
}

/* Question number badge */
.faq-q-num{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;min-width:28px;background:var(--blue);color:#fff;border-radius:var(--radius);font-size:11px;font-weight:700;font-family:var(--fontmain);flex-shrink:0}
.faq-btn:not(.collapsed) .faq-q-num{background:var(--blue)}

/* Answer body */
.faq-answer{font-size:15px;color:var(--gray);line-height:1.85;padding:4px 20px 20px 60px;background:rgba(37,89,139,.03)}

/* Smooth accordion */
.faq-accordion .accordion-collapse{transition:all .3s ease}

@media(max-width:575px){
    .faq-btn{font-size:14px;padding:14px 12px}
    .faq-answer{padding:4px 12px 16px 12px}
}

/* ==========================================================
   PARTNER / CLIENT CARDS SLIDER  — 4 col, one-by-one
   ========================================================== */
.partner-cards-section{padding:60px 0}
.partner-track-wrap{overflow:hidden}
.partner-track{display:flex;gap:20px;transition:transform .45s cubic-bezier(.4,0,.2,1);width:max-content}

/* Slide — fixed px width, 4 visible on desktop */
.partner-slide{
    flex-shrink:0;
    width:320px;
}

/* Card */
.partner-card{
    background:var(--white);
    border:1px solid var(--lgray);
    border-radius:var(--radius);
    overflow:hidden;
    display:flex;
    flex-direction:column;
    transition:var(--transition);
    height:100%;
}
.partner-card:hover{    box-shadow: 5px 5px 0 #C9D7E5;transform:translateY(-4px)}

/* Image area */
.partner-card-img-wrap{
    position:relative;
    height:300px;
    overflow:hidden;
}
.partner-card-img{
    width:100%;
    height:100%;
    object-fit:cover;
    transition:transform .5s ease;
}
.partner-card:hover .partner-card-img{transform:scale(1.06)}

/* Dark overlay */
.partner-card-img-wrap::before{
    content:'';
    position:absolute;
    inset:0;
    background:linear-gradient(to bottom,rgba(0,0,0,.15) 0,rgba(0,0,0,.05) 40%,rgba(0,0,0,.45) 100%);
    z-index:1;
}

/* Number — top left */
.partner-card-num{
    position:absolute;
    top:12px;
    left:14px;
    font-family:var(--fontmain);
    font-size:14px;
    font-weight:700;
    color:rgba(255,255,255,.85);
    letter-spacing:1px;
    z-index:2;
}

/* Icon — bottom right */
.partner-card-icon{
    position:absolute;
    bottom:14px;
    right:14px;
    width:44px;
    height:44px;
    background:var(--blue);
    border-radius:var(--radius);
    display:flex;
    align-items:center;
    justify-content:center;
    z-index:2;
    transition:background .3s ease;
}
.partner-card:hover .partner-card-icon{background:#fff}
.partner-card-icon i{font-size:20px;color:#fff;transition:color .3s ease}
.partner-card:hover .partner-card-icon i{color:var(--blue)}

/* Body */
.partner-card-body{padding:20px;flex:1;display:flex;flex-direction:column}
.partner-card-label{
    display:inline-block;
    font-family:var(--fontmain);
    font-size:11px;
    font-weight:700;
    text-transform:uppercase;
    letter-spacing:1.5px;
    color:var(--blue);
    margin-bottom:8px;
}
.partner-card-body h5{
	
    font-family:var(--fontmain);
    font-size:18px;
    font-weight:800;
    color:var(--dgray);
    line-height:1.4;
    margin-bottom:10px;
    display:-webkit-box;
    -webkit-line-clamp:2;
    -webkit-box-orient:vertical;
    overflow:hidden;
}
.partner-card-body p{
    font-size:16px;
    color:var(--gray);
    line-height:1.7;
    flex:1;
    display:-webkit-box;
    -webkit-line-clamp:3;
    -webkit-box-orient:vertical;
    overflow:hidden;
    margin-bottom:0;
}

/* Footer */
.partner-card-footer{
    padding:14px 20px;
}
.partner-card-footerlink{
    display:inline-flex;
    align-items:center;
    gap:6px;
    font-family:var(--fontmain);
    font-size:14px;
    font-weight:700;
    text-transform:uppercase;
    letter-spacing:1.5px;
    color:var(--gray);
    text-decoration:none;
    transition:var(--transition);
}
.partner-card-footerlink a i{transition:transform .3s ease}
.partner-card-footerlink a:hover{color:var(--blue)}
.partner-card-footerlink a:hover i{transform:translateX(4px)}

/* Dots */
.partner-dots{display:flex;justify-content:center;gap:6px;padding-top:28px}
.partner-dot{width:8px;height:8px;border-radius:50%;background:var(--lgray);border:none;padding:0;cursor:pointer;transition:all .3s ease}
.partner-dot.active{background:var(--blue);width:24px;border-radius:4px}

/* Responsive */
@media(max-width:1199px){
    .partner-slide{width:260px}
    .partner-cards-section{padding:40px 0 0 0}
}
@media(max-width:767px){
    .partner-slide{width:300px}
}
@media(max-width:575px){
    .partner-slide{width:calc(100vw - 48px)}
    .partner-track-wrap{overflow-x:auto;scrollbar-width:none}
    .partner-track-wrap::-webkit-scrollbar{display:none}
    .partner-track{gap:16px}
}

/* ── ISO Certification Strip ── */
.footer-iso-strip{background:rgba(0,0,0,.45);border-top:1px solid rgba(255,255,255,.12);color:#fff;}
.footer-iso-logo{filter:drop-shadow(0 2px 4px rgba(0,0,0,.4));}
.footer-iso-text{color:#fff;}
